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)
358 lines (357 loc) • 41.1 kB
JavaScript
'use strict';
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
try {
var info = gen[key](arg);
var value = info.value;
} catch (error) {
reject(error);
return;
}
if (info.done) {
resolve(value);
} else {
Promise.resolve(value).then(_next, _throw);
}
}
function _async_to_generator(fn) {
return function() {
var self = this, args = arguments;
return new Promise(function(resolve, reject) {
var gen = fn.apply(self, args);
function _next(value) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
}
function _throw(err) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
}
_next(undefined);
});
};
}
import HistoryStorage from './historyStorage';
import HistoryDatabase from './historyDatabase/index';
import { AVLTree } from '../binary-search-tree/avltree';
import LoggerManager from '../logger';
let MemoryHistoryStorage = class MemoryHistoryStorage extends HistoryStorage {
/**
* Initializes the storage and loads required data from a persistent storage
* @param {string} accountId account id
* @param {string} [application] application. Default is MetaApi
*/ initialize(accountId, application = 'MetaApi') {
var _this = this, _superprop_get_initialize = ()=>super.initialize;
return _async_to_generator(function*() {
yield _superprop_get_initialize().call(_this, accountId, application);
let { deals, historyOrders } = yield _this._historyDatabase.loadHistory(accountId, application);
for (let deal of deals){
yield _this._addDeal(deal, true);
}
for (let historyOrder of historyOrders){
yield _this._addHistoryOrder(historyOrder, true);
}
})();
}
/**
* Resets the storage. Intended for use in tests
* @returns {Promise} promise when the history is removed
*/ clear() {
var _this = this;
return _async_to_generator(function*() {
_this._reset();
yield _this._historyDatabase.clear(_this._accountId, _this._application);
})();
}
/**
* Returns the time of the last history order record stored in the history storage
* @param {Number} [instanceNumber] index of an account instance connected
* @returns {Date} the time of the last history order record stored in the history storage
*/ lastHistoryOrderTime(instanceNumber) {
return this._maxHistoryOrderTime;
}
/**
* Returns the time of the last history deal record stored in the history storage
* @param {Number} [instanceNumber] index of an account instance connected
* @returns {Date} the time of the last history deal record stored in the history storage
*/ lastDealTime(instanceNumber) {
return this._maxDealTime;
}
/**
* Invoked when a new MetaTrader history order is added
* @param {String} instanceIndex index of an account instance connected
* @param {MetatraderOrder} historyOrder new MetaTrader history order
*/ onHistoryOrderAdded(instanceIndex, historyOrder) {
var _this = this;
return _async_to_generator(function*() {
yield _this._addHistoryOrder(historyOrder);
})();
}
/**
* Invoked when a new MetaTrader history deal is added
* @param {String} instanceIndex index of an account instance connected
* @param {MetatraderDeal} deal new MetaTrader history deal
*/ onDealAdded(instanceIndex, deal) {
var _this = this;
return _async_to_generator(function*() {
yield _this._addDeal(deal);
})();
}
/**
* Returns all deals
* @returns {Array<MetatraderDeal>} all deals
*/ get deals() {
return this.getDealsByTimeRange(new Date(0), new Date(8640000000000000));
}
/**
* Returns deals by ticket id
* @param {string} id ticket id
* @returns {Array<MetatraderDeal>} deals found
*/ getDealsByTicket(id) {
let deals = Object.values(this._dealsByTicket[id] || {});
deals.sort(this._dealsComparator);
return deals;
}
/**
* Returns deals by position id
* @param {string} positionId position id
* @returns {Array<MetatraderDeal>} deals found
*/ getDealsByPosition(positionId) {
let deals = Object.values(this._dealsByPosition[positionId] || {});
deals.sort(this._dealsComparator);
return deals;
}
/**
* Returns deals by time range
* @param startTime start time, inclusive
* @param endTime end time, inclusive
* @returns {Array<MetatraderDeal>} deals found
*/ getDealsByTimeRange(startTime, endTime) {
let deals = this._dealsByTime.betweenBounds({
$gte: {
time: startTime,
id: 0,
entryType: ''
},
$lte: {
time: endTime,
id: Number.MAX_VALUE,
entryType: ''
}
});
return deals;
}
/**
* Returns all history orders
* @returns {Array<MetatraderOrder>} all history orders
*/ get historyOrders() {
return this.getHistoryOrdersByTimeRange(new Date(0), new Date(8640000000000000));
}
/**
* Returns history orders by ticket id
* @param {string} id ticket id
* @returns {Array<MetatraderOrder>} history orders found
*/ getHistoryOrdersByTicket(id) {
let historyOrders = Object.values(this._historyOrdersByTicket[id] || {});
historyOrders.sort(this._historyOrdersComparator);
return historyOrders;
}
/**
* Returns history orders by position id
* @param {string} positionId position id
* @returns {Array<MetatraderOrder>} history orders found
*/ getHistoryOrdersByPosition(positionId) {
let historyOrders = Object.values(this._historyOrdersByPosition[positionId] || {});
historyOrders.sort(this._historyOrdersComparator);
return historyOrders;
}
/**
* Returns history orders by time range
* @param startTime start time, inclusive
* @param endTime end time, inclusive
* @returns {Array<MetatraderOrder>} hisotry orders found
*/ getHistoryOrdersByTimeRange(startTime, endTime) {
let historyOrders = this._historyOrdersByTime.betweenBounds({
$gte: {
doneTime: startTime,
id: 0,
type: '',
state: ''
},
$lte: {
doneTime: endTime,
id: Number.MAX_VALUE,
type: '',
state: ''
}
});
return historyOrders;
}
/**
* Invoked when a synchronization of history deals on a MetaTrader account have finished to indicate progress of an
* initial terminal state synchronization
* @param {String} instanceIndex index of an account instance connected
* @param {String} synchronizationId synchronization request id
* @return {Promise} promise which resolves when the asynchronous event is processed
*/ onDealsSynchronized(instanceIndex, synchronizationId) {
var _this = this, _superprop_get_onDealsSynchronized = ()=>super.onDealsSynchronized;
return _async_to_generator(function*() {
yield _this._flushDatabase();
yield _superprop_get_onDealsSynchronized().call(_this, instanceIndex, synchronizationId);
})();
}
_reset() {
this._orderSynchronizationFinished = {};
this._dealSynchronizationFinished = {};
this._dealsByTicket = {};
this._dealsByPosition = {};
this._historyOrdersByTicket = {};
this._historyOrdersByPosition = {};
// eslint-disable-next-line complexity
this._historyOrdersComparator = (o1, o2)=>{
let timeDiff = (o1.doneTime || new Date(0)).getTime() - (o2.doneTime || new Date(0)).getTime();
if (timeDiff === 0) {
let idDiff = o1.id - o2.id;
if (idDiff === 0) {
if (o1.type > o2.type) {
return 1;
} else if (o1.type < o2.type) {
return -1;
} else {
if (o1.state > o2.state) {
return 1;
} else if (o1.state < o2.state) {
return -1;
} else {
return 0;
}
}
} else {
return idDiff;
}
} else {
return timeDiff;
}
};
this._historyOrdersByTime = new AVLTree({
compareKeys: this._historyOrdersComparator
});
this._dealsComparator = (d1, d2)=>{
let timeDiff = (d1.time || new Date(0)).getTime() - (d2.time || new Date(0)).getTime();
if (timeDiff === 0) {
let idDiff = d1.id - d2.id;
if (idDiff === 0) {
if (d1.entryType > d2.entryType) {
return 1;
} else if (d1.entryType < d2.entryType) {
return -1;
} else {
return 0;
}
} else {
return idDiff;
}
} else {
return timeDiff;
}
};
this._dealsByTime = new AVLTree({
compareKeys: this._dealsComparator
});
this._maxHistoryOrderTime = new Date(0);
this._maxDealTime = new Date(0);
this._newHistoryOrders = [];
this._newDeals = [];
clearTimeout(this._flushTimeout);
delete this._flushTimeout;
}
// eslint-disable-next-line complexity
_addDeal(deal, existing) {
var _this = this;
return _async_to_generator(function*() {
let key = _this._getDealKey(deal);
_this._dealsByTicket[deal.id] = _this._dealsByTicket[deal.id] || {};
let newDeal = !existing && !_this._dealsByTicket[deal.id][key];
_this._dealsByTicket[deal.id][key] = deal;
if (deal.positionId) {
_this._dealsByPosition[deal.positionId] = _this._dealsByPosition[deal.positionId] || {};
_this._dealsByPosition[deal.positionId][key] = deal;
}
_this._dealsByTime.delete(deal);
_this._dealsByTime.insert(deal, deal);
if (deal.time && (!_this._maxDealTime || _this._maxDealTime.getTime() < deal.time.getTime())) {
_this._maxDealTime = deal.time;
}
if (newDeal) {
_this._newDeals.push(deal);
clearTimeout(_this._flushTimeout);
_this._flushTimeout = setTimeout(_this._flushDatabase.bind(_this), 5000);
}
})();
}
_getDealKey(deal) {
return (deal.time || new Date(0)).toISOString() + ':' + deal.id + ':' + deal.entryType;
}
// eslint-disable-next-line complexity
_addHistoryOrder(historyOrder, existing) {
var _this = this;
return _async_to_generator(function*() {
let key = _this._getHistoryOrderKey(historyOrder);
_this._historyOrdersByTicket[historyOrder.id] = _this._historyOrdersByTicket[historyOrder.id] || {};
let newHistoryOrder = !existing && !_this._historyOrdersByTicket[historyOrder.id][key];
_this._historyOrdersByTicket[historyOrder.id][key] = historyOrder;
if (historyOrder.positionId) {
_this._historyOrdersByPosition[historyOrder.positionId] = _this._historyOrdersByPosition[historyOrder.positionId] || {};
_this._historyOrdersByPosition[historyOrder.positionId][key] = historyOrder;
}
_this._historyOrdersByTime.delete(historyOrder);
_this._historyOrdersByTime.insert(historyOrder, historyOrder);
if (historyOrder.doneTime && (!_this._maxHistoryOrderTime || _this._maxHistoryOrderTime.getTime() < historyOrder.doneTime.getTime())) {
_this._maxHistoryOrderTime = historyOrder.doneTime;
}
if (newHistoryOrder) {
_this._newHistoryOrders.push(historyOrder);
clearTimeout(_this._flushTimeout);
_this._flushTimeout = setTimeout(_this._flushDatabase.bind(_this), 5000);
}
})();
}
_getHistoryOrderKey(historyOrder) {
return (historyOrder.doneTime || new Date(0)).toISOString() + ':' + historyOrder.id + ':' + historyOrder.type + ':' + historyOrder.state;
}
_flushDatabase() {
var _this = this;
return _async_to_generator(function*() {
if (_this._flushPromise) {
yield _this._flushPromise;
}
if (_this._flushRunning) {
return;
}
_this._flushRunning = true;
let resolve;
_this._flushPromise = new Promise((res)=>resolve = res);
try {
yield _this._historyDatabase.flush(_this._accountId, _this._application, _this._newHistoryOrders, _this._newDeals);
_this._newHistoryOrders = [];
_this._newDeals = [];
_this._logger.debug(`${_this._accountId}: flushed history db`);
} catch (err) {
_this._logger.warn(`${_this._accountId}: error flushing history db`, err);
_this._flushTimeout = setTimeout(_this._flushDatabase.bind(_this), 15000);
} finally{
resolve();
_this._flushRunning = false;
}
})();
}
/**
* Constructs the in-memory history store instance
*/ constructor(){
super();
this._historyDatabase = HistoryDatabase.getInstance();
this._reset();
this._logger = LoggerManager.getLogger('MemoryHistoryStorage');
}
};
/**
* History storage which stores MetaTrader history in RAM
*/ export { MemoryHistoryStorage as default };
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["<anon>"],"sourcesContent":["'use strict';\n\nimport HistoryStorage from './historyStorage';\nimport HistoryDatabase from './historyDatabase/index';\nimport { AVLTree } from '../binary-search-tree/avltree'\nimport LoggerManager from '../logger';\n\n/**\n * History storage which stores MetaTrader history in RAM\n */\nexport default class MemoryHistoryStorage extends HistoryStorage {\n\n  /**\n   * Constructs the in-memory history store instance\n   */\n  constructor() {\n    super();\n    this._historyDatabase = HistoryDatabase.getInstance();\n    this._reset();\n    this._logger = LoggerManager.getLogger('MemoryHistoryStorage');\n  }\n\n  /**\n   * Initializes the storage and loads required data from a persistent storage\n   * @param {string} accountId account id\n   * @param {string} [application] application. Default is MetaApi\n   */\n  async initialize(accountId, application = 'MetaApi') {\n    await super.initialize(accountId, application);\n    let {deals, historyOrders} = await this._historyDatabase.loadHistory(accountId, application);\n    for (let deal of deals) {\n      await this._addDeal(deal, true);\n    }\n    for (let historyOrder of historyOrders) {\n      await this._addHistoryOrder(historyOrder, true);\n    }\n  }\n\n  /**\n   * Resets the storage. Intended for use in tests\n   * @returns {Promise} promise when the history is removed\n   */\n  async clear() {\n    this._reset();\n    await this._historyDatabase.clear(this._accountId, this._application);\n  }\n\n  /**\n   * Returns the time of the last history order record stored in the history storage\n   * @param {Number} [instanceNumber] index of an account instance connected\n   * @returns {Date} the time of the last history order record stored in the history storage\n   */\n  lastHistoryOrderTime(instanceNumber) {\n    return this._maxHistoryOrderTime;\n  }\n\n  /**\n   * Returns the time of the last history deal record stored in the history storage\n   * @param {Number} [instanceNumber] index of an account instance connected\n   * @returns {Date} the time of the last history deal record stored in the history storage\n   */\n  lastDealTime(instanceNumber) {\n    return this._maxDealTime;\n  }\n\n  /**\n   * Invoked when a new MetaTrader history order is added\n   * @param {String} instanceIndex index of an account instance connected\n   * @param {MetatraderOrder} historyOrder new MetaTrader history order\n   */\n  async onHistoryOrderAdded(instanceIndex, historyOrder) {\n    await this._addHistoryOrder(historyOrder);\n  }\n\n  /**\n   * Invoked when a new MetaTrader history deal is added\n   * @param {String} instanceIndex index of an account instance connected\n   * @param {MetatraderDeal} deal new MetaTrader history deal\n   */\n  async onDealAdded(instanceIndex, deal) {\n    await this._addDeal(deal);\n  }\n\n  /**\n   * Returns all deals\n   * @returns {Array<MetatraderDeal>} all deals\n   */\n  get deals() {\n    return this.getDealsByTimeRange(new Date(0), new Date(8640000000000000));\n  }\n\n  /**\n   * Returns deals by ticket id\n   * @param {string} id ticket id\n   * @returns {Array<MetatraderDeal>} deals found\n   */\n  getDealsByTicket(id) {\n    let deals = Object.values(this._dealsByTicket[id] || {});\n    deals.sort(this._dealsComparator);\n    return deals;\n  }\n\n  /**\n   * Returns deals by position id\n   * @param {string} positionId position id\n   * @returns {Array<MetatraderDeal>} deals found\n   */\n  getDealsByPosition(positionId) {\n    let deals = Object.values(this._dealsByPosition[positionId] || {});\n    deals.sort(this._dealsComparator);\n    return deals;\n  }\n\n  /**\n   * Returns deals by time range\n   * @param startTime start time, inclusive\n   * @param endTime end time, inclusive\n   * @returns {Array<MetatraderDeal>} deals found\n   */\n  getDealsByTimeRange(startTime, endTime) {\n    let deals = this._dealsByTime.betweenBounds({\n      $gte: {time: startTime, id: 0, entryType: ''},\n      $lte: {time: endTime, id: Number.MAX_VALUE, entryType: ''}\n    });\n    return deals;\n  }\n\n  /**\n   * Returns all history orders\n   * @returns {Array<MetatraderOrder>} all history orders\n   */\n  get historyOrders() {\n    return this.getHistoryOrdersByTimeRange(new Date(0), new Date(8640000000000000));\n  }\n\n  /**\n   * Returns history orders by ticket id\n   * @param {string} id ticket id\n   * @returns {Array<MetatraderOrder>} history orders found\n   */\n  getHistoryOrdersByTicket(id) {\n    let historyOrders = Object.values(this._historyOrdersByTicket[id] || {});\n    historyOrders.sort(this._historyOrdersComparator);\n    return historyOrders;\n  }\n\n  /**\n   * Returns history orders by position id\n   * @param {string} positionId position id\n   * @returns {Array<MetatraderOrder>} history orders found\n   */\n  getHistoryOrdersByPosition(positionId) {\n    let historyOrders = Object.values(this._historyOrdersByPosition[positionId] || {});\n    historyOrders.sort(this._historyOrdersComparator);\n    return historyOrders;\n  }\n\n  /**\n   * Returns history orders by time range\n   * @param startTime start time, inclusive\n   * @param endTime end time, inclusive\n   * @returns {Array<MetatraderOrder>} hisotry orders found\n   */\n  getHistoryOrdersByTimeRange(startTime, endTime) {\n    let historyOrders = this._historyOrdersByTime.betweenBounds({\n      $gte: {doneTime: startTime, id: 0, type: '', state: ''},\n      $lte: {doneTime: endTime, id: Number.MAX_VALUE, type: '', state: ''}\n    });\n    return historyOrders;\n  }\n\n  /**\n   * Invoked when a synchronization of history deals on a MetaTrader account have finished to indicate progress of an\n   * initial terminal state synchronization\n   * @param {String} instanceIndex index of an account instance connected\n   * @param {String} synchronizationId synchronization request id\n   * @return {Promise} promise which resolves when the asynchronous event is processed\n   */\n  async onDealsSynchronized(instanceIndex, synchronizationId) {\n    await this._flushDatabase();\n    await super.onDealsSynchronized(instanceIndex, synchronizationId);\n  }\n\n  _reset() {\n    this._orderSynchronizationFinished = {};\n    this._dealSynchronizationFinished = {};\n    this._dealsByTicket = {};\n    this._dealsByPosition = {};\n    this._historyOrdersByTicket = {};\n    this._historyOrdersByPosition = {};\n    // eslint-disable-next-line complexity\n    this._historyOrdersComparator = (o1, o2) => {\n      let timeDiff = (o1.doneTime || new Date(0)).getTime() - (o2.doneTime || new Date(0)).getTime();\n      if (timeDiff === 0) {\n        let idDiff = o1.id - o2.id;\n        if (idDiff === 0) {\n          if (o1.type > o2.type) {\n            return 1;\n          } else if (o1.type < o2.type) {\n            return -1;\n          } else {\n            if (o1.state > o2.state) {\n              return 1;\n            } else if (o1.state < o2.state) {\n              return -1;\n            } else {\n              return 0;\n            }\n          }\n        } else {\n          return idDiff;\n        }\n      } else {\n        return timeDiff;\n      }\n    };\n    this._historyOrdersByTime = new AVLTree({compareKeys: this._historyOrdersComparator});\n    this._dealsComparator = (d1, d2) => {\n      let timeDiff = (d1.time || new Date(0)).getTime() - (d2.time || new Date(0)).getTime();\n      if (timeDiff === 0) {\n        let idDiff = d1.id - d2.id;\n        if (idDiff === 0) {\n          if (d1.entryType > d2.entryType) {\n            return 1;\n          } else if (d1.entryType < d2.entryType) {\n            return -1;\n          } else {\n            return 0;\n          }\n        } else {\n          return idDiff;\n        }\n      } else {\n        return timeDiff;\n      }\n    };\n    this._dealsByTime = new AVLTree({compareKeys: this._dealsComparator});\n    this._maxHistoryOrderTime = new Date(0);\n    this._maxDealTime = new Date(0);\n    this._newHistoryOrders = [];\n    this._newDeals = [];\n    clearTimeout(this._flushTimeout);\n    delete this._flushTimeout;\n  }\n\n  // eslint-disable-next-line complexity\n  async _addDeal(deal, existing) {\n    let key = this._getDealKey(deal);\n    this._dealsByTicket[deal.id] = this._dealsByTicket[deal.id] || {};\n    let newDeal = !existing && !this._dealsByTicket[deal.id][key];\n    this._dealsByTicket[deal.id][key] = deal;\n    if (deal.positionId) {\n      this._dealsByPosition[deal.positionId] = this._dealsByPosition[deal.positionId] || {};\n      this._dealsByPosition[deal.positionId][key] = deal;\n    }\n    this._dealsByTime.delete(deal);\n    this._dealsByTime.insert(deal, deal);\n    if (deal.time && (!this._maxDealTime || this._maxDealTime.getTime() < deal.time.getTime())) {\n      this._maxDealTime = deal.time;\n    }\n    if (newDeal) {\n      this._newDeals.push(deal);\n      clearTimeout(this._flushTimeout);\n      this._flushTimeout = setTimeout(this._flushDatabase.bind(this), 5000);\n    }\n  }\n\n  _getDealKey(deal) {\n    return (deal.time || new Date(0)).toISOString() + ':' + deal.id + ':' + deal.entryType;\n  }\n\n  // eslint-disable-next-line complexity\n  async _addHistoryOrder(historyOrder, existing) {\n    let key = this._getHistoryOrderKey(historyOrder);\n    this._historyOrdersByTicket[historyOrder.id] = this._historyOrdersByTicket[historyOrder.id] || {};\n    let newHistoryOrder = !existing && !this._historyOrdersByTicket[historyOrder.id][key];\n    this._historyOrdersByTicket[historyOrder.id][key] = historyOrder;\n    if (historyOrder.positionId) {\n      this._historyOrdersByPosition[historyOrder.positionId] = this._historyOrdersByPosition[historyOrder.positionId] ||\n        {};\n      this._historyOrdersByPosition[historyOrder.positionId][key] = historyOrder;\n    }\n    this._historyOrdersByTime.delete(historyOrder);\n    this._historyOrdersByTime.insert(historyOrder, historyOrder);\n    if (historyOrder.doneTime && (!this._maxHistoryOrderTime ||\n        this._maxHistoryOrderTime.getTime() < historyOrder.doneTime.getTime())) {\n      this._maxHistoryOrderTime = historyOrder.doneTime;\n    }\n    if (newHistoryOrder) {\n      this._newHistoryOrders.push(historyOrder);\n      clearTimeout(this._flushTimeout);\n      this._flushTimeout = setTimeout(this._flushDatabase.bind(this), 5000);\n    }\n  }\n\n  _getHistoryOrderKey(historyOrder) {\n    return (historyOrder.doneTime || new Date(0)).toISOString() + ':' + historyOrder.id + ':' +\n      historyOrder.type + ':' + historyOrder.state;\n  }\n\n  async _flushDatabase() {\n    if (this._flushPromise) {\n      await this._flushPromise;\n    }\n    if (this._flushRunning) {\n      return;\n    }\n    this._flushRunning = true;\n    let resolve;\n    this._flushPromise = new Promise(res => resolve = res);\n    try {\n      await this._historyDatabase.flush(this._accountId, this._application, this._newHistoryOrders, this._newDeals);\n      this._newHistoryOrders = [];\n      this._newDeals = [];\n      this._logger.debug(`${this._accountId}: flushed history db`);\n    } catch (err) {\n      this._logger.warn(`${this._accountId}: error flushing history db`, err);\n      this._flushTimeout = setTimeout(this._flushDatabase.bind(this), 15000);\n    } finally {\n      resolve();\n      this._flushRunning = false;\n    }\n  }\n\n}\n"],"names":["HistoryStorage","HistoryDatabase","AVLTree","LoggerManager","MemoryHistoryStorage","initialize","accountId","application","deals","historyOrders","_historyDatabase","loadHistory","deal","_addDeal","historyOrder","_addHistoryOrder","clear","_reset","_accountId","_application","lastHistoryOrderTime","instanceNumber","_maxHistoryOrderTime","lastDealTime","_maxDealTime","onHistoryOrderAdded","instanceIndex","onDealAdded","getDealsByTimeRange","Date","getDealsByTicket","id","Object","values","_dealsByTicket","sort","_dealsComparator","getDealsByPosition","positionId","_dealsByPosition","startTime","endTime","_dealsByTime","betweenBounds","$gte","time","entryType","$lte","Number","MAX_VALUE","getHistoryOrdersByTimeRange","getHistoryOrdersByTicket","_historyOrdersByTicket","_historyOrdersComparator","getHistoryOrdersByPosition","_historyOrdersByPosition","_historyOrdersByTime","doneTime","type","state","onDealsSynchronized","synchronizationId","_flushDatabase","_orderSynchronizationFinished","_dealSynchronizationFinished","o1","o2","timeDiff","getTime","idDiff","compareKeys","d1","d2","_newHistoryOrders","_newDeals","clearTimeout","_flushTimeout","existing","key","_getDealKey","newDeal","delete","insert","push","setTimeout","bind","toISOString","_getHistoryOrderKey","newHistoryOrder","_flushPromise","_flushRunning","resolve","Promise","res","flush","_logger","debug","err","warn","constructor","getInstance","getLogger"],"mappings":"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"}