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
JavaScript
;
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"}