feat: updateSongChallenge (#1024)

Closes #707

untested but should be correct based on all the information I could find

Reviewed-on: OpenWF/SpaceNinjaServer#1024
This commit is contained in:
Sainan 2025-02-28 18:18:33 -08:00
parent da2b50d537
commit bbc40d5534
4 changed files with 71 additions and 2 deletions

View 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;
}

View File

@ -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 } }
); );

View File

@ -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);

View File

@ -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[];
}