Merge branch 'defer-BundleLoader-addBundles' into 3.8.0

This commit is contained in:
TheSparta 2024-03-24 18:51:43 +00:00
commit 05a4680ae7
4 changed files with 39 additions and 63 deletions

View File

@ -3,9 +3,7 @@ import { inject, injectable } from "tsyringe";
import { BundleLoader } from "@spt-aki/loaders/BundleLoader"; import { BundleLoader } from "@spt-aki/loaders/BundleLoader";
import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes"; import { ConfigTypes } from "@spt-aki/models/enums/ConfigTypes";
import { IHttpConfig } from "@spt-aki/models/spt/config/IHttpConfig"; import { IHttpConfig } from "@spt-aki/models/spt/config/IHttpConfig";
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
import { ConfigServer } from "@spt-aki/servers/ConfigServer"; import { ConfigServer } from "@spt-aki/servers/ConfigServer";
import { HttpFileUtil } from "@spt-aki/utils/HttpFileUtil";
import { HttpResponseUtil } from "@spt-aki/utils/HttpResponseUtil"; import { HttpResponseUtil } from "@spt-aki/utils/HttpResponseUtil";
@injectable() @injectable()
@ -14,9 +12,7 @@ export class BundleCallbacks
protected httpConfig: IHttpConfig; protected httpConfig: IHttpConfig;
constructor( constructor(
@inject("WinstonLogger") protected logger: ILogger,
@inject("HttpResponseUtil") protected httpResponse: HttpResponseUtil, @inject("HttpResponseUtil") protected httpResponse: HttpResponseUtil,
@inject("HttpFileUtil") protected httpFileUtil: HttpFileUtil,
@inject("BundleLoader") protected bundleLoader: BundleLoader, @inject("BundleLoader") protected bundleLoader: BundleLoader,
@inject("ConfigServer") protected configServer: ConfigServer, @inject("ConfigServer") protected configServer: ConfigServer,
) )
@ -24,29 +20,15 @@ export class BundleCallbacks
this.httpConfig = this.configServer.getConfig(ConfigTypes.HTTP); this.httpConfig = this.configServer.getConfig(ConfigTypes.HTTP);
} }
// eslint-disable-next-line @typescript-eslint/no-unused-vars
public sendBundle(sessionID: string, req: any, resp: any, body: any): void
{
this.logger.info(`[BUNDLE]: ${req.url}`);
const key = req.url.split("/bundle/")[1];
const bundle = this.bundleLoader.getBundle(key, true);
// send bundle
this.httpFileUtil.sendFile(resp, bundle.path);
}
/** /**
* Handle singleplayer/bundles * Handle singleplayer/bundles
*/ */
// eslint-disable-next-line @typescript-eslint/no-unused-vars
public getBundles(url: string, info: any, sessionID: string): string public getBundles(url: string, info: any, sessionID: string): string
{ {
const local = this.httpConfig.ip === "127.0.0.1" || this.httpConfig.ip === "localhost"; const local = this.httpConfig.ip === "127.0.0.1" || this.httpConfig.ip === "localhost";
return this.httpResponse.noBody(this.bundleLoader.getBundles(local)); return this.httpResponse.noBody(this.bundleLoader.getBundles(local));
} }
// eslint-disable-next-line @typescript-eslint/no-unused-vars
public getBundle(url: string, info: any, sessionID: string): string public getBundle(url: string, info: any, sessionID: string): string
{ {
return "BUNDLE"; return "BUNDLE";

View File

@ -1,6 +1,5 @@
import { DependencyContainer, inject, injectable } from "tsyringe"; import { DependencyContainer, inject, injectable } from "tsyringe";
import { BundleLoader } from "@spt-aki/loaders/BundleLoader";
import { ModTypeCheck } from "@spt-aki/loaders/ModTypeCheck"; import { ModTypeCheck } from "@spt-aki/loaders/ModTypeCheck";
import { PreAkiModLoader } from "@spt-aki/loaders/PreAkiModLoader"; import { PreAkiModLoader } from "@spt-aki/loaders/PreAkiModLoader";
import { IPostAkiLoadMod } from "@spt-aki/models/external/IPostAkiLoadMod"; import { IPostAkiLoadMod } from "@spt-aki/models/external/IPostAkiLoadMod";
@ -8,15 +7,14 @@ import { IPostAkiLoadModAsync } from "@spt-aki/models/external/IPostAkiLoadModAs
import { IModLoader } from "@spt-aki/models/spt/mod/IModLoader"; import { IModLoader } from "@spt-aki/models/spt/mod/IModLoader";
import { ILogger } from "@spt-aki/models/spt/utils/ILogger"; import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
import { LocalisationService } from "@spt-aki/services/LocalisationService"; import { LocalisationService } from "@spt-aki/services/LocalisationService";
import { VFS } from "@spt-aki/utils/VFS";
@injectable() @injectable()
export class PostAkiModLoader implements IModLoader export class PostAkiModLoader implements IModLoader
{ {
protected container: DependencyContainer;
constructor( constructor(
@inject("WinstonLogger") protected logger: ILogger, @inject("WinstonLogger") protected logger: ILogger,
@inject("BundleLoader") protected bundleLoader: BundleLoader,
@inject("VFS") protected vfs: VFS,
@inject("PreAkiModLoader") protected preAkiModLoader: PreAkiModLoader, @inject("PreAkiModLoader") protected preAkiModLoader: PreAkiModLoader,
@inject("LocalisationService") protected localisationService: LocalisationService, @inject("LocalisationService") protected localisationService: LocalisationService,
@inject("ModTypeCheck") protected modTypeCheck: ModTypeCheck, @inject("ModTypeCheck") protected modTypeCheck: ModTypeCheck,
@ -32,12 +30,12 @@ export class PostAkiModLoader implements IModLoader
{ {
if (globalThis.G_MODS_ENABLED) if (globalThis.G_MODS_ENABLED)
{ {
await this.executeMods(this.preAkiModLoader.getContainer()); this.container = this.preAkiModLoader.getContainer();
this.addBundles(); await this.executeModsAsync();
} }
} }
protected async executeMods(container: DependencyContainer): Promise<void> protected async executeModsAsync(): Promise<void>
{ {
const mods = this.preAkiModLoader.sortModsLoadOrder(); const mods = this.preAkiModLoader.sortModsLoadOrder();
for (const modName of mods) for (const modName of mods)
@ -54,7 +52,7 @@ export class PostAkiModLoader implements IModLoader
{ {
try try
{ {
await (mod.mod as IPostAkiLoadModAsync).postAkiLoadAsync(container); await (mod.mod as IPostAkiLoadModAsync).postAkiLoadAsync(this.container);
} }
catch (err) catch (err)
{ {
@ -69,21 +67,7 @@ export class PostAkiModLoader implements IModLoader
if (this.modTypeCheck.isPostAkiLoad(mod.mod)) if (this.modTypeCheck.isPostAkiLoad(mod.mod))
{ {
(mod.mod as IPostAkiLoadMod).postAkiLoad(container); (mod.mod as IPostAkiLoadMod).postAkiLoad(this.container);
}
}
}
protected addBundles(): void
{
const mods = this.preAkiModLoader.sortModsLoadOrder();
for (const modName of mods)
{
// add mod bundles
const modpath = this.preAkiModLoader.getModPath(modName);
if (this.vfs.exists(`${modpath}bundles.json`))
{
this.bundleLoader.addBundles(modpath);
} }
} }
} }

View File

@ -1,6 +1,7 @@
import { DependencyContainer, inject, injectable } from "tsyringe"; import { DependencyContainer, inject, injectable } from "tsyringe";
import { OnLoad } from "@spt-aki/di/OnLoad"; import { OnLoad } from "@spt-aki/di/OnLoad";
import { BundleLoader } from "@spt-aki/loaders/BundleLoader";
import { ModTypeCheck } from "@spt-aki/loaders/ModTypeCheck"; import { ModTypeCheck } from "@spt-aki/loaders/ModTypeCheck";
import { PreAkiModLoader } from "@spt-aki/loaders/PreAkiModLoader"; import { PreAkiModLoader } from "@spt-aki/loaders/PreAkiModLoader";
import { IPostDBLoadMod } from "@spt-aki/models/external/IPostDBLoadMod"; import { IPostDBLoadMod } from "@spt-aki/models/external/IPostDBLoadMod";
@ -11,8 +12,11 @@ import { LocalisationService } from "@spt-aki/services/LocalisationService";
@injectable() @injectable()
export class PostDBModLoader implements OnLoad export class PostDBModLoader implements OnLoad
{ {
protected container: DependencyContainer;
constructor( constructor(
@inject("WinstonLogger") protected logger: ILogger, @inject("WinstonLogger") protected logger: ILogger,
@inject("BundleLoader") protected bundleLoader: BundleLoader,
@inject("PreAkiModLoader") protected preAkiModLoader: PreAkiModLoader, @inject("PreAkiModLoader") protected preAkiModLoader: PreAkiModLoader,
@inject("LocalisationService") protected localisationService: LocalisationService, @inject("LocalisationService") protected localisationService: LocalisationService,
@inject("ModTypeCheck") protected modTypeCheck: ModTypeCheck, @inject("ModTypeCheck") protected modTypeCheck: ModTypeCheck,
@ -23,7 +27,9 @@ export class PostDBModLoader implements OnLoad
{ {
if (globalThis.G_MODS_ENABLED) if (globalThis.G_MODS_ENABLED)
{ {
await this.executeMods(this.preAkiModLoader.getContainer()); this.container = this.preAkiModLoader.getContainer();
await this.executeModsAsync();
this.addBundles();
} }
} }
@ -37,7 +43,7 @@ export class PostDBModLoader implements OnLoad
return this.preAkiModLoader.getModPath(mod); return this.preAkiModLoader.getModPath(mod);
} }
protected async executeMods(container: DependencyContainer): Promise<void> protected async executeModsAsync(): Promise<void>
{ {
const mods = this.preAkiModLoader.sortModsLoadOrder(); const mods = this.preAkiModLoader.sortModsLoadOrder();
for (const modName of mods) for (const modName of mods)
@ -54,7 +60,7 @@ export class PostDBModLoader implements OnLoad
{ {
try try
{ {
await (mod.mod as IPostDBLoadModAsync).postDBLoadAsync(container); await (mod.mod as IPostDBLoadModAsync).postDBLoadAsync(this.container);
} }
catch (err) catch (err)
{ {
@ -69,7 +75,21 @@ export class PostDBModLoader implements OnLoad
if (this.modTypeCheck.isPostDBAkiLoad(mod.mod)) if (this.modTypeCheck.isPostDBAkiLoad(mod.mod))
{ {
(mod.mod as IPostDBLoadMod).postDBLoad(container); (mod.mod as IPostDBLoadMod).postDBLoad(this.container);
}
}
}
protected addBundles(): void
{
const importedMods = this.preAkiModLoader.getImportedModDetails();
for (const [mod, pkg] of Object.entries(importedMods))
{
const modPath = this.preAkiModLoader.getModPath(mod);
if (pkg.isBundleMod ?? false)
{
this.bundleLoader.addBundles(modPath);
} }
} }
} }

View File

@ -4,7 +4,6 @@ import path from "node:path";
import semver from "semver"; import semver from "semver";
import { DependencyContainer, inject, injectable } from "tsyringe"; import { DependencyContainer, inject, injectable } from "tsyringe";
import { BundleLoader } from "@spt-aki/loaders/BundleLoader";
import { ModLoadOrder } from "@spt-aki/loaders/ModLoadOrder"; import { ModLoadOrder } from "@spt-aki/loaders/ModLoadOrder";
import { ModTypeCheck } from "@spt-aki/loaders/ModTypeCheck"; import { ModTypeCheck } from "@spt-aki/loaders/ModTypeCheck";
import { ModDetails } from "@spt-aki/models/eft/profile/IAkiProfile"; import { ModDetails } from "@spt-aki/models/eft/profile/IAkiProfile";
@ -24,7 +23,7 @@ import { VFS } from "@spt-aki/utils/VFS";
@injectable() @injectable()
export class PreAkiModLoader implements IModLoader export class PreAkiModLoader implements IModLoader
{ {
protected static container: DependencyContainer; protected container: DependencyContainer;
protected readonly basepath = "user/mods/"; protected readonly basepath = "user/mods/";
protected readonly modOrderPath = "user/mods/order.json"; protected readonly modOrderPath = "user/mods/order.json";
@ -39,7 +38,6 @@ export class PreAkiModLoader implements IModLoader
@inject("VFS") protected vfs: VFS, @inject("VFS") protected vfs: VFS,
@inject("JsonUtil") protected jsonUtil: JsonUtil, @inject("JsonUtil") protected jsonUtil: JsonUtil,
@inject("ModCompilerService") protected modCompilerService: ModCompilerService, @inject("ModCompilerService") protected modCompilerService: ModCompilerService,
@inject("BundleLoader") protected bundleLoader: BundleLoader,
@inject("LocalisationService") protected localisationService: LocalisationService, @inject("LocalisationService") protected localisationService: LocalisationService,
@inject("ConfigServer") protected configServer: ConfigServer, @inject("ConfigServer") protected configServer: ConfigServer,
@inject("ModLoadOrder") protected modLoadOrder: ModLoadOrder, @inject("ModLoadOrder") protected modLoadOrder: ModLoadOrder,
@ -57,9 +55,9 @@ export class PreAkiModLoader implements IModLoader
{ {
if (globalThis.G_MODS_ENABLED) if (globalThis.G_MODS_ENABLED)
{ {
PreAkiModLoader.container = container; this.container = container;
await this.importModsAsync(); await this.importModsAsync();
await this.executeModsAsync(container); await this.executeModsAsync();
} }
} }
@ -363,10 +361,9 @@ export class PreAkiModLoader implements IModLoader
/** /**
* Execute each mod found in this.imported * Execute each mod found in this.imported
* @param container Dependence container to give to mod when it runs
* @returns void promise * @returns void promise
*/ */
protected async executeModsAsync(container: DependencyContainer): Promise<void> protected async executeModsAsync(): Promise<void>
{ {
// Sort mods load order // Sort mods load order
const source = this.sortModsLoadOrder(); const source = this.sortModsLoadOrder();
@ -401,7 +398,7 @@ export class PreAkiModLoader implements IModLoader
{ {
try try
{ {
await (requiredMod.mod as IPreAkiLoadModAsync).preAkiLoadAsync(container); await (requiredMod.mod as IPreAkiLoadModAsync).preAkiLoadAsync(this.container);
globalThis[mod] = requiredMod; globalThis[mod] = requiredMod;
} }
catch (err) catch (err)
@ -420,7 +417,7 @@ export class PreAkiModLoader implements IModLoader
// Perform sync load of mod // Perform sync load of mod
if (this.modTypeCheck.isPreAkiLoad(requiredMod.mod)) if (this.modTypeCheck.isPreAkiLoad(requiredMod.mod))
{ {
(requiredMod.mod as IPreAkiLoadMod).preAkiLoad(container); (requiredMod.mod as IPreAkiLoadMod).preAkiLoad(this.container);
globalThis[mod] = requiredMod; globalThis[mod] = requiredMod;
} }
} }
@ -450,13 +447,6 @@ export class PreAkiModLoader implements IModLoader
{ {
const modPath = this.getModPath(mod); const modPath = this.getModPath(mod);
const isBundleMod = pkg.isBundleMod ?? false;
if (isBundleMod)
{
this.bundleLoader.addBundles(modPath);
}
const typeScriptFiles = this.vfs.getFilesOfType(`${modPath}src`, ".ts"); const typeScriptFiles = this.vfs.getFilesOfType(`${modPath}src`, ".ts");
if (typeScriptFiles.length > 0) if (typeScriptFiles.length > 0)
@ -736,9 +726,9 @@ export class PreAkiModLoader implements IModLoader
public getContainer(): DependencyContainer public getContainer(): DependencyContainer
{ {
if (PreAkiModLoader.container) if (this.container)
{ {
return PreAkiModLoader.container; return this.container;
} }
throw new Error(this.localisationService.getText("modloader-dependency_container_not_initalized")); throw new Error(this.localisationService.getText("modloader-dependency_container_not_initalized"));