UNPKG

metaapi.cloud-sdk

Version:

SDK for MetaApi, a professional cloud forex API which includes MetaTrader REST API and MetaTrader websocket API. Supports both MetaTrader 5 (MT5) and MetaTrader 4 (MT4). CopyFactory copy trading API included. (https://metaapi.cloud)

103 lines (102 loc) 11.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _log4jsapi = /*#__PURE__*/ _interop_require_default(require("@log4js-node/log4js-api")); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } let log4jsEnabled = false; /** * Manages loggers of the entire sdk */ let LoggerManager = class LoggerManager { /** * Enables using Log4js logger with extended log levels for debugging instead of * console.* functions. Note that log4js configuration performed by the user. */ static useLog4js() { log4jsEnabled = true; } /** * Creates a new logger for specified category * @param {String} category Logger category * @return {Logger} Created logger */ static getLogger(category) { if (log4jsEnabled) { const logger = _log4jsapi.default.getLogger(category); if (logger._log) { const originalLog = logger._log.bind(logger); logger._log = function(level, data) { if (typeof data[0] === "function") { data[0] = data[0](); } originalLog(level, data); }; } return logger; } else { return new NativeLogger(); } } }; /** * Native logger that uses console.* functions */ let NativeLogger = class NativeLogger { /** * Supposed to log messages of trace level * @param {String|Function} message Message or message generator to log * @param {*[]} args Additional args to message */ trace(message, ...args) { // this logger does not print trace messages } /** * Supposed to log messages of debug level * @param {String|Function} message Message or message generator to log * @param {*[]} args Additional args to message */ debug(message, ...args) { // this logger does not print debug messages } /** * Prints a message with console.log * @param {String|Function} message Message or message generator to log * @param {*[]} args Additional args to message */ info(message, ...args) { this._log("log", message, args); } /** * Prints a message with console.warn * @param {String|Function} message Message or message generator to log * @param {*[]} args Additional args to message */ warn(message, ...args) { this._log("warn", message, args); } /** * Prints a message with console.error * @param {String|Function} message Message or message generator to log * @param {*[]} args Additional args to message */ error(message, ...args) { this._log("error", message, args); } /** * Prints a message with console.error * @param {String|Function} message Message or message generator to log * @param {*[]} args Additional args to message */ fatal(message, ...args) { this._log("error", message, args); } _log(level, message, args) { if (typeof message === "function") { message = message(); } console[level](`[${new Date().toISOString()}] ${message}`, ...args); } }; const _default = LoggerManager; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["<anon>"],"sourcesContent":["'use strict';\n\nimport log4js from '@log4js-node/log4js-api';\n\nlet log4jsEnabled = false;\n\n/**\n * Manages loggers of the entire sdk\n */\nclass LoggerManager {\n\n  /**\n   * Enables using Log4js logger with extended log levels for debugging instead of\n   * console.* functions. Note that log4js configuration performed by the user.\n   */\n  static useLog4js() {\n    log4jsEnabled = true;\n  }\n\n  /**\n   * Creates a new logger for specified category\n   * @param {String} category Logger category\n   * @return {Logger} Created logger\n   */\n  static getLogger(category): Logger {\n    if (log4jsEnabled) {\n      const logger = log4js.getLogger(category);\n      if (logger._log) {\n        const originalLog = logger._log.bind(logger);\n        logger._log = function (level, data) {\n          if (typeof data[0] === 'function') {\n            data[0] = data[0]();\n          }\n          originalLog(level, data);\n        };\n      }\n      return logger;\n    } else {\n      return new NativeLogger();\n    }\n  }\n}\n\n/**\n * Logger interface\n */\nexport interface Logger {\n  \n  /**\n   * Supposed to log messages of trace level\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  trace(message: string | (() => string), ...args: any[]): void;\n\n  /**\n   * Supposed to log messages of debug level\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  debug(message: string | (() => string), ...args: any[]): void;\n\n  /**\n   * Prints a message with console.log\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  info(message: string | (() => string), ...args: any[]): void;\n\n  /**\n   * Prints a message with console.warn\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  warn(message: string | (() => string), ...args: any[]): void;\n\n  /**\n   * Prints a message with console.error\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  error(message: string | (() => string), ...args: any[]): void;\n\n  /**\n   * Prints a message with console.error\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  fatal(message: string | (() => string), ...args: any[]): void;\n}\n\n/**\n * Native logger that uses console.* functions\n */\nclass NativeLogger {\n\n  /**\n   * Supposed to log messages of trace level\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  trace(message, ...args) {\n    // this logger does not print trace messages\n  }\n\n  /**\n   * Supposed to log messages of debug level\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  debug(message, ...args) {\n    // this logger does not print debug messages\n  }\n\n  /**\n   * Prints a message with console.log\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  info(message, ...args) {\n    this._log('log', message, args);\n  }\n\n  /**\n   * Prints a message with console.warn\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  warn(message, ...args) {\n    this._log('warn', message, args);\n  }\n\n  /**\n   * Prints a message with console.error\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  error(message, ...args) {\n    this._log('error', message, args);\n  }\n\n  /**\n   * Prints a message with console.error\n   * @param {String|Function} message Message or message generator to log\n   * @param {*[]} args Additional args to message\n   */\n  fatal(message, ...args) {\n    this._log('error', message, args);\n  }\n\n  _log(level, message, args) {\n    if (typeof message === 'function') {\n      message = message();\n    }\n    console[level](`[${new Date().toISOString()}] ${message}`, ...args);\n  }\n}\n\nexport default LoggerManager;"],"names":["log4jsEnabled","LoggerManager","useLog4js","getLogger","category","logger","log4js","_log","originalLog","bind","level","data","NativeLogger","trace","message","args","debug","info","warn","error","fatal","console","Date","toISOString"],"mappings":"AAAA;;;;+BA8JA;;;eAAA;;;kEA5JmB;;;;;;AAEnB,IAAIA,gBAAgB;AAEpB;;CAEC,GACD,IAAA,AAAMC,gBAAN,MAAMA;IAEJ;;;GAGC,GACD,OAAOC,YAAY;QACjBF,gBAAgB;IAClB;IAEA;;;;GAIC,GACD,OAAOG,UAAUC,QAAQ,EAAU;QACjC,IAAIJ,eAAe;YACjB,MAAMK,SAASC,kBAAM,CAACH,SAAS,CAACC;YAChC,IAAIC,OAAOE,IAAI,EAAE;gBACf,MAAMC,cAAcH,OAAOE,IAAI,CAACE,IAAI,CAACJ;gBACrCA,OAAOE,IAAI,GAAG,SAAUG,KAAK,EAAEC,IAAI;oBACjC,IAAI,OAAOA,IAAI,CAAC,EAAE,KAAK,YAAY;wBACjCA,IAAI,CAAC,EAAE,GAAGA,IAAI,CAAC,EAAE;oBACnB;oBACAH,YAAYE,OAAOC;gBACrB;YACF;YACA,OAAON;QACT,OAAO;YACL,OAAO,IAAIO;QACb;IACF;AACF;AAkDA;;CAEC,GACD,IAAA,AAAMA,eAAN,MAAMA;IAEJ;;;;GAIC,GACDC,MAAMC,OAAO,EAAE,GAAGC,IAAI,EAAE;IACtB,4CAA4C;IAC9C;IAEA;;;;GAIC,GACDC,MAAMF,OAAO,EAAE,GAAGC,IAAI,EAAE;IACtB,4CAA4C;IAC9C;IAEA;;;;GAIC,GACDE,KAAKH,OAAO,EAAE,GAAGC,IAAI,EAAE;QACrB,IAAI,CAACR,IAAI,CAAC,OAAOO,SAASC;IAC5B;IAEA;;;;GAIC,GACDG,KAAKJ,OAAO,EAAE,GAAGC,IAAI,EAAE;QACrB,IAAI,CAACR,IAAI,CAAC,QAAQO,SAASC;IAC7B;IAEA;;;;GAIC,GACDI,MAAML,OAAO,EAAE,GAAGC,IAAI,EAAE;QACtB,IAAI,CAACR,IAAI,CAAC,SAASO,SAASC;IAC9B;IAEA;;;;GAIC,GACDK,MAAMN,OAAO,EAAE,GAAGC,IAAI,EAAE;QACtB,IAAI,CAACR,IAAI,CAAC,SAASO,SAASC;IAC9B;IAEAR,KAAKG,KAAK,EAAEI,OAAO,EAAEC,IAAI,EAAE;QACzB,IAAI,OAAOD,YAAY,YAAY;YACjCA,UAAUA;QACZ;QACAO,OAAO,CAACX,MAAM,CAAC,CAAC,CAAC,EAAE,IAAIY,OAAOC,WAAW,GAAG,EAAE,EAAET,QAAQ,CAAC,KAAKC;IAChE;AACF;MAEA,WAAed"}