1 | "use strict";
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 |
|
18 | var _a, _b, _c, _d;
|
19 | Object.defineProperty(exports, "__esModule", { value: true });
|
20 | exports.isTracerEnabled = exports.trace = exports.log = exports.setLoggerVerbosity = exports.setLogger = exports.getLogger = void 0;
|
21 | const constants_1 = require("./constants");
|
22 | const DEFAULT_LOGGER = {
|
23 | error: (message, ...optionalParams) => {
|
24 | console.error('E ' + message, ...optionalParams);
|
25 | },
|
26 | info: (message, ...optionalParams) => {
|
27 | console.error('I ' + message, ...optionalParams);
|
28 | },
|
29 | debug: (message, ...optionalParams) => {
|
30 | console.error('D ' + message, ...optionalParams);
|
31 | },
|
32 | };
|
33 | let _logger = DEFAULT_LOGGER;
|
34 | let _logVerbosity = constants_1.LogVerbosity.ERROR;
|
35 | const verbosityString = (_b = (_a = process.env.GRPC_NODE_VERBOSITY) !== null && _a !== void 0 ? _a : process.env.GRPC_VERBOSITY) !== null && _b !== void 0 ? _b : '';
|
36 | switch (verbosityString.toUpperCase()) {
|
37 | case 'DEBUG':
|
38 | _logVerbosity = constants_1.LogVerbosity.DEBUG;
|
39 | break;
|
40 | case 'INFO':
|
41 | _logVerbosity = constants_1.LogVerbosity.INFO;
|
42 | break;
|
43 | case 'ERROR':
|
44 | _logVerbosity = constants_1.LogVerbosity.ERROR;
|
45 | break;
|
46 | case 'NONE':
|
47 | _logVerbosity = constants_1.LogVerbosity.NONE;
|
48 | break;
|
49 | default:
|
50 |
|
51 | }
|
52 | exports.getLogger = () => {
|
53 | return _logger;
|
54 | };
|
55 | exports.setLogger = (logger) => {
|
56 | _logger = logger;
|
57 | };
|
58 | exports.setLoggerVerbosity = (verbosity) => {
|
59 | _logVerbosity = verbosity;
|
60 | };
|
61 |
|
62 | exports.log = (severity, ...args) => {
|
63 | let logFunction;
|
64 | if (severity >= _logVerbosity) {
|
65 | switch (severity) {
|
66 | case constants_1.LogVerbosity.DEBUG:
|
67 | logFunction = _logger.debug;
|
68 | break;
|
69 | case constants_1.LogVerbosity.INFO:
|
70 | logFunction = _logger.info;
|
71 | break;
|
72 | case constants_1.LogVerbosity.ERROR:
|
73 | logFunction = _logger.error;
|
74 | break;
|
75 | }
|
76 | |
77 |
|
78 | if (!logFunction) {
|
79 | logFunction = _logger.error;
|
80 | }
|
81 | if (logFunction) {
|
82 | logFunction.bind(_logger)(...args);
|
83 | }
|
84 | }
|
85 | };
|
86 | const tracersString = (_d = (_c = process.env.GRPC_NODE_TRACE) !== null && _c !== void 0 ? _c : process.env.GRPC_TRACE) !== null && _d !== void 0 ? _d : '';
|
87 | const enabledTracers = new Set();
|
88 | const disabledTracers = new Set();
|
89 | for (const tracerName of tracersString.split(',')) {
|
90 | if (tracerName.startsWith('-')) {
|
91 | disabledTracers.add(tracerName.substring(1));
|
92 | }
|
93 | else {
|
94 | enabledTracers.add(tracerName);
|
95 | }
|
96 | }
|
97 | const allEnabled = enabledTracers.has('all');
|
98 | function trace(severity, tracer, text) {
|
99 | if (isTracerEnabled(tracer)) {
|
100 | exports.log(severity, new Date().toISOString() + ' | ' + tracer + ' | ' + text);
|
101 | }
|
102 | }
|
103 | exports.trace = trace;
|
104 | function isTracerEnabled(tracer) {
|
105 | return !disabledTracers.has(tracer) &&
|
106 | (allEnabled || enabledTracers.has(tracer));
|
107 | }
|
108 | exports.isTracerEnabled = isTracerEnabled;
|
109 |
|
\ | No newline at end of file |