2023-03-03 15:23:46 +00:00
|
|
|
import { DependencyContainer, inject, injectable } from "tsyringe";
|
2023-10-19 17:21:17 +00:00
|
|
|
|
|
|
|
import { ModTypeCheck } from "@spt-aki/loaders/ModTypeCheck";
|
|
|
|
import { PreAkiModLoader } from "@spt-aki/loaders/PreAkiModLoader";
|
|
|
|
import { IPostAkiLoadMod } from "@spt-aki/models/external/IPostAkiLoadMod";
|
|
|
|
import { IPostAkiLoadModAsync } from "@spt-aki/models/external/IPostAkiLoadModAsync";
|
|
|
|
import { IModLoader } from "@spt-aki/models/spt/mod/IModLoader";
|
|
|
|
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
|
|
|
import { LocalisationService } from "@spt-aki/services/LocalisationService";
|
2023-03-03 15:23:46 +00:00
|
|
|
|
|
|
|
@injectable()
|
|
|
|
export class PostAkiModLoader implements IModLoader
|
|
|
|
{
|
2024-03-24 17:52:38 +00:00
|
|
|
protected container: DependencyContainer;
|
|
|
|
|
2023-03-03 15:23:46 +00:00
|
|
|
constructor(
|
|
|
|
@inject("WinstonLogger") protected logger: ILogger,
|
|
|
|
@inject("PreAkiModLoader") protected preAkiModLoader: PreAkiModLoader,
|
|
|
|
@inject("LocalisationService") protected localisationService: LocalisationService,
|
2023-11-15 20:35:05 -05:00
|
|
|
@inject("ModTypeCheck") protected modTypeCheck: ModTypeCheck,
|
2023-03-03 15:23:46 +00:00
|
|
|
)
|
2023-11-15 20:35:05 -05:00
|
|
|
{}
|
2023-03-03 15:23:46 +00:00
|
|
|
|
|
|
|
public getModPath(mod: string): string
|
|
|
|
{
|
|
|
|
return this.preAkiModLoader.getModPath(mod);
|
|
|
|
}
|
|
|
|
|
|
|
|
public async load(): Promise<void>
|
|
|
|
{
|
|
|
|
if (globalThis.G_MODS_ENABLED)
|
|
|
|
{
|
2024-03-24 17:52:38 +00:00
|
|
|
this.container = this.preAkiModLoader.getContainer();
|
|
|
|
await this.executeModsAsync();
|
2023-03-03 15:23:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-24 17:52:38 +00:00
|
|
|
protected async executeModsAsync(): Promise<void>
|
2023-03-03 15:23:46 +00:00
|
|
|
{
|
|
|
|
const mods = this.preAkiModLoader.sortModsLoadOrder();
|
|
|
|
for (const modName of mods)
|
|
|
|
{
|
|
|
|
// // import class
|
2023-11-15 20:35:05 -05:00
|
|
|
const filepath = `${this.preAkiModLoader.getModPath(modName)}${
|
|
|
|
this.preAkiModLoader.getImportedModDetails()[modName].main
|
|
|
|
}`;
|
2023-03-03 15:23:46 +00:00
|
|
|
const modpath = `${process.cwd()}/${filepath}`;
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
|
|
const mod = require(modpath);
|
2023-10-10 11:03:20 +00:00
|
|
|
|
|
|
|
if (this.modTypeCheck.isPostAkiLoadAsync(mod.mod))
|
2023-03-03 15:23:46 +00:00
|
|
|
{
|
2023-11-15 20:35:05 -05:00
|
|
|
try
|
2023-10-10 11:03:20 +00:00
|
|
|
{
|
2024-03-24 17:52:38 +00:00
|
|
|
await (mod.mod as IPostAkiLoadModAsync).postAkiLoadAsync(this.container);
|
2023-10-10 11:03:20 +00:00
|
|
|
}
|
2023-11-15 20:35:05 -05:00
|
|
|
catch (err)
|
2023-10-10 11:03:20 +00:00
|
|
|
{
|
2023-11-15 20:35:05 -05:00
|
|
|
this.logger.error(
|
|
|
|
this.localisationService.getText(
|
|
|
|
"modloader-async_mod_error",
|
|
|
|
`${err?.message ?? ""}\n${err.stack ?? ""}`,
|
|
|
|
),
|
|
|
|
);
|
2023-10-10 11:03:20 +00:00
|
|
|
}
|
2023-03-03 15:23:46 +00:00
|
|
|
}
|
2023-10-10 11:03:20 +00:00
|
|
|
|
|
|
|
if (this.modTypeCheck.isPostAkiLoad(mod.mod))
|
2023-03-03 15:23:46 +00:00
|
|
|
{
|
2024-03-24 17:52:38 +00:00
|
|
|
(mod.mod as IPostAkiLoadMod).postAkiLoad(this.container);
|
2023-03-03 15:23:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-11-15 20:35:05 -05:00
|
|
|
}
|