aboutsummaryrefslogtreecommitdiff
path: root/build
diff options
context:
space:
mode:
Diffstat (limited to 'build')
-rw-r--r--build/cleaners/skyblock/inventory.js62
-rw-r--r--build/cleaners/skyblock/member.js4
2 files changed, 65 insertions, 1 deletions
diff --git a/build/cleaners/skyblock/inventory.js b/build/cleaners/skyblock/inventory.js
new file mode 100644
index 0000000..1927add
--- /dev/null
+++ b/build/cleaners/skyblock/inventory.js
@@ -0,0 +1,62 @@
+"use strict";
+var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
+ if (k2 === undefined) k2 = k;
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
+}) : (function(o, m, k, k2) {
+ if (k2 === undefined) k2 = k;
+ o[k2] = m[k];
+}));
+var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
+}) : function(o, v) {
+ o["default"] = v;
+});
+var __importStar = (this && this.__importStar) || function (mod) {
+ if (mod && mod.__esModule) return mod;
+ var result = {};
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
+ __setModuleDefault(result, mod);
+ return result;
+};
+Object.defineProperty(exports, "__esModule", { value: true });
+exports.cleanInventories = exports.INVENTORIES = exports.cleanInventory = void 0;
+const nbt = __importStar(require("prismarine-nbt"));
+function base64decode(base64) {
+ return Buffer.from(base64, 'base64');
+}
+function cleanInventory(encodedNbt) {
+ return new Promise(resolve => {
+ const base64Data = base64decode(encodedNbt);
+ nbt.parse(base64Data, false, (err, value) => {
+ const simplifiedNbt = nbt.simplify(value);
+ // .i because hypixel decided to do that
+ resolve(simplifiedNbt.i);
+ });
+ });
+}
+exports.cleanInventory = cleanInventory;
+exports.INVENTORIES = {
+ armor: 'inv_armor',
+ inventory: 'inv_contents',
+ ender_chest: 'ender_chest_contents',
+ talisman_bag: 'talisman_bag',
+ potion_bag: 'potion_bag',
+ fishing_bag: 'fishing_bag',
+ quiver: 'quiver',
+ trick_or_treat_bag: 'candy_inventory_contents',
+ wardrobe: 'wardrobe_contents'
+};
+async function cleanInventories(data) {
+ var _a;
+ const cleanInventories = {};
+ for (const cleanInventoryName in exports.INVENTORIES) {
+ const hypixelInventoryName = exports.INVENTORIES[cleanInventoryName];
+ const encodedInventoryContents = (_a = data[hypixelInventoryName]) === null || _a === void 0 ? void 0 : _a.data;
+ let inventoryContents;
+ if (encodedInventoryContents)
+ inventoryContents = await cleanInventory(encodedInventoryContents);
+ cleanInventories[cleanInventoryName] = inventoryContents;
+ }
+ return cleanInventories;
+}
+exports.cleanInventories = cleanInventories;
diff --git a/build/cleaners/skyblock/member.js b/build/cleaners/skyblock/member.js
index 736593a..74da48a 100644
--- a/build/cleaners/skyblock/member.js
+++ b/build/cleaners/skyblock/member.js
@@ -22,6 +22,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
exports.cleanSkyBlockProfileMemberResponse = void 0;
const cached = __importStar(require("../../hypixelCached"));
const fairysouls_1 = require("./fairysouls");
+const inventory_1 = require("./inventory");
const minions_1 = require("./minions");
const stats_1 = require("./stats");
/** Cleans up a member (from skyblock/profile) */
@@ -36,7 +37,8 @@ async function cleanSkyBlockProfileMemberResponse(member, included = null) {
// last_death: ??? idk how this is formatted,
stats: statsIncluded ? stats_1.cleanProfileStats(member === null || member === void 0 ? void 0 : member.stats) : undefined,
minions: statsIncluded ? minions_1.cleanMinions(member) : undefined,
- fairy_souls: statsIncluded ? fairysouls_1.cleanFairySouls(member) : undefined
+ fairy_souls: statsIncluded ? fairysouls_1.cleanFairySouls(member) : undefined,
+ inventories: statsIncluded ? await inventory_1.cleanInventories(member) : undefined,
};
}
exports.cleanSkyBlockProfileMemberResponse = cleanSkyBlockProfileMemberResponse;