Get stats from Blizzard's career profile pages.
https://playoverwatch.com/en-us/career/PLATFORM/BATTLETAG
Gets rank level, endorsements, hero stats and most played time for quickplay and competitive.
import * as owapi from '@endbug/overwatch-stats-api'
(async () => {
const stats = await ow.getAllStats('xQc-11273', 'pc');
console.log(stats);
})();
- Profiles in Overwatch are private by default and this module can only get stats that are publicly available. You can make your profile public in game under options -> social -> career profile visibility: PUBLIC
- Profile visibility and the profile stats in general only update upon exiting the game: they may take some time to update on Blizzard's website and therefore through this module.
- Because this module gets the profile page and parses it, best practice would be to simply use
getAllStats()
and cache it for some time, using each part as needed since accessing and downloading the whole page multiple times for each different section of stats will result in excessive hits to Blizzard's site and could potentially lead to ratelimits. - This module does not do any caching and you should definitely consider this if using it in some kind of web API application.
You can see the actual results of the commands by using the interactive demo on RunKit.
There are pre-compiled example responses in the examples
directory of this repo.
battletag
are Blizzard battletags in the "NAME-DISCRIMINATOR"
format (e.g. "xQc-11273"
) and are case sensitive.
platform
can be either pc
, xbl
or psn
for PC, Xbox Live and PlayStation Network profiles respectively.
Get all stats from other 3 methods combined.
Get basic info like rank, level, endorsements and link to profile, stars and border images.
Get hero stats for competitive and quickplay with categories under each hero and an "overall" hero for overall stats in that mode.
Get the most played heros for competitive and quickplay with a HH:MM:SS time string and link to their thumbnail image in descending order of time played.
These methods return promises that are sometimes rejected with an Error
:
- If the profile can't be found:
Error('PROFILE_NOT_FOUND');
- If the profile is private.
Error('PROFILE_PRIVATE');
This package is forked from overwatch-stats-api
by @fatchan