feat: implement syndicateStandingBonus endpoint (#583)
This commit is contained in:
parent
b84258a893
commit
52c0a3123e
61
src/controllers/api/syndicateStandingBonusController.ts
Normal file
61
src/controllers/api/syndicateStandingBonusController.ts
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
import { RequestHandler } from "express";
|
||||||
|
import { getAccountIdForRequest } from "@/src/services/loginService";
|
||||||
|
import { addMiscItems, getInventory } from "@/src/services/inventoryService";
|
||||||
|
import { IMiscItem } from "@/src/types/inventoryTypes/inventoryTypes";
|
||||||
|
import { IOid } from "@/src/types/commonTypes";
|
||||||
|
import { ExportSyndicates } from "warframe-public-export-plus";
|
||||||
|
|
||||||
|
export const syndicateStandingBonusController: RequestHandler = async (req, res) => {
|
||||||
|
const accountId = await getAccountIdForRequest(req);
|
||||||
|
const request = JSON.parse(String(req.body)) as ISyndicateStandingBonusRequest;
|
||||||
|
|
||||||
|
let gainedStanding = 0;
|
||||||
|
request.Operation.Items.forEach(item => {
|
||||||
|
const medallion = (ExportSyndicates[request.Operation.AffiliationTag].medallions ?? []).find(
|
||||||
|
medallion => medallion.itemType == item.ItemType
|
||||||
|
);
|
||||||
|
if (medallion) {
|
||||||
|
gainedStanding += medallion.standing * item.ItemCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
item.ItemCount *= -1;
|
||||||
|
});
|
||||||
|
|
||||||
|
const inventory = await getInventory(accountId);
|
||||||
|
addMiscItems(inventory, request.Operation.Items);
|
||||||
|
|
||||||
|
const syndicate = inventory.Affiliations.find(x => x.Tag == request.Operation.AffiliationTag);
|
||||||
|
if (syndicate !== undefined) {
|
||||||
|
syndicate.Standing += gainedStanding;
|
||||||
|
} else {
|
||||||
|
inventory.Affiliations.push({
|
||||||
|
Tag: request.Operation.AffiliationTag,
|
||||||
|
Standing: gainedStanding
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: Subtract from daily limit bin; maybe also a cheat to skip that.
|
||||||
|
|
||||||
|
await inventory.save();
|
||||||
|
|
||||||
|
res.json({
|
||||||
|
InventoryChanges: {
|
||||||
|
MiscItems: request.Operation.Items
|
||||||
|
},
|
||||||
|
AffiliationMods: [
|
||||||
|
{
|
||||||
|
Tag: request.Operation.AffiliationTag,
|
||||||
|
Standing: gainedStanding
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
interface ISyndicateStandingBonusRequest {
|
||||||
|
Operation: {
|
||||||
|
AffiliationTag: string;
|
||||||
|
AlternateBonusReward: ""; // ???
|
||||||
|
Items: IMiscItem[];
|
||||||
|
};
|
||||||
|
ModularWeaponId: IOid; // Seems to just be "000000000000000000000000", also note there's a "Category" query field
|
||||||
|
}
|
@ -62,6 +62,7 @@ import { startRecipeController } from "@/src/controllers/api/startRecipeControll
|
|||||||
import { stepSequencersController } from "@/src/controllers/api/stepSequencersController";
|
import { stepSequencersController } from "@/src/controllers/api/stepSequencersController";
|
||||||
import { surveysController } from "@/src/controllers/api/surveysController";
|
import { surveysController } from "@/src/controllers/api/surveysController";
|
||||||
import { syndicateSacrificeController } from "../controllers/api/syndicateSacrificeController";
|
import { syndicateSacrificeController } from "../controllers/api/syndicateSacrificeController";
|
||||||
|
import { syndicateStandingBonusController } from "../controllers/api/syndicateStandingBonusController";
|
||||||
import { tauntHistoryController } from "@/src/controllers/api/tauntHistoryController";
|
import { tauntHistoryController } from "@/src/controllers/api/tauntHistoryController";
|
||||||
import { trainingResultController } from "@/src/controllers/api/trainingResultController";
|
import { trainingResultController } from "@/src/controllers/api/trainingResultController";
|
||||||
import { updateChallengeProgressController } from "@/src/controllers/api/updateChallengeProgressController";
|
import { updateChallengeProgressController } from "@/src/controllers/api/updateChallengeProgressController";
|
||||||
@ -139,6 +140,7 @@ apiRouter.post("/startDojoRecipe.php", startDojoRecipeController);
|
|||||||
apiRouter.post("/startRecipe.php", startRecipeController);
|
apiRouter.post("/startRecipe.php", startRecipeController);
|
||||||
apiRouter.post("/stepSequencers.php", stepSequencersController);
|
apiRouter.post("/stepSequencers.php", stepSequencersController);
|
||||||
apiRouter.post("/syndicateSacrifice.php", syndicateSacrificeController);
|
apiRouter.post("/syndicateSacrifice.php", syndicateSacrificeController);
|
||||||
|
apiRouter.post("/syndicateStandingBonus.php", syndicateStandingBonusController);
|
||||||
apiRouter.post("/tauntHistory.php", tauntHistoryController);
|
apiRouter.post("/tauntHistory.php", tauntHistoryController);
|
||||||
apiRouter.post("/trainingResult.php", trainingResultController);
|
apiRouter.post("/trainingResult.php", trainingResultController);
|
||||||
apiRouter.post("/updateChallengeProgress.php", updateChallengeProgressController);
|
apiRouter.post("/updateChallengeProgress.php", updateChallengeProgressController);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user