mirror of
https://github.com/xuthus83/pigallery2.git
synced 2025-01-14 14:43:17 +08:00
Implementing custom Logger, removing deprecated winston dependency
Winston had a major API refactor since v2, so update was not straight forward. Pigallery also uses simple logging, so no need for the complex feature set of winston.
This commit is contained in:
parent
f59ba6eb98
commit
2fa1c8f87f
13
package-lock.json
generated
13
package-lock.json
generated
@ -5837,7 +5837,8 @@
|
|||||||
"colors": {
|
"colors": {
|
||||||
"version": "1.0.3",
|
"version": "1.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/colors/-/colors-1.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/colors/-/colors-1.0.3.tgz",
|
||||||
"integrity": "sha1-BDP0TYCWgP3rYO0mDxsMJi6CpAs="
|
"integrity": "sha1-BDP0TYCWgP3rYO0mDxsMJi6CpAs=",
|
||||||
|
"dev": true
|
||||||
},
|
},
|
||||||
"combined-stream": {
|
"combined-stream": {
|
||||||
"version": "1.0.7",
|
"version": "1.0.7",
|
||||||
@ -6936,7 +6937,8 @@
|
|||||||
"cycle": {
|
"cycle": {
|
||||||
"version": "1.0.3",
|
"version": "1.0.3",
|
||||||
"resolved": "https://registry.npmjs.org/cycle/-/cycle-1.0.3.tgz",
|
"resolved": "https://registry.npmjs.org/cycle/-/cycle-1.0.3.tgz",
|
||||||
"integrity": "sha1-IegLK+hYD5i0aPN5QwZisEbDStI="
|
"integrity": "sha1-IegLK+hYD5i0aPN5QwZisEbDStI=",
|
||||||
|
"dev": true
|
||||||
},
|
},
|
||||||
"cyclist": {
|
"cyclist": {
|
||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
@ -8323,7 +8325,8 @@
|
|||||||
"eyes": {
|
"eyes": {
|
||||||
"version": "0.1.8",
|
"version": "0.1.8",
|
||||||
"resolved": "https://registry.npmjs.org/eyes/-/eyes-0.1.8.tgz",
|
"resolved": "https://registry.npmjs.org/eyes/-/eyes-0.1.8.tgz",
|
||||||
"integrity": "sha1-Ys8SAjTGg3hdkCNIqADvPgzCC8A="
|
"integrity": "sha1-Ys8SAjTGg3hdkCNIqADvPgzCC8A=",
|
||||||
|
"dev": true
|
||||||
},
|
},
|
||||||
"fancy-log": {
|
"fancy-log": {
|
||||||
"version": "1.3.2",
|
"version": "1.3.2",
|
||||||
@ -18459,7 +18462,8 @@
|
|||||||
"stack-trace": {
|
"stack-trace": {
|
||||||
"version": "0.0.10",
|
"version": "0.0.10",
|
||||||
"resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz",
|
"resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz",
|
||||||
"integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA="
|
"integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA=",
|
||||||
|
"dev": true
|
||||||
},
|
},
|
||||||
"static-extend": {
|
"static-extend": {
|
||||||
"version": "0.1.2",
|
"version": "0.1.2",
|
||||||
@ -21401,6 +21405,7 @@
|
|||||||
"version": "2.4.5",
|
"version": "2.4.5",
|
||||||
"resolved": "https://registry.npmjs.org/winston/-/winston-2.4.5.tgz",
|
"resolved": "https://registry.npmjs.org/winston/-/winston-2.4.5.tgz",
|
||||||
"integrity": "sha512-TWoamHt5yYvsMarGlGEQE59SbJHqGsZV8/lwC+iCcGeAe0vUaOh+Lv6SYM17ouzC/a/LB1/hz/7sxFBtlu1l4A==",
|
"integrity": "sha512-TWoamHt5yYvsMarGlGEQE59SbJHqGsZV8/lwC+iCcGeAe0vUaOh+Lv6SYM17ouzC/a/LB1/hz/7sxFBtlu1l4A==",
|
||||||
|
"dev": true,
|
||||||
"requires": {
|
"requires": {
|
||||||
"async": "~1.0.0",
|
"async": "~1.0.0",
|
||||||
"colors": "1.0.x",
|
"colors": "1.0.x",
|
||||||
|
@ -53,8 +53,7 @@
|
|||||||
"ts-exif-parser": "0.2.2",
|
"ts-exif-parser": "0.2.2",
|
||||||
"ts-node-iptc": "1.0.11",
|
"ts-node-iptc": "1.0.11",
|
||||||
"typeconfig": "2.0.15",
|
"typeconfig": "2.0.15",
|
||||||
"typeorm": "0.2.32",
|
"typeorm": "0.2.32"
|
||||||
"winston": "2.4.5"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@angular-devkit/build-angular": "0.1102.12",
|
"@angular-devkit/build-angular": "0.1102.12",
|
||||||
|
@ -1,42 +1,65 @@
|
|||||||
import * as winston from 'winston';
|
|
||||||
import {Config} from '../common/config/private/Config';
|
import {Config} from '../common/config/private/Config';
|
||||||
import {LogLevel} from '../common/config/private/PrivateConfig';
|
import {LogLevel} from '../common/config/private/PrivateConfig';
|
||||||
|
|
||||||
|
export type logFN = (...args: (string | number)[]) => void;
|
||||||
|
|
||||||
const forcedDebug = process.env.NODE_ENV === 'debug';
|
const forcedDebug = process.env.NODE_ENV === 'debug';
|
||||||
|
|
||||||
if (forcedDebug === true) {
|
if (forcedDebug === true) {
|
||||||
console.log('NODE_ENV environmental variable is set to debug, forcing all logs to print');
|
console.log('NODE_ENV environmental variable is set to debug, forcing all logs to print');
|
||||||
}
|
}
|
||||||
export const winstonSettings = {
|
|
||||||
transports: [
|
|
||||||
new winston.transports.Console({
|
|
||||||
level: forcedDebug === true ? LogLevel[LogLevel.silly] : LogLevel[Config.Server.Log.level],
|
|
||||||
handleExceptions: true,
|
|
||||||
json: false,
|
|
||||||
colorize: true,
|
|
||||||
timestamp(): string {
|
|
||||||
return (new Date()).toLocaleString();
|
|
||||||
},
|
|
||||||
label: 'innerLabel',
|
|
||||||
formatter: (options: any) => {
|
|
||||||
// Return string will be passed to logger.
|
|
||||||
return options.timestamp() + '[' + (winston as any).config.colorize(options.level, options.level.toUpperCase()) + '] ' +
|
|
||||||
(undefined !== options.message ? options.message : '') +
|
|
||||||
(options.meta && Object.keys(options.meta).length ? '\n\t' + JSON.stringify(options.meta) : '');
|
|
||||||
},
|
|
||||||
debugStdout: true
|
|
||||||
} as any)
|
|
||||||
],
|
|
||||||
exitOnError: false
|
|
||||||
};
|
|
||||||
|
|
||||||
export type logFN = (...args: (string | number)[]) => {};
|
export class Logger {
|
||||||
|
public static silly(...args: (string | number)[]): void {
|
||||||
|
if (!forcedDebug && Config.Server.Log.level < LogLevel.silly) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Logger.log(`[\x1b[35mSILLY\x1b[0m]`, ...args);
|
||||||
|
}
|
||||||
|
|
||||||
export const Logger: {
|
public static debug(...args: (string | number)[]): void {
|
||||||
error: logFN,
|
if (!forcedDebug && Config.Server.Log.level < LogLevel.debug) {
|
||||||
warn: logFN,
|
return;
|
||||||
info: logFN,
|
}
|
||||||
verbose: logFN,
|
Logger.log(`[\x1b[34mDEBUG\x1b[0m]`, ...args);
|
||||||
debug: logFN,
|
|
||||||
silly: logFN
|
}
|
||||||
} = new (winston as any).Logger(winstonSettings);
|
|
||||||
|
|
||||||
|
public static verbose(...args: (string | number)[]): void {
|
||||||
|
if (!forcedDebug && Config.Server.Log.level < LogLevel.verbose) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Logger.log(`[\x1b[36mVERBS\x1b[0m]`, ...args);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static info(...args: (string | number)[]): void {
|
||||||
|
if (!forcedDebug && Config.Server.Log.level < LogLevel.info) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Logger.log(`[\x1b[32mINFO_\x1b[0m]`, ...args);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static warn(...args: (string | number)[]): void {
|
||||||
|
if (!forcedDebug && Config.Server.Log.level < LogLevel.warn) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Logger.log(`[\x1b[33mWARN_\x1b[0m]`, ...args);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static error(...args: (string | number)[]): void {
|
||||||
|
|
||||||
|
Logger.log(`[\x1b[31mERROR\x1b[0m]`, ...args);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static log(tag: string, ...args: (string | number)[]): void {
|
||||||
|
const date = (new Date()).toLocaleString();
|
||||||
|
let LOG_TAG = '';
|
||||||
|
if (args.length > 0 && typeof args[0] === 'string' && args[0].startsWith('[') && args[0].endsWith(']')) {
|
||||||
|
LOG_TAG = args[0];
|
||||||
|
args.shift();
|
||||||
|
}
|
||||||
|
console.log(date + tag + LOG_TAG, ...args);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -10,6 +10,8 @@ import {IVersionManager} from './database/interfaces/IVersionManager';
|
|||||||
import {IJobManager} from './database/interfaces/IJobManager';
|
import {IJobManager} from './database/interfaces/IJobManager';
|
||||||
import {LocationManager} from './database/LocationManager';
|
import {LocationManager} from './database/LocationManager';
|
||||||
|
|
||||||
|
const LOG_TAG = '[ObjectManagers]';
|
||||||
|
|
||||||
export class ObjectManagers {
|
export class ObjectManagers {
|
||||||
|
|
||||||
private static instance: ObjectManagers = null;
|
private static instance: ObjectManagers = null;
|
||||||
@ -162,7 +164,7 @@ export class ObjectManagers {
|
|||||||
ObjectManagers.getInstance().VersionManager = new VersionManager();
|
ObjectManagers.getInstance().VersionManager = new VersionManager();
|
||||||
ObjectManagers.getInstance().LocationManager = new LocationManager();
|
ObjectManagers.getInstance().LocationManager = new LocationManager();
|
||||||
this.InitCommonManagers();
|
this.InitCommonManagers();
|
||||||
Logger.debug('SQL DB inited');
|
Logger.debug(LOG_TAG, 'SQL DB inited');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@ import {DirectoryDTO} from '../../../common/entities/DirectoryDTO';
|
|||||||
import {RendererInput} from './PhotoWorker';
|
import {RendererInput} from './PhotoWorker';
|
||||||
import {TaskQue, TaskQueEntry} from './TaskQue';
|
import {TaskQue, TaskQueEntry} from './TaskQue';
|
||||||
import {ITaskExecuter} from './TaskExecuter';
|
import {ITaskExecuter} from './TaskExecuter';
|
||||||
import {DirectoryScanSettings, DiskMangerWorker} from './DiskMangerWorker';
|
import {DirectoryScanSettings} from './DiskMangerWorker';
|
||||||
|
|
||||||
|
|
||||||
interface WorkerWrapper<O> {
|
interface WorkerWrapper<O> {
|
||||||
@ -13,6 +13,8 @@ interface WorkerWrapper<O> {
|
|||||||
poolTask: TaskQueEntry<WorkerTask, O>;
|
poolTask: TaskQueEntry<WorkerTask, O>;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const LOG_TAG = '[ThreadPool]';
|
||||||
|
|
||||||
export class ThreadPool<O> {
|
export class ThreadPool<O> {
|
||||||
|
|
||||||
public static WorkerCount = 0;
|
public static WorkerCount = 0;
|
||||||
@ -20,7 +22,7 @@ export class ThreadPool<O> {
|
|||||||
private taskQue = new TaskQue<WorkerTask, O>();
|
private taskQue = new TaskQue<WorkerTask, O>();
|
||||||
|
|
||||||
constructor(private size: number) {
|
constructor(private size: number) {
|
||||||
Logger.silly('Creating thread pool with', size, 'workers');
|
Logger.silly(LOG_TAG, 'Creating thread pool with', size, 'workers');
|
||||||
for (let i = 0; i < size; i++) {
|
for (let i = 0; i < size; i++) {
|
||||||
this.startWorker();
|
this.startWorker();
|
||||||
}
|
}
|
||||||
@ -60,13 +62,13 @@ export class ThreadPool<O> {
|
|||||||
this.workers.push(worker);
|
this.workers.push(worker);
|
||||||
worker.worker.on('online', (): void => {
|
worker.worker.on('online', (): void => {
|
||||||
ThreadPool.WorkerCount++;
|
ThreadPool.WorkerCount++;
|
||||||
Logger.debug('Worker ' + worker.worker.process.pid + ' is online, worker count:', ThreadPool.WorkerCount);
|
Logger.debug(LOG_TAG, 'Worker ' + worker.worker.process.pid + ' is online, worker count:', ThreadPool.WorkerCount);
|
||||||
});
|
});
|
||||||
worker.worker.on('exit', (code, signal): void => {
|
worker.worker.on('exit', (code, signal): void => {
|
||||||
ThreadPool.WorkerCount--;
|
ThreadPool.WorkerCount--;
|
||||||
Logger.warn('Worker ' + worker.worker.process.pid + ' died with code: ' + code +
|
Logger.warn(LOG_TAG, 'Worker ' + worker.worker.process.pid + ' died with code: ' + code +
|
||||||
', and signal: ' + signal + ', worker count:', ThreadPool.WorkerCount);
|
', and signal: ' + signal + ', worker count:', ThreadPool.WorkerCount);
|
||||||
Logger.debug('Starting a new worker');
|
Logger.debug(LOG_TAG, 'Starting a new worker');
|
||||||
this.startWorker();
|
this.startWorker();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -7,10 +7,10 @@ import {DirectoryDTO} from '../../../common/entities/DirectoryDTO';
|
|||||||
|
|
||||||
declare var process: NodeJS.Process;
|
declare var process: NodeJS.Process;
|
||||||
declare var global: NodeJS.Global;
|
declare var global: NodeJS.Global;
|
||||||
|
const LOG_TAG = '[Worker]';
|
||||||
export class Worker {
|
export class Worker {
|
||||||
public static process<O extends (void | DirectoryDTO<MediaDTO>)>(): void {
|
public static process<O extends (void | DirectoryDTO<MediaDTO>)>(): void {
|
||||||
Logger.debug('Worker is waiting for tasks');
|
Logger.debug(LOG_TAG, 'Worker is waiting for tasks');
|
||||||
process.on('message', async (task: WorkerTask) => {
|
process.on('message', async (task: WorkerTask) => {
|
||||||
try {
|
try {
|
||||||
let result = null;
|
let result = null;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user