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)

215 lines (214 loc) 26 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return ProvisioningProfileClient; } }); const _fs = /*#__PURE__*/ _interop_require_default(require("fs")); const _metaApiclient = /*#__PURE__*/ _interop_require_default(require("../metaApi.client")); const _formdata = /*#__PURE__*/ _interop_require_default(require("form-data")); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } let ProvisioningProfileClient = class ProvisioningProfileClient extends _metaApiclient.default { /** * Provisioning profile model * @typedef {Object} ProvisioningProfileDto * @property {String} _id provisioning profile unique identifier * @property {String} name provisioning profile name * @property {Number} version MetaTrader version (allowed values are 4 and 5) * @property {String} status provisioning profile status (allowed values are new and active) * @property {String} brokerTimezone broker timezone name from Time Zone Database * @property {String} brokerDSTSwitchTimezone broker DST switch timezone name from Time Zone Database */ /** * MT version * @typedef {4 | 5} Version */ /** * Provisioning profile type * @typedef {'mtTerminal' | 'managerApi'} ProvisioningProfileType */ /** * Provisioning profile status * @typedef {'new' | 'active'} ProvisioningProfileStatus */ /** * Get provisioning profiles API version * @typedef {'1' | '2'} GetProvisioningProfilesApiVersion */ /** * @typedef {Object} ProvisioningProfilesFilter * @property {number} [offset] Search offset (defaults to 0) (must be greater or equal to 0) * @property {number} [limit] Search limit (defaults to 1000) * (must be greater or equal to 1 and less or equal to 1000) * @property {Version} [version] MT version * @property {ProvisioningProfileType} [type] Profile type * @property {ProvisioningProfileStatus} [status] Profile status * @property {string} [query] Partially search over provisioning profile name to match query */ /** * Provisioning profiles list model * @typedef {Object} ProvisioningProfilesListDto * @property {String} count provisioning profiles count * @property {Array<ProvisioningProfileDto>} items provisioning profiles list */ /** * Retrieves provisioning profiles owned by user * (see https://metaapi.cloud/docs/provisioning/api/provisioningProfile/readProvisioningProfiles/) * Method is accessible only with API access token * @param {ProvisioningProfilesFilter} [profilesFilter] provisioning profiles filter * @param {GetProvisioningProfilesApiVersion} [apiVersion] api version to use * @return {Promise<Array<ProvisioningProfileDto> | ProvisioningProfilesListDto>} promise resolving with provisioning profiles found */ getProvisioningProfiles(profilesFilter = {}, apiVersion) { if (this._isNotJwtToken()) { return this._handleNoAccessError("getProvisioningProfiles"); } const opts = { url: `${this._host}/users/current/provisioning-profiles`, method: "GET", params: profilesFilter, headers: { "auth-token": this._token }, json: true }; if (apiVersion) { opts.headers["api-version"] = apiVersion; } return this._httpClient.request(opts, "getProvisioningProfiles"); } /** * Retrieves a provisioning profile by id (see * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/readProvisioningProfile/). Throws an error if * profile is not found. * Method is accessible only with API access token * @param {String} id provisioning profile id * @return {Promise<ProvisioningProfileDto>} promise resolving with provisioning profile found */ getProvisioningProfile(id) { if (this._isNotJwtToken()) { return this._handleNoAccessError("getProvisioningProfile"); } const opts = { url: `${this._host}/users/current/provisioning-profiles/${id}`, method: "GET", headers: { "auth-token": this._token }, json: true }; return this._httpClient.request(opts, "getProvisioningProfile"); } /** * New provisioning profile model * @typedef {Object} NewProvisioningProfileDto * @property {String} name provisioning profile name * @property {Number} version MetaTrader version (allowed values are 4 and 5) * @property {String} brokerTimezone broker timezone name from Time Zone Database * @property {String} brokerDSTSwitchTimezone broker DST switch timezone name from Time Zone Database */ /** * Provisioning profile id model * @typedef {Object} ProvisioningProfileIdDto * @property {String} id provisioning profile unique identifier */ /** * Creates a new provisioning profile (see * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/createNewProvisioningProfile/). After creating a * provisioning profile you are required to upload extra files in order to activate the profile for further use. * Method is accessible only with API access token * @param {NewProvisioningProfileDto} provisioningProfile provisioning profile to create * @return {Promise<ProvisioningProfileIdDto>} promise resolving with an id of the provisioning profile created */ createProvisioningProfile(provisioningProfile) { if (this._isNotJwtToken()) { return this._handleNoAccessError("createProvisioningProfile"); } const opts = { url: `${this._host}/users/current/provisioning-profiles`, method: "POST", headers: { "auth-token": this._token }, json: true, data: provisioningProfile }; return this._httpClient.request(opts, "createProvisioningProfile"); } /** * Uploads a file to a provisioning profile (see * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/uploadFilesToProvisioningProfile/). Uploading a * file by name is allowed only for Node.js. * Method is accessible only with API access token * @param {String} provisioningProfileId provisioning profile id to upload file to * @param {String} fileName name of the file to upload. Allowed values are servers.dat for MT5 profile, broker.srv for * MT4 profile * @param {String|Buffer} file path to a file to upload or buffer containing file contents * @return {Promise} promise resolving when file upload is completed */ uploadProvisioningProfileFile(provisioningProfileId, fileName, file) { if (this._isNotJwtToken()) { return this._handleNoAccessError("uploadProvisioningProfileFile"); } const formData = new _formdata.default(); if (typeof file === "string") { file = _fs.default.createReadStream(file); formData.append("file", file); } else { formData.append("file", file, "serverFile"); } const opts = { method: "PUT", url: `${this._host}/users/current/provisioning-profiles/${provisioningProfileId}/${fileName}`, data: formData, headers: { ...formData.getHeaders(), "auth-token": this._token } }; return this._httpClient.request(opts, "uploadProvisioningProfileFile"); } /** * Deletes a provisioning profile (see * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/deleteProvisioningProfile/). Please note that in * order to delete a provisioning profile you need to delete MT accounts connected to it first. * Method is accessible only with API access token * @param {String} id provisioning profile id * @return {Promise} promise resolving when provisioning profile is deleted */ deleteProvisioningProfile(id) { if (this._isNotJwtToken()) { return this._handleNoAccessError("deleteProvisioningProfile"); } const opts = { url: `${this._host}/users/current/provisioning-profiles/${id}`, method: "DELETE", headers: { "auth-token": this._token }, json: true }; return this._httpClient.request(opts, "deleteProvisioningProfile"); } /** * Updated provisioning profile data * @typedef {Object} ProvisioningProfileUpdateDto * @property {String} name provisioning profile name */ /** * Updates existing provisioning profile data (see * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/updateProvisioningProfile/). * Method is accessible only with API access token * @param {String} id provisioning profile id * @param {ProvisioningProfileUpdateDto} provisioningProfile updated provisioning profile * @return {Promise} promise resolving when provisioning profile is updated */ updateProvisioningProfile(id, provisioningProfile) { if (this._isNotJwtToken()) { return this._handleNoAccessError("updateProvisioningProfile"); } const opts = { url: `${this._host}/users/current/provisioning-profiles/${id}`, method: "PUT", headers: { "auth-token": this._token }, json: true, data: provisioningProfile }; return this._httpClient.request(opts, "updateProvisioningProfile"); } }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["<anon>"],"sourcesContent":["'use strict';\n\nimport fs from 'fs';\n\nimport MetaApiClient from '../metaApi.client';\nimport FormData from 'form-data';\n\n/**\n * metaapi.cloud provisioning profile API client (see https://metaapi.cloud/docs/provisioning/)\n */\nexport default class ProvisioningProfileClient extends MetaApiClient {\n\n  /**\n   * Provisioning profile model\n   * @typedef {Object} ProvisioningProfileDto\n   * @property {String} _id provisioning profile unique identifier\n   * @property {String} name provisioning profile name\n   * @property {Number} version MetaTrader version (allowed values are 4 and 5)\n   * @property {String} status provisioning profile status (allowed values are new and active)\n   * @property {String} brokerTimezone broker timezone name from Time Zone Database\n   * @property {String} brokerDSTSwitchTimezone broker DST switch timezone name from Time Zone Database\n   */\n\n  /**\n   * MT version\n   * @typedef {4 | 5} Version\n   */\n\n  /**\n   * Provisioning profile type\n   * @typedef {'mtTerminal' | 'managerApi'} ProvisioningProfileType\n   */\n\n  /**\n   * Provisioning profile status\n   * @typedef {'new' | 'active'} ProvisioningProfileStatus\n   */\n\n  /**\n   * Get provisioning profiles API version\n   * @typedef {'1' | '2'} GetProvisioningProfilesApiVersion\n   */\n\n  /**\n   * @typedef {Object} ProvisioningProfilesFilter\n   * @property {number} [offset] Search offset (defaults to 0) (must be greater or equal to 0)\n   * @property {number} [limit] Search limit (defaults to 1000) \n   * (must be greater or equal to 1 and less or equal to 1000)\n   * @property {Version} [version] MT version\n   * @property {ProvisioningProfileType} [type] Profile type\n   * @property {ProvisioningProfileStatus} [status] Profile status\n   * @property {string} [query] Partially search over provisioning profile name to match query\n   */\n\n  /**\n   * Provisioning profiles list model\n   * @typedef {Object} ProvisioningProfilesListDto\n   * @property {String} count provisioning profiles count\n   * @property {Array<ProvisioningProfileDto>} items provisioning profiles list\n   */\n\n\n  /**\n   * Retrieves provisioning profiles owned by user\n   * (see https://metaapi.cloud/docs/provisioning/api/provisioningProfile/readProvisioningProfiles/)\n   * Method is accessible only with API access token\n   * @param {ProvisioningProfilesFilter} [profilesFilter] provisioning profiles filter\n   * @param {GetProvisioningProfilesApiVersion} [apiVersion] api version to use\n   * @return {Promise<Array<ProvisioningProfileDto> | ProvisioningProfilesListDto>} promise resolving with provisioning profiles found\n   */\n  getProvisioningProfiles(profilesFilter = {}, apiVersion) {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('getProvisioningProfiles');\n    }\n    const opts = {\n      url: `${this._host}/users/current/provisioning-profiles`,\n      method: 'GET',\n      params: profilesFilter,\n      headers: {\n        'auth-token': this._token\n      },\n      json: true\n    };\n    if (apiVersion) {\n      opts.headers['api-version'] = apiVersion;\n    }\n    return this._httpClient.request(opts, 'getProvisioningProfiles');\n  }\n\n  /**\n   * Retrieves a provisioning profile by id (see\n   * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/readProvisioningProfile/). Throws an error if\n   * profile is not found.\n   * Method is accessible only with API access token\n   * @param {String} id provisioning profile id\n   * @return {Promise<ProvisioningProfileDto>} promise resolving with provisioning profile found\n   */\n  getProvisioningProfile(id) {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('getProvisioningProfile');\n    }\n    const opts = {\n      url: `${this._host}/users/current/provisioning-profiles/${id}`,\n      method: 'GET',\n      headers: {\n        'auth-token': this._token\n      },\n      json: true\n    };\n    return this._httpClient.request(opts, 'getProvisioningProfile');\n  }\n\n  /**\n   * New provisioning profile model\n   * @typedef {Object} NewProvisioningProfileDto\n   * @property {String} name provisioning profile name\n   * @property {Number} version MetaTrader version (allowed values are 4 and 5)\n   * @property {String} brokerTimezone broker timezone name from Time Zone Database\n   * @property {String} brokerDSTSwitchTimezone broker DST switch timezone name from Time Zone Database\n   */\n\n  /**\n   * Provisioning profile id model\n   * @typedef {Object} ProvisioningProfileIdDto\n   * @property {String} id provisioning profile unique identifier\n   */\n\n  /**\n   * Creates a new provisioning profile (see\n   * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/createNewProvisioningProfile/). After creating a\n   * provisioning profile you are required to upload extra files in order to activate the profile for further use.\n   * Method is accessible only with API access token\n   * @param {NewProvisioningProfileDto} provisioningProfile provisioning profile to create\n   * @return {Promise<ProvisioningProfileIdDto>} promise resolving with an id of the provisioning profile created\n   */\n  createProvisioningProfile(provisioningProfile) {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('createProvisioningProfile');\n    }\n    const opts = {\n      url: `${this._host}/users/current/provisioning-profiles`,\n      method: 'POST',\n      headers: {\n        'auth-token': this._token\n      },\n      json: true,\n      data: provisioningProfile\n    };\n    return this._httpClient.request(opts, 'createProvisioningProfile');\n  }\n\n  /**\n   * Uploads a file to a provisioning profile (see\n   * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/uploadFilesToProvisioningProfile/). Uploading a\n   * file by name is allowed only for Node.js.\n   * Method is accessible only with API access token\n   * @param {String} provisioningProfileId provisioning profile id to upload file to\n   * @param {String} fileName name of the file to upload. Allowed values are servers.dat for MT5 profile, broker.srv for\n   * MT4 profile\n   * @param {String|Buffer} file path to a file to upload or buffer containing file contents\n   * @return {Promise} promise resolving when file upload is completed\n   */\n  uploadProvisioningProfileFile(provisioningProfileId, fileName, file) {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('uploadProvisioningProfileFile');\n    }\n\n    const formData = new FormData();\n    if (typeof file === 'string') {\n      file = fs.createReadStream(file);\n      formData.append('file', file);\n    } else {\n      formData.append('file', file, 'serverFile');\n    }\n\n    const opts = {\n      method: 'PUT',\n      url: `${this._host}/users/current/provisioning-profiles/${provisioningProfileId}/${fileName}`,\n      data: formData,\n      headers: {\n        ...formData.getHeaders(),\n        'auth-token': this._token,\n      }\n    };\n    return this._httpClient.request(opts, 'uploadProvisioningProfileFile');\n  }\n\n  /**\n   * Deletes a provisioning profile (see\n   * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/deleteProvisioningProfile/). Please note that in\n   * order to delete a provisioning profile you need to delete MT accounts connected to it first.\n   * Method is accessible only with API access token\n   * @param {String} id provisioning profile id\n   * @return {Promise} promise resolving when provisioning profile is deleted\n   */\n  deleteProvisioningProfile(id) {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('deleteProvisioningProfile');\n    }\n    const opts = {\n      url: `${this._host}/users/current/provisioning-profiles/${id}`,\n      method: 'DELETE',\n      headers: {\n        'auth-token': this._token\n      },\n      json: true\n    };\n    return this._httpClient.request(opts, 'deleteProvisioningProfile');\n  }\n\n  /**\n   * Updated provisioning profile data\n   * @typedef {Object} ProvisioningProfileUpdateDto\n   * @property {String} name provisioning profile name\n   */\n\n  /**\n   * Updates existing provisioning profile data (see\n   * https://metaapi.cloud/docs/provisioning/api/provisioningProfile/updateProvisioningProfile/).\n   * Method is accessible only with API access token\n   * @param {String} id provisioning profile id\n   * @param {ProvisioningProfileUpdateDto} provisioningProfile updated provisioning profile\n   * @return {Promise} promise resolving when provisioning profile is updated\n   */\n  updateProvisioningProfile(id, provisioningProfile) {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('updateProvisioningProfile');\n    }\n    const opts = {\n      url: `${this._host}/users/current/provisioning-profiles/${id}`,\n      method: 'PUT',\n      headers: {\n        'auth-token': this._token\n      },\n      json: true,\n      data: provisioningProfile\n    };\n    return this._httpClient.request(opts, 'updateProvisioningProfile');\n  }\n\n}\n"],"names":["ProvisioningProfileClient","MetaApiClient","getProvisioningProfiles","profilesFilter","apiVersion","_isNotJwtToken","_handleNoAccessError","opts","url","_host","method","params","headers","_token","json","_httpClient","request","getProvisioningProfile","id","createProvisioningProfile","provisioningProfile","data","uploadProvisioningProfileFile","provisioningProfileId","fileName","file","formData","FormData","fs","createReadStream","append","getHeaders","deleteProvisioningProfile","updateProvisioningProfile"],"mappings":"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"}