node-battle
is a client for Blizzard's World of Warcraft Community Web API.
npm install battle
First you need an API key so head to the developer portal and register an application.
var battle = require('battle');
// create a new client with a default region
var client = battle.createClient({
apiKey: '...',
region: 'eu'
});
// load an item
client.item({ id: 72095 }, function (err, item) {
console.log(item);
});
// load a character from a US realm
client.character({
region: 'us',
realm: 'nesingwary',
name: 'havøk',
fields: 'stats'
}, function (err, char) {
console.log(char);
});
// also nice errors
client.item({ id: 99999999 }, function (err, item) {
console.log(err instanceof battle.APIError) // true
console.log(err.statusCode) // 404
console.log(err.message) // "unable to get item information."
console.log(err.body) // json body
});
Options:
options.apiKey
- required[options.region]
- optional, defaults tous
. Supports:us
,eu
,kr
,tw
,ch
Returns: an instance of battle.Client
The client supports all endpoints found on Blizzard's API docs.
Sending a request to the character
endpoint:
client.character({
region: 'us', // optional param
realm: 'nesingwary', // required param
name: 'havøk', // required param
fields: 'stats' // optional param
}, function (err, data) {
// do your thing
})
Note: Passing in params.region
will override the client's default region.
Note: all request parameters that are not required to build the url (such as fields
in the example above) will be sent
to the API as query string parameters.
Available endpoints and their required parameters:
achievement : '/api/wow/achievement/:id',
auction : '/api/wow/auction/data/:realm',
battlePetAbility : '/api/wow/battlePet/ability/:id',
battlePetSpecies : '/api/wow/battlePet/species/:id',
battlePetStats : '/api/wow/battlePet/stats/:id',
challengeRealm : '/api/wow/challenge/:realm',
challengeRegion : '/api/wow/challenge/region',
character : '/api/wow/character/:realm/:name',
item : '/api/wow/item/:id',
itemSet : '/api/wow/item/set/:id',
guild : '/api/wow/guild/:realm/:name',
arenaTeam : '/api/wow/arena/:realm/:size/:name', // size=2v2, 3v3, 5v5
arenaLadder : '/api/wow/pvp/arena/:battlegroup/:size',
ratedBg : '/api/wow/pvp/ratedbg/ladder',
quest : '/api/wow/quest/:id',
realm : '/api/wow/realm/status',
recipe : '/api/wow/recipe/:id',
spell : '/api/wow/spell/:id',
battlegroups : '/api/wow/data/battlegroups/',
races : '/api/wow/data/character/races',
classes : '/api/wow/data/character/classes',
achievements : '/api/wow/data/character/achievements',
guildRewards : '/api/wow/data/guild/rewards',
guildPerks : '/api/wow/data/guild/perks',
guildAchievements: '/api/wow/data/guild/achievements',
itemClasses : '/api/wow/data/item/classes',
talents : '/api/wow/data/talents',
petTypes : '/api/wow/data/pet/types'
The error class used for API errors. err.statusCode
, err.message
and err.body
are populated from the response.