Version v1.0.0
Welcome to the RiotAPI PHP7 library repo! The goal of this library is to create easy-to-use library for anyone who might need one. This is fully object oriented API wrapper for League of Legends' API. A small DataDragon API is also included.
Here are some handy features:
- Rate limit caching and limit exceeding prevention - fully automatic.
- Call caching - this enables the library to re-use already fetched data within short timespan - saving time and API rate limit.
- StaticData linking - library can automatically link Static Data related to your request right into the returned object.
- Custom callbacks - you can set custom function which will be called before or after the request is processed.
- Object extensions - you can implement own methods to the fetched API objects itself and enable yourself to use them later to ease of your work.
- Interim mode support, you are going to be able to use the API the same way
whether your key is in
interim mode
or not (meaning you won't need to change anything when you jump to production). - CLI supported! You can use the library easily even in PHP CLI mode.
- Objects everywhere! API calls return data in special objects.
Please, refer mainly to the wiki pages.
The easiest way to get this library is to use Composer. While
having Composer installed it takes only composer require dolejska-daniel/riot-api
to
get the library ready!
If you are not fan of Composer, you can download whole repository in .zip archive
or clone the repository using Git - git clone https://github.com/dolejska-daniel/riot-api
.
But in this case, you will have to create your own autoload function.
Below you can find table of implemented API resources and the version in which they are currently implemented. Please refer to wiki pages for more information about endpoints and resources.
Resource | Status |
---|---|
Champion | |
Champion Mastery | |
League | |
Masteries | |
Match | |
Runes | |
Spectator | |
Static Data | |
Stats | |
Status | |
Summoner | |
Tournament | |
Tournament Stub |
How to begin?
// Include all required files
require_once __DIR__ . "/vendor/autoload.php";
use RiotAPI\RiotAPI;
use RiotAPI\Definitions\Region;
// Initialize the library
$api = new RiotAPI([
// Your API key, you can get one at https://developer.riotgames.com/
RiotAPI::SET_KEY => 'YOUR_RIOT_API_KEY',
// Target region (you can change it during lifetime of the library instance)
RiotAPI::SET_REGION => Region::EUROPE_EAST,
]);
// And now you are ready to rock!
$ch = $api->getStaticChampion(61); // Orianna <3
And there is a lot more what you can set when initializing the library - mainly to enable special features or to amend behaviour of the library. Please see the wiki pages for complete list of library's settings.
Working with RiotAPI can not be easier, just watch how to fetch summoner information based on summoner's name:
// ...initialization...
// this fetches the summoner data and returns SummonerDto object
$summoner = $api->getSummonerByName('I am TheKronnY');
echo $summoner->id; // 30904166
echo $summoner->name; // I am TheKronnY
echo $summoner->summonerLevel; // 30
print_r($summoner->getData()); // Or array of all the data
/* Array
* (
* [id] => 30904166
* [name] => I am TheKronnY
* [profileIconId] => 540
* [summonerLevel] => 30
* [revisionDate] => 1484850969000
* )
*/
..or how to fetch a static champion data?
// ...initialization...
// this fetches the champion data and returns StaticChampionDto object
$champion = $api->getStaticChampion(61);
echo $champion->name; // Orianna
echo $champion->title; // the Lady of Clockwork
print_r($champion->getData()); // Or array of all the data
/* Array
* (
* [id] => 61
* [name] => "Orianna"
* [key] => "Orianna"
* [title] => "the Lady of Clockwork"
* )
*/
Cache providers are responsible for keeping data of rate limiting and call caching within instances of the library. This feature is automatically enabled, when any of previously mentioned features is used.
When using this feature, you can set RiotAPI::SET_CACHE_PROVIDER
to any class,
thought it has to implement Objects\ICacheProvider
interface.
By using RiotAPI::SET_CACHE_PROVIDER_PARAMS
option, you can pass any
variables to the cache provider.
For more, please see the wiki pages.
This clever feature will easily prevent exceeding your per key
call limits & method limits. In order to enable this feature, you have to set
RiotAPI::SET_CACHE_RATELIMIT
to true
. Everything is completly automatic,
so all you need to do is to enable this feature.
For more, please see the wiki pages.
This feature can prevent unnecessary calls to API within short timespan
by temporarily saving fetched data from API and using them as the result data.
In order to enable this feature, you have to set RiotAPI::SET_CACHE_CALLS
to true
.
You should also provide RiotAPI::SET_CACHE_CALLS_LENGTH
option or else default
time interval of 60 seconds
will be used.
For more, please see the wiki pages.
This feature allows you to automatically link static data related to your request.
This action is time consuming (works well when caching call data for
StaticData resource
), but calls to StaticData resource
are not counted
to your rate limit so there is no problem in using it.
For more, please see the wiki pages.
Using extensions for ApiObjects is useful tool, allowing implementation
of your own methods into the ApiObjects itself. Extensions are enabled by
using settings option RiotAPI::SET_EXTENSIONS
when initializing the library.
Any extending class must implement Objects\IApiObjectExtension
. Only class names
are provided, no instances required. Extension will be initialized (instantiated)
when object is being initialized.
For more, please see the wiki pages.
Custom function callback before and after the call is made.
Before request callbacks have ability to cancel upcomming request - when false
is returned
by any callback function, exception Exceptions\RequestException
is raised and
request is cancelled.
For more, please see the wiki pages.
For more information about CLI support, please see the wiki pages.
How easy it is to work with images? For instance, to get splash image of Orianna?
echo DataDragonAPI::getChampionSplashO($api->getStaticChampion(61));
, that easy.
Want to know more? TBA