feat: claim circuit rewards
This commit is contained in:
parent
f068b74841
commit
a5115d464f
@ -1,11 +1,13 @@
|
|||||||
import { RequestHandler } from "express";
|
import { RequestHandler } from "express";
|
||||||
import { getAccountIdForRequest } from "@/src/services/loginService";
|
import { getAccountIdForRequest } from "@/src/services/loginService";
|
||||||
import { getInventory } from "@/src/services/inventoryService";
|
import { combineInventoryChanges, getInventory } from "@/src/services/inventoryService";
|
||||||
import { getJSONfromString } from "@/src/helpers/stringHelpers";
|
import { getJSONfromString } from "@/src/helpers/stringHelpers";
|
||||||
import { IEndlessXpReward, IInventoryClient, TEndlessXpCategory } from "@/src/types/inventoryTypes/inventoryTypes";
|
import { IEndlessXpReward, IInventoryClient, TEndlessXpCategory } from "@/src/types/inventoryTypes/inventoryTypes";
|
||||||
import { logger } from "@/src/utils/logger";
|
import { logger } from "@/src/utils/logger";
|
||||||
import { ExportRewards, ICountedStoreItem } from "warframe-public-export-plus";
|
import { ExportRewards, ICountedStoreItem } from "warframe-public-export-plus";
|
||||||
import { getRandomElement } from "@/src/services/rngService";
|
import { getRandomElement } from "@/src/services/rngService";
|
||||||
|
import { handleStoreItemAcquisition } from "@/src/services/purchaseService";
|
||||||
|
import { IInventoryChanges } from "@/src/types/purchaseTypes";
|
||||||
|
|
||||||
export const endlessXpController: RequestHandler = async (req, res) => {
|
export const endlessXpController: RequestHandler = async (req, res) => {
|
||||||
const accountId = await getAccountIdForRequest(req);
|
const accountId = await getAccountIdForRequest(req);
|
||||||
@ -42,17 +44,46 @@ export const endlessXpController: RequestHandler = async (req, res) => {
|
|||||||
res.json({
|
res.json({
|
||||||
NewProgress: inventory.toJSON<IInventoryClient>().EndlessXP!.find(x => x.Category == payload.Category)!
|
NewProgress: inventory.toJSON<IInventoryClient>().EndlessXP!.find(x => x.Category == payload.Category)!
|
||||||
});
|
});
|
||||||
|
} else if (payload.Mode == "c") {
|
||||||
|
const inventory = await getInventory(accountId);
|
||||||
|
const entry = inventory.EndlessXP!.find(x => x.Category == payload.Category)!;
|
||||||
|
const inventoryChanges: IInventoryChanges = {};
|
||||||
|
for (const reward of entry.PendingRewards) {
|
||||||
|
if (entry.Claim < reward.RequiredTotalXp && reward.RequiredTotalXp <= entry.Earn) {
|
||||||
|
combineInventoryChanges(
|
||||||
|
inventoryChanges,
|
||||||
|
(
|
||||||
|
await handleStoreItemAcquisition(
|
||||||
|
reward.Rewards[0].StoreItem,
|
||||||
|
inventory,
|
||||||
|
reward.Rewards[0].ItemCount
|
||||||
|
)
|
||||||
|
).InventoryChanges
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
entry.Claim = entry.Earn;
|
||||||
|
await inventory.save();
|
||||||
|
res.json({
|
||||||
|
InventoryChanges: inventoryChanges,
|
||||||
|
ClaimedXp: entry.Claim
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
logger.debug(`data provided to ${req.path}: ${String(req.body)}`);
|
logger.debug(`data provided to ${req.path}: ${String(req.body)}`);
|
||||||
throw new Error(`unexpected endlessXp mode: ${payload.Mode}`);
|
throw new Error(`unexpected endlessXp mode: ${payload.Mode}`);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
interface IEndlessXpRequest {
|
type IEndlessXpRequest =
|
||||||
Mode: string; // "r"
|
| {
|
||||||
Category: TEndlessXpCategory;
|
Mode: "r";
|
||||||
Choices: string[];
|
Category: TEndlessXpCategory;
|
||||||
}
|
Choices: string[];
|
||||||
|
}
|
||||||
|
| {
|
||||||
|
Mode: "c" | "something else";
|
||||||
|
Category: TEndlessXpCategory;
|
||||||
|
};
|
||||||
|
|
||||||
const generateRandomRewards = (deckName: string): ICountedStoreItem[] => {
|
const generateRandomRewards = (deckName: string): ICountedStoreItem[] => {
|
||||||
const reward = getRandomElement(ExportRewards[deckName][0])!;
|
const reward = getRandomElement(ExportRewards[deckName][0])!;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user