Commit | Line | Data |
---|---|---|
6c1761d4 | 1 | import type { Format } from 'logform'; |
8387cd31 | 2 | import { Logger, createLogger, format, transport } from 'winston'; |
8387cd31 | 3 | import DailyRotateFile from 'winston-daily-rotate-file'; |
0d8140bd | 4 | import TransportType from 'winston/lib/winston/transports/index.js'; |
8114d10e JB |
5 | |
6 | import Configuration from './Configuration'; | |
7ec46a9a | 7 | import Utils from './Utils'; |
7ec46a9a | 8 | |
6bf6769e | 9 | let transports: transport[]; |
d42ee3c9 | 10 | if (Configuration.getLogRotate() === true) { |
6bf6769e | 11 | const logMaxFiles = Configuration.getLogMaxFiles(); |
9988696d | 12 | const logMaxSize = Configuration.getLogMaxSize(); |
6bf6769e | 13 | transports = [ |
e7aeea18 JB |
14 | new DailyRotateFile({ |
15 | filename: Utils.insertAt( | |
16 | Configuration.getLogErrorFile(), | |
17 | '-%DATE%', | |
18 | Configuration.getLogErrorFile().indexOf('.log') | |
19 | ), | |
20 | level: 'error', | |
9988696d JB |
21 | ...(logMaxFiles && { maxFiles: logMaxFiles }), |
22 | ...(logMaxSize && { maxSize: logMaxSize }), | |
e7aeea18 JB |
23 | }), |
24 | new DailyRotateFile({ | |
25 | filename: Utils.insertAt( | |
26 | Configuration.getLogFile(), | |
27 | '-%DATE%', | |
28 | Configuration.getLogFile().indexOf('.log') | |
29 | ), | |
9988696d JB |
30 | ...(logMaxFiles && { maxFiles: logMaxFiles }), |
31 | ...(logMaxSize && { maxSize: logMaxSize }), | |
e7aeea18 | 32 | }), |
6bf6769e JB |
33 | ]; |
34 | } else { | |
35 | transports = [ | |
0d8140bd JB |
36 | new TransportType.File({ filename: Configuration.getLogErrorFile(), level: 'error' }), |
37 | new TransportType.File({ filename: Configuration.getLogFile() }), | |
6bf6769e JB |
38 | ]; |
39 | } | |
7dde0b73 | 40 | |
9f2e3130 JB |
41 | const logger: Logger = createLogger({ |
42 | level: Configuration.getLogLevel(), | |
c0f4be74 | 43 | format: format.combine(format.splat(), (format[Configuration.getLogFormat()] as () => Format)()), |
17e9e8ce | 44 | transports, |
9f2e3130 | 45 | }); |
7dde0b73 JB |
46 | |
47 | // | |
48 | // If enabled, log to the `console` with the format: | |
49 | // `${info.level}: ${info.message} JSON.stringify({ ...rest }) ` | |
50 | // | |
7ec46a9a | 51 | if (Configuration.getLogConsole()) { |
e7aeea18 | 52 | logger.add( |
0d8140bd | 53 | new TransportType.Console({ |
c0f4be74 JB |
54 | format: format.combine( |
55 | format.splat(), | |
56 | (format[Configuration.getLogFormat()] as () => Format)() | |
57 | ), | |
e7aeea18 JB |
58 | }) |
59 | ); | |
7dde0b73 JB |
60 | } |
61 | ||
9f2e3130 | 62 | export default logger; |