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