chore: move syndicate sacrifice stuff into syndicateSacrificeController (#682)
This commit is contained in:
parent
52d1b72701
commit
e7a9f2e2b8
@ -1,24 +1,59 @@
|
|||||||
import { getJSONfromString } from "@/src/helpers/stringHelpers";
|
import { getJSONfromString } from "@/src/helpers/stringHelpers";
|
||||||
import { syndicateSacrifice } from "@/src/services/inventoryService";
|
|
||||||
import { ISyndicateSacrifice } from "@/src/types/syndicateTypes";
|
|
||||||
import { RequestHandler } from "express";
|
import { RequestHandler } from "express";
|
||||||
import { getAccountIdForRequest } from "@/src/services/loginService";
|
import { getAccountIdForRequest } from "@/src/services/loginService";
|
||||||
|
import { ExportSyndicates } from "warframe-public-export-plus";
|
||||||
|
import { handleStoreItemAcquisition } from "@/src/services/purchaseService";
|
||||||
|
import { getInventory } from "@/src/services/inventoryService";
|
||||||
|
import { IInventoryChanges } from "@/src/types/purchaseTypes";
|
||||||
|
|
||||||
const syndicateSacrificeController: RequestHandler = async (request, response) => {
|
export const syndicateSacrificeController: RequestHandler = async (request, response) => {
|
||||||
const accountId = await getAccountIdForRequest(request);
|
const accountId = await getAccountIdForRequest(request);
|
||||||
const update = getJSONfromString(String(request.body)) as ISyndicateSacrifice;
|
const inventory = await getInventory(accountId);
|
||||||
let reply = {};
|
const data = getJSONfromString(String(request.body)) as ISyndicateSacrifice;
|
||||||
try {
|
|
||||||
if (typeof update !== "object") {
|
|
||||||
throw new Error("Invalid data format");
|
|
||||||
}
|
|
||||||
|
|
||||||
reply = await syndicateSacrifice(update, accountId);
|
let syndicate = inventory.Affiliations.find(x => x.Tag == data.AffiliationTag);
|
||||||
} catch (err) {
|
if (!syndicate) {
|
||||||
console.error("Error parsing JSON data:", err);
|
syndicate = inventory.Affiliations[inventory.Affiliations.push({ Tag: data.AffiliationTag, Standing: 0 }) - 1];
|
||||||
}
|
}
|
||||||
|
|
||||||
response.json(reply);
|
let reward: string | undefined;
|
||||||
|
|
||||||
|
const manifest = ExportSyndicates[data.AffiliationTag];
|
||||||
|
if (manifest?.initiationReward && data.SacrificeLevel == 0) {
|
||||||
|
reward = manifest.initiationReward;
|
||||||
|
syndicate.Initiated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
const level = data.SacrificeLevel - (syndicate.Title ?? 0);
|
||||||
|
const res: ISyndicateSacrificeResponse = {
|
||||||
|
AffiliationTag: data.AffiliationTag,
|
||||||
|
InventoryChanges: {},
|
||||||
|
Level: data.SacrificeLevel,
|
||||||
|
LevelIncrease: level <= 0 ? 1 : level,
|
||||||
|
NewEpisodeReward: syndicate?.Tag == "RadioLegionIntermission9Syndicate"
|
||||||
|
};
|
||||||
|
|
||||||
|
if (syndicate?.Title !== undefined) syndicate.Title += 1;
|
||||||
|
|
||||||
|
await inventory.save();
|
||||||
|
|
||||||
|
if (reward) {
|
||||||
|
res.InventoryChanges = (await handleStoreItemAcquisition(reward, accountId)).InventoryChanges;
|
||||||
|
}
|
||||||
|
|
||||||
|
response.json(res);
|
||||||
};
|
};
|
||||||
|
|
||||||
export { syndicateSacrificeController };
|
interface ISyndicateSacrifice {
|
||||||
|
AffiliationTag: string;
|
||||||
|
SacrificeLevel: number;
|
||||||
|
AllowMultiple: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ISyndicateSacrificeResponse {
|
||||||
|
AffiliationTag: string;
|
||||||
|
Level: number;
|
||||||
|
LevelIncrease: number;
|
||||||
|
InventoryChanges: IInventoryChanges;
|
||||||
|
NewEpisodeReward: boolean;
|
||||||
|
}
|
||||||
|
@ -28,7 +28,6 @@ import {
|
|||||||
} from "../types/requestTypes";
|
} from "../types/requestTypes";
|
||||||
import { logger } from "@/src/utils/logger";
|
import { logger } from "@/src/utils/logger";
|
||||||
import { getWeaponType, getExalted } from "@/src/services/itemDataService";
|
import { getWeaponType, getExalted } from "@/src/services/itemDataService";
|
||||||
import { ISyndicateSacrifice, ISyndicateSacrificeResponse } from "../types/syndicateTypes";
|
|
||||||
import { IEquipmentClient, IItemConfig } from "../types/inventoryTypes/commonInventoryTypes";
|
import { IEquipmentClient, IItemConfig } from "../types/inventoryTypes/commonInventoryTypes";
|
||||||
import {
|
import {
|
||||||
ExportArcanes,
|
ExportArcanes,
|
||||||
@ -38,11 +37,9 @@ import {
|
|||||||
ExportRecipes,
|
ExportRecipes,
|
||||||
ExportResources,
|
ExportResources,
|
||||||
ExportSentinels,
|
ExportSentinels,
|
||||||
ExportSyndicates,
|
|
||||||
ExportUpgrades
|
ExportUpgrades
|
||||||
} from "warframe-public-export-plus";
|
} from "warframe-public-export-plus";
|
||||||
import { createShip } from "./shipService";
|
import { createShip } from "./shipService";
|
||||||
import { handleStoreItemAcquisition } from "./purchaseService";
|
|
||||||
|
|
||||||
export const createInventory = async (
|
export const createInventory = async (
|
||||||
accountOwnerId: Types.ObjectId,
|
accountOwnerId: Types.ObjectId,
|
||||||
@ -552,45 +549,6 @@ export const updateTheme = async (data: IThemeUpdateRequest, accountId: string):
|
|||||||
await inventory.save();
|
await inventory.save();
|
||||||
};
|
};
|
||||||
|
|
||||||
export const syndicateSacrifice = async (
|
|
||||||
data: ISyndicateSacrifice,
|
|
||||||
accountId: string
|
|
||||||
): Promise<ISyndicateSacrificeResponse> => {
|
|
||||||
const inventory = await getInventory(accountId);
|
|
||||||
|
|
||||||
let syndicate = inventory.Affiliations.find(x => x.Tag == data.AffiliationTag);
|
|
||||||
if (!syndicate) {
|
|
||||||
syndicate = inventory.Affiliations[inventory.Affiliations.push({ Tag: data.AffiliationTag, Standing: 0 }) - 1];
|
|
||||||
}
|
|
||||||
|
|
||||||
let reward: string | undefined;
|
|
||||||
|
|
||||||
const manifest = ExportSyndicates[data.AffiliationTag];
|
|
||||||
if (manifest?.initiationReward && data.SacrificeLevel == 0) {
|
|
||||||
reward = manifest.initiationReward;
|
|
||||||
syndicate.Initiated = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
const level = data.SacrificeLevel - (syndicate.Title ?? 0);
|
|
||||||
const res: ISyndicateSacrificeResponse = {
|
|
||||||
AffiliationTag: data.AffiliationTag,
|
|
||||||
InventoryChanges: {},
|
|
||||||
Level: data.SacrificeLevel,
|
|
||||||
LevelIncrease: level <= 0 ? 1 : level,
|
|
||||||
NewEpisodeReward: syndicate?.Tag == "RadioLegionIntermission9Syndicate"
|
|
||||||
};
|
|
||||||
|
|
||||||
if (syndicate?.Title !== undefined) syndicate.Title += 1;
|
|
||||||
|
|
||||||
await inventory.save();
|
|
||||||
|
|
||||||
if (reward) {
|
|
||||||
res.InventoryChanges = (await handleStoreItemAcquisition(reward, accountId)).InventoryChanges;
|
|
||||||
}
|
|
||||||
|
|
||||||
return res;
|
|
||||||
};
|
|
||||||
|
|
||||||
export const addEquipment = async (
|
export const addEquipment = async (
|
||||||
category: TEquipmentKey,
|
category: TEquipmentKey,
|
||||||
type: string,
|
type: string,
|
||||||
|
@ -1,15 +0,0 @@
|
|||||||
import { IInventoryChanges } from "./purchaseTypes";
|
|
||||||
|
|
||||||
export interface ISyndicateSacrifice {
|
|
||||||
AffiliationTag: string;
|
|
||||||
SacrificeLevel: number;
|
|
||||||
AllowMultiple: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface ISyndicateSacrificeResponse {
|
|
||||||
AffiliationTag: string;
|
|
||||||
Level: number;
|
|
||||||
LevelIncrease: number;
|
|
||||||
InventoryChanges: IInventoryChanges;
|
|
||||||
NewEpisodeReward: boolean;
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user