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