johnleider / battlenet-api
A package to retrieve information from Blizzard's API
Fund package maintenance!
feross
Requires
- php: >=7.0
- guzzlehttp/guzzle: ^6.0
This package is not auto-updated.
Last update: 2025-05-06 06:43:20 UTC
README
A package for Battle.net's API (http://dev.battle.net/)
Usage
Instantiate the game API you wish to use with your API Key, API Secret and Region
$diablo = new Diablo( $key, $secret, 'us', 'en_US' );
Example API calls:
// Retrieve Season Leaderboard data $diablo = new Diablo($key, $secret, 'us', 'en_US'); $diablo->setAccessToken($accessToken); $barbarian = $diablo->season($season) ->barbarian() ->get(); $barbarian_hardcore = $diablo->season($season) ->hardcore() ->barbarian() ->get(); $profile = $diablo->careerProfile('battle_tag'); $hero = $diablo->hero('battle_tag', 'id');
Pooling Requests
You can pool multiple requests by chaining requests before calling get().
$diablo = new Diablo($key, $secret, 'us', 'en_US');
$diablo->setAccessToken($accessToken);
$leaderboards = $diablo->season($season)
->barbarian()
->crusader()
->demonhunter()
->monk()
->witchdoctor()
->wizard()
->team(2)
->team(3)
->team(4)
->get();
$profile = $diablo->setRegion('eu')
->careerProfile($battle_tag)
->get();
foreach ($request->heroes as $hero) {
$diablo->hero($hero->id);
}
$heroes = $diablo->get();
This will asynchronously request 25 concurrent requests at a time. The response will return as an array of JSON objects. The call will not be made until the get method is called.