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