Improved image import functionality to allow for image path overrides e.g. adjusting trader images
Pass routes into getImages() function
This commit is contained in:
parent
8b26f01d1b
commit
4a44b004a6
@ -2,5 +2,6 @@
|
|||||||
"ip": "127.0.0.1",
|
"ip": "127.0.0.1",
|
||||||
"port": 6969,
|
"port": 6969,
|
||||||
"webSocketPingDelayMs": 90000,
|
"webSocketPingDelayMs": 90000,
|
||||||
"logRequests": true
|
"logRequests": true,
|
||||||
|
"serverImagePathOverride": { }
|
||||||
}
|
}
|
@ -7,4 +7,6 @@ export interface IHttpConfig extends IBaseConfig
|
|||||||
ip: string
|
ip: string
|
||||||
port: number
|
port: number
|
||||||
logRequests: boolean
|
logRequests: boolean
|
||||||
|
/** e.g. "Aki_Data/Server/images/traders/579dc571d53a0658a154fbec.png": "Aki_Data/Server/images/traders/NewTraderImage.png" */
|
||||||
|
serverImagePathOverride: Record<string, string>
|
||||||
}
|
}
|
@ -1,9 +1,12 @@
|
|||||||
import { inject, injectable } from "tsyringe";
|
import { inject, injectable } from "tsyringe";
|
||||||
|
|
||||||
import { OnLoad } from "../di/OnLoad";
|
import { OnLoad } from "../di/OnLoad";
|
||||||
|
import { ConfigTypes } from "../models/enums/ConfigTypes";
|
||||||
|
import { IHttpConfig } from "../models/spt/config/IHttpConfig";
|
||||||
import { IDatabaseTables } from "../models/spt/server/IDatabaseTables";
|
import { IDatabaseTables } from "../models/spt/server/IDatabaseTables";
|
||||||
import { ILogger } from "../models/spt/utils/ILogger";
|
import { ILogger } from "../models/spt/utils/ILogger";
|
||||||
import { ImageRouter } from "../routers/ImageRouter";
|
import { ImageRouter } from "../routers/ImageRouter";
|
||||||
|
import { ConfigServer } from "../servers/ConfigServer";
|
||||||
import { DatabaseServer } from "../servers/DatabaseServer";
|
import { DatabaseServer } from "../servers/DatabaseServer";
|
||||||
import { LocalisationService } from "../services/LocalisationService";
|
import { LocalisationService } from "../services/LocalisationService";
|
||||||
import { EncodingUtil } from "./EncodingUtil";
|
import { EncodingUtil } from "./EncodingUtil";
|
||||||
@ -17,7 +20,8 @@ export class DatabaseImporter implements OnLoad
|
|||||||
{
|
{
|
||||||
private hashedFile: any;
|
private hashedFile: any;
|
||||||
private valid = VaildationResult.UNDEFINED;
|
private valid = VaildationResult.UNDEFINED;
|
||||||
private filepath;
|
private filepath: string;
|
||||||
|
protected httpConfig: IHttpConfig;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@inject("WinstonLogger") protected logger: ILogger,
|
@inject("WinstonLogger") protected logger: ILogger,
|
||||||
@ -28,9 +32,11 @@ export class DatabaseImporter implements OnLoad
|
|||||||
@inject("ImageRouter") protected imageRouter: ImageRouter,
|
@inject("ImageRouter") protected imageRouter: ImageRouter,
|
||||||
@inject("EncodingUtil") protected encodingUtil: EncodingUtil,
|
@inject("EncodingUtil") protected encodingUtil: EncodingUtil,
|
||||||
@inject("HashUtil") protected hashUtil: HashUtil,
|
@inject("HashUtil") protected hashUtil: HashUtil,
|
||||||
@inject("ImporterUtil") protected importerUtil: ImporterUtil
|
@inject("ImporterUtil") protected importerUtil: ImporterUtil,
|
||||||
|
@inject("ConfigServer") protected configServer: ConfigServer
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
this.httpConfig = this.configServer.getConfig(ConfigTypes.HTTP);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async onLoad(): Promise<void>
|
public async onLoad(): Promise<void>
|
||||||
@ -41,11 +47,13 @@ export class DatabaseImporter implements OnLoad
|
|||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// reading the dynamic SHA1 file - Ask Alex or Chomp
|
// Reading the dynamic SHA1 file
|
||||||
const file = "checks.dat";
|
const file = "checks.dat";
|
||||||
const fileWithPath = `${this.filepath}${file}`;
|
const fileWithPath = `${this.filepath}${file}`;
|
||||||
if (this.vfs.exists(fileWithPath))
|
if (this.vfs.exists(fileWithPath))
|
||||||
|
{
|
||||||
this.hashedFile = this.jsonUtil.deserialize(this.encodingUtil.fromBase64(this.vfs.readFile(fileWithPath)));
|
this.hashedFile = this.jsonUtil.deserialize(this.encodingUtil.fromBase64(this.vfs.readFile(fileWithPath)));
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this.valid = VaildationResult.NOT_FOUND;
|
this.valid = VaildationResult.NOT_FOUND;
|
||||||
@ -61,7 +69,14 @@ export class DatabaseImporter implements OnLoad
|
|||||||
|
|
||||||
await this.hydrateDatabase(this.filepath);
|
await this.hydrateDatabase(this.filepath);
|
||||||
|
|
||||||
this.loadImages(`${this.filepath}images/`);
|
this.loadImages(`${this.filepath}images/`, [
|
||||||
|
"/files/CONTENT/banners/",
|
||||||
|
"/files/handbook/",
|
||||||
|
"/files/Hideout/",
|
||||||
|
"/files/launcher/",
|
||||||
|
"/files/quest/icon/",
|
||||||
|
"/files/trader/avatar/"
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -124,30 +139,47 @@ export class DatabaseImporter implements OnLoad
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public loadImages(filepath: string): void
|
/**
|
||||||
|
* Find and map files with image router inside a designated path
|
||||||
|
* @param filepath Path to find files in
|
||||||
|
*/
|
||||||
|
public loadImages(filepath: string, routes: string[]): void
|
||||||
{
|
{
|
||||||
const dirs = this.vfs.getDirs(filepath);
|
const directories = this.vfs.getDirs(filepath);
|
||||||
const routes = [
|
for (const directoryIndex in directories)
|
||||||
"/files/CONTENT/banners/",
|
|
||||||
"/files/handbook/",
|
|
||||||
"/files/Hideout/",
|
|
||||||
"/files/launcher/",
|
|
||||||
"/files/quest/icon/",
|
|
||||||
"/files/trader/avatar/"
|
|
||||||
];
|
|
||||||
|
|
||||||
for (const i in dirs)
|
|
||||||
{
|
{
|
||||||
const files = this.vfs.getFiles(`${filepath}${dirs[i]}`);
|
// Get all files in directory
|
||||||
|
const filesInDirectory = this.vfs.getFiles(`${filepath}${directories[directoryIndex]}`);
|
||||||
for (const file of files)
|
for (const file of filesInDirectory)
|
||||||
{
|
{
|
||||||
|
// Register each file in image router
|
||||||
const filename = this.vfs.stripExtension(file);
|
const filename = this.vfs.stripExtension(file);
|
||||||
this.imageRouter.addRoute(`${routes[i]}${filename}`, `${filepath}${dirs[i]}/${file}`);
|
const routeKey = `${routes[directoryIndex]}${filename}`;
|
||||||
|
let imagePath = `${filepath}${directories[directoryIndex]}/${file}`;
|
||||||
|
|
||||||
|
const pathOverride = this.getImagePathOverride(imagePath);
|
||||||
|
if (pathOverride)
|
||||||
|
{
|
||||||
|
imagePath = pathOverride;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.imageRouter.addRoute(routeKey, imagePath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Map icon file separately
|
||||||
this.imageRouter.addRoute("/favicon.ico", `${filepath}icon.ico`);
|
this.imageRouter.addRoute("/favicon.ico", `${filepath}icon.ico`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check for a path override in the http json config file
|
||||||
|
* @param imagePath Key
|
||||||
|
* @returns override for key
|
||||||
|
*/
|
||||||
|
protected getImagePathOverride(imagePath: string): string
|
||||||
|
{
|
||||||
|
return this.httpConfig.serverImagePathOverride[imagePath];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
enum VaildationResult
|
enum VaildationResult
|
||||||
|
Loading…
x
Reference in New Issue
Block a user