2022-09-18 23:07:41 +09:00
|
|
|
import { Inject, Injectable } from '@nestjs/common';
|
|
|
|
import * as SyslogPro from 'syslog-pro';
|
|
|
|
import { DI } from '@/di-symbols.js';
|
2022-09-21 05:33:11 +09:00
|
|
|
import type { Config } from '@/config.js';
|
2022-09-18 23:07:41 +09:00
|
|
|
import Logger from '@/logger.js';
|
2022-12-04 15:03:09 +09:00
|
|
|
import { bindThis } from '@/decorators.js';
|
2022-09-18 23:07:41 +09:00
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class LoggerService {
|
2022-09-19 03:11:50 +09:00
|
|
|
private syslogClient;
|
2022-09-18 23:07:41 +09:00
|
|
|
|
|
|
|
constructor(
|
|
|
|
@Inject(DI.config)
|
|
|
|
private config: Config,
|
|
|
|
) {
|
|
|
|
if (this.config.syslog) {
|
2022-09-19 03:11:50 +09:00
|
|
|
this.syslogClient = new SyslogPro.RFC5424({
|
2022-09-18 23:07:41 +09:00
|
|
|
applacationName: 'Misskey',
|
|
|
|
timestamp: true,
|
|
|
|
encludeStructuredData: true,
|
|
|
|
color: true,
|
|
|
|
extendedColor: true,
|
|
|
|
server: {
|
|
|
|
target: config.syslog.host,
|
|
|
|
port: config.syslog.port,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-04 15:03:09 +09:00
|
|
|
@bindThis
|
2022-09-18 23:07:41 +09:00
|
|
|
public getLogger(domain: string, color?: string | undefined, store?: boolean) {
|
2022-09-19 03:11:50 +09:00
|
|
|
return new Logger(domain, color, store, this.syslogClient);
|
2022-09-18 23:07:41 +09:00
|
|
|
}
|
|
|
|
}
|