Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

battlenet-api

Package Overview
Dependencies
Maintainers
1
Versions
41
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

battlenet-api

A wrapper for the Battle.net API

  • 0.6.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4
decreased by-55.56%
Maintainers
1
Weekly downloads
 
Created
Source

Battle.net API

![Gitter](https://badges.gitter.im/Join Chat.svg)

A Node JS wrapper for the Battle.net API

Install

Add battlenet-api to your package.json file and install with:

npm install

Or add and install it in a single step:

npm install battlenet-api --save

How to use

Step 1: require() the Battle.net API within your application:

var bnet = require('battlenet-api')();

Step 2: Call the API methods to request data:

bnet.wow.character.profile(parameters, [config,] callback);

Step 3: ???

Step 4: Profit.

Battle.net API Key

Your private Battle.net API key must be present in order to get a valid Battle.net API response. There are several ways to include it in the request:

As an optional parameter with each method

bnet.wow.character.profile(parameters, {apikey: your_api_key}, callback);

As an optional parameter with require

var bnet = require('battlenet-api')(your_api_key);

As a system environment variable

$ sudo BATTLENET_API_KEY=[your_api_key] node server.js

While all three ways of using the API key can be used together, the Method usage will override the Require usage which will override the Environment Variable usage. Use the most appropriate way of setting the API key that suits your needs. Please see the documentation at the Blizzard Developer Portal to obtain your own Battle.net API key.

Documentation

Each API method receives a parameters object, an optional configuration object, and a callback function to execute once the request has completed. The available request parameters for each method are explained in the Overview.

bnet.wow.character.profile(parameters, [config,] callback);

parameters: Required. The individual per-method parameters can be found in the overview. ALL API methods will accept an origin and locale.

  • origin Required. This indicates which regional API endpoint to use and will match the region in which the user plays. The supported origins depends on the game you are requesting data for.
  • locale Optional. This localizes the returned results to the specified language. The supported locales depend on which origin is used, and when no locale is supplied the Battle.net API will default to the primary language of that region.

config: Optional. Accepts the following configuration options.

  • apikey Optional. Your Battle.net API key is set here if not supplied by the Require or Environment Variable.
  • timeout Optional. Defaults to 10000.
  • gzip Optional. Defaults to true.
  • maxRedirects Optional. Defaults to 10.

callback Required. The callback function receives two arguments error and response.

  • error is only applicable when there's an issue with the request connection. Otherwise null.
  • response will contain the request response body parsed as JSON.

A fully-formed request will look something like this:

bnet.wow.character.guild({ origin: 'us', realm: 'amanthul', name: 'charni' }, { apikey: BATTLENET_API_KEY }, function(err, resp) {
  console.log(resp);
});

Overview

World of Warcraft

Starcraft 2

Diablo 3


World of Warcraft

The World of Warcraft API methods are available through the wow object of the Battle.net API.

var wow = bnet.wow;

The supported origins and locales for the World of Warcraft API are:

OriginLocales
usen_US, es_MX, pt_BR
euen_GB, es_ES, fr_FR, ru_RU, de_DE, pl_PL, pt_PT, it_IT
krko_KR
twzh_TW

Achievement

Parameters

id the unique achievement ID.

Usage

bnet.wow.achievement({origin: 'us', id: 2144}, callback);

Auction

Parameters

realm the slugified realm name.

Usage

bnet.wow.auction({origin: 'us', realm: 'amanthul'}, callback);

Battle Pet

Abilities

Parameters

id the unique ID of the battle pet ability.

Usage

bnet.wow.battlePet.ability({origin: 'us', id: 640}, callback);

Species

Parameters

id the unique ID of the battle pet species.

Usage

bnet.wow.battlePet.species({origin: 'us', id: 258}, callback);

Stats

Parameters

id the unique ID of the battle pet species.

fields an object containing the battle pet level, breedId, and qualityId

Usage

bnet.wow.battlePet.stats({origin: 'us', id: 258, fields: { level: 25, breedId: 5, qualityId: 4 }}, callback);

Challenge

Realm Leaderboard

Parameters

realm the slugified realm name.

Usage

bnet.wow.challenge.realmLeaderboard({origin: 'us', realm: 'amanthul'}, callback);

Region Leaderboard

Usage

bnet.wow.challenge.regionLeaderboard({origin: 'us'}, callback);

Character

All World of Warcraft character requests require the following parameters:

realm the slugified realm of the character.

name the name of the character.

Profile

Returns basic profile data about the character.

Usage

bnet.wow.character.profile({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Achievements

Returns the achievement data of the character.

Usage

bnet.wow.character.achievements({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Appearance

Returns the appearance data of the character.

Usage

bnet.wow.character.appearance({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Guild

Returns the guild data of the character.

Usage

bnet.wow.character.guild({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Hunter Pets

Returns the hunter pet data of the character (where applicable).

Usage

bnet.wow.character.hunterPets({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Items

Returns the item data of the character.

Usage

bnet.wow.character.items({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Mounts

Returns the mount data of the character.

Usage

bnet.wow.character.mounts({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Pets

Returns the pet data of the character.

Usage

bnet.wow.character.pets({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Pet Slots

Returns the pet slots data of the character.

Usage

bnet.wow.character.petSlots({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Progression

Returns the progression data of the character.

Usage

bnet.wow.character.progression({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

PVP

Returns the PVP data of the character.

Usage

bnet.wow.character.pvp({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Quests

Returns the quest data of the character.

Usage

bnet.wow.character.quests({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Reputation

Returns the reputation data of the character.

Usage

bnet.wow.character.reputation({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Stats

Returns the statistics data of the character.

Usage

bnet.wow.character.stats({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Talents

Returns the talent data of the character.

Usage

bnet.wow.character.talents({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Titles

Returns the title data of the character.

Usage

bnet.wow.character.titles({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Audit

Returns an audit of the character's equipment.

Usage

bnet.wow.character.audit({origin: 'us', realm: 'amanthul', name: 'charni'}, callback);

Aggregate

Returns the specified character fields aggregated in a single request.

Parameters

fields an array of one or more character fields.

Usage

bnet.wow.character.aggregate({origin: 'us', realm: 'amanthul', name: 'charni', fields: ['pets', 'petSlots']}, callback);

Data Resources

Battlegroups

Usage

bnet.wow.data.battlegroups({origin: 'us'}, callback);

Character Achievements

Usage

bnet.wow.data.characterAchievements({origin: 'us'}, callback);

Character Classes

Usage

bnet.wow.data.characterClasses({origin: 'us'}, callback);

Character Races

Usage

bnet.wow.data.characterRaces({origin: 'us'}, callback);

Guild Achievements

Usage

bnet.wow.data.guildAchievements({origin: 'us'}, callback);

Guild Perks

Usage

bnet.wow.data.guildPerks({origin: 'us'}, callback);

Guild Rewards

Usage

bnet.wow.data.guildRewards({origin: 'us'}, callback);

Item Classes

Usage

bnet.wow.data.itemClasses({origin: 'us'}, callback);

Pet Types

Usage

bnet.wow.data.petTypes({origin: 'us'}, callback);

Talents

Usage

bnet.wow.data.talents({origin: 'us'}, callback);

Item

Item

Returns the item data of the specified item ID.

Parameters

id the unique item ID.

Usage

bnet.wow.item.item({origin: 'us', id: 18803}, callback);

Item Set

Returns the item set data of the specified set ID.

Parameters

id the unique item set ID.

Usage

bnet.wow.item.set({origin: 'us', id: 1060}, callback);

Guild

All World of Warcraft guild requests require the following parameters:

realm the slugified realm of the guild.

name the name of the guild.

Aggregate

Returns the specified guild fields aggregated in a single request.

Parameters

fields an array of one or more guild fields.

Usage

bnet.wow.guild.aggregate({origin: 'us', realm: 'amanthul', name: 'blackwolf', fields: ['members', 'achievements']}, callback);

Achievements

Returns the achievement data of the guild.

Usage

bnet.wow.guild.achievements({origin: 'us', realm: 'amanthul', name: 'blackwolf'}, callback);

Challenge

Returns the challenge data of the guild.

Usage

bnet.wow.guild.challenge({origin: 'us', realm: 'amanthul', name: 'blackwolf'}, callback);

Members

Returns the members data of the guild.

Usage

bnet.wow.guild.members({origin: 'us', realm: 'amanthul', name: 'blackwolf'}, callback);

News

Returns the news data of the guild.

Usage

bnet.wow.guild.news({origin: 'us', realm: 'amanthul', name: 'blackwolf'}, callback);

Profile

Returns basic profile data of the guild.

Usage

bnet.wow.guild.profile({origin: 'us', realm: 'amanthul', name: 'blackwolf'}, callback);

PVP

Leaderboards

Parameters

bracket [2v2, 3v3, 5v5, rbg]

Usage

bnet.wow.pvp.leaderboards({origin: 'us', bracket: '2v2'}, callback);

Quest

Parameters

id the unique quest ID.

Usage

bnet.wow.quest({origin: 'us', quest: 13146}, callback);

Realm Status

Parameters

fields [optional] an array of one or more realms to limit.

Usage

All realms

bnet.wow.realmStatus({origin: 'us'}, callback);

Selected realms

bnet.wow.realmStatus({origin: 'us', realms: ['proudmoore', 'blackrock']}, callback);

Recipe

Parameters

id the unique recipe ID.

Usage

bnet.wow.recipe({origin: 'us', id: 33994}, callback);

Spell

Parameters

id the unique spell ID.

Usage

bnet.wow.spell({origin: 'us', id: 8056}, callback);

Starcraft 2

The Starcraft 2 API methods are available through the sc2 object of the Battle.net API.

var sc2 = bnet.sc2;

The supported origins and locales for the Starcraft 2 API are:

OriginLocales
usen_US, es_MX, pt_BR
euen_GB, es_ES, fr_FR, ru_RU, de_DE, pl_PL, pt_PT, it_IT
seaen_US
krko_KR
twzh_TW

Profile

All Starcraft 2 profile requests require the following parameters.

id the unique player ID.

region the player's region ID.

name the player's profile name.

Profile

Returns basic profile data for the specified player.

Usage

bnet.sc2.profile.profile({origin: 'us', id: 2137104, region: 1, name: 'skt'}, callback);

Ladders

Returns ladder data for the specified player.

Usage

bnet.sc2.profile.ladders({origin: 'us', id: 2137104, region: 1, name: 'skt'}, callback);

Match history

Returns match history data for the specified player.

Usage

bnet.sc2.profile.matchHistory({origin: 'us', id: 2137104, region: 1, name: 'skt'}, callback);

Ladder

Parameters

id the unique ladder ID.

Usage

bnet.sc2.ladder({origin: 'us', id: 655}, callback);

Data Resources

Achievements

Usage

bnet.sc2.data.achievements({origin: 'us'}, callback);

Rewards

Usage

bnet.sc2.data.rewards({origin: 'us'}, callback);

Diablo 3

The Diablo 3 API methods are available through the d3 object of the Battle.net API.

var d3 = bnet.d3;

The supported origins and locales for the Diablo 3 API are:

OriginLocales
usen_US, es_MX, pt_BR
euen_GB, es_ES, fr_FR, ru_RU, de_DE, pl_PL, pt_PT, it_IT
krko_KR
twzh_TW

Data Resources

Artisan

Parameters

artisan the name of the artisan [blacksmith, jeweller, mystic]

Usage

bnet.d3.data.artisan({origin: 'us', artisan: 'blacksmith'}, callback);

Follower

Parameters

follower the name of the follower [templar, enchantress, scoundrel]

Usage

bnet.d3.data.follower({origin: 'us', follower: 'blacksmith'}, callback);

Item

Parameters

item the item data string.

Usage

bnet.d3.data.item({origin: 'us', item: 'CrABCL-oudQGEgcIBBWZWjYNHWU61OAdyg3pEx07J28kHevi5AUd8dNq1TCLAjj_AkAAUBJYBGD_AmorCgwIABDX3bKmiICA4DESGwi5u5abChIHCAQVIpaumDCPAjgAQAFYBJABAGorCgwIABCl3rKmiICA4DESGwiR9M-gAhIHCAQVIpaumDCLAjgAQAFYBJABAIABRqUBOydvJK0Bj5DKULUBAXBvArgB9aCdsg7AAQEYsuqy0wFQAFgC'} callback);

Profile

Career

Parameters

tag the player's battle tag.

bnet.d3.profile.career({origin: 'us', tag: 'skt-1884'}, callback);

Hero

Parameters

tag the player battle tag.

hero the hero ID.

bnet.d3.profile.hero({origin: 'us', tag: 'skt-1884', hero: 287801}, callback);

Keywords

FAQs

Package last updated on 29 Dec 2014

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc