Difference between revisions of "Ryzom API"

From EncyclopAtys

Jump to: navigation, search
(Wiki implemetation)
(In Game)
 
(39 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{WIP}}
+
<noinclude>{{Trad
__TOC__
+
|DE = Ryzom API |DEs= 4
 +
|EN = Ryzom API |ENs= 0
 +
|ES = Ryzom API |ESs= 2
 +
|FR = Ryzom API |FRs=
 +
|RU = Ryzom API |RUs=
 +
|H  = 1
 +
|palette=
 +
|ref=
 +
|com=
 +
}}{{Clear}}<div style = "float:right;"> <small>__TOC__</small></div></noinclude>
 
<br />
 
<br />
 
<br />
 
<br />
Line 7: Line 16:
 
This page is the [[Portal:Forge|Ryzom Forge]] version of <span class="plainlinks">[https://api.ryzom.com/ api.ryzom.com]</span> site
 
This page is the [[Portal:Forge|Ryzom Forge]] version of <span class="plainlinks">[https://api.ryzom.com/ api.ryzom.com]</span> site
  
According to [[:wikipedia:Application programming interface|Wikipedia]], an An API or "''Application Programming interface''"  is a computing interface which defines interactions between multiple software intermediaries. It defines the kinds of calls or requests that can be made, how to make them, the data formats that should be used, the conventions to follow, etc. [...]Through information hiding, APIs enable modular programming, which allows users to use the interface independently of the implementation.  
+
According to [[:wikipedia:Application programming interface|Wikipedia]], an API or "''Application Programming interface''"  is a computing interface which defines interactions between multiple software intermediaries. It defines the kinds of calls or requests that can be made, how to make them, the data formats that should be used, the conventions to follow, etc. [...]Through information hiding, APIs enable modular programming, which allows users to use the interface independently of the implementation.  
  
 
In our case: [[Ryzom API]] is an URL based system to get some Ryzom ''in-game information'' like game time, character, guild profile...
 
In our case: [[Ryzom API]] is an URL based system to get some Ryzom ''in-game information'' like game time, character, guild profile...
Line 14: Line 23:
 
=Basics=
 
=Basics=
 
== Base URL ==
 
== Base URL ==
All requests are using '''<span class="plainlinks">[https://api.ryzom.com https://api.ryzom.com]</span>''' as base url.
+
All requests are using '''<code><nowiki>https://api.ryzom.com</nowiki></code>''' as base url.
  
 
== API keys ==
 
== API keys ==
Line 22: Line 31:
  
 
== PHP API ==
 
== PHP API ==
[[:wikipedia:PHP|PHP]] API library can be found in the [https://bitbucket.org/nimetu/ryzomapi_lite/src/default/ ryzomapi_lite] repository.
+
[[:wikipedia:PHP|PHP]] API library can be found in the [https://gitlab.com/ryzom/web/ryzom-api-client ryzom API client] repository.
  
 
== Third party libraries ==
 
== Third party libraries ==
([[:wikipedia:PHP|PHP]]) Sheet translations and info about resources can be found from the <span class="plainlinks">[https://github.com/nimetu/ryzom-extra https://github.com/nimetu/ryzom_extra]</span> repository. The <span class="plainlinks">[https://github.com/nimetu/ryzom_extra/tree/json-resources json-resources]</span> branch has data in [[:wikipedia:JSON|JSON]] format.
+
([[:wikipedia:PHP|PHP]]) Sheet translations and info about resources can be found in the <span class="plainlinks">[https://github.com/nimetu/ryzom_extra https://github.com/nimetu/ryzom_extra]</span> repository. The <span class="plainlinks">[https://github.com/nimetu/ryzom_extra/tree/json-resources json-resources]</span> branch has data in [[:wikipedia:JSON|JSON]] format.
  
 +
== python Interface ?==
 
=Functions=
 
=Functions=
 
==[[Ryzom API/Time|Time]]==
 
==[[Ryzom API/Time|Time]]==
 
{{/Time}}
 
{{/Time}}
  
==Character==
+
==[[Ryzom API/Character|Character]]==
 +
{{/Character}}
  
==Guilds==
+
==[[Ryzom API/Guilds|Guilds]]==
 +
{{/Guilds}}
  
==Guild==
+
==[[Ryzom API/Guild|Guild]]==
 +
{{/Guild}}
  
 
== API error codes ==
 
== API error codes ==
 +
 +
;404 invalid api key :
 +
:No such API key.
 +
;403 key expired :
 +
:API key is valid, but has expired
 +
;503 character data is not initialized:
 +
;503 guild data is not initialized:
 +
:Temporary server side error indicating that character/guild info is currently not available.
 +
:Data will be available after character has logged in to game
 
----
 
----
Tools
+
 
 +
=Tools=
 +
 
 +
== [[Ryzom API/Render|Render]] ==
 +
{{/Render}}
 +
 
 +
== [[Ryzom API/Guild icon|Guild icon]] ==
 +
{{/Guild icon}}
 +
 
 +
== [[Ryzom API/Item icon|Item icon]] ==
 +
{{/Item icon}}
 
----
 
----
== Render ==
+
 
== Guild icon ==
+
=In Game=
== Item icon ==
+
== [[Ryzom API/AppZone|AppZone]] ==
----
+
{{/AppZone}}
In Game
+
 
----
+
== In-Game-Browser ==
== AppZone ==
+
 
== Ingame browser ==
 
----
 
WikipAtys
 
 
----
 
----
 +
 +
=WikipAtys=
 
==Wiki implemetation==
 
==Wiki implemetation==
Pages in [[:Category:API templates|Category : "API templates]]":
+
Pages in [[:Category:API templates|Category : "API templates]]" :
 
{{#dpl:
 
{{#dpl:
 
category=API templates
 
category=API templates
 
}}
 
}}
<br />
+
 
<br />
+
;<big><big>⚠</big></big>Warning:
<br />
+
: The code required to retrieve icons is raw html. You won't be able to format pictures as "easily" as when you use wiki code and the image is stored on [[:Atys:Main Page|Atys commons]].
<br />
+
 
 +
=== Examples ===
 +
*[[Crafting/Crafting Part Table]]
 +
*[[Template:APIitemIcon]] (documentation examples)
 +
 
 +
=Links=
 +
*API Documentation (sources):
 +
**➡ https://api.ryzom.com/
 +
** ⛔ http://dev.ryzom.com/projects/ryzom-api/wiki (registered developers, 🔑 password required)
 +
*Example page and php library sources : https://bitbucket.org/nimetu/ryzomapi_lite
 +
*Live working example page (Ballistic Mystix) : http://ryapp.bmsite.net/
 +
*API discussion in forum : http://app.ryzom.com/app_forum/index.php?page=topic/view/18541
 +
*the App (Appzone) Api key to create and get a key:  https://app.ryzom.com/app_ryzomapi/index.php?
 
<noinclude><br />
 
<noinclude><br />
 
<br />
 
<br />
----
+
{{clear}}
<references/>
+
{{Reflist|subpages=1}}{{Portal|Forge}}
----
+
[[Category:Ryzom API]]  [[Category:Tutorials]] [[Category:Reference Guides]]
{{clear}}{{last version link|Ryzom API}}
+
[[de:Ryzom API]] [[en:Ryzom API]] [[es:Ryzom API]] [[fr:Ryzom API]] [[ru:Ryzom API]] <!-- for Interlanguage  menu-->{{last version link|Ryzom API}}</noinclude>
{{Portal|Forge}}
 
[[Category:Forge]] [[Category:Ryzom API]]
 
[[de:Ryzom API]]
 
[[en:Ryzom API]]
 
[[es:Ryzom API]]
 
[[fr:Ryzom API]]
 
[[ru:Ryzom API]] </noinclude>
 

Latest revision as of 14:00, 27 May 2023

de:Ryzom API en:Ryzom API es:Ryzom API fr:Ryzom API ru:Ryzom API
 
UnderConstruction.png
Translation to review
Don't blame the contributors, but come and help them 😎

Reference text ( Maintained text, used as reference ) :
Notes: (Leda, 2023-05-27)





This page is the Ryzom Forge version of api.ryzom.com site

According to Wikipedia, an API or "Application Programming interface" is a computing interface which defines interactions between multiple software intermediaries. It defines the kinds of calls or requests that can be made, how to make them, the data formats that should be used, the conventions to follow, etc. [...]Through information hiding, APIs enable modular programming, which allows users to use the interface independently of the implementation.

In our case: Ryzom API is an URL based system to get some Ryzom in-game information like game time, character, guild profile... API changes log can be found on forum.

Basics

Base URL

All requests are using https://api.ryzom.com as base url.

API keys

  • API keys are 41 alphanumeric characters. Character keys start with 'c' and guild keys with 'g'.
  • API keys must be created using "RyzomAPI app": https://app.ryzom.com/app_ryzomapi
  • You must be guild leader or high officer to manage and view guild api key.

PHP API

PHP API library can be found in the ryzom API client repository.

Third party libraries

(PHP) Sheet translations and info about resources can be found in the https://github.com/nimetu/ryzom_extra repository. The json-resources branch has data in JSON format.

python Interface ?

Functions

Time

To know the time and date in Ryzom.

Usage

<base URL>/time.php

URL Parameters

format
(optional), defaults ro raw.
  • raw : Returns the tick. The server tick is a 32 bit integer that increases by one every 100 milliseconds.
  • txt : Returns a homine-readable string.
  • xml : Returns an xml file that contains all shard time information.

Cache duration

The data is cached for 1 minute.

XML structure

<shard_time>
  <server_tick>514105152</server_tick>
  <jena_year>2576</jena_year>
  <day_of_jy>319</day_of_jy>
  <month_of_jy>10</month_of_jy>
  <cycle>0</cycle>
  <day_of_cycle>319</day_of_cycle>
  <month_of_cycle>10</month_of_cycle>
  <day_of_month>19</day_of_month>
  <day_of_week>1</day_of_week>
  <season>3</season>
  <day_of_season>49</day_of_season>
  <time_of_day>13</time_of_day>
  <txt_en>13h - Dua, Mystia 20, 1st AC 2576</txt_en>
  <txt_fr>13h - Dua, Mystia 20, 1er CA 2576</txt_fr>
  <txt_de>13h - Dua, Mystia 20, 1. AZ 2576</txt_de>
  <cache created="1387437183" expire="1387437243"/>
</shard_time>

PHP interface

ryzom_time_api() : Returns SimpleXMLElement or boolean false on failure.
<?php
  require_once "ryzomapi_lite.php";

  $time = ryzom_time_api('xml');
  if ($time !== false) {
    $txt_en = htmlspecialchars($time->txt_en);
    echo "Atys time is {$txt_en}";
  } else {
    echo "API failure";
  }
?>


Character

Access character information.

Usage

<base URL>/character.php?apikey=key
<base URL>/character.php?apikey[=key1&apikey[]=key2

URL Parameters

apikey
Character API key starting with 'c'

Cache Duration

<character> xml element has attributes *created* and *cached_until* (utc timestamp)

XML structure

API is able to return information about multiple characters at once and so each <character> element is child of <ryzomapi> root element:

<ryzomapi>
  <character apikey="key1" created="1387369332" modules="C01:P01" cached_until="1387369632">
    ....
  </character>
  <character apikey="key2" created="1387369332" modules="P01" cached_until="1387369632">
    ....
  </character>
</ryzomapi>

Invalid key error:

<character apikey="key1" created="1387369873">
  <error code="404">invalid key</error>
</character>

Possible error codes are listed on API error codes.

PHP interface

ryzom_character_api($apikey)
$apikey can be either string (single key) or array of strings.
On success, function returns associative array of SimpleXMLElement with apikey as array index.
On failure, function returns boolean false.
<?php
require_once "ryzomapi_lite.php";
function info($char) {
  if (isset($char->error)) {
    $apikey = htmlspecialchars($char['apikey']);
    $error = htmlspecialchars($char->error);
    $code = (int)$char->error['code'];
    echo "Character API key '{$apikey}' failed: {$code}:{$error}";
  } else {
    $name = htmlspecialchars($char->name);
    echo "Character name: {$name}";
  }
}
$apikey = 'cABCDEF';
$chars = ryzom_character_api($apikey);
if ($chars !== false) {
  info($chars[$apikey]);
} else {
  echo "Character API failed";
}
$apikeys = ['cABCDEF', 'c123456'];
$chars = ryzom_character_api($apikeys);
if ($chars !== false) {
  foreach($chars as $char) {
    info($char);
  }
} else {
  echo "Character API failed";
}


Guilds

Displays the list of all guilds.

Usage

<base URL>/guilds.php

Cache Duration

Returned XML has <cache> element with attributes created and expire (utc timestamp)

XML structure

<guilds>
  <cache created="1387371064" expire="1387374664"/>
  <shard>atys</shard>
  <guild>
    <gid>105906182</gid>
    <name>Atrium</name>
    <race>Fyros</race>
    <icon>575080624687965565</icon>
    <creation_date>131736955</creation_date>
    <description>Here you are the Keeper, your destiny is to make the rules to be respected</description>
  </guild>
  <guild>
    ....
  </guild>
</guilds>

PHP interface

ryzom_guildlist_api()

Function returns SimpleXMLElement object on success or boolean false on error.

<?php
  require_once "ryzomapi_lite.php";

  $guilds = ryzom_guildlist_api();
  if ($guilds !== false) {
    echo '<pre>';
    foreach($guilds->guild as $guild) {
      $gid = (int)$guild->gid;
      $name = htmlspecialchars($guild->name);
      echo "{$gid} {$name}\n";
    }
    echo '</pre>';
  } else {
    echo "API failure";


Guild

Access to guild information.


Usage

<base URL>/guild.php?apikey=key
<base URL>/guild.php?apikey[]=key1&apikey[]=key2

URL Parameters

apikey 
Guild API key starting with 'g'

Cache Duration

Guild xml element has attributes created and cached_until (utc timestamp)

XML structure

API is able to return information for multiple guilds at once and so each <guild> element is a child of <ryzomapi> root elements

<ryzomapi>
  <guild apikey="key1" created"1387369332" modules="G01:G02:G03:G04:P01" cached_until="1387369632">
    ...
  </guild>
  <guild apikey="key2" created"1387369332" modules="P01" cached_until="1387369632">
    ...
  </guild>
</ryzomapi>

Invalid key error:

<guild apikey="key1" created="1387369873">
  <error code="404">invalid key</error>
</guild>

Possible error codes are listed on API error codes.

PHP interface

ryzom_guild_api($apikey)

$apikey can be either a string or array of strings

Function will return associative array of SimpleXMLElement with $apikey as array index On failure function returns boolean false

<?php
require_once "ryzomapi_lite.php";

function info($guild) {
  if (isset($guild->error)) {
    $apikey = htmlspecialchars($guild['apikey']);
    $error = htmlspecialchars($guild->error);
    $code = (int)$guild->error['code'];
    echo "Guild API key '{$apikey}' failed: {$code}:{$error}";
  } else {
    $name = htmlspecialchars($guild->name);
    echo "Guild name: {$name}";
  }
}

$apikey = 'gABCDEF';
$guilds = ryzom_guild_api($apikey);
if ($guilds !== false) {
  info($guilds[$apikey]);
} else {
  echo "Guild API failed";
}

$apikeys = ['gABCDEF', 'g123456'];
$guilds = ryzom_guild_api($apikeys);
if ($guilds !== false) {
  foreach($guilds as $guild) {
    info($guild);
  }
} else {
  echo "Guild API failed";
}


API error codes

404 invalid api key 
No such API key.
403 key expired 
API key is valid, but has expired
503 character data is not initialized
503 guild data is not initialized
Temporary server side error indicating that character/guild info is currently not available.
Data will be available after character has logged in to game

Tools

Render

This is a set of PHP function to render a web page using Ryzom style.


CSS file

You need to manually include ryzom css file :

<link href="https://api.ryzom.com/data/css/ryzom_ui.css" rel="stylesheet" media="all">

PHP interface

ryzom_render_window($title, $content, array $links)

Returns html markup resembling ingame window style

$title
$content
$links - (optional) associative array that defines right side buttons on window title bar
<?php
require_once "ryzomapi_lite.php";

$links = array(
  array('href' => 'http://www.ryzom.com/', 'text' => 'Ryzom website'),
  array('href' => 'http://app.ryzom.com/app_ryzomapi/', 'text' => 'RyzomAPI app'),
);

echo ryzom_render_window('Title', 'Hello World!', $links);


Guild icon

Retrieves a guild icon

Usage

<base URL>/guild_icon.php?icon=:icon&size=:size

URL Parameters

icon 
It's a raw 64bit number from Character xml or Guild list xml file
size (optional)
s (default) Small guild icon (32x32 pixels)
b Big guild icon (64x64 pixels)

Cache Duration

It's cached for ever. Since the icon is unique and never changes. For a specific icon, it'll always return the same image.

PHP interface

ryzom_guild_icon_url($icon, $size)

Returns a string that contains the url to display a guild icon.

<?php
require_once "ryzomapi_lite.php";

$url = ryzom_guild_icon_url("4505559206514131", 'b');
echo "<img src=\"$url\" alt=\"\">";


Item icon

Retrieves Item icons (see also: Ryzom API/Item sheetids)

Usage

<base URL>/item_icon.php?sheetid=iczahp_3.sitem&c=1&q=0&s=0&sap=-1&destroyed=0&label=1&locked=0

URL Parameters

Parameter Description Default Example icon
sheetid It's the id of an item that you can find in the Character xml file.
For example, iczahp_3.sitem is a valid sheetid.
sheetids can me found in Nimetu's ryzom_extra repository
iczahp_3.sitem
c (optional), default is 1
The color of the item. It's a value between 0 and 7
c=1
0 1 2 3
4 5 6 7
q (optional), default is 0
The quality of the item.
q=0
0 120
s (optional), default is 0
The size of the stack.
s=0
0 53
sap (optional) number of sap plus 1 of the item.
-1 = (default) No sap icon, no number
0 = sap icon, no number
sap=-1
-1 0 1 2 8
destroyed (optional) displays the item as if it was destroyed (with a red cross)
0 = (default)
destroyed=0
0 1
label (optional), draws icon text if present
1 = (default)
label=1
0 1
locked (optional) display the item as if it was locked by the owner
0 = (default)
locked=0
0 1

Cache Duration

It's cached for ever. Since the icon is unique and never change. For a specific icon, it'll always return the same image.

PHP interface

ryzom_item_icon_url($sheetid, $c=-1, $q=0, $s=0, $sap=-1, $destroyed=false, $label=true, $locked=false)

Returns a string that contains the url to display a item icon.

<?php
require_once "ryzomapi_lite.php";

$url = ryzom_item_icon_url('iczahp_3.sitem', 2);

echo "<img src=\"{$url}\" alt=\"\">";



In Game

AppZone

User authentication for apps registered in AppZone

Usage

URL values
user -- base64 encoded php serialized array
checksum -- sha1 hash_hmac with app secret key from AppZone

Because of php serialize, checksum must be validated before user value can be safely used.
A validating checksum will also give a strong guarantee that the user is who he claims to be.

Example how the response is created:

$userArray = [
  'timestamp' => "0.9696200 1503915319",
  'app_url' => 'http://...',
  'id' => "1",
  'char_name' => 'player',
  'race' => 'tryker',
  'cult' => 'neutral',
  'civ' => 'neutral',
  'organization' => 'marauder',
  'guild_id' => '105906000',
  'guild_icon' => '17',
  'guild_name' => 'guild',
  'grade' => 'Leader',
  'lang' => 'en'
];

$user = base64_encode(serialize($userArray));
$checksum = hash_hmac('sha1', $user, $appKey);

timestamp contains microseconds and seconds when the response was created and should be checked to prevent replaying the same response multiple times.
app_url must be checked to prevent same AppZone response to be used in other apps.

PHP interface

ryzom_app_authenticate(&$user)

This function verifies AppZone user and checksum url parameters. Uses $_GET['user'] and $_GET['checksum'] directly.
Function returns boolean true if successful. $user variable will contain info from AppZone or an error message if there was an error

$_SESSION['app.user']
is set for future requests. PHP session is required.

Constants that should be defined :
RYAPI_AUTH_KEY
secret key in AppZone
if empty, then user info is not verified (not recommended)
RYAPI_APP_URL
app url in AppZone
if empty, then automatic best guess url is tried
if false, then app url is not verified
RYAPI_APP_MAXAGE
max age in seconds for AppZone url to be valid
if 0, then timestamp is not verified
<?php
  require_once "ryzomapi_lite.php";

  define('RYAPI_AUTH_KEY', 'secret-key');
  define('RYAPI_APP_URL', 'http://app.url/');
  define('RYAPI_APP_MAXAGE', 30);

  session_start();

  $user = false;
  if (ryzom_app_authenticate($user)) {
    $charName = htmlspecialchars($user['char_name']);
    echo "Hello {$charName}!";
  } else {
    $error = htmlspecialchars($user);
    echo "Authentication failure ({$error}).";
  }


In-Game-Browser


WikipAtys

Wiki implemetation

Pages in Category : "API templates" :

Warning
The code required to retrieve icons is raw html. You won't be able to format pictures as "easily" as when you use wiki code and the image is stored on Atys commons.

Examples

Links





Complements to this page:


Last version 2023-05-27•