Updated profile migrations to partially support 3.9

This commit is contained in:
Dev 2024-08-29 18:07:19 +01:00
parent aa942dbbcc
commit 27540f31f0

View File

@ -20,6 +20,7 @@ import { IServerDetails } from "@spt/models/eft/game/IServerDetails";
import { ISptProfile } from "@spt/models/eft/profile/ISptProfile"; import { ISptProfile } from "@spt/models/eft/profile/ISptProfile";
import { BonusType } from "@spt/models/enums/BonusType"; import { BonusType } from "@spt/models/enums/BonusType";
import { ConfigTypes } from "@spt/models/enums/ConfigTypes"; import { ConfigTypes } from "@spt/models/enums/ConfigTypes";
import { HideoutAreas } from "@spt/models/enums/HideoutAreas";
import { SkillTypes } from "@spt/models/enums/SkillTypes"; import { SkillTypes } from "@spt/models/enums/SkillTypes";
import { Traders } from "@spt/models/enums/Traders"; import { Traders } from "@spt/models/enums/Traders";
import { Weapons } from "@spt/models/enums/Weapons"; import { Weapons } from "@spt/models/enums/Weapons";
@ -158,6 +159,11 @@ export class GameController {
return; return;
} }
//3.9 migrations
if (fullProfile.spt.version.includes("3.9")) {
this.migrate39xProfile(fullProfile);
}
if (Array.isArray(fullProfile.characters.pmc.WishList)) { if (Array.isArray(fullProfile.characters.pmc.WishList)) {
fullProfile.characters.pmc.WishList = {}; fullProfile.characters.pmc.WishList = {};
} }
@ -170,12 +176,6 @@ export class GameController {
this.logger.debug(`Started game with sessionId: ${sessionID} ${pmcProfile.Info?.Nickname}`); this.logger.debug(`Started game with sessionId: ${sessionID} ${pmcProfile.Info?.Nickname}`);
// Migrate aki object data into spt for 3.9.0 release
if ((fullProfile as any).aki) {
fullProfile.spt = this.cloner.clone((fullProfile as any).aki);
delete (fullProfile as any).aki;
}
if (this.coreConfig.fixes.fixProfileBreakingInventoryItemIssues) { if (this.coreConfig.fixes.fixProfileBreakingInventoryItemIssues) {
this.profileFixerService.fixProfileBreakingInventoryItemIssues(pmcProfile); this.profileFixerService.fixProfileBreakingInventoryItemIssues(pmcProfile);
} }
@ -243,6 +243,47 @@ export class GameController {
} }
} }
protected migrate39xProfile(fullProfile: ISptProfile) {
// Karma
if (typeof fullProfile.characters.pmc.karmaValue === "undefined") {
fullProfile.characters.pmc.karmaValue = 0;
}
// Equipment area
const equipmentArea = fullProfile.characters.pmc.Hideout.Areas.find(
(area) => area.type === HideoutAreas.EQUIPMENT_PRESETS_STAND,
);
if (!equipmentArea) {
fullProfile.characters.pmc.Hideout.Areas.push({
active: true,
completeTime: 0,
constructing: false,
lastRecipe: "",
level: 0,
passiveBonusesEnabled: true,
slots: [],
type: HideoutAreas.EQUIPMENT_PRESETS_STAND,
});
}
// Cultist circle area
const circleArea = fullProfile.characters.pmc.Hideout.Areas.find(
(area) => area.type === HideoutAreas.CIRCLE_OF_CULTISTS,
);
if (!circleArea) {
fullProfile.characters.pmc.Hideout.Areas.push({
active: true,
completeTime: 0,
constructing: false,
lastRecipe: "",
level: 0,
passiveBonusesEnabled: true,
slots: [],
type: HideoutAreas.CIRCLE_OF_CULTISTS,
});
}
}
protected adjustHideoutCraftTimes(overrideSeconds: number): void { protected adjustHideoutCraftTimes(overrideSeconds: number): void {
if (overrideSeconds === -1) { if (overrideSeconds === -1) {
return; return;