mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-12 06:56:24 +00:00
144 lines
3.5 KiB
TypeScript
144 lines
3.5 KiB
TypeScript
import * as bunyan from 'bunyan';
|
|
import * as shortid from 'shortid';
|
|
|
|
import is from '@sindresorhus/is';
|
|
import { RenovateStream } from './pretty-stdout';
|
|
import configSerializer from './config-serializer';
|
|
import errSerializer from './err-serializer';
|
|
import cmdSerializer from './cmd-serializer';
|
|
import { ErrorStream, withSanitizer } from './utils';
|
|
|
|
let logContext: string = process.env.LOG_CONTEXT || shortid.generate();
|
|
let meta = {};
|
|
|
|
export interface LogError {
|
|
level: bunyan.LogLevel;
|
|
meta: any;
|
|
msg?: string;
|
|
}
|
|
|
|
const errors = new ErrorStream();
|
|
|
|
const stdout: bunyan.Stream = {
|
|
name: 'stdout',
|
|
level: (process.env.LOG_LEVEL as bunyan.LogLevel) || 'info',
|
|
stream: process.stdout,
|
|
};
|
|
|
|
if (process.env.LOG_FORMAT !== 'json') {
|
|
// TODO: typings
|
|
const prettyStdOut = new RenovateStream() as any;
|
|
prettyStdOut.pipe(process.stdout);
|
|
stdout.stream = prettyStdOut;
|
|
stdout.type = 'raw';
|
|
}
|
|
|
|
const bunyanLogger = bunyan.createLogger({
|
|
name: 'renovate',
|
|
serializers: {
|
|
body: configSerializer,
|
|
cmd: cmdSerializer,
|
|
config: configSerializer,
|
|
migratedConfig: configSerializer,
|
|
originalConfig: configSerializer,
|
|
presetConfig: configSerializer,
|
|
oldConfig: configSerializer,
|
|
newConfig: configSerializer,
|
|
err: errSerializer,
|
|
},
|
|
streams: [
|
|
stdout,
|
|
{
|
|
name: 'error',
|
|
level: 'error' as bunyan.LogLevel,
|
|
stream: errors as any,
|
|
type: 'raw',
|
|
},
|
|
].map(withSanitizer),
|
|
});
|
|
|
|
const logFactory = (level: bunyan.LogLevelString): any => {
|
|
return (p1: any, p2: any): void => {
|
|
if (p2) {
|
|
// meta and msg provided
|
|
bunyanLogger[level]({ logContext, ...meta, ...p1 }, p2);
|
|
} else if (is.string(p1)) {
|
|
// only message provided
|
|
bunyanLogger[level]({ logContext, ...meta }, p1);
|
|
} else {
|
|
// only meta provided
|
|
bunyanLogger[level]({ logContext, ...meta, ...p1 });
|
|
}
|
|
};
|
|
};
|
|
|
|
const loggerLevels: bunyan.LogLevelString[] = [
|
|
'trace',
|
|
'debug',
|
|
'info',
|
|
'warn',
|
|
'error',
|
|
'fatal',
|
|
];
|
|
|
|
interface Logger {
|
|
trace(msg: string): void;
|
|
trace(meta: Record<string, any>, msg?: string): void;
|
|
debug(msg: string): void;
|
|
debug(meta: Record<string, any>, msg?: string): void;
|
|
info(msg: string): void;
|
|
info(meta: Record<string, any>, msg?: string): void;
|
|
warn(msg: string): void;
|
|
warn(meta: Record<string, any>, msg?: string): void;
|
|
error(msg: string): void;
|
|
error(meta: Record<string, any>, msg?: string): void;
|
|
fatal(msg: string): void;
|
|
fatal(meta: Record<string, any>, msg?: string): void;
|
|
}
|
|
|
|
export const logger: Logger = {} as any;
|
|
|
|
loggerLevels.forEach(loggerLevel => {
|
|
logger[loggerLevel] = logFactory(loggerLevel);
|
|
});
|
|
|
|
export function setContext(value: string): void {
|
|
logContext = value;
|
|
}
|
|
|
|
export function getContext(): any {
|
|
return logContext;
|
|
}
|
|
|
|
// setMeta overrides existing meta, may remove fields if no longer existing
|
|
export function setMeta(obj: any): void {
|
|
meta = { ...obj };
|
|
}
|
|
|
|
// addMeta overrides or adds fields but does not remove any
|
|
export function addMeta(obj: any): void {
|
|
meta = { ...meta, ...obj };
|
|
}
|
|
|
|
// removeMeta removes the provided fields from meta
|
|
export function removeMeta(fields: string[]): void {
|
|
Object.keys(meta).forEach(key => {
|
|
if (fields.includes(key)) {
|
|
delete meta[key];
|
|
}
|
|
});
|
|
}
|
|
|
|
export /* istanbul ignore next */ function addStream(
|
|
stream: bunyan.Stream
|
|
): void {
|
|
bunyanLogger.addStream(withSanitizer(stream));
|
|
}
|
|
|
|
export function levels(name: string, level: bunyan.LogLevel): void {
|
|
bunyanLogger.levels(name, level);
|
|
}
|
|
|
|
export function getErrors(): any {
|
|
return errors.getErrors();
|
|
}
|