feat: retrievePetFromStasis
All checks were successful
Build / build (22) (push) Successful in 41s
Build / build (20) (push) Successful in 1m11s
Build / build (18) (push) Successful in 1m20s
Build / build (20) (pull_request) Successful in 1m11s
Build / build (18) (pull_request) Successful in 44s
Build / build (22) (pull_request) Successful in 1m6s
All checks were successful
Build / build (22) (push) Successful in 41s
Build / build (20) (push) Successful in 1m11s
Build / build (18) (push) Successful in 1m20s
Build / build (20) (pull_request) Successful in 1m11s
Build / build (18) (pull_request) Successful in 44s
Build / build (22) (pull_request) Successful in 1m6s
This commit is contained in:
parent
a56ff89bb9
commit
bf906321f6
33
src/controllers/api/retrievePetFromStasisController.ts
Normal file
33
src/controllers/api/retrievePetFromStasisController.ts
Normal file
@ -0,0 +1,33 @@
|
||||
import { getJSONfromString } from "@/src/helpers/stringHelpers";
|
||||
import { getInventory } from "@/src/services/inventoryService";
|
||||
import { getAccountIdForRequest } from "@/src/services/loginService";
|
||||
import { Status } from "@/src/types/inventoryTypes/inventoryTypes";
|
||||
import { RequestHandler } from "express";
|
||||
|
||||
export const retrievePetFromStasisController: RequestHandler = async (req, res) => {
|
||||
const accountId = await getAccountIdForRequest(req);
|
||||
const inventory = await getInventory(accountId, "KubrowPets");
|
||||
const data = getJSONfromString<IRetrievePetFromStasisRequest>(String(req.body));
|
||||
|
||||
let oldPetId: string | undefined;
|
||||
for (const pet of inventory.KubrowPets) {
|
||||
if (pet.Details!.Status == Status.StatusAvailable) {
|
||||
pet.Details!.Status = Status.StatusStasis;
|
||||
oldPetId = pet._id.toString();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
inventory.KubrowPets.id(data.petId)!.Details!.Status = Status.StatusAvailable;
|
||||
|
||||
await inventory.save();
|
||||
res.json({
|
||||
petId: data.petId,
|
||||
oldPetId,
|
||||
status: Status.StatusAvailable
|
||||
});
|
||||
};
|
||||
|
||||
interface IRetrievePetFromStasisRequest {
|
||||
petId: string;
|
||||
}
|
@ -84,6 +84,7 @@ import { queueDojoComponentDestructionController } from "@/src/controllers/api/q
|
||||
import { redeemPromoCodeController } from "@/src/controllers/api/redeemPromoCodeController";
|
||||
import { removeFromGuildController } from "@/src/controllers/api/removeFromGuildController";
|
||||
import { rerollRandomModController } from "@/src/controllers/api/rerollRandomModController";
|
||||
import { retrievePetFromStasisController } from "@/src/controllers/api/retrievePetFromStasisController";
|
||||
import { saveDialogueController } from "@/src/controllers/api/saveDialogueController";
|
||||
import { saveLoadoutController } from "@/src/controllers/api/saveLoadout";
|
||||
import { saveSettingsController } from "@/src/controllers/api/saveSettingsController";
|
||||
@ -228,6 +229,7 @@ apiRouter.post("/purchase.php", purchaseController);
|
||||
apiRouter.post("/redeemPromoCode.php", redeemPromoCodeController);
|
||||
apiRouter.post("/removeFromGuild.php", removeFromGuildController);
|
||||
apiRouter.post("/rerollRandomMod.php", rerollRandomModController);
|
||||
apiRouter.post("/retrievePetFromStasis.php", retrievePetFromStasisController);
|
||||
apiRouter.post("/saveDialogue.php", saveDialogueController);
|
||||
apiRouter.post("/saveLoadout.php", saveLoadoutController);
|
||||
apiRouter.post("/saveSettings.php", saveSettingsController);
|
||||
|
Loading…
x
Reference in New Issue
Block a user