1 | const expressWinston = require('express-winston');
|
2 | const uuidv1 = require('uuid/v1');
|
3 | const { lw } = require('@hatsa/log/transports/googlecloud');
|
4 |
|
5 | const createRequestLogger = ({logger}) => expressWinston.logger({
|
6 | winstonInstance: logger,
|
7 | expressFormat: true,
|
8 | metaField: null,
|
9 | meta: true,
|
10 | ignoreRoute: req => {
|
11 |
|
12 | if (req.path.startsWith('/assets/'))
|
13 | return true;
|
14 |
|
15 | if (req.path.startsWith('/static/'))
|
16 | return true;
|
17 |
|
18 | return false;
|
19 | }
|
20 | });
|
21 |
|
22 | const createErrorLogger = ({logger}) => expressWinston.errorLogger({
|
23 | winstonInstance: logger,
|
24 | metaField: null,
|
25 |
|
26 |
|
27 | msg: "{{err.message}}",
|
28 |
|
29 | level: 'error'
|
30 | });
|
31 |
|
32 | const loggerMiddleware = ({logger}) => (req, res, next) => {
|
33 |
|
34 | const traceHeader = req.get('x-cloud-trace-context') || '';
|
35 | const traceId = traceHeader.includes('/') ? traceHeader.split('/')[0] : undefined;
|
36 |
|
37 | const aeReqId = req.get('x-appengine-request-log-id');
|
38 | const cfReqId = req.get('function-execution-id');
|
39 | const reqId = aeReqId || cfReqId || uuidv1();
|
40 |
|
41 | const meta = { labels: { execution_id: reqId } };
|
42 |
|
43 |
|
44 | if (traceId)
|
45 | meta['logging.googleapis.com/trace'] = `projects/hatsa-tst-01/traces/${traceId}`;
|
46 |
|
47 | req.log = logger.child(meta);
|
48 |
|
49 | next();
|
50 |
|
51 | |
52 |
|
53 |
|
54 |
|
55 |
|
56 |
|
57 |
|
58 |
|
59 |
|
60 |
|
61 |
|
62 |
|
63 |
|
64 | };
|
65 |
|
66 | const genStackdriverLogTraceMw = logger => lw.express.makeMiddleware(logger);
|
67 |
|
68 | module.exports = {
|
69 | createRequestLogger,
|
70 | createErrorLogger,
|
71 | loggerMiddleware,
|
72 | genStackdriverLogTraceMw
|
73 | }; |
\ | No newline at end of file |