StarRail.js
About
A Node.js library for Star Rail.
Features
- User Data and Character Stats by UID.
- All Characters and All Light Cones Data.
- Cache Updater for the new update of Honkai: Star Rail. (Update characters and light cones immediately.)
Installation
Node.js 16 or newer is required.
Install starrail.js including Star Rail cache data.
npm install starrail.js
Install using ghproxy.com
If you have already moved the cache to another folder, you can also install without downloading the cache.
npm install starrail.js --sr-nocache=true
About Star Rail Cache Data
Star Rail cache data is from Dimbreath/StarRailData
This data contains data of characters, light cones, materials, and more structure information of Star Rail.
You can change your cache directory.
const { StarRail } = require("starrail.js");
// Change the directory to store cache data.
// Default directory is **/starrail.js/cache.
const client = new StarRail();
client.cachedAssetsManager.cacheDirectoryPath = "./cache";
client.cachedAssetsManager.cacheDirectorySetup();
// OR
const client = new StarRail({ cacheDirectory: "./cache" });
client.cachedAssetsManager.cacheDirectorySetup();
Updating
You can update your Star Rail cache data.
const { StarRail } = require("starrail.js");
const client = new StarRail({ showFetchCacheLog: true }); // showFetchCacheLog is true by default
client.cachedAssetsManager.fetchAllContents(); // returns promise
Also, you can activate auto cache updater.
When using the auto-cache updater, we recommend moving the cache directory directly under your project folder. (DO NOT delete **/starrail.js/cache when moving directory, just delete all folders/files in it.)
const { StarRail } = require("starrail.js");
const client = new StarRail();
client.cachedAssetsManager.activateAutoCacheUpdater({
instant: true, // Run the first update check immediately
timeout: 60 * 60 * 1000, // 1 hour interval
onUpdateStart: async () => {
console.log("Updating Star Rail Data...");
},
onUpdateEnd: async () => {
client.cachedAssetsManager.refreshAllData(); // Refresh memory
console.log("Updating Completed!");
}
});
// // deactivate
// client.cachedAssetsManager.deactivateAutoCacheUpdater();
How to use
Fetching Player Data
const { StarRail } = require("starrail.js");
const client = new StarRail();
client.fetchUser(800069903).then(user => {
console.log(user);
});
Star Rail Character List
const { StarRail } = require("starrail.js");
const client = new StarRail();
const characters = client.getAllCharacters();
// print character names with language "en"
console.log(characters.map(c => c.name.get("en")));
Star Rail Light Cone List
const { StarRail } = require("starrail.js");
const client = new StarRail();
const lightCones = client.getAllLightCones();
// print light cone names with language "jp"
console.log(lightCones.map(w => w.name.get("jp")));
More examples are available in example folder.
For more information, please check Documentation.
You can see the changelog here.