feat: updateSongChallenge (#1024)
Closes #707 untested but should be correct based on all the information I could find Reviewed-on: #1024
This commit is contained in:
		
							parent
							
								
									da2b50d537
								
							
						
					
					
						commit
						bbc40d5534
					
				
							
								
								
									
										50
									
								
								src/controllers/api/updateSongChallengeController.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								src/controllers/api/updateSongChallengeController.ts
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,50 @@
 | 
				
			|||||||
 | 
					import { getJSONfromString } from "@/src/helpers/stringHelpers";
 | 
				
			||||||
 | 
					import { addShipDecorations, getInventory } from "@/src/services/inventoryService";
 | 
				
			||||||
 | 
					import { getAccountIdForRequest } from "@/src/services/loginService";
 | 
				
			||||||
 | 
					import { IInventoryChanges } from "@/src/types/purchaseTypes";
 | 
				
			||||||
 | 
					import { RequestHandler } from "express";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export const updateSongChallengeController: RequestHandler = async (req, res) => {
 | 
				
			||||||
 | 
					    const accountId = await getAccountIdForRequest(req);
 | 
				
			||||||
 | 
					    const inventory = await getInventory(accountId);
 | 
				
			||||||
 | 
					    const request = getJSONfromString<IUpdateSongChallengeRequest>(String(req.body));
 | 
				
			||||||
 | 
					    inventory.SongChallenges ??= [];
 | 
				
			||||||
 | 
					    let songChallenge = inventory.SongChallenges.find(x => x.Song == request.Song);
 | 
				
			||||||
 | 
					    if (!songChallenge) {
 | 
				
			||||||
 | 
					        songChallenge =
 | 
				
			||||||
 | 
					            inventory.SongChallenges[inventory.SongChallenges.push({ Song: request.Song, Difficulties: [] }) - 1];
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    songChallenge.Difficulties.push(request.Difficulty);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    const response: IUpdateSongChallengeResponse = {
 | 
				
			||||||
 | 
					        Song: request.Song,
 | 
				
			||||||
 | 
					        Difficulty: request.Difficulty
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // Handle all songs being completed on all difficulties
 | 
				
			||||||
 | 
					    if (inventory.SongChallenges.length == 12 && !inventory.SongChallenges.find(x => x.Difficulties.length != 2)) {
 | 
				
			||||||
 | 
					        response.Reward = "/Lotus/StoreItems/Types/Items/ShipDecos/LisetPropShawzinDuviri";
 | 
				
			||||||
 | 
					        const shipDecorationChanges = [
 | 
				
			||||||
 | 
					            { ItemType: "/Lotus/Types/Items/ShipDecos/LisetPropShawzinDuviri", ItemCount: 1 }
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					        response.InventoryChanges = {
 | 
				
			||||||
 | 
					            ShipDecorations: shipDecorationChanges
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					        addShipDecorations(inventory, shipDecorationChanges);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    await inventory.save();
 | 
				
			||||||
 | 
					    res.json(response);
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					interface IUpdateSongChallengeRequest {
 | 
				
			||||||
 | 
					    Song: string;
 | 
				
			||||||
 | 
					    Difficulty: number;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					interface IUpdateSongChallengeResponse {
 | 
				
			||||||
 | 
					    Song: string;
 | 
				
			||||||
 | 
					    Difficulty: number;
 | 
				
			||||||
 | 
					    Reward?: string;
 | 
				
			||||||
 | 
					    InventoryChanges?: IInventoryChanges;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -73,7 +73,8 @@ import {
 | 
				
			|||||||
    IDroneClient,
 | 
					    IDroneClient,
 | 
				
			||||||
    IAlignment,
 | 
					    IAlignment,
 | 
				
			||||||
    ICollectibleEntry,
 | 
					    ICollectibleEntry,
 | 
				
			||||||
    IIncentiveState
 | 
					    IIncentiveState,
 | 
				
			||||||
 | 
					    ISongChallenge
 | 
				
			||||||
} from "../../types/inventoryTypes/inventoryTypes";
 | 
					} from "../../types/inventoryTypes/inventoryTypes";
 | 
				
			||||||
import { IOid } from "../../types/commonTypes";
 | 
					import { IOid } from "../../types/commonTypes";
 | 
				
			||||||
import {
 | 
					import {
 | 
				
			||||||
@ -965,6 +966,14 @@ const collectibleEntrySchema = new Schema<ICollectibleEntry>(
 | 
				
			|||||||
    { _id: false }
 | 
					    { _id: false }
 | 
				
			||||||
);
 | 
					);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const songChallengeSchema = new Schema<ISongChallenge>(
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        Song: String,
 | 
				
			||||||
 | 
					        Difficulties: [Number]
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    { _id: false }
 | 
				
			||||||
 | 
					);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const pendingCouponSchema = new Schema<IPendingCouponDatabase>(
 | 
					const pendingCouponSchema = new Schema<IPendingCouponDatabase>(
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        Expiry: { type: Date, default: new Date(0) },
 | 
					        Expiry: { type: Date, default: new Date(0) },
 | 
				
			||||||
@ -1323,7 +1332,9 @@ const inventorySchema = new Schema<IInventoryDatabase, InventoryDocumentProps>(
 | 
				
			|||||||
        EndlessXP: { type: [endlessXpProgressSchema], default: undefined },
 | 
					        EndlessXP: { type: [endlessXpProgressSchema], default: undefined },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        DialogueHistory: dialogueHistorySchema,
 | 
					        DialogueHistory: dialogueHistorySchema,
 | 
				
			||||||
        CalendarProgress: calenderProgressSchema
 | 
					        CalendarProgress: calenderProgressSchema,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        SongChallenges: { type: [songChallengeSchema], default: undefined }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    { timestamps: { createdAt: "Created", updatedAt: false } }
 | 
					    { timestamps: { createdAt: "Created", updatedAt: false } }
 | 
				
			||||||
);
 | 
					);
 | 
				
			||||||
 | 
				
			|||||||
@ -92,6 +92,7 @@ import { updateAlignmentController } from "@/src/controllers/api/updateAlignment
 | 
				
			|||||||
import { updateChallengeProgressController } from "@/src/controllers/api/updateChallengeProgressController";
 | 
					import { updateChallengeProgressController } from "@/src/controllers/api/updateChallengeProgressController";
 | 
				
			||||||
import { updateQuestController } from "@/src/controllers/api/updateQuestController";
 | 
					import { updateQuestController } from "@/src/controllers/api/updateQuestController";
 | 
				
			||||||
import { updateSessionGetController, updateSessionPostController } from "@/src/controllers/api/updateSessionController";
 | 
					import { updateSessionGetController, updateSessionPostController } from "@/src/controllers/api/updateSessionController";
 | 
				
			||||||
 | 
					import { updateSongChallengeController } from "@/src/controllers/api/updateSongChallengeController";
 | 
				
			||||||
import { updateThemeController } from "@/src/controllers/api/updateThemeController";
 | 
					import { updateThemeController } from "@/src/controllers/api/updateThemeController";
 | 
				
			||||||
import { upgradesController } from "@/src/controllers/api/upgradesController";
 | 
					import { upgradesController } from "@/src/controllers/api/upgradesController";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -196,6 +197,7 @@ apiRouter.post("/updateChallengeProgress.php", updateChallengeProgressController
 | 
				
			|||||||
apiRouter.post("/updateNodeIntros.php", genericUpdateController);
 | 
					apiRouter.post("/updateNodeIntros.php", genericUpdateController);
 | 
				
			||||||
apiRouter.post("/updateQuest.php", updateQuestController);
 | 
					apiRouter.post("/updateQuest.php", updateQuestController);
 | 
				
			||||||
apiRouter.post("/updateSession.php", updateSessionPostController);
 | 
					apiRouter.post("/updateSession.php", updateSessionPostController);
 | 
				
			||||||
 | 
					apiRouter.post("/updateSongChallenge.php", updateSongChallengeController);
 | 
				
			||||||
apiRouter.post("/updateTheme.php", updateThemeController);
 | 
					apiRouter.post("/updateTheme.php", updateThemeController);
 | 
				
			||||||
apiRouter.post("/upgrades.php", upgradesController);
 | 
					apiRouter.post("/upgrades.php", upgradesController);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -325,6 +325,7 @@ export interface IInventoryClient extends IDailyAffiliations, InventoryClientEqu
 | 
				
			|||||||
    EndlessXP?: IEndlessXpProgress[];
 | 
					    EndlessXP?: IEndlessXpProgress[];
 | 
				
			||||||
    DialogueHistory?: IDialogueHistoryClient;
 | 
					    DialogueHistory?: IDialogueHistoryClient;
 | 
				
			||||||
    CalendarProgress: ICalendarProgress;
 | 
					    CalendarProgress: ICalendarProgress;
 | 
				
			||||||
 | 
					    SongChallenges?: ISongChallenge[];
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export interface IAffiliation {
 | 
					export interface IAffiliation {
 | 
				
			||||||
@ -1079,3 +1080,8 @@ export interface ICalendarProgress {
 | 
				
			|||||||
    YearProgress: { Upgrades: unknown[] };
 | 
					    YearProgress: { Upgrades: unknown[] };
 | 
				
			||||||
    SeasonProgress: ISeasonProgress;
 | 
					    SeasonProgress: ISeasonProgress;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export interface ISongChallenge {
 | 
				
			||||||
 | 
					    Song: string;
 | 
				
			||||||
 | 
					    Difficulties: number[];
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user