logger: remove unused structured data

The `data` field is not used anywhere in the logger. While it would
be possible to send structured data through syslog, it seems unnecessary
at present and also the way in which this structured data would have to be
provided sounds too cumbersome to implement for no real value.
This commit is contained in:
Johann150 2023-05-18 22:42:30 +02:00
parent c5327f74d4
commit 85a392ee33
Signed by untrusted user: Johann150
GPG key ID: 9EE6577A2A06F8F1
6 changed files with 32 additions and 55 deletions

View file

@ -41,7 +41,7 @@ function greet(): void {
} }
bootLogger.info('Welcome to FoundKey!'); bootLogger.info('Welcome to FoundKey!');
bootLogger.info(`FoundKey v${meta.version}`, null, true); bootLogger.info(`FoundKey v${meta.version}`, true);
} }
/** /**
@ -59,7 +59,7 @@ export async function masterMain(): Promise<void> {
config = loadConfigBoot(); config = loadConfigBoot();
await connectDb(); await connectDb();
} catch (e) { } catch (e) {
bootLogger.error('Fatal error occurred during initialization', {}, true); bootLogger.error('Fatal error occurred during initialization', true);
process.exit(1); process.exit(1);
} }
@ -69,7 +69,7 @@ export async function masterMain(): Promise<void> {
await spawnWorkers(config.clusterLimits); await spawnWorkers(config.clusterLimits);
} }
bootLogger.succ(`Now listening on port ${config.port} on ${config.url}`, null, true); bootLogger.succ(`Now listening on port ${config.port} on ${config.url}`, true);
if (!envOption.noDaemons) { if (!envOption.noDaemons) {
import('../daemons/server-stats.js').then(x => x.serverStats()); import('../daemons/server-stats.js').then(x => x.serverStats());
@ -84,7 +84,7 @@ function showEnvironment(): void {
if (env !== 'production') { if (env !== 'production') {
logger.warn('The environment is not in production mode.'); logger.warn('The environment is not in production mode.');
logger.warn('DO NOT USE FOR PRODUCTION PURPOSE!', {}, true); logger.warn('DO NOT USE FOR PRODUCTION PURPOSE!', true);
} }
} }
@ -109,7 +109,7 @@ function loadConfigBoot(): Config {
} catch (exception) { } catch (exception) {
const e = exception as Partial<NodeJS.ErrnoException> | Error; const e = exception as Partial<NodeJS.ErrnoException> | Error;
if ('code' in e && e.code === 'ENOENT') { if ('code' in e && e.code === 'ENOENT') {
configLogger.error('Configuration file not found', {}, true); configLogger.error('Configuration file not found', true);
process.exit(1); process.exit(1);
} else if (e instanceof Error) { } else if (e instanceof Error) {
configLogger.error(e.message); configLogger.error(e.message);
@ -133,7 +133,7 @@ async function connectDb(): Promise<void> {
const v = await db.query('SHOW server_version').then(x => x[0].server_version); const v = await db.query('SHOW server_version').then(x => x[0].server_version);
dbLogger.succ(`Connected: v${v}`); dbLogger.succ(`Connected: v${v}`);
} catch (e) { } catch (e) {
dbLogger.error('Cannot connect', {}, true); dbLogger.error('Cannot connect', true);
dbLogger.error(e as Error | string); dbLogger.error(e as Error | string);
process.exit(1); process.exit(1);
} }

View file

@ -39,8 +39,8 @@ systemQueue
.on('waiting', (jobId) => systemLogger.debug(`waiting id=${jobId}`)) .on('waiting', (jobId) => systemLogger.debug(`waiting id=${jobId}`))
.on('active', (job) => systemLogger.debug(`active id=${job.id}`)) .on('active', (job) => systemLogger.debug(`active id=${job.id}`))
.on('completed', (job, result) => systemLogger.debug(`completed(${result}) id=${job.id}`)) .on('completed', (job, result) => systemLogger.debug(`completed(${result}) id=${job.id}`))
.on('failed', (job, err) => systemLogger.warn(`failed(${err}) id=${job.id}`, { job, e: renderError(err) })) .on('failed', (job, err) => systemLogger.warn(`failed(${err}) id=${job.id}`))
.on('error', (job: any, err: Error) => systemLogger.error(`error ${err}`, { job, e: renderError(err) })) .on('error', (job: any, err: Error) => systemLogger.error(`error ${err}`))
.on('stalled', (job) => systemLogger.warn(`stalled id=${job.id}`)); .on('stalled', (job) => systemLogger.warn(`stalled id=${job.id}`));
deliverQueue deliverQueue
@ -48,31 +48,31 @@ deliverQueue
.on('active', (job) => deliverLogger.debug(`active ${getJobInfo(job, true)} to=${job.data.to}`)) .on('active', (job) => deliverLogger.debug(`active ${getJobInfo(job, true)} to=${job.data.to}`))
.on('completed', (job, result) => deliverLogger.debug(`completed(${result}) ${getJobInfo(job, true)} to=${job.data.to}`)) .on('completed', (job, result) => deliverLogger.debug(`completed(${result}) ${getJobInfo(job, true)} to=${job.data.to}`))
.on('failed', (job, err) => deliverLogger.warn(`failed(${err}) ${getJobInfo(job)} to=${job.data.to}`)) .on('failed', (job, err) => deliverLogger.warn(`failed(${err}) ${getJobInfo(job)} to=${job.data.to}`))
.on('error', (job: any, err: Error) => deliverLogger.error(`error ${err}`, { job, e: renderError(err) })) .on('error', (job: any, err: Error) => deliverLogger.error(`error ${err}`))
.on('stalled', (job) => deliverLogger.warn(`stalled ${getJobInfo(job)} to=${job.data.to}`)); .on('stalled', (job) => deliverLogger.warn(`stalled ${getJobInfo(job)} to=${job.data.to}`));
inboxQueue inboxQueue
.on('waiting', (jobId) => inboxLogger.debug(`waiting id=${jobId}`)) .on('waiting', (jobId) => inboxLogger.debug(`waiting id=${jobId}`))
.on('active', (job) => inboxLogger.debug(`active ${getJobInfo(job, true)}`)) .on('active', (job) => inboxLogger.debug(`active ${getJobInfo(job, true)}`))
.on('completed', (job, result) => inboxLogger.debug(`completed(${result}) ${getJobInfo(job, true)}`)) .on('completed', (job, result) => inboxLogger.debug(`completed(${result}) ${getJobInfo(job, true)}`))
.on('failed', (job, err) => inboxLogger.warn(`failed(${err}) ${getJobInfo(job)} activity=${job.data.activity ? job.data.activity.id : 'none'}`, { job, e: renderError(err) })) .on('failed', (job, err) => inboxLogger.warn(`failed(${err}) ${getJobInfo(job)} activity=${job.data.activity ? job.data.activity.id : 'none'}`))
.on('error', (job: any, err: Error) => inboxLogger.error(`error ${err}`, { job, e: renderError(err) })) .on('error', (job: any, err: Error) => inboxLogger.error(`error ${err}`))
.on('stalled', (job) => inboxLogger.warn(`stalled ${getJobInfo(job)} activity=${job.data.activity ? job.data.activity.id : 'none'}`)); .on('stalled', (job) => inboxLogger.warn(`stalled ${getJobInfo(job)} activity=${job.data.activity ? job.data.activity.id : 'none'}`));
dbQueue dbQueue
.on('waiting', (jobId) => dbLogger.debug(`waiting id=${jobId}`)) .on('waiting', (jobId) => dbLogger.debug(`waiting id=${jobId}`))
.on('active', (job) => dbLogger.debug(`active id=${job.id}`)) .on('active', (job) => dbLogger.debug(`active id=${job.id}`))
.on('completed', (job, result) => dbLogger.debug(`completed(${result}) id=${job.id}`)) .on('completed', (job, result) => dbLogger.debug(`completed(${result}) id=${job.id}`))
.on('failed', (job, err) => dbLogger.warn(`failed(${err}) id=${job.id}`, { job, e: renderError(err) })) .on('failed', (job, err) => dbLogger.warn(`failed(${err}) id=${job.id}`))
.on('error', (job: any, err: Error) => dbLogger.error(`error ${err}`, { job, e: renderError(err) })) .on('error', (job: any, err: Error) => dbLogger.error(`error ${err}`))
.on('stalled', (job) => dbLogger.warn(`stalled id=${job.id}`)); .on('stalled', (job) => dbLogger.warn(`stalled id=${job.id}`));
objectStorageQueue objectStorageQueue
.on('waiting', (jobId) => objectStorageLogger.debug(`waiting id=${jobId}`)) .on('waiting', (jobId) => objectStorageLogger.debug(`waiting id=${jobId}`))
.on('active', (job) => objectStorageLogger.debug(`active id=${job.id}`)) .on('active', (job) => objectStorageLogger.debug(`active id=${job.id}`))
.on('completed', (job, result) => objectStorageLogger.debug(`completed(${result}) id=${job.id}`)) .on('completed', (job, result) => objectStorageLogger.debug(`completed(${result}) id=${job.id}`))
.on('failed', (job, err) => objectStorageLogger.warn(`failed(${err}) id=${job.id}`, { job, e: renderError(err) })) .on('failed', (job, err) => objectStorageLogger.warn(`failed(${err}) id=${job.id}`))
.on('error', (job: any, err: Error) => objectStorageLogger.error(`error ${err}`, { job, e: renderError(err) })) .on('error', (job: any, err: Error) => objectStorageLogger.error(`error ${err}`))
.on('stalled', (job) => objectStorageLogger.warn(`stalled id=${job.id}`)); .on('stalled', (job) => objectStorageLogger.warn(`stalled id=${job.id}`));
webhookDeliverQueue webhookDeliverQueue
@ -80,7 +80,7 @@ webhookDeliverQueue
.on('active', (job) => webhookLogger.debug(`active ${getJobInfo(job, true)} to=${job.data.to}`)) .on('active', (job) => webhookLogger.debug(`active ${getJobInfo(job, true)} to=${job.data.to}`))
.on('completed', (job, result) => webhookLogger.debug(`completed(${result}) ${getJobInfo(job, true)} to=${job.data.to}`)) .on('completed', (job, result) => webhookLogger.debug(`completed(${result}) ${getJobInfo(job, true)} to=${job.data.to}`))
.on('failed', (job, err) => webhookLogger.warn(`failed(${err}) ${getJobInfo(job)} to=${job.data.to}`)) .on('failed', (job, err) => webhookLogger.warn(`failed(${err}) ${getJobInfo(job)} to=${job.data.to}`))
.on('error', (job: any, err: Error) => webhookLogger.error(`error ${err}`, { job, e: renderError(err) })) .on('error', (job: any, err: Error) => webhookLogger.error(`error ${err}`))
.on('stalled', (job) => webhookLogger.warn(`stalled ${getJobInfo(job)} to=${job.data.to}`)); .on('stalled', (job) => webhookLogger.warn(`stalled ${getJobInfo(job)} to=${job.data.to}`));
export function deliver(user: ThinUser, content: unknown, to: string | null) { export function deliver(user: ThinUser, content: unknown, to: string | null) {

View file

@ -74,13 +74,7 @@ export async function createNote(value: string | IObject, resolver: Resolver, si
const err = validateNote(object); const err = validateNote(object);
if (err) { if (err) {
apLogger.error(`${err.message}`, { apLogger.error(`${err.message}`);
resolver: {
history: resolver.getHistory(),
},
value,
object,
});
throw new Error('invalid note'); throw new Error('invalid note');
} }

View file

@ -82,15 +82,7 @@ export default async (endpoint: string, user: ILocalUser | null | undefined, tok
if (e instanceof ApiError) { if (e instanceof ApiError) {
throw e; throw e;
} else { } else {
apiLogger.error(`Internal error occurred in ${ep.name}: ${e.message}`, { apiLogger.error(`Internal error occurred in ${ep.name}: ${e.message}`);
ep: ep.name,
ps: data,
e: {
message: e.message,
code: e.name,
stack: e.stack,
},
});
throw new ApiError('INTERNAL_ERROR', { throw new ApiError('INTERNAL_ERROR', {
e: { e: {
message: e.message, message: e.message,

View file

@ -60,10 +60,7 @@ export async function uploadFromUrl({
logger.succ(`Got: ${driveFile.id}`); logger.succ(`Got: ${driveFile.id}`);
return driveFile; return driveFile;
} catch (e) { } catch (e) {
logger.error(`Failed to create drive file: ${e}`, { logger.error(`Failed to create drive file: ${e}`);
url,
e,
});
throw e; throw e;
} finally { } finally {
cleanup(); cleanup();

View file

@ -84,7 +84,7 @@ export default class Logger {
* @param important Whether to highlight this message as especially important. * @param important Whether to highlight this message as especially important.
* @param subDomains Names of sub-loggers to be added. * @param subDomains Names of sub-loggers to be added.
*/ */
private log(level: Level, message: string, data?: Record<string, any> | null, important = false, subDomains: Domain[] = [], _store = true): void { private log(level: Level, message: string, important = false, subDomains: Domain[] = [], _store = true): void {
if (envOption.quiet) return; if (envOption.quiet) return;
const store = _store && this.store; const store = _store && this.store;
@ -94,7 +94,7 @@ export default class Logger {
// If this logger has a parent logger, delegate the actual logging to it, // If this logger has a parent logger, delegate the actual logging to it,
// so the parent domain(s) will be logged properly. // so the parent domain(s) will be logged properly.
if (this.parentLogger) { if (this.parentLogger) {
this.parentLogger.log(level, message, data, important, [this.domain].concat(subDomains), store); this.parentLogger.log(level, message, important, [this.domain].concat(subDomains), store);
return; return;
} }
@ -154,17 +154,15 @@ export default class Logger {
* Log an error message. * Log an error message.
* Use in situations where execution cannot be continued. * Use in situations where execution cannot be continued.
* @param err Error or string containing an error message * @param err Error or string containing an error message
* @param data Data relating to the error
* @param important Whether this error is important * @param important Whether this error is important
*/ */
public error(err: string | Error, data: Record<string, any> = {}, important = false): void { public error(err: string | Error, important = false): void {
if (err instanceof Error) { if (err instanceof Error) {
data.e = err; this.log(LEVELS.error, err.toString(), important);
this.log(LEVELS.error, err.toString(), data, important);
} else if (typeof err === 'object') { } else if (typeof err === 'object') {
this.log(LEVELS.error, `${(err as any).message || (err as any).name || err}`, data, important); this.log(LEVELS.error, `${(err as any).message || (err as any).name || err}`, important);
} else { } else {
this.log(LEVELS.error, `${err}`, data, important); this.log(LEVELS.error, `${err}`, important);
} }
} }
@ -172,21 +170,19 @@ export default class Logger {
* Log a warning message. * Log a warning message.
* Use in situations where execution can continue but needs to be improved. * Use in situations where execution can continue but needs to be improved.
* @param message Warning message * @param message Warning message
* @param data Data relating to the warning
* @param important Whether this warning is important * @param important Whether this warning is important
*/ */
public warn(message: string, data?: Record<string, any> | null, important = false): void { public warn(message: string, important = false): void {
this.log(LEVELS.warning, message, data, important); this.log(LEVELS.warning, message, important);
} }
/** /**
* Log a success message. * Log a success message.
* Use in situations where something has been successfully done. * Use in situations where something has been successfully done.
* @param message Success message * @param message Success message
* @param data Data relating to the success
* @param important Whether this success message is important * @param important Whether this success message is important
*/ */
public succ(message: string, data?: Record<string, any> | null, important = false): void { public succ(message: string, important = false): void {
this.log(LEVELS.success, message, important); this.log(LEVELS.success, message, important);
} }
@ -194,21 +190,19 @@ export default class Logger {
* Log a debug message. * Log a debug message.
* Use for debugging (information needed by developers but not required by users). * Use for debugging (information needed by developers but not required by users).
* @param message Debug message * @param message Debug message
* @param data Data relating to the debug message
* @param important Whether this debug message is important * @param important Whether this debug message is important
*/ */
public debug(message: string, data?: Record<string, any> | null, important = false): void { public debug(message: string, important = false): void {
this.log(LEVELS.debug, message, data, important); this.log(LEVELS.debug, message, important);
} }
/** /**
* Log an informational message. * Log an informational message.
* Use when something needs to be logged but doesn't fit into other levels. * Use when something needs to be logged but doesn't fit into other levels.
* @param message Info message * @param message Info message
* @param data Data relating to the info message
* @param important Whether this info message is important * @param important Whether this info message is important
*/ */
public info(message: string, data?: Record<string, any> | null, important = false): void { public info(message: string, important = false): void {
this.log(LEVELS.info, message, data, important); this.log(LEVELS.info, message, important);
} }
} }