Removes IUUidGenerator Class
Removes the `IUUidGenerator` class in favour of the built-in `crypto.randomUUID()` method.
This commit is contained in:
parent
0ad85b45e1
commit
a190311612
@ -2,7 +2,6 @@ import readline from "node:readline";
|
|||||||
|
|
||||||
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
||||||
import { AsyncQueue } from "@spt-aki/utils/AsyncQueue";
|
import { AsyncQueue } from "@spt-aki/utils/AsyncQueue";
|
||||||
import { UUidGenerator } from "@spt-aki/utils/UUidGenerator";
|
|
||||||
import { WinstonMainLogger } from "@spt-aki/utils/logging/WinstonMainLogger";
|
import { WinstonMainLogger } from "@spt-aki/utils/logging/WinstonMainLogger";
|
||||||
|
|
||||||
export class ErrorHandler
|
export class ErrorHandler
|
||||||
@ -12,7 +11,7 @@ export class ErrorHandler
|
|||||||
|
|
||||||
constructor()
|
constructor()
|
||||||
{
|
{
|
||||||
this.logger = new WinstonMainLogger(new AsyncQueue(), new UUidGenerator());
|
this.logger = new WinstonMainLogger(new AsyncQueue());
|
||||||
this.readLine = readline.createInterface({
|
this.readLine = readline.createInterface({
|
||||||
input: process.stdin,
|
input: process.stdin,
|
||||||
output: process.stdout
|
output: process.stdout
|
||||||
|
@ -124,7 +124,6 @@ import { PostAkiModLoader } from "@spt-aki/loaders/PostAkiModLoader";
|
|||||||
import { PostDBModLoader } from "@spt-aki/loaders/PostDBModLoader";
|
import { PostDBModLoader } from "@spt-aki/loaders/PostDBModLoader";
|
||||||
import { PreAkiModLoader } from "@spt-aki/loaders/PreAkiModLoader";
|
import { PreAkiModLoader } from "@spt-aki/loaders/PreAkiModLoader";
|
||||||
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
||||||
import { IUUidGenerator } from "@spt-aki/models/spt/utils/IUuidGenerator";
|
|
||||||
import { EventOutputHolder } from "@spt-aki/routers/EventOutputHolder";
|
import { EventOutputHolder } from "@spt-aki/routers/EventOutputHolder";
|
||||||
import { HttpRouter } from "@spt-aki/routers/HttpRouter";
|
import { HttpRouter } from "@spt-aki/routers/HttpRouter";
|
||||||
import { ImageRouter } from "@spt-aki/routers/ImageRouter";
|
import { ImageRouter } from "@spt-aki/routers/ImageRouter";
|
||||||
@ -240,7 +239,6 @@ import { MathUtil } from "@spt-aki/utils/MathUtil";
|
|||||||
import { ObjectId } from "@spt-aki/utils/ObjectId";
|
import { ObjectId } from "@spt-aki/utils/ObjectId";
|
||||||
import { RandomUtil } from "@spt-aki/utils/RandomUtil";
|
import { RandomUtil } from "@spt-aki/utils/RandomUtil";
|
||||||
import { TimeUtil } from "@spt-aki/utils/TimeUtil";
|
import { TimeUtil } from "@spt-aki/utils/TimeUtil";
|
||||||
import { UUidGenerator } from "@spt-aki/utils/UUidGenerator";
|
|
||||||
import { VFS } from "@spt-aki/utils/VFS";
|
import { VFS } from "@spt-aki/utils/VFS";
|
||||||
import { Watermark, WatermarkLocale } from "@spt-aki/utils/Watermark";
|
import { Watermark, WatermarkLocale } from "@spt-aki/utils/Watermark";
|
||||||
import { WinstonMainLogger } from "@spt-aki/utils/logging/WinstonMainLogger";
|
import { WinstonMainLogger } from "@spt-aki/utils/logging/WinstonMainLogger";
|
||||||
@ -379,7 +377,6 @@ export class Container
|
|||||||
depContainer.register<WatermarkLocale>("WatermarkLocale", WatermarkLocale, { lifecycle: Lifecycle.Singleton });
|
depContainer.register<WatermarkLocale>("WatermarkLocale", WatermarkLocale, { lifecycle: Lifecycle.Singleton });
|
||||||
depContainer.register<Watermark>("Watermark", Watermark, { lifecycle: Lifecycle.Singleton });
|
depContainer.register<Watermark>("Watermark", Watermark, { lifecycle: Lifecycle.Singleton });
|
||||||
depContainer.register<IAsyncQueue>("AsyncQueue", AsyncQueue, { lifecycle: Lifecycle.Singleton });
|
depContainer.register<IAsyncQueue>("AsyncQueue", AsyncQueue, { lifecycle: Lifecycle.Singleton });
|
||||||
depContainer.register<IUUidGenerator>("UUidGenerator", UUidGenerator, { lifecycle: Lifecycle.Singleton });
|
|
||||||
depContainer.register<HttpFileUtil>("HttpFileUtil", HttpFileUtil, { lifecycle: Lifecycle.Singleton });
|
depContainer.register<HttpFileUtil>("HttpFileUtil", HttpFileUtil, { lifecycle: Lifecycle.Singleton });
|
||||||
depContainer.register<ModLoadOrder>("ModLoadOrder", ModLoadOrder, { lifecycle: Lifecycle.Singleton });
|
depContainer.register<ModLoadOrder>("ModLoadOrder", ModLoadOrder, { lifecycle: Lifecycle.Singleton });
|
||||||
depContainer.register<ModTypeCheck>("ModTypeCheck", ModTypeCheck, { lifecycle: Lifecycle.Singleton });
|
depContainer.register<ModTypeCheck>("ModTypeCheck", ModTypeCheck, { lifecycle: Lifecycle.Singleton });
|
||||||
|
@ -1,4 +0,0 @@
|
|||||||
export interface IUUidGenerator
|
|
||||||
{
|
|
||||||
generate(): string
|
|
||||||
}
|
|
@ -1,29 +0,0 @@
|
|||||||
import { injectable } from "tsyringe";
|
|
||||||
|
|
||||||
import { IUUidGenerator } from "@spt-aki/models/spt/utils/IUuidGenerator";
|
|
||||||
|
|
||||||
@injectable()
|
|
||||||
export class UUidGenerator implements IUUidGenerator
|
|
||||||
{
|
|
||||||
// https://stackoverflow.com/a/8809472
|
|
||||||
public generate(): string
|
|
||||||
{ // Public Domain/MIT
|
|
||||||
let date = new Date().getTime();//Timestamp
|
|
||||||
let time = ((typeof performance !== "undefined") && performance.now && (performance.now() * 1000)) || 0;//Time in microseconds since page-load or 0 if unsupported
|
|
||||||
return "xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function (c)
|
|
||||||
{
|
|
||||||
let rand = Math.random() * 16;//random number between 0 and 16
|
|
||||||
if (date > 0)
|
|
||||||
{//Use timestamp until depleted
|
|
||||||
rand = (date + rand) % 16 | 0;
|
|
||||||
date = Math.floor(date / 16);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{//Use microseconds since page-load if supported
|
|
||||||
rand = (time + rand) % 16 | 0;
|
|
||||||
time = Math.floor(time / 16);
|
|
||||||
}
|
|
||||||
return (c === "x" ? rand : (rand & 0x3 | 0x8)).toString(16);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,13 +1,13 @@
|
|||||||
import { writeFileSync } from "atomically";
|
|
||||||
import fs from "node:fs";
|
|
||||||
import path, { resolve } from "node:path";
|
|
||||||
import { promisify } from "node:util";
|
|
||||||
import lockfile from "proper-lockfile";
|
|
||||||
import "reflect-metadata";
|
import "reflect-metadata";
|
||||||
import { inject, injectable } from "tsyringe";
|
import { inject, injectable } from "tsyringe";
|
||||||
|
|
||||||
|
import fs from "node:fs";
|
||||||
|
import crypto from "node:crypto";
|
||||||
|
import { promisify } from "node:util";
|
||||||
|
import path, { resolve } from "node:path";
|
||||||
|
import { writeFileSync } from "atomically";
|
||||||
|
import lockfile from "proper-lockfile";
|
||||||
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
||||||
import { IUUidGenerator } from "@spt-aki/models/spt/utils/IUuidGenerator";
|
|
||||||
|
|
||||||
@injectable()
|
@injectable()
|
||||||
export class VFS
|
export class VFS
|
||||||
@ -24,9 +24,8 @@ export class VFS
|
|||||||
renamePromisify: (oldPath: fs.PathLike, newPath: fs.PathLike) => Promise<void>;
|
renamePromisify: (oldPath: fs.PathLike, newPath: fs.PathLike) => Promise<void>;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@inject("AsyncQueue") protected asyncQueue: IAsyncQueue,
|
@inject("AsyncQueue") protected asyncQueue: IAsyncQueue
|
||||||
@inject("UUidGenerator") protected uuidGenerator: IUUidGenerator
|
)
|
||||||
)
|
|
||||||
{
|
{
|
||||||
this.accessFilePromisify = promisify(fs.access);
|
this.accessFilePromisify = promisify(fs.access);
|
||||||
this.copyFilePromisify = promisify(fs.copyFile);
|
this.copyFilePromisify = promisify(fs.copyFile);
|
||||||
@ -51,7 +50,7 @@ export class VFS
|
|||||||
{
|
{
|
||||||
// Create the command to add to the queue
|
// Create the command to add to the queue
|
||||||
const command = {
|
const command = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.accessFilePromisify(filepath)
|
cmd: async () => await this.accessFilePromisify(filepath)
|
||||||
};
|
};
|
||||||
// Wait for the command completion
|
// Wait for the command completion
|
||||||
@ -75,7 +74,7 @@ export class VFS
|
|||||||
public async copyAsync(filepath: fs.PathLike, target: fs.PathLike): Promise<void>
|
public async copyAsync(filepath: fs.PathLike, target: fs.PathLike): Promise<void>
|
||||||
{
|
{
|
||||||
const command = {
|
const command = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.copyFilePromisify(filepath, target)
|
cmd: async () => await this.copyFilePromisify(filepath, target)
|
||||||
};
|
};
|
||||||
await this.asyncQueue.waitFor(command);
|
await this.asyncQueue.waitFor(command);
|
||||||
@ -89,7 +88,7 @@ export class VFS
|
|||||||
public async createDirAsync(filepath: string): Promise<void>
|
public async createDirAsync(filepath: string): Promise<void>
|
||||||
{
|
{
|
||||||
const command = {
|
const command = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.mkdirPromisify(filepath.substr(0, filepath.lastIndexOf("/")), { "recursive": true })
|
cmd: async () => await this.mkdirPromisify(filepath.substr(0, filepath.lastIndexOf("/")), { "recursive": true })
|
||||||
};
|
};
|
||||||
await this.asyncQueue.waitFor(command);
|
await this.asyncQueue.waitFor(command);
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
import fs from "node:fs";
|
import fs from "node:fs";
|
||||||
|
import crypto from "node:crypto";
|
||||||
import { promisify } from "node:util";
|
import { promisify } from "node:util";
|
||||||
import winston, { createLogger, format, transports } from "winston";
|
import winston, { createLogger, format, transports } from "winston";
|
||||||
import DailyRotateFile from "winston-daily-rotate-file";
|
import DailyRotateFile from "winston-daily-rotate-file";
|
||||||
@ -10,7 +11,6 @@ import { SptLogger } from "@spt-aki/models/spt/logging/SptLogger";
|
|||||||
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
||||||
import { ICommand } from "@spt-aki/models/spt/utils/ICommand";
|
import { ICommand } from "@spt-aki/models/spt/utils/ICommand";
|
||||||
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
||||||
import { IUUidGenerator } from "@spt-aki/models/spt/utils/IUuidGenerator";
|
|
||||||
|
|
||||||
export abstract class AbstractWinstonLogger implements ILogger
|
export abstract class AbstractWinstonLogger implements ILogger
|
||||||
{
|
{
|
||||||
@ -49,9 +49,8 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
protected writeFilePromisify: (path: fs.PathLike, data: string, options?: any) => Promise<void>;
|
protected writeFilePromisify: (path: fs.PathLike, data: string, options?: any) => Promise<void>;
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
protected asyncQueue: IAsyncQueue,
|
protected asyncQueue: IAsyncQueue
|
||||||
protected uuidGenerator: IUUidGenerator
|
)
|
||||||
)
|
|
||||||
{
|
{
|
||||||
this.filePath = `${this.getFilePath()}${this.getFileName()}`;
|
this.filePath = `${this.getFilePath()}${this.getFileName()}`;
|
||||||
this.writeFilePromisify = promisify(fs.writeFile);
|
this.writeFilePromisify = promisify(fs.writeFile);
|
||||||
@ -140,7 +139,7 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
public async writeToLogFile(data: string | Daum): Promise<void>
|
public async writeToLogFile(data: string | Daum): Promise<void>
|
||||||
{
|
{
|
||||||
const command: ICommand = {
|
const command: ICommand = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.writeFilePromisify(this.filePath, `${data}\n`, true)
|
cmd: async () => await this.writeFilePromisify(this.filePath, `${data}\n`, true)
|
||||||
};
|
};
|
||||||
await this.asyncQueue.waitFor(command);
|
await this.asyncQueue.waitFor(command);
|
||||||
@ -165,14 +164,14 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
if (typeof (data) === "string")
|
if (typeof (data) === "string")
|
||||||
{
|
{
|
||||||
command = {
|
command = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await tmpLogger.log("custom", data)
|
cmd: async () => await tmpLogger.log("custom", data)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
command = {
|
command = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await tmpLogger.log("custom", JSON.stringify(data, null, 4))
|
cmd: async () => await tmpLogger.log("custom", JSON.stringify(data, null, 4))
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -183,7 +182,7 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
public async error(data: string | Record<string, unknown>): Promise<void>
|
public async error(data: string | Record<string, unknown>): Promise<void>
|
||||||
{
|
{
|
||||||
const command: ICommand = {
|
const command: ICommand = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.logger.error(data)
|
cmd: async () => await this.logger.error(data)
|
||||||
};
|
};
|
||||||
await this.asyncQueue.waitFor(command);
|
await this.asyncQueue.waitFor(command);
|
||||||
@ -192,7 +191,7 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
public async warning(data: string | Record<string, unknown>): Promise<void>
|
public async warning(data: string | Record<string, unknown>): Promise<void>
|
||||||
{
|
{
|
||||||
const command: ICommand = {
|
const command: ICommand = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.logger.warn(data)
|
cmd: async () => await this.logger.warn(data)
|
||||||
};
|
};
|
||||||
await this.asyncQueue.waitFor(command);
|
await this.asyncQueue.waitFor(command);
|
||||||
@ -201,7 +200,7 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
public async success(data: string | Record<string, unknown>): Promise<void>
|
public async success(data: string | Record<string, unknown>): Promise<void>
|
||||||
{
|
{
|
||||||
const command: ICommand = {
|
const command: ICommand = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.logger.succ(data)
|
cmd: async () => await this.logger.succ(data)
|
||||||
};
|
};
|
||||||
await this.asyncQueue.waitFor(command);
|
await this.asyncQueue.waitFor(command);
|
||||||
@ -210,7 +209,7 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
public async info(data: string | Record<string, unknown>): Promise<void>
|
public async info(data: string | Record<string, unknown>): Promise<void>
|
||||||
{
|
{
|
||||||
const command: ICommand = {
|
const command: ICommand = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.logger.info(data)
|
cmd: async () => await this.logger.info(data)
|
||||||
};
|
};
|
||||||
await this.asyncQueue.waitFor(command);
|
await this.asyncQueue.waitFor(command);
|
||||||
@ -225,7 +224,7 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
public async logWithColor(data: string | Record<string, unknown>, textColor: LogTextColor, backgroundColor = LogBackgroundColor.DEFAULT): Promise<void>
|
public async logWithColor(data: string | Record<string, unknown>, textColor: LogTextColor, backgroundColor = LogBackgroundColor.DEFAULT): Promise<void>
|
||||||
{
|
{
|
||||||
const command: ICommand = {
|
const command: ICommand = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.log(data, textColor.toString(), backgroundColor.toString())
|
cmd: async () => await this.log(data, textColor.toString(), backgroundColor.toString())
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -239,14 +238,14 @@ export abstract class AbstractWinstonLogger implements ILogger
|
|||||||
if (onlyShowInConsole)
|
if (onlyShowInConsole)
|
||||||
{
|
{
|
||||||
command = {
|
command = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.log(data, this.logLevels.colors.debug)
|
cmd: async () => await this.log(data, this.logLevels.colors.debug)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
command = {
|
command = {
|
||||||
uuid: this.uuidGenerator.generate(),
|
uuid: crypto.randomUUID(),
|
||||||
cmd: async () => await this.logger.debug(data)
|
cmd: async () => await this.logger.debug(data)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import { inject, injectable } from "tsyringe";
|
import { inject, injectable } from "tsyringe";
|
||||||
|
|
||||||
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
||||||
import { IUUidGenerator } from "@spt-aki/models/spt/utils/IUuidGenerator";
|
|
||||||
import { AbstractWinstonLogger } from "@spt-aki/utils/logging/AbstractWinstonLogger";
|
import { AbstractWinstonLogger } from "@spt-aki/utils/logging/AbstractWinstonLogger";
|
||||||
|
|
||||||
@injectable()
|
@injectable()
|
||||||
@ -9,11 +8,10 @@ export class WinstonMainLogger extends AbstractWinstonLogger
|
|||||||
{
|
{
|
||||||
|
|
||||||
constructor(
|
constructor(
|
||||||
@inject("AsyncQueue") protected asyncQueue: IAsyncQueue,
|
@inject("AsyncQueue") protected asyncQueue: IAsyncQueue
|
||||||
@inject("UUidGenerator") protected uuidGenerator: IUUidGenerator
|
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
super(asyncQueue, uuidGenerator);
|
super(asyncQueue);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected isLogExceptions(): boolean
|
protected isLogExceptions(): boolean
|
||||||
|
@ -1,18 +1,16 @@
|
|||||||
import { inject, injectable } from "tsyringe";
|
import { inject, injectable } from "tsyringe";
|
||||||
|
|
||||||
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
import { IAsyncQueue } from "@spt-aki/models/spt/utils/IAsyncQueue";
|
||||||
import { IUUidGenerator } from "@spt-aki/models/spt/utils/IUuidGenerator";
|
|
||||||
import { AbstractWinstonLogger } from "@spt-aki/utils/logging/AbstractWinstonLogger";
|
import { AbstractWinstonLogger } from "@spt-aki/utils/logging/AbstractWinstonLogger";
|
||||||
|
|
||||||
@injectable()
|
@injectable()
|
||||||
export class WinstonRequestLogger extends AbstractWinstonLogger
|
export class WinstonRequestLogger extends AbstractWinstonLogger
|
||||||
{
|
{
|
||||||
constructor(
|
constructor(
|
||||||
@inject("AsyncQueue") protected asyncQueue: IAsyncQueue,
|
@inject("AsyncQueue") protected asyncQueue: IAsyncQueue
|
||||||
@inject("UUidGenerator") protected uuidGenerator: IUUidGenerator
|
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
super(asyncQueue, uuidGenerator);
|
super(asyncQueue);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected isLogExceptions(): boolean
|
protected isLogExceptions(): boolean
|
||||||
|
Loading…
Reference in New Issue
Block a user