forked from OpenWF/SpaceNinjaServer
feat: leveling up intrinsics (#725)
This commit is contained in:
parent
83617ae287
commit
f56fc232f2
31
src/controllers/api/playerSkillsController.ts
Normal file
31
src/controllers/api/playerSkillsController.ts
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
import { getJSONfromString } from "@/src/helpers/stringHelpers";
|
||||||
|
import { getInventory } from "@/src/services/inventoryService";
|
||||||
|
import { getAccountIdForRequest } from "@/src/services/loginService";
|
||||||
|
import { IPlayerSkills } from "@/src/types/inventoryTypes/inventoryTypes";
|
||||||
|
import { RequestHandler } from "express";
|
||||||
|
|
||||||
|
export const playerSkillsController: RequestHandler = async (req, res) => {
|
||||||
|
const accountId = await getAccountIdForRequest(req);
|
||||||
|
const inventory = await getInventory(accountId);
|
||||||
|
const request = getJSONfromString(String(req.body)) as IPlayerSkillsRequest;
|
||||||
|
|
||||||
|
const oldRank: number = inventory.PlayerSkills[request.Skill as keyof IPlayerSkills];
|
||||||
|
const cost = (request.Pool == "LPP_DRIFTER" ? drifterCosts[oldRank] : 1 << oldRank) * 1000;
|
||||||
|
inventory.PlayerSkills[request.Pool as keyof IPlayerSkills] -= cost;
|
||||||
|
inventory.PlayerSkills[request.Skill as keyof IPlayerSkills]++;
|
||||||
|
await inventory.save();
|
||||||
|
|
||||||
|
res.json({
|
||||||
|
Pool: request.Pool,
|
||||||
|
PoolInc: -cost,
|
||||||
|
Skill: request.Skill,
|
||||||
|
Rank: oldRank + 1
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
interface IPlayerSkillsRequest {
|
||||||
|
Pool: string;
|
||||||
|
Skill: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
const drifterCosts = [20, 25, 30, 45, 65, 90, 125, 160, 205, 255];
|
@ -439,18 +439,17 @@ const seasonChallengeHistorySchema = new Schema<ISeasonChallenge>(
|
|||||||
//TODO: check whether this is complete
|
//TODO: check whether this is complete
|
||||||
const playerSkillsSchema = new Schema<IPlayerSkills>(
|
const playerSkillsSchema = new Schema<IPlayerSkills>(
|
||||||
{
|
{
|
||||||
LPP_SPACE: Number,
|
LPP_SPACE: { type: Number, default: 0 },
|
||||||
LPP_DRIFTER: Number,
|
LPS_PILOTING: { type: Number, default: 0 },
|
||||||
LPS_NONE: Number,
|
LPS_GUNNERY: { type: Number, default: 0 },
|
||||||
LPS_PILOTING: Number,
|
LPS_TACTICAL: { type: Number, default: 0 },
|
||||||
LPS_GUNNERY: Number,
|
LPS_ENGINEERING: { type: Number, default: 0 },
|
||||||
LPS_TACTICAL: Number,
|
LPS_COMMAND: { type: Number, default: 0 },
|
||||||
LPS_ENGINEERING: Number,
|
LPP_DRIFTER: { type: Number, default: 0 },
|
||||||
LPS_COMMAND: Number,
|
LPS_DRIFT_COMBAT: { type: Number, default: 0 },
|
||||||
LPS_DRIFT_COMBAT: Number,
|
LPS_DRIFT_RIDING: { type: Number, default: 0 },
|
||||||
LPS_DRIFT_RIDING: Number,
|
LPS_DRIFT_OPPORTUNITY: { type: Number, default: 0 },
|
||||||
LPS_DRIFT_OPPORTUNITY: Number,
|
LPS_DRIFT_ENDURANCE: { type: Number, default: 0 }
|
||||||
LPS_DRIFT_ENDURANCE: Number
|
|
||||||
},
|
},
|
||||||
{ _id: false }
|
{ _id: false }
|
||||||
);
|
);
|
||||||
@ -1018,7 +1017,7 @@ const inventorySchema = new Schema<IInventoryDatabase, InventoryDocumentProps>(
|
|||||||
|
|
||||||
//Modulars lvl and exp(Railjack|Duviri)
|
//Modulars lvl and exp(Railjack|Duviri)
|
||||||
//https://warframe.fandom.com/wiki/Intrinsics
|
//https://warframe.fandom.com/wiki/Intrinsics
|
||||||
PlayerSkills: playerSkillsSchema,
|
PlayerSkills: { type: playerSkillsSchema, default: {} },
|
||||||
|
|
||||||
//TradeBannedUntil data
|
//TradeBannedUntil data
|
||||||
TradeBannedUntil: Schema.Types.Mixed,
|
TradeBannedUntil: Schema.Types.Mixed,
|
||||||
|
@ -46,6 +46,7 @@ import { missionInventoryUpdateController } from "@/src/controllers/api/missionI
|
|||||||
import { modularWeaponCraftingController } from "@/src/controllers/api/modularWeaponCraftingController";
|
import { modularWeaponCraftingController } from "@/src/controllers/api/modularWeaponCraftingController";
|
||||||
import { modularWeaponSaleController } from "@/src/controllers/api/modularWeaponSaleController";
|
import { modularWeaponSaleController } from "@/src/controllers/api/modularWeaponSaleController";
|
||||||
import { nameWeaponController } from "@/src/controllers/api/nameWeaponController";
|
import { nameWeaponController } from "@/src/controllers/api/nameWeaponController";
|
||||||
|
import { playerSkillsController } from "@/src/controllers/api/playerSkillsController";
|
||||||
import { projectionManagerController } from "../controllers/api/projectionManagerController";
|
import { projectionManagerController } from "../controllers/api/projectionManagerController";
|
||||||
import { purchaseController } from "@/src/controllers/api/purchaseController";
|
import { purchaseController } from "@/src/controllers/api/purchaseController";
|
||||||
import { queueDojoComponentDestructionController } from "@/src/controllers/api/queueDojoComponentDestructionController";
|
import { queueDojoComponentDestructionController } from "@/src/controllers/api/queueDojoComponentDestructionController";
|
||||||
@ -134,6 +135,7 @@ apiRouter.post("/login.php", loginController);
|
|||||||
apiRouter.post("/missionInventoryUpdate.php", missionInventoryUpdateController);
|
apiRouter.post("/missionInventoryUpdate.php", missionInventoryUpdateController);
|
||||||
apiRouter.post("/modularWeaponCrafting.php", modularWeaponCraftingController);
|
apiRouter.post("/modularWeaponCrafting.php", modularWeaponCraftingController);
|
||||||
apiRouter.post("/nameWeapon.php", nameWeaponController);
|
apiRouter.post("/nameWeapon.php", nameWeaponController);
|
||||||
|
apiRouter.post("/playerSkills.php", playerSkillsController);
|
||||||
apiRouter.post("/projectionManager.php", projectionManagerController);
|
apiRouter.post("/projectionManager.php", projectionManagerController);
|
||||||
apiRouter.post("/purchase.php", purchaseController);
|
apiRouter.post("/purchase.php", purchaseController);
|
||||||
apiRouter.post("/rerollRandomMod.php", rerollRandomModController);
|
apiRouter.post("/rerollRandomMod.php", rerollRandomModController);
|
||||||
|
@ -819,13 +819,12 @@ export interface IPersonalTechProject {
|
|||||||
|
|
||||||
export interface IPlayerSkills {
|
export interface IPlayerSkills {
|
||||||
LPP_SPACE: number;
|
LPP_SPACE: number;
|
||||||
LPP_DRIFTER: number;
|
|
||||||
LPS_NONE: number;
|
|
||||||
LPS_PILOTING: number;
|
LPS_PILOTING: number;
|
||||||
LPS_GUNNERY: number;
|
LPS_GUNNERY: number;
|
||||||
LPS_TACTICAL: number;
|
LPS_TACTICAL: number;
|
||||||
LPS_ENGINEERING: number;
|
LPS_ENGINEERING: number;
|
||||||
LPS_COMMAND: number;
|
LPS_COMMAND: number;
|
||||||
|
LPP_DRIFTER: number;
|
||||||
LPS_DRIFT_COMBAT: number;
|
LPS_DRIFT_COMBAT: number;
|
||||||
LPS_DRIFT_RIDING: number;
|
LPS_DRIFT_RIDING: number;
|
||||||
LPS_DRIFT_OPPORTUNITY: number;
|
LPS_DRIFT_OPPORTUNITY: number;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user