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)
147 lines (146 loc) • 15.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return TokenManagementClient;
}
});
const _metaApiclient = /*#__PURE__*/ _interop_require_default(require("../metaApi.client"));
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
let TokenManagementClient = class TokenManagementClient extends _metaApiclient.default {
/**
* Gets access rules manifest
* @returns {Promise<Array<ManifestAccessRule>>} access rules manifest
*/ getAccessRules() {
if (this._isNotJwtToken()) {
return this._handleNoAccessError("getAccessRules");
}
const opts = {
url: `${this._host}/access-rule-manifest`,
method: "GET",
headers: {
"auth-token": this._token
},
json: true
};
return this._httpClient.request(opts, "getAccessRules");
}
/**
* Returns narrowed down token with given access rules
* @param {NarrowDownAccessRules | NarrowDownSimplifiedAccessRules} narrowDownPayload narrow down payload
* @param {Number} [validityInHours] token validity in hours
* @return {Promise<NarrowedDownToken>} promise resolving with narrowed down token
*/ narrowDownToken(accessRules, validityInHours) {
if (this._isNotJwtToken()) {
return this._handleNoAccessError("narrowDownToken");
}
if (validityInHours) {
validityInHours = `?validity-in-hours=${validityInHours}`;
}
const opts = {
url: `${this._host}/users/current/narrow-down-auth-token${validityInHours || ""}`,
method: "POST",
headers: {
"auth-token": this._token
},
json: true,
data: accessRules
};
return this._httpClient.request(opts, "narrowDownToken");
}
/**
* Access rules manifest
* @typedef {Object} ManifestAccessRule
* @property {String} id application id
* @property {String} application application name
* @property {String} description application description
* @property {Array<ManifestEntity>} entities application resources entities
* @property {Array<ManifestService>} services application services
* @property {Array<ManifestMethodGroup>} methodGroups application method groups
* @property {Array<ManifestRoles>} roles application roles
* @property {String} [entityCompositionDescription] application entity composition description
*/ /**
* Access rules manifest resource entity
* @typedef {Object} ManifestEntity
* @property {String} description entity description
* @property {String} entity entity name
* @property {String} [idDescription] entity id description
*/ /**
* Access rules manifest application service
* @typedef {Object} ManifestService
* @property {String} description service description
* @property {String} service service name
*/ /**
* Access rules manifest application method group
* @typedef {Object} ManifestMethodGroup
* @property {String} group method group name
* @property {String} description method group description
* @property {Array<ManifestMethod>} methods method group methods
*/ /**
* Access rules manifest application method
* @typedef {Object} ManifestMethod
* @property {String} description method description
* @property {Array<String>} method method name
* @property {Array<String>} [scopes] method scopes
*/ /**
* Access rules manifest application roles
* @typedef {Object} ManifestRoles
* @property {String} description application roles description
* @property {Array<String>} roles application roles
*/ /**
* Narrowed down token access rules
* @typedef {Object} NarrowDownAccessRules
* @property {Array<AccessRule>} accessRules applications access rules to grant
*/ /**
* Narrowed down token simplified access rules
* @typedef {Object} NarrowDownSimplifiedAccessRules
* @property {Array<AccessRuleResource>} [resources] resources to grant access to
* @property {Array<String>} [roles] roles to grant access to
* @property {Array<String>} [applications] applications to grant access to
*/ /**
* Narrowed down token access rule
* @typedef {Object} AccessRule
* @property {String} id application id to grant access to
* @property {String} application application to grant access to
* @property {String} service application service to grant access to
* @property {Array<MethodGroups>} methodGroups application service methodGroups to
* grant access to
* @property {Array<AccessRuleResource>} resources application service resources
* to grant access to
* @property {Array<String>} roles access rule roles to grant access to
*/ /**
* Narrowed token access rule method groups
* @typedef {Object} MethodGroups
* @property {String} group method group
* @property {Array<Method>} methods method group methods
*/ /**
* Method group method
* @typedef {Object} Method
* @property {String} method method
* @property {Array<String>} [scopes] method scopes
*/ /**
* Narrowed token access rule resource
* @typedef {Object} AccessRuleResource
* @property {String} entity entity
* @property {String} id entity id
*/ /**
* New narrowed down token model
* @typedef {Object} NarrowedDownToken
* @property {String} token authorization token value
*/ /**
* Constructs token management API client instance
* @param {HttpClient} httpClient HTTP client
* @param {DomainClient} domainClient domain client
*/ constructor(httpClient, domainClient){
super(httpClient, domainClient);
this._host = `https://profile-api-v1.${domainClient.domain}`;
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["<anon>"],"sourcesContent":["'use strict';\n\nimport MetaApiClient from '../metaApi.client';\n\n/**\n * metaapi.cloud Token Management API client\n */\nexport default class TokenManagementClient extends MetaApiClient {\n\n  /**\n   * Access rules manifest\n   * @typedef {Object} ManifestAccessRule\n   * @property {String} id application id\n   * @property {String} application application name\n   * @property {String} description application description\n   * @property {Array<ManifestEntity>} entities application resources entities\n   * @property {Array<ManifestService>} services application services\n   * @property {Array<ManifestMethodGroup>} methodGroups application method groups\n   * @property {Array<ManifestRoles>} roles application roles\n   * @property {String} [entityCompositionDescription] application entity composition description\n   */\n\n  /**\n   * Access rules manifest resource entity\n   * @typedef {Object} ManifestEntity\n   * @property {String} description entity description\n   * @property {String} entity entity name\n   * @property {String} [idDescription] entity id description\n   */\n\n  /**\n   * Access rules manifest application service\n   * @typedef {Object} ManifestService\n   * @property {String} description service description\n   * @property {String} service service name\n   */\n\n  /**\n   * Access rules manifest application method group\n   * @typedef {Object} ManifestMethodGroup\n   * @property {String} group method group name\n   * @property {String} description method group description\n   * @property {Array<ManifestMethod>} methods method group methods\n   */\n\n  /**\n   * Access rules manifest application method\n   * @typedef {Object} ManifestMethod\n   * @property {String} description method description\n   * @property {Array<String>} method method name\n   * @property {Array<String>} [scopes] method scopes\n   */\n\n  /**\n   * Access rules manifest application roles\n   * @typedef {Object} ManifestRoles\n   * @property {String} description application roles description\n   * @property {Array<String>} roles application roles\n   */\n\n  /**\n   * Narrowed down token access rules\n   * @typedef {Object} NarrowDownAccessRules\n   * @property {Array<AccessRule>} accessRules applications access rules to grant\n   */\n\n  /**\n   * Narrowed down token simplified access rules\n   * @typedef {Object} NarrowDownSimplifiedAccessRules\n   * @property {Array<AccessRuleResource>} [resources] resources to grant access to\n   * @property {Array<String>} [roles] roles to grant access to\n   * @property {Array<String>} [applications] applications to grant access to\n   */\n\n  /**\n   * Narrowed down token access rule\n   * @typedef {Object} AccessRule\n   * @property {String} id application id to grant access to\n   * @property {String} application application to grant access to\n   * @property {String} service application service to grant access to\n   * @property {Array<MethodGroups>} methodGroups application service methodGroups to\n   * grant access to\n   * @property {Array<AccessRuleResource>} resources application service resources \n   * to grant access to\n   * @property {Array<String>} roles access rule roles to grant access to\n   */\n\n  /**\n   * Narrowed token access rule method groups \n   * @typedef {Object} MethodGroups\n   * @property {String} group method group\n   * @property {Array<Method>} methods method group methods\n   */\n\n  /**\n   * Method group method\n   * @typedef {Object} Method\n   * @property {String} method method\n   * @property {Array<String>} [scopes] method scopes\n   */\n\n  /**\n   * Narrowed token access rule resource \n   * @typedef {Object} AccessRuleResource\n   * @property {String} entity entity\n   * @property {String} id entity id\n   */\n\n  /**\n   * New narrowed down token model\n   * @typedef {Object} NarrowedDownToken\n   * @property {String} token authorization token value\n   */\n\n  /**\n   * Constructs token management API client instance\n   * @param {HttpClient} httpClient HTTP client\n   * @param {DomainClient} domainClient domain client\n   */\n  constructor(httpClient, domainClient) {\n    super(httpClient, domainClient);\n    this._host = `https://profile-api-v1.${domainClient.domain}`;\n  }\n\n  /**\n   * Gets access rules manifest\n   * @returns {Promise<Array<ManifestAccessRule>>} access rules manifest\n   */\n  getAccessRules() {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('getAccessRules');\n    }\n    const opts = {\n      url: `${this._host}/access-rule-manifest`,\n      method: 'GET',\n      headers: {\n        'auth-token': this._token\n      },\n      json: true\n    };\n    return this._httpClient.request(opts, 'getAccessRules');\n  }\n\n  /**\n   * Returns narrowed down token with given access rules\n   * @param {NarrowDownAccessRules | NarrowDownSimplifiedAccessRules} narrowDownPayload narrow down payload\n   * @param {Number} [validityInHours] token validity in hours\n   * @return {Promise<NarrowedDownToken>} promise resolving with narrowed down token\n   */\n  narrowDownToken(accessRules, validityInHours) {\n    if (this._isNotJwtToken()) {\n      return this._handleNoAccessError('narrowDownToken');\n    }\n    if (validityInHours) {\n      validityInHours = `?validity-in-hours=${validityInHours}`;\n    }\n    const opts = {\n      url: `${this._host}/users/current/narrow-down-auth-token${validityInHours || ''}`,\n      method: 'POST',\n      headers: {\n        'auth-token': this._token\n      },\n      json: true,\n      data: accessRules\n    };\n    return this._httpClient.request(opts, 'narrowDownToken');\n  }\n\n}"],"names":["TokenManagementClient","MetaApiClient","getAccessRules","_isNotJwtToken","_handleNoAccessError","opts","url","_host","method","headers","_token","json","_httpClient","request","narrowDownToken","accessRules","validityInHours","data","constructor","httpClient","domainClient","domain"],"mappings":"AAAA;;;;;;;eAOqBA;;;sEALK;;;;;;AAKX,IAAA,AAAMA,wBAAN,MAAMA,8BAA8BC,sBAAa;IAqH9D;;;GAGC,GACDC,iBAAiB;QACf,IAAI,IAAI,CAACC,cAAc,IAAI;YACzB,OAAO,IAAI,CAACC,oBAAoB,CAAC;QACnC;QACA,MAAMC,OAAO;YACXC,KAAK,CAAC,EAAE,IAAI,CAACC,KAAK,CAAC,qBAAqB,CAAC;YACzCC,QAAQ;YACRC,SAAS;gBACP,cAAc,IAAI,CAACC,MAAM;YAC3B;YACAC,MAAM;QACR;QACA,OAAO,IAAI,CAACC,WAAW,CAACC,OAAO,CAACR,MAAM;IACxC;IAEA;;;;;GAKC,GACDS,gBAAgBC,WAAW,EAAEC,eAAe,EAAE;QAC5C,IAAI,IAAI,CAACb,cAAc,IAAI;YACzB,OAAO,IAAI,CAACC,oBAAoB,CAAC;QACnC;QACA,IAAIY,iBAAiB;YACnBA,kBAAkB,CAAC,mBAAmB,EAAEA,gBAAgB,CAAC;QAC3D;QACA,MAAMX,OAAO;YACXC,KAAK,CAAC,EAAE,IAAI,CAACC,KAAK,CAAC,qCAAqC,EAAES,mBAAmB,GAAG,CAAC;YACjFR,QAAQ;YACRC,SAAS;gBACP,cAAc,IAAI,CAACC,MAAM;YAC3B;YACAC,MAAM;YACNM,MAAMF;QACR;QACA,OAAO,IAAI,CAACH,WAAW,CAACC,OAAO,CAACR,MAAM;IACxC;IA7JA;;;;;;;;;;;GAWC,GAED;;;;;;GAMC,GAED;;;;;GAKC,GAED;;;;;;GAMC,GAED;;;;;;GAMC,GAED;;;;;GAKC,GAED;;;;GAIC,GAED;;;;;;GAMC,GAED;;;;;;;;;;;GAWC,GAED;;;;;GAKC,GAED;;;;;GAKC,GAED;;;;;GAKC,GAED;;;;GAIC,GAED;;;;GAIC,GACDa,YAAYC,UAAU,EAAEC,YAAY,CAAE;QACpC,KAAK,CAACD,YAAYC;QAClB,IAAI,CAACb,KAAK,GAAG,CAAC,uBAAuB,EAAEa,aAAaC,MAAM,CAAC,CAAC;IAC9D;AA8CF"}