jsforce
Version:
Salesforce API Library for JavaScript
388 lines (383 loc) • 43.2 kB
JavaScript
import _Object$keys from "@babel/runtime-corejs3/core-js-stable/object/keys";
import _Object$getOwnPropertySymbols from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols";
import _filterInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/filter";
import _Object$getOwnPropertyDescriptor from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor";
import _forEachInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/for-each";
import _Object$getOwnPropertyDescriptors from "@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors";
import _Object$defineProperties from "@babel/runtime-corejs3/core-js-stable/object/define-properties";
import _Object$defineProperty from "@babel/runtime-corejs3/core-js-stable/object/define-property";
import _Reflect$construct from "@babel/runtime-corejs3/core-js-stable/reflect/construct";
import _possibleConstructorReturn from "@babel/runtime-corejs3/helpers/possibleConstructorReturn";
import _getPrototypeOf from "@babel/runtime-corejs3/helpers/getPrototypeOf";
import _inherits from "@babel/runtime-corejs3/helpers/inherits";
import _wrapNativeSuper from "@babel/runtime-corejs3/helpers/wrapNativeSuper";
import _asyncToGenerator from "@babel/runtime-corejs3/helpers/asyncToGenerator";
import _defineProperty from "@babel/runtime-corejs3/helpers/defineProperty";
import _classCallCheck from "@babel/runtime-corejs3/helpers/classCallCheck";
import _createClass from "@babel/runtime-corejs3/helpers/createClass";
function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? _Reflect$construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
import _regeneratorRuntime from "@babel/runtime-corejs3/regenerator";
function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context12, _context13; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context12 = ownKeys(Object(t), !0)).call(_context12, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context13 = ownKeys(Object(t))).call(_context13, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/slice";
import _endsWithInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/ends-with";
import _concatInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/concat";
import _includesInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/includes";
import "core-js/modules/es.error.cause.js";
import "core-js/modules/es.array.join.js";
import "core-js/modules/es.function.name.js";
import "core-js/modules/es.object.keys.js";
import "core-js/modules/es.array.push.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/es.regexp.exec.js";
import "core-js/modules/es.regexp.to-string.js";
import "core-js/modules/es.string.replace.js";
/**
*
*/
import { createHash, randomBytes } from 'crypto';
import querystring from 'querystring';
import Transport, { HttpProxyTransport, XdProxyTransport } from './transport';
var defaultOAuth2Config = {
loginUrl: 'https://login.salesforce.com'
};
// Makes a nodejs base64 encoded string compatible with rfc4648 alternative encoding for urls.
// @param base64Encoded a nodejs base64 encoded string
function base64UrlEscape(base64Encoded) {
// builtin node js base 64 encoding is not 64 url compatible.
// See https://toolsn.ietf.org/html/rfc4648#section-5
return base64Encoded.replace(/\+/g, '-').replace(/\//g, '_').replace(/=/g, '');
}
/**
* type defs
*/
/**
* OAuth2 class
*/
export var OAuth2 = /*#__PURE__*/function () {
/**
*
*/
function OAuth2(config) {
_classCallCheck(this, OAuth2);
var loginUrl = config.loginUrl,
authzServiceUrl = config.authzServiceUrl,
tokenServiceUrl = config.tokenServiceUrl,
revokeServiceUrl = config.revokeServiceUrl,
clientId = config.clientId,
clientSecret = config.clientSecret,
redirectUri = config.redirectUri,
proxyUrl = config.proxyUrl,
httpProxy = config.httpProxy,
useVerifier = config.useVerifier;
if (authzServiceUrl && tokenServiceUrl) {
var _context;
this.loginUrl = _sliceInstanceProperty(_context = authzServiceUrl.split('/')).call(_context, 0, 3).join('/');
this.authzServiceUrl = authzServiceUrl;
this.tokenServiceUrl = tokenServiceUrl;
this.revokeServiceUrl = revokeServiceUrl || "".concat(this.loginUrl, "/services/oauth2/revoke");
} else {
var _context2, _context3, _context4, _context5;
this.loginUrl = loginUrl !== null && loginUrl !== void 0 ? loginUrl : defaultOAuth2Config.loginUrl;
var maybeSlash = _endsWithInstanceProperty(_context2 = this.loginUrl).call(_context2, '/') ? '' : '/';
this.authzServiceUrl = _concatInstanceProperty(_context3 = "".concat(this.loginUrl)).call(_context3, maybeSlash, "services/oauth2/authorize");
this.tokenServiceUrl = _concatInstanceProperty(_context4 = "".concat(this.loginUrl)).call(_context4, maybeSlash, "services/oauth2/token");
this.revokeServiceUrl = _concatInstanceProperty(_context5 = "".concat(this.loginUrl)).call(_context5, maybeSlash, "services/oauth2/revoke");
}
this.clientId = clientId;
this.clientSecret = clientSecret;
this.redirectUri = redirectUri;
if (proxyUrl) {
this._transport = new XdProxyTransport(proxyUrl);
} else if (httpProxy) {
this._transport = new HttpProxyTransport(httpProxy);
} else {
this._transport = new Transport();
}
if (useVerifier) {
// Set a code verifier string for OAuth authorization
this.codeVerifier = base64UrlEscape(randomBytes(Math.ceil(128)).toString('base64'));
}
}
/**
* Get Salesforce OAuth2 authorization page URL to redirect user agent.
*/
return _createClass(OAuth2, [{
key: "getAuthorizationUrl",
value: function getAuthorizationUrl() {
var _context6;
var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
if (this.codeVerifier) {
// code verifier must be a base 64 url encoded hash of 128 bytes of random data. Our random data is also
// base 64 url encoded. See Connection.create();
params.code_challenge = base64UrlEscape(createHash('sha256').update(this.codeVerifier).digest('base64'));
}
var _params = _objectSpread(_objectSpread({}, params), {}, {
response_type: 'code',
client_id: this.clientId,
redirect_uri: this.redirectUri
});
return this.authzServiceUrl + (_includesInstanceProperty(_context6 = this.authzServiceUrl).call(_context6, '?') ? '&' : '?') + querystring.stringify(_params);
}
/**
* OAuth2 Refresh Token Flow
*/
}, {
key: "refreshToken",
value: (function () {
var _refreshToken2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(_refreshToken) {
var params, ret;
return _regeneratorRuntime.wrap(function _callee$(_context7) {
while (1) switch (_context7.prev = _context7.next) {
case 0:
if (this.clientId) {
_context7.next = 2;
break;
}
throw new Error('No OAuth2 client id information is specified');
case 2:
params = {
grant_type: 'refresh_token',
refresh_token: _refreshToken,
client_id: this.clientId
};
if (this.clientSecret) {
params.client_secret = this.clientSecret;
}
_context7.next = 6;
return this._postParams(params);
case 6:
ret = _context7.sent;
return _context7.abrupt("return", ret);
case 8:
case "end":
return _context7.stop();
}
}, _callee, this);
}));
function refreshToken(_x) {
return _refreshToken2.apply(this, arguments);
}
return refreshToken;
}()
/**
* Send access token request to the token endpoint.
* When a code (string) is passed in first argument, it will use Web Server Authentication Flow (Authorization Code Grant).
* Otherwise, it will use the specified `grant_type` and pass parameters to the endpoint.
*/
)
}, {
key: "requestToken",
value: (function () {
var _requestToken = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(codeOrParams) {
var params,
_params,
ret,
_args2 = arguments;
return _regeneratorRuntime.wrap(function _callee2$(_context8) {
while (1) switch (_context8.prev = _context8.next) {
case 0:
params = _args2.length > 1 && _args2[1] !== undefined ? _args2[1] : {};
if (!(typeof codeOrParams === 'string' && (!this.clientId || !this.redirectUri))) {
_context8.next = 3;
break;
}
throw new Error('No OAuth2 client id or redirect uri configuration is specified');
case 3:
_params = _objectSpread(_objectSpread({}, params), typeof codeOrParams === 'string' ? {
grant_type: 'authorization_code',
code: codeOrParams
} : codeOrParams);
if (this.clientId) {
_params.client_id = this.clientId;
}
if (this.clientSecret) {
_params.client_secret = this.clientSecret;
}
if (this.redirectUri) {
_params.redirect_uri = this.redirectUri;
}
_context8.next = 9;
return this._postParams(_params);
case 9:
ret = _context8.sent;
return _context8.abrupt("return", ret);
case 11:
case "end":
return _context8.stop();
}
}, _callee2, this);
}));
function requestToken(_x2) {
return _requestToken.apply(this, arguments);
}
return requestToken;
}()
/**
* OAuth2 Username-Password Flow (Resource Owner Password Credentials)
*/
)
}, {
key: "authenticate",
value: (function () {
var _authenticate = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3(username, password) {
var ret;
return _regeneratorRuntime.wrap(function _callee3$(_context9) {
while (1) switch (_context9.prev = _context9.next) {
case 0:
if (!(!this.clientId || !this.clientSecret)) {
_context9.next = 2;
break;
}
throw new Error('No valid OAuth2 client configuration set');
case 2:
_context9.next = 4;
return this._postParams({
grant_type: 'password',
username: username,
password: password,
client_id: this.clientId,
client_secret: this.clientSecret
});
case 4:
ret = _context9.sent;
return _context9.abrupt("return", ret);
case 6:
case "end":
return _context9.stop();
}
}, _callee3, this);
}));
function authenticate(_x3, _x4) {
return _authenticate.apply(this, arguments);
}
return authenticate;
}()
/**
* OAuth2 Revoke Session Token
*/
)
}, {
key: "revokeToken",
value: (function () {
var _revokeToken = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee4(token) {
var response, res;
return _regeneratorRuntime.wrap(function _callee4$(_context10) {
while (1) switch (_context10.prev = _context10.next) {
case 0:
_context10.next = 2;
return this._transport.httpRequest({
method: 'POST',
url: this.revokeServiceUrl,
body: querystring.stringify({
token: token
}),
headers: {
'content-type': 'application/x-www-form-urlencoded'
}
});
case 2:
response = _context10.sent;
if (!(response.statusCode >= 400)) {
_context10.next = 7;
break;
}
res = querystring.parse(response.body);
if (!res || !res.error) {
res = {
error: "ERROR_HTTP_".concat(response.statusCode),
error_description: response.body
};
}
throw new (/*#__PURE__*/function (_Error) {
function _class(_ref) {
var _this;
var error = _ref.error,
error_description = _ref.error_description;
_classCallCheck(this, _class);
_this = _callSuper(this, _class, [error_description]);
_this.name = error;
return _this;
}
_inherits(_class, _Error);
return _createClass(_class);
}(/*#__PURE__*/_wrapNativeSuper(Error)))(res);
case 7:
case "end":
return _context10.stop();
}
}, _callee4, this);
}));
function revokeToken(_x5) {
return _revokeToken.apply(this, arguments);
}
return revokeToken;
}()
/**
* @private
*/
)
}, {
key: "_postParams",
value: (function () {
var _postParams2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee5(params) {
var response, res;
return _regeneratorRuntime.wrap(function _callee5$(_context11) {
while (1) switch (_context11.prev = _context11.next) {
case 0:
if (this.codeVerifier) params.code_verifier = this.codeVerifier;
_context11.next = 3;
return this._transport.httpRequest({
method: 'POST',
url: this.tokenServiceUrl,
body: querystring.stringify(params),
headers: {
'content-type': 'application/x-www-form-urlencoded'
}
});
case 3:
response = _context11.sent;
try {
res = JSON.parse(response.body);
} catch (e) {
/* eslint-disable no-empty */
}
if (!(response.statusCode >= 400)) {
_context11.next = 8;
break;
}
res = res || {
error: "ERROR_HTTP_".concat(response.statusCode),
error_description: response.body
};
throw new (/*#__PURE__*/function (_Error2) {
function _class2(_ref2) {
var _this2;
var error = _ref2.error,
error_description = _ref2.error_description;
_classCallCheck(this, _class2);
_this2 = _callSuper(this, _class2, [error_description]);
_this2.name = error;
return _this2;
}
_inherits(_class2, _Error2);
return _createClass(_class2);
}(/*#__PURE__*/_wrapNativeSuper(Error)))(res);
case 8:
return _context11.abrupt("return", res);
case 9:
case "end":
return _context11.stop();
}
}, _callee5, this);
}));
function _postParams(_x6) {
return _postParams2.apply(this, arguments);
}
return _postParams;
}())
}]);
}();
export default OAuth2;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createHash","randomBytes","querystring","Transport","HttpProxyTransport","XdProxyTransport","defaultOAuth2Config","loginUrl","base64UrlEscape","base64Encoded","replace","OAuth2","config","_classCallCheck","authzServiceUrl","tokenServiceUrl","revokeServiceUrl","clientId","clientSecret","redirectUri","proxyUrl","httpProxy","useVerifier","_context","_sliceInstanceProperty","split","call","join","concat","_context2","_context3","_context4","_context5","maybeSlash","_endsWithInstanceProperty","_concatInstanceProperty","_transport","codeVerifier","Math","ceil","toString","_createClass","key","value","getAuthorizationUrl","_context6","params","arguments","length","undefined","code_challenge","update","digest","_params","_objectSpread","response_type","client_id","redirect_uri","_includesInstanceProperty","stringify","_refreshToken2","_asyncToGenerator","_regeneratorRuntime","mark","_callee","refreshToken","ret","wrap","_callee$","_context7","prev","next","Error","grant_type","refresh_token","client_secret","_postParams","sent","abrupt","stop","_x","apply","_requestToken","_callee2","codeOrParams","_args2","_callee2$","_context8","code","requestToken","_x2","_authenticate","_callee3","username","password","_callee3$","_context9","authenticate","_x3","_x4","_revokeToken","_callee4","token","response","res","_callee4$","_context10","httpRequest","method","url","body","headers","statusCode","parse","error","error_description","_Error","_class","_ref","_this","_callSuper","name","_inherits","_wrapNativeSuper","revokeToken","_x5","_postParams2","_callee5","_callee5$","_context11","code_verifier","JSON","e","_Error2","_class2","_ref2","_this2","_x6"],"sources":["../src/oauth2.ts"],"sourcesContent":["/**\n *\n */\nimport {createHash, randomBytes} from 'crypto';\nimport querystring from 'querystring';\nimport Transport, {HttpProxyTransport, XdProxyTransport} from './transport';\nimport {Optional} from './types';\n\nconst defaultOAuth2Config = {\n  loginUrl: 'https://login.salesforce.com',\n};\n\n// Makes a nodejs base64 encoded string compatible with rfc4648 alternative encoding for urls.\n// @param base64Encoded a nodejs base64 encoded string\nfunction base64UrlEscape(base64Encoded: string): string {\n  // builtin node js base 64 encoding is not 64 url compatible.\n  // See https://toolsn.ietf.org/html/rfc4648#section-5\n  return base64Encoded\n    .replace(/\\+/g, '-')\n    .replace(/\\//g, '_')\n    .replace(/=/g, '');\n}\n\n/**\n * type defs\n */\nexport type OAuth2Config = {\n  clientId?: string;\n  clientSecret?: string;\n  redirectUri?: string;\n  loginUrl?: string;\n  authzServiceUrl?: string;\n  tokenServiceUrl?: string;\n  revokeServiceUrl?: string;\n  proxyUrl?: string;\n  httpProxy?: string;\n  useVerifier?: boolean;\n};\n\nexport type AuthzRequestParams = {\n  scope?: string;\n  state?: string;\n  code_challenge?: string;\n} & {\n  [attr: string]: string;\n};\n\nexport type TokenResponse = {\n  token_type: 'Bearer';\n  /**\n   * Space-separated list of OAuth scopes associated with the access token\n   *\n   * For the OAuth 2.0 Web Server Flow, this can be a subset of the registered scopes if specified when requesting the auth code.\n   *\n   * See: https://help.salesforce.com/s/articleView?id=xcloud.remoteaccess_oauth_tokens_scopes.htm&type=5\n   */\n  scope: string;\n  /**\n   * Identity URL\n   *\n   * The format of the URL is https://login.salesforce.com/id/orgID/userID.\n   */\n  id: string;\n  access_token: string;\n  refresh_token?: string;\n  signature: string;\n  issued_at: string;\n  instance_url: string;\n  sfdc_community_url?: string;\n  sfdc_community_id?: string;\n};\n\n/**\n * OAuth2 class\n */\nexport class OAuth2 {\n  loginUrl: string;\n  authzServiceUrl: string;\n  tokenServiceUrl: string;\n  revokeServiceUrl: string;\n  clientId: Optional<string>;\n  clientSecret: Optional<string>;\n  redirectUri: Optional<string>;\n  codeVerifier: Optional<string>;\n\n  _transport: Transport;\n\n  /**\n   *\n   */\n  constructor(config: OAuth2Config) {\n    const {\n      loginUrl,\n      authzServiceUrl,\n      tokenServiceUrl,\n      revokeServiceUrl,\n      clientId,\n      clientSecret,\n      redirectUri,\n      proxyUrl,\n      httpProxy,\n      useVerifier,\n    } = config;\n    if (authzServiceUrl && tokenServiceUrl) {\n      this.loginUrl = authzServiceUrl.split('/').slice(0, 3).join('/');\n      this.authzServiceUrl = authzServiceUrl;\n      this.tokenServiceUrl = tokenServiceUrl;\n      this.revokeServiceUrl =\n        revokeServiceUrl || `${this.loginUrl}/services/oauth2/revoke`;\n    } else {\n      this.loginUrl = loginUrl ?? defaultOAuth2Config.loginUrl\n\n      const maybeSlash = this.loginUrl.endsWith('/') ? '' : '/'\n\n      this.authzServiceUrl = `${this.loginUrl}${maybeSlash}services/oauth2/authorize`\n      this.tokenServiceUrl = `${this.loginUrl}${maybeSlash}services/oauth2/token`\n      this.revokeServiceUrl = `${this.loginUrl}${maybeSlash}services/oauth2/revoke`\n    }\n    this.clientId = clientId;\n    this.clientSecret = clientSecret;\n    this.redirectUri = redirectUri;\n    if (proxyUrl) {\n      this._transport = new XdProxyTransport(proxyUrl);\n    } else if (httpProxy) {\n      this._transport = new HttpProxyTransport(httpProxy);\n    } else {\n      this._transport = new Transport();\n    }\n    if (useVerifier) {\n      // Set a code verifier string for OAuth authorization\n      this.codeVerifier = base64UrlEscape(\n        randomBytes(Math.ceil(128)).toString('base64'),\n      );\n    }\n  }\n\n  /**\n   * Get Salesforce OAuth2 authorization page URL to redirect user agent.\n   */\n  getAuthorizationUrl(params: AuthzRequestParams = {}) {\n    if (this.codeVerifier) {\n      // code verifier must be a base 64 url encoded hash of 128 bytes of random data. Our random data is also\n      // base 64 url encoded. See Connection.create();\n      params.code_challenge = base64UrlEscape(\n        createHash('sha256').update(this.codeVerifier).digest('base64'),\n      );\n    }\n\n    const _params = {\n      ...params,\n      response_type: 'code',\n      client_id: this.clientId,\n      redirect_uri: this.redirectUri,\n    };\n    return (\n      this.authzServiceUrl +\n      (this.authzServiceUrl.includes('?') ? '&' : '?') +\n      querystring.stringify(_params as { [name: string]: any })\n    );\n  }\n\n  /**\n   * OAuth2 Refresh Token Flow\n   */\n  async refreshToken(refreshToken: string): Promise<TokenResponse> {\n    if (!this.clientId) {\n      throw new Error('No OAuth2 client id information is specified');\n    }\n    const params: { [prop: string]: string } = {\n      grant_type: 'refresh_token',\n      refresh_token: refreshToken,\n      client_id: this.clientId,\n    };\n    if (this.clientSecret) {\n      params.client_secret = this.clientSecret;\n    }\n    const ret = await this._postParams(params);\n    return ret as TokenResponse;\n  }\n\n  /**\n   * Send access token request to the token endpoint.\n   * When a code (string) is passed in first argument, it will use Web Server Authentication Flow (Authorization Code Grant).\n   * Otherwise, it will use the specified `grant_type` and pass parameters to the endpoint.\n   */\n  async requestToken(\n    codeOrParams: string | { grant_type: string; [name: string]: string },\n    params: { [prop: string]: string } = {},\n  ): Promise<TokenResponse> {\n    if (\n      typeof codeOrParams === 'string' &&\n      (!this.clientId || !this.redirectUri)\n    ) {\n      throw new Error(\n        'No OAuth2 client id or redirect uri configuration is specified',\n      );\n    }\n    const _params: { [prop: string]: string } = {\n      ...params,\n      ...(typeof codeOrParams === 'string'\n        ? { grant_type: 'authorization_code', code: codeOrParams }\n        : codeOrParams),\n    };\n    if (this.clientId) {\n      _params.client_id = this.clientId;\n    }\n    if (this.clientSecret) {\n      _params.client_secret = this.clientSecret;\n    }\n    if (this.redirectUri) {\n      _params.redirect_uri = this.redirectUri;\n    }\n    const ret = await this._postParams(_params);\n    return ret as TokenResponse;\n  }\n\n  /**\n   * OAuth2 Username-Password Flow (Resource Owner Password Credentials)\n   */\n  async authenticate(\n    username: string,\n    password: string,\n  ): Promise<TokenResponse> {\n    if (!this.clientId || !this.clientSecret) {\n      throw new Error('No valid OAuth2 client configuration set');\n    }\n    const ret = await this._postParams({\n      grant_type: 'password',\n      username,\n      password,\n      client_id: this.clientId,\n      client_secret: this.clientSecret,\n    });\n    return ret as TokenResponse;\n  }\n\n  /**\n   * OAuth2 Revoke Session Token\n   */\n  async revokeToken(token: string): Promise<void> {\n    const response = await this._transport.httpRequest({\n      method: 'POST',\n      url: this.revokeServiceUrl,\n      body: querystring.stringify({ token }),\n      headers: {\n        'content-type': 'application/x-www-form-urlencoded',\n      },\n    });\n    if (response.statusCode >= 400) {\n      let res: any = querystring.parse(response.body);\n      if (!res || !res.error) {\n        res = {\n          error: `ERROR_HTTP_${response.statusCode}`,\n          error_description: response.body,\n        };\n      }\n      throw new (class extends Error {\n        constructor({\n          error,\n          error_description,\n        }: {\n          error: string;\n          error_description: string;\n        }) {\n          super(error_description);\n          this.name = error;\n        }\n      })(res);\n    }\n  }\n\n  /**\n   * @private\n   */\n  async _postParams(params: { [name: string]: string }): Promise<any> {\n    if (this.codeVerifier) params.code_verifier = this.codeVerifier;\n\n    const response = await this._transport.httpRequest({\n      method: 'POST',\n      url: this.tokenServiceUrl,\n      body: querystring.stringify(params),\n      headers: {\n        'content-type': 'application/x-www-form-urlencoded',\n      },\n    });\n    let res;\n    try {\n      res = JSON.parse(response.body);\n    } catch (e) {\n      /* eslint-disable no-empty */\n    }\n    if (response.statusCode >= 400) {\n      res = res || {\n        error: `ERROR_HTTP_${response.statusCode}`,\n        error_description: response.body,\n      };\n      throw new (class extends Error {\n        constructor({\n          error,\n          error_description,\n        }: {\n          error: string;\n          error_description: string;\n        }) {\n          super(error_description);\n          this.name = error;\n        }\n      })(res);\n    }\n    return res;\n  }\n}\n\nexport default OAuth2;\n"],"mappings":"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","ignoreList":[]}