From 6301411a86b901e7a3cc9013827ce7a3ae5968bd Mon Sep 17 00:00:00 2001 From: Dev Date: Tue, 1 Oct 2024 10:57:59 +0100 Subject: [PATCH] Removed unnecessary use of `ProfileSnapshotService` --- project/src/controllers/MatchController.ts | 3 -- project/src/helpers/ProfileHelper.ts | 45 ---------------------- 2 files changed, 48 deletions(-) diff --git a/project/src/controllers/MatchController.ts b/project/src/controllers/MatchController.ts index 365f79cd..7102d389 100644 --- a/project/src/controllers/MatchController.ts +++ b/project/src/controllers/MatchController.ts @@ -16,7 +16,6 @@ import { ConfigServer } from "@spt/servers/ConfigServer"; import { SaveServer } from "@spt/servers/SaveServer"; import { LocationLifecycleService } from "@spt/services/LocationLifecycleService"; import { MatchLocationService } from "@spt/services/MatchLocationService"; -import { ProfileSnapshotService } from "@spt/services/ProfileSnapshotService"; import { ICloner } from "@spt/utils/cloners/ICloner"; import { inject, injectable } from "tsyringe"; @@ -30,7 +29,6 @@ export class MatchController { @inject("SaveServer") protected saveServer: SaveServer, @inject("MatchLocationService") protected matchLocationService: MatchLocationService, @inject("ConfigServer") protected configServer: ConfigServer, - @inject("ProfileSnapshotService") protected profileSnapshotService: ProfileSnapshotService, @inject("ApplicationContext") protected applicationContext: ApplicationContext, @inject("LocationLifecycleService") protected locationLifecycleService: LocationLifecycleService, @inject("PrimaryCloner") protected cloner: ICloner, @@ -96,7 +94,6 @@ export class MatchController { // Store the profile as-is for later use on the post-raid exp screen const currentProfile = this.saveServer.getProfile(sessionID); - this.profileSnapshotService.storeProfileSnapshot(sessionID, currentProfile); } /** diff --git a/project/src/helpers/ProfileHelper.ts b/project/src/helpers/ProfileHelper.ts index dd168396..aac1dbce 100644 --- a/project/src/helpers/ProfileHelper.ts +++ b/project/src/helpers/ProfileHelper.ts @@ -14,7 +14,6 @@ import { ConfigServer } from "@spt/servers/ConfigServer"; import { SaveServer } from "@spt/servers/SaveServer"; import { DatabaseService } from "@spt/services/DatabaseService"; import { LocalisationService } from "@spt/services/LocalisationService"; -import { ProfileSnapshotService } from "@spt/services/ProfileSnapshotService"; import { HashUtil } from "@spt/utils/HashUtil"; import { TimeUtil } from "@spt/utils/TimeUtil"; import { Watermark } from "@spt/utils/Watermark"; @@ -33,7 +32,6 @@ export class ProfileHelper { @inject("SaveServer") protected saveServer: SaveServer, @inject("DatabaseService") protected databaseService: DatabaseService, @inject("ItemHelper") protected itemHelper: ItemHelper, - @inject("ProfileSnapshotService") protected profileSnapshotService: ProfileSnapshotService, @inject("LocalisationService") protected localisationService: LocalisationService, @inject("ConfigServer") protected configServer: ConfigServer, @inject("PrimaryCloner") protected cloner: ICloner, @@ -85,16 +83,6 @@ export class ProfileHelper { // Sanitize any data the client can not receive this.sanitizeProfileForClient(fullProfileClone); - // Edge-case, true post raid - if (this.profileSnapshotService.hasProfileSnapshot(sessionId)) { - return this.postRaidXpWorkaroundFix( - sessionId, - fullProfileClone.characters.pmc, - fullProfileClone.characters.scav, - output, - ); - } - // PMC must be at array index 0, scav at 1 output.push(fullProfileClone.characters.pmc); output.push(fullProfileClone.characters.scav); @@ -102,39 +90,6 @@ export class ProfileHelper { return output; } - /** - * Fix xp doubling on post-raid xp reward screen by sending a 'dummy' profile to the post-raid screen - * Server saves the post-raid changes prior to the xp screen getting the profile, this results in the xp screen using - * the now updated profile values as a base, meaning it shows x2 xp gained - * Instead, clone the post-raid profile (so we dont alter its values), apply the pre-raid xp values to the cloned objects and return - * Delete snapshot of pre-raid profile prior to returning profile data - * @param sessionId Session id - * @param output pmc and scav profiles array - * @param pmcProfile post-raid pmc profile - * @param scavProfile post-raid scav profile - * @returns Updated profile array - */ - protected postRaidXpWorkaroundFix( - sessionId: string, - clonedPmc: IPmcData, - clonedScav: IPmcData, - output: IPmcData[], - ): IPmcData[] { - const profileSnapshot = this.profileSnapshotService.getProfileSnapshot(sessionId); - clonedPmc.Info.Level = profileSnapshot.characters.pmc.Info.Level; - clonedPmc.Info.Experience = profileSnapshot.characters.pmc.Info.Experience; - - clonedScav.Info.Level = profileSnapshot.characters.scav.Info.Level; - clonedScav.Info.Experience = profileSnapshot.characters.scav.Info.Experience; - - this.profileSnapshotService.clearProfileSnapshot(sessionId); - - output.push(clonedPmc); - output.push(clonedScav); - - return output; - } - /** * Sanitize any information from the profile that the client does not expect to receive * @param clonedProfile A clone of the full player profile