UNPKG

14.3 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.default = void 0;
7
8var _os = _interopRequireDefault(require("os"));
9
10var _stringUtils = require("./stringUtils");
11
12var _InfluxDBClient = _interopRequireDefault(require("./InfluxDBClient"));
13
14var _S3Logger = _interopRequireDefault(require("./S3Logger"));
15
16function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
18function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
19
20function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
21
22const ORDERED_LOG_LEVELS = ['debug', 'info', 'warn', 'error'];
23
24const HOSTNAME = _os.default.hostname();
25
26class System {
27 static async setConfig(systemConfig) {
28 System._config = _objectSpread({
29 // det default values
30 logLevel: 'info',
31 system: 'none'
32 }, systemConfig);
33 System.activeLogLevels = ORDERED_LOG_LEVELS.slice(ORDERED_LOG_LEVELS.indexOf(System._config.logLevel));
34 System.runId = `${(0, _stringUtils.pad)(Math.round((Date.now() - new Date(new Date().getFullYear(), 0, 1).getTime()) / 1000), 8)}-${(0, _stringUtils.pad)(Math.floor(Math.random() * 10000), 4)}`; // seconds since start of year
35 // init InfluxDBClient
36
37 System.influxDBClients = (System._config.influxDBs || []).map(idbConfig => new _InfluxDBClient.default(idbConfig.host, idbConfig.dbName, idbConfig.statNameMode, idbConfig.flushIntervalMS, {
38 system: System._config.system,
39 component: System._config.component,
40 hostname: HOSTNAME,
41 env: System._config.env
42 }));
43 System._s3logger = new _S3Logger.default({
44 noHTTPS: (System._config.s3Logging || {}).noHTTPS,
45 host: (System._config.s3Logging || {}).host,
46 dataFieldsToPromote: (System._config.s3Logging || {}).dataFieldsToPromote,
47 dataFieldsToRemove: (System._config.s3Logging || {}).dataFieldsToRemove,
48 systemMeta: {
49 hostname: HOSTNAME,
50 system: System._config.system,
51 component: System._config.component,
52 env: System._config.env,
53 run_id: System.runId,
54 ver: System._config.ver
55 }
56 }); // track 'start'
57
58 await Promise.all(System.influxDBClients.map(idbClient => idbClient.trackMetrics([{
59 statName: 'appStart',
60 dims: {
61 module: 'System'
62 },
63 value: 1
64 }])));
65 }
66
67 static getConfig() {
68 if (!System._config) {
69 throw new Error('System config accessed before set');
70 }
71
72 return System._config;
73 }
74
75 static setAWSClient(awsClient) {
76 System._awsClient = awsClient;
77 }
78
79 static queueLogRecord(logObj) {
80 if (System._s3logger) System._s3logger.queueLogRecord(logObj);
81 }
82
83 static async flush() {
84 await Promise.all([(async () => {
85 if (System._s3logger) await System._s3logger.flushLogs();
86 })(), ...System.influxDBClients.map(idbClient => (async () => {
87 await idbClient.trackMetrics([{
88 statName: 'appEnd',
89 dims: {
90 module: 'System'
91 },
92 value: 1
93 }]);
94 await idbClient.flushMetrics();
95 })())]);
96 }
97
98}
99
100exports.default = System;
101
102_defineProperty(System, "activeLogLevels", void 0);
103
104_defineProperty(System, "runId", void 0);
105
106_defineProperty(System, "influxDBClients", void 0);
107
108_defineProperty(System, "_s3logger", void 0);
109
110_defineProperty(System, "_config", void 0);
111
112_defineProperty(System, "_awsClient", void 0);
113//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/System.js"],"names":["ORDERED_LOG_LEVELS","HOSTNAME","os","hostname","System","setConfig","systemConfig","_config","logLevel","system","activeLogLevels","slice","indexOf","runId","Math","round","Date","now","getFullYear","getTime","floor","random","influxDBClients","influxDBs","map","idbConfig","InfluxDBClient","host","dbName","statNameMode","flushIntervalMS","component","env","_s3logger","S3Logger","noHTTPS","s3Logging","dataFieldsToPromote","dataFieldsToRemove","systemMeta","run_id","ver","Promise","all","idbClient","trackMetrics","statName","dims","module","value","getConfig","Error","setAWSClient","awsClient","_awsClient","queueLogRecord","logObj","flush","flushLogs","flushMetrics"],"mappings":"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","sourcesContent":["// @flow\n\n// NOTE: dont use Module here, this class is used by Module\nimport os from 'os'\n\nimport type AWSClient from './AWSClient'\nimport type { StatNameMode } from './InfluxDBClient'\n\nimport { pad } from './stringUtils'\nimport InfluxDBClient from './InfluxDBClient'\nimport S3Logger from './S3Logger'\n\nconst ORDERED_LOG_LEVELS = ['debug', 'info', 'warn', 'error']\nconst HOSTNAME = os.hostname()\n\ntype SystemConfig = {|\n  env: string,\n  influxDBs?: ?Array<{\n    statNameMode: StatNameMode,\n    host: string,\n    dbName: string,\n    flushIntervalMS?: ?number,\n  }>,\n  lifesignIntervalMS?: ?number,\n  logLevel?: 'debug' | 'info' | 'warn' | 'error',\n  aws: {\n    accountId: string,\n    defaultRegion: string,\n    profile?: ?string,\n  },\n  system: string,\n  component: string,\n  ver: string,\n  s3Logging?: ?{\n    noHTTPS?: boolean,\n    host: string,\n    dataFieldsToPromote?: ?{ [id: string]: string }, \n    dataFieldsToRemove?: ?Array<string>, \n  },\n  trackVitalsIntervalMS?: ?number,\n  // trackingSchema?: ?number,\n|}\n\n\nexport default class System {\n\n  static activeLogLevels: Array<string>\n  static runId: string\n  static influxDBClients: Array<InfluxDBClient>\n\n  static _s3logger: ?S3Logger\n  static _config: SystemConfig\n  static _awsClient: AWSClient\n \n  \n  static async setConfig(systemConfig: SystemConfig) {\n    System._config = {\n\n      // det default values\n      logLevel: 'info',\n      system: 'none',\n\n      ...systemConfig,\n\n    }\n    System.activeLogLevels = ORDERED_LOG_LEVELS.slice(ORDERED_LOG_LEVELS.indexOf(System._config.logLevel))\n    System.runId = `${pad(Math.round((Date.now() - new Date((new Date()).getFullYear(), 0, 1).getTime()) / 1000), 8)}-${pad(Math.floor(Math.random() * 10000), 4)}` // seconds since start of year\n\n    // init InfluxDBClient\n    System.influxDBClients = (System._config.influxDBs || []).map(idbConfig => new InfluxDBClient(\n      idbConfig.host, \n      idbConfig.dbName,\n      idbConfig.statNameMode,\n      idbConfig.flushIntervalMS,\n      {\n        system: System._config.system,\n        component: System._config.component,\n        hostname: HOSTNAME,\n        env: System._config.env,\n      })\n    )\n\n    System._s3logger = new S3Logger({\n      noHTTPS: (System._config.s3Logging || {}).noHTTPS,\n      host: (System._config.s3Logging || {}).host,\n      dataFieldsToPromote: (System._config.s3Logging || {}).dataFieldsToPromote,\n      dataFieldsToRemove: (System._config.s3Logging || {}).dataFieldsToRemove,\n      systemMeta: {\n        hostname: HOSTNAME,\n        system: System._config.system,\n        component: System._config.component,\n        env: System._config.env,\n        run_id: System.runId,\n        ver: System._config.ver,\n      },\n    })\n\n    // track 'start'\n    await Promise.all(System.influxDBClients.map(idbClient => idbClient.trackMetrics([{\n      statName: 'appStart',\n      dims: {\n        module: 'System',\n      },\n      value: 1,\n    }])))\n    \n  }\n\n  static getConfig(): SystemConfig {\n    if (!System._config) {\n      throw new Error('System config accessed before set')\n    }\n    return System._config\n  }\n\n\n  static setAWSClient(awsClient: AWSClient) {\n    System._awsClient = awsClient\n  }\n\n  static queueLogRecord(logObj: Object): void {\n    if (System._s3logger)\n      System._s3logger.queueLogRecord(logObj)\n  }\n\n  static async flush(): Promise<void> {\n    await Promise.all([\n\n      (async () => {\n        if (System._s3logger)\n          await System._s3logger.flushLogs()\n      })(),\n\n      ...System.influxDBClients.map(idbClient => (async () => {\n        await idbClient.trackMetrics([{\n          statName: 'appEnd',\n          dims: { module: 'System' },\n          value: 1,\n        }])\n\n        await idbClient.flushMetrics()\n      })()),\n\n    ])\n  }\n}\n"]}
\No newline at end of file