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   * 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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA,SAAQA,UAAU,EAAEC,WAAW,QAAO,QAAQ;AAC9C,OAAOC,WAAW,MAAM,aAAa;AACrC,OAAOC,SAAS,IAAGC,kBAAkB,EAAEC,gBAAgB,QAAO,aAAa;AAG3E,IAAMC,mBAAmB,GAAG;EAC1BC,QAAQ,EAAE;AACZ,CAAC;;AAED;AACA;AACA,SAASC,eAAeA,CAACC,aAAqB,EAAU;EACtD;EACA;EACA,OAAOA,aAAa,CACjBC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CACnBA,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CACnBA,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;AACtB;;AAEA;AACA;AACA;;AAuCA;AACA;AACA;AACA,WAAaC,MAAM;EAYjB;AACF;AACA;EACE,SAAAA,OAAYC,MAAoB,EAAE;IAAAC,eAAA,OAAAF,MAAA;IAChC,IACEJ,QAAQ,GAUNK,MAAM,CAVRL,QAAQ;MACRO,eAAe,GASbF,MAAM,CATRE,eAAe;MACfC,eAAe,GAQbH,MAAM,CARRG,eAAe;MACfC,gBAAgB,GAOdJ,MAAM,CAPRI,gBAAgB;MAChBC,QAAQ,GAMNL,MAAM,CANRK,QAAQ;MACRC,YAAY,GAKVN,MAAM,CALRM,YAAY;MACZC,WAAW,GAITP,MAAM,CAJRO,WAAW;MACXC,QAAQ,GAGNR,MAAM,CAHRQ,QAAQ;MACRC,SAAS,GAEPT,MAAM,CAFRS,SAAS;MACTC,WAAW,GACTV,MAAM,CADRU,WAAW;IAEb,IAAIR,eAAe,IAAIC,eAAe,EAAE;MAAA,IAAAQ,QAAA;MACtC,IAAI,CAAChB,QAAQ,GAAGiB,sBAAA,CAAAD,QAAA,GAAAT,eAAe,CAACW,KAAK,CAAC,GAAG,CAAC,EAAAC,IAAA,CAAAH,QAAA,EAAO,CAAC,EAAE,CAAC,CAAC,CAACI,IAAI,CAAC,GAAG,CAAC;MAChE,IAAI,CAACb,eAAe,GAAGA,eAAe;MACtC,IAAI,CAACC,eAAe,GAAGA,eAAe;MACtC,IAAI,CAACC,gBAAgB,GACnBA,gBAAgB,OAAAY,MAAA,CAAO,IAAI,CAACrB,QAAQ,4BAAyB;IACjE,CAAC,MAAM;MAAA,IAAAsB,SAAA,EAAAC,SAAA,EAAAC,SAAA,EAAAC,SAAA;MACL,IAAI,CAACzB,QAAQ,GAAGA,QAAQ,aAARA,QAAQ,cAARA,QAAQ,GAAID,mBAAmB,CAACC,QAAQ;MAExD,IAAM0B,UAAU,GAAGC,yBAAA,CAAAL,SAAA,OAAI,CAACtB,QAAQ,EAAAmB,IAAA,CAAAG,SAAA,EAAU,GAAG,CAAC,GAAG,EAAE,GAAG,GAAG;MAEzD,IAAI,CAACf,eAAe,GAAAqB,uBAAA,CAAAL,SAAA,MAAAF,MAAA,CAAM,IAAI,CAACrB,QAAQ,GAAAmB,IAAA,CAAAI,SAAA,EAAGG,UAAU,8BAA2B;MAC/E,IAAI,CAAClB,eAAe,GAAAoB,uBAAA,CAAAJ,SAAA,MAAAH,MAAA,CAAM,IAAI,CAACrB,QAAQ,GAAAmB,IAAA,CAAAK,SAAA,EAAGE,UAAU,0BAAuB;MAC3E,IAAI,CAACjB,gBAAgB,GAAAmB,uBAAA,CAAAH,SAAA,MAAAJ,MAAA,CAAM,IAAI,CAACrB,QAAQ,GAAAmB,IAAA,CAAAM,SAAA,EAAGC,UAAU,2BAAwB;IAC/E;IACA,IAAI,CAAChB,QAAQ,GAAGA,QAAQ;IACxB,IAAI,CAACC,YAAY,GAAGA,YAAY;IAChC,IAAI,CAACC,WAAW,GAAGA,WAAW;IAC9B,IAAIC,QAAQ,EAAE;MACZ,IAAI,CAACgB,UAAU,GAAG,IAAI/B,gBAAgB,CAACe,QAAQ,CAAC;IAClD,CAAC,MAAM,IAAIC,SAAS,EAAE;MACpB,IAAI,CAACe,UAAU,GAAG,IAAIhC,kBAAkB,CAACiB,SAAS,CAAC;IACrD,CAAC,MAAM;MACL,IAAI,CAACe,UAAU,GAAG,IAAIjC,SAAS,CAAC,CAAC;IACnC;IACA,IAAImB,WAAW,EAAE;MACf;MACA,IAAI,CAACe,YAAY,GAAG7B,eAAe,CACjCP,WAAW,CAACqC,IAAI,CAACC,IAAI,CAAC,GAAG,CAAC,CAAC,CAACC,QAAQ,CAAC,QAAQ,CAC/C,CAAC;IACH;EACF;;EAEA;AACF;AACA;EAFE,OAAAC,YAAA,CAAA9B,MAAA;IAAA+B,GAAA;IAAAC,KAAA,EAGA,SAAAC,mBAAmBA,CAAA,EAAkC;MAAA,IAAAC,SAAA;MAAA,IAAjCC,MAA0B,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC,CAAC;MACjD,IAAI,IAAI,CAACV,YAAY,EAAE;QACrB;QACA;QACAS,MAAM,CAACI,cAAc,GAAG1C,eAAe,CACrCR,UAAU,CAAC,QAAQ,CAAC,CAACmD,MAAM,CAAC,IAAI,CAACd,YAAY,CAAC,CAACe,MAAM,CAAC,QAAQ,CAChE,CAAC;MACH;MAEA,IAAMC,OAAO,GAAAC,aAAA,CAAAA,aAAA,KACRR,MAAM;QACTS,aAAa,EAAE,MAAM;QACrBC,SAAS,EAAE,IAAI,CAACvC,QAAQ;QACxBwC,YAAY,EAAE,IAAI,CAACtC;MAAW,EAC/B;MACD,OACE,IAAI,CAACL,eAAe,IACnB4C,yBAAA,CAAAb,SAAA,OAAI,CAAC/B,eAAe,EAAAY,IAAA,CAAAmB,SAAA,EAAU,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,GAChD3C,WAAW,CAACyD,SAAS,CAACN,OAAkC,CAAC;IAE7D;;IAEA;AACF;AACA;EAFE;IAAAX,GAAA;IAAAC,KAAA;MAAA,IAAAiB,cAAA,GAAAC,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAGA,SAAAC,QAAmBC,aAAoB;QAAA,IAAAnB,MAAA,EAAAoB,GAAA;QAAA,OAAAJ,mBAAA,CAAAK,IAAA,UAAAC,SAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAAC,IAAA,GAAAD,SAAA,CAAAE,IAAA;YAAA;cAAA,IAChC,IAAI,CAACtD,QAAQ;gBAAAoD,SAAA,CAAAE,IAAA;gBAAA;cAAA;cAAA,MACV,IAAIC,KAAK,CAAC,8CAA8C,CAAC;YAAA;cAE3D1B,MAAkC,GAAG;gBACzC2B,UAAU,EAAE,eAAe;gBAC3BC,aAAa,EAAET,aAAY;gBAC3BT,SAAS,EAAE,IAAI,CAACvC;cAClB,CAAC;cACD,IAAI,IAAI,CAACC,YAAY,EAAE;gBACrB4B,MAAM,CAAC6B,aAAa,GAAG,IAAI,CAACzD,YAAY;cAC1C;cAACmD,SAAA,CAAAE,IAAA;cAAA,OACiB,IAAI,CAACK,WAAW,CAAC9B,MAAM,CAAC;YAAA;cAApCoB,GAAG,GAAAG,SAAA,CAAAQ,IAAA;cAAA,OAAAR,SAAA,CAAAS,MAAA,WACFZ,GAAG;YAAA;YAAA;cAAA,OAAAG,SAAA,CAAAU,IAAA;UAAA;QAAA,GAAAf,OAAA;MAAA,CACX;MAAA,SAdKC,YAAYA,CAAAe,EAAA;QAAA,OAAApB,cAAA,CAAAqB,KAAA,OAAAlC,SAAA;MAAA;MAAA,OAAZkB,YAAY;IAAA;IAgBlB;AACF;AACA;AACA;AACA;IAJE;EAAA;IAAAvB,GAAA;IAAAC,KAAA;MAAA,IAAAuC,aAAA,GAAArB,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAKA,SAAAoB,SACEC,YAAqE;QAAA,IAAAtC,MAAA;UAAAO,OAAA;UAAAa,GAAA;UAAAmB,MAAA,GAAAtC,SAAA;QAAA,OAAAe,mBAAA,CAAAK,IAAA,UAAAmB,UAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAAjB,IAAA,GAAAiB,SAAA,CAAAhB,IAAA;YAAA;cACrEzB,MAAkC,GAAAuC,MAAA,CAAArC,MAAA,QAAAqC,MAAA,QAAApC,SAAA,GAAAoC,MAAA,MAAG,CAAC,CAAC;cAAA,MAGrC,OAAOD,YAAY,KAAK,QAAQ,KAC/B,CAAC,IAAI,CAACnE,QAAQ,IAAI,CAAC,IAAI,CAACE,WAAW,CAAC;gBAAAoE,SAAA,CAAAhB,IAAA;gBAAA;cAAA;cAAA,MAE/B,IAAIC,KAAK,CACb,gEACF,CAAC;YAAA;cAEGnB,OAAmC,GAAAC,aAAA,CAAAA,aAAA,KACpCR,MAAM,GACL,OAAOsC,YAAY,KAAK,QAAQ,GAChC;gBAAEX,UAAU,EAAE,oBAAoB;gBAAEe,IAAI,EAAEJ;cAAa,CAAC,GACxDA,YAAY;cAElB,IAAI,IAAI,CAACnE,QAAQ,EAAE;gBACjBoC,OAAO,CAACG,SAAS,GAAG,IAAI,CAACvC,QAAQ;cACnC;cACA,IAAI,IAAI,CAACC,YAAY,EAAE;gBACrBmC,OAAO,CAACsB,aAAa,GAAG,IAAI,CAACzD,YAAY;cAC3C;cACA,IAAI,IAAI,CAACC,WAAW,EAAE;gBACpBkC,OAAO,CAACI,YAAY,GAAG,IAAI,CAACtC,WAAW;cACzC;cAACoE,SAAA,CAAAhB,IAAA;cAAA,OACiB,IAAI,CAACK,WAAW,CAACvB,OAAO,CAAC;YAAA;cAArCa,GAAG,GAAAqB,SAAA,CAAAV,IAAA;cAAA,OAAAU,SAAA,CAAAT,MAAA,WACFZ,GAAG;YAAA;YAAA;cAAA,OAAAqB,SAAA,CAAAR,IAAA;UAAA;QAAA,GAAAI,QAAA;MAAA,CACX;MAAA,SA7BKM,YAAYA,CAAAC,GAAA;QAAA,OAAAR,aAAA,CAAAD,KAAA,OAAAlC,SAAA;MAAA;MAAA,OAAZ0C,YAAY;IAAA;IA+BlB;AACF;AACA;IAFE;EAAA;IAAA/C,GAAA;IAAAC,KAAA;MAAA,IAAAgD,aAAA,GAAA9B,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAGA,SAAA6B,SACEC,QAAgB,EAChBC,QAAgB;QAAA,IAAA5B,GAAA;QAAA,OAAAJ,mBAAA,CAAAK,IAAA,UAAA4B,UAAAC,SAAA;UAAA,kBAAAA,SAAA,CAAA1B,IAAA,GAAA0B,SAAA,CAAAzB,IAAA;YAAA;cAAA,MAEZ,CAAC,IAAI,CAACtD,QAAQ,IAAI,CAAC,IAAI,CAACC,YAAY;gBAAA8E,SAAA,CAAAzB,IAAA;gBAAA;cAAA;cAAA,MAChC,IAAIC,KAAK,CAAC,0CAA0C,CAAC;YAAA;cAAAwB,SAAA,CAAAzB,IAAA;cAAA,OAE3C,IAAI,CAACK,WAAW,CAAC;gBACjCH,UAAU,EAAE,UAAU;gBACtBoB,QAAQ,EAARA,QAAQ;gBACRC,QAAQ,EAARA,QAAQ;gBACRtC,SAAS,EAAE,IAAI,CAACvC,QAAQ;gBACxB0D,aAAa,EAAE,IAAI,CAACzD;cACtB,CAAC,CAAC;YAAA;cANIgD,GAAG,GAAA8B,SAAA,CAAAnB,IAAA;cAAA,OAAAmB,SAAA,CAAAlB,MAAA,WAOFZ,GAAG;YAAA;YAAA;cAAA,OAAA8B,SAAA,CAAAjB,IAAA;UAAA;QAAA,GAAAa,QAAA;MAAA,CACX;MAAA,SAfKK,YAAYA,CAAAC,GAAA,EAAAC,GAAA;QAAA,OAAAR,aAAA,CAAAV,KAAA,OAAAlC,SAAA;MAAA;MAAA,OAAZkD,YAAY;IAAA;IAiBlB;AACF;AACA;IAFE;EAAA;IAAAvD,GAAA;IAAAC,KAAA;MAAA,IAAAyD,YAAA,GAAAvC,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAGA,SAAAsC,SAAkBC,KAAa;QAAA,IAAAC,QAAA,EAAAC,GAAA;QAAA,OAAA1C,mBAAA,CAAAK,IAAA,UAAAsC,UAAAC,UAAA;UAAA,kBAAAA,UAAA,CAAApC,IAAA,GAAAoC,UAAA,CAAAnC,IAAA;YAAA;cAAAmC,UAAA,CAAAnC,IAAA;cAAA,OACN,IAAI,CAACnC,UAAU,CAACuE,WAAW,CAAC;gBACjDC,MAAM,EAAE,MAAM;gBACdC,GAAG,EAAE,IAAI,CAAC7F,gBAAgB;gBAC1B8F,IAAI,EAAE5G,WAAW,CAACyD,SAAS,CAAC;kBAAE2C,KAAK,EAALA;gBAAM,CAAC,CAAC;gBACtCS,OAAO,EAAE;kBACP,cAAc,EAAE;gBAClB;cACF,CAAC,CAAC;YAAA;cAPIR,QAAQ,GAAAG,UAAA,CAAA7B,IAAA;cAAA,MAQV0B,QAAQ,CAACS,UAAU,IAAI,GAAG;gBAAAN,UAAA,CAAAnC,IAAA;gBAAA;cAAA;cACxBiC,GAAQ,GAAGtG,WAAW,CAAC+G,KAAK,CAACV,QAAQ,CAACO,IAAI,CAAC;cAC/C,IAAI,CAACN,GAAG,IAAI,CAACA,GAAG,CAACU,KAAK,EAAE;gBACtBV,GAAG,GAAG;kBACJU,KAAK,gBAAAtF,MAAA,CAAgB2E,QAAQ,CAACS,UAAU,CAAE;kBAC1CG,iBAAiB,EAAEZ,QAAQ,CAACO;gBAC9B,CAAC;cACH;cAAC,MACK,4BAAAM,MAAA;gBACJ,SAAAC,OAAAC,IAAA,EAMG;kBAAA,IAAAC,KAAA;kBAAA,IALDL,KAAK,GAAAI,IAAA,CAALJ,KAAK;oBACLC,iBAAiB,GAAAG,IAAA,CAAjBH,iBAAiB;kBAAAtG,eAAA,OAAAwG,MAAA;kBAKjBE,KAAA,GAAAC,UAAA,OAAAH,MAAA,GAAMF,iBAAiB;kBACvBI,KAAA,CAAKE,IAAI,GAAGP,KAAK;kBAAC,OAAAK,KAAA;gBACpB;gBAACG,SAAA,CAAAL,MAAA,EAAAD,MAAA;gBAAA,OAAA3E,YAAA,CAAA4E,MAAA;cAAA,eAAAM,gBAAA,CAVsBnD,KAAK,IAW3BgC,GAAG,CAAC;YAAA;YAAA;cAAA,OAAAE,UAAA,CAAA3B,IAAA;UAAA;QAAA,GAAAsB,QAAA;MAAA,CAEV;MAAA,SA9BKuB,WAAWA,CAAAC,GAAA;QAAA,OAAAzB,YAAA,CAAAnB,KAAA,OAAAlC,SAAA;MAAA;MAAA,OAAX6E,WAAW;IAAA;IAgCjB;AACF;AACA;IAFE;EAAA;IAAAlF,GAAA;IAAAC,KAAA;MAAA,IAAAmF,YAAA,GAAAjE,iBAAA,cAAAC,mBAAA,CAAAC,IAAA,CAGA,SAAAgE,SAAkBjF,MAAkC;QAAA,IAAAyD,QAAA,EAAAC,GAAA;QAAA,OAAA1C,mBAAA,CAAAK,IAAA,UAAA6D,UAAAC,UAAA;UAAA,kBAAAA,UAAA,CAAA3D,IAAA,GAAA2D,UAAA,CAAA1D,IAAA;YAAA;cAClD,IAAI,IAAI,CAAClC,YAAY,EAAES,MAAM,CAACoF,aAAa,GAAG,IAAI,CAAC7F,YAAY;cAAC4F,UAAA,CAAA1D,IAAA;cAAA,OAEzC,IAAI,CAACnC,UAAU,CAACuE,WAAW,CAAC;gBACjDC,MAAM,EAAE,MAAM;gBACdC,GAAG,EAAE,IAAI,CAAC9F,eAAe;gBACzB+F,IAAI,EAAE5G,WAAW,CAACyD,SAAS,CAACb,MAAM,CAAC;gBACnCiE,OAAO,EAAE;kBACP,cAAc,EAAE;gBAClB;cACF,CAAC,CAAC;YAAA;cAPIR,QAAQ,GAAA0B,UAAA,CAAApD,IAAA;cASd,IAAI;gBACF2B,GAAG,GAAG2B,IAAI,CAAClB,KAAK,CAACV,QAAQ,CAACO,IAAI,CAAC;cACjC,CAAC,CAAC,OAAOsB,CAAC,EAAE;gBACV;cAAA;cACD,MACG7B,QAAQ,CAACS,UAAU,IAAI,GAAG;gBAAAiB,UAAA,CAAA1D,IAAA;gBAAA;cAAA;cAC5BiC,GAAG,GAAGA,GAAG,IAAI;gBACXU,KAAK,gBAAAtF,MAAA,CAAgB2E,QAAQ,CAACS,UAAU,CAAE;gBAC1CG,iBAAiB,EAAEZ,QAAQ,CAACO;cAC9B,CAAC;cAAC,MACI,4BAAAuB,OAAA;gBACJ,SAAAC,QAAAC,KAAA,EAMG;kBAAA,IAAAC,MAAA;kBAAA,IALDtB,KAAK,GAAAqB,KAAA,CAALrB,KAAK;oBACLC,iBAAiB,GAAAoB,KAAA,CAAjBpB,iBAAiB;kBAAAtG,eAAA,OAAAyH,OAAA;kBAKjBE,MAAA,GAAAhB,UAAA,OAAAc,OAAA,GAAMnB,iBAAiB;kBACvBqB,MAAA,CAAKf,IAAI,GAAGP,KAAK;kBAAC,OAAAsB,MAAA;gBACpB;gBAACd,SAAA,CAAAY,OAAA,EAAAD,OAAA;gBAAA,OAAA5F,YAAA,CAAA6F,OAAA;cAAA,eAAAX,gBAAA,CAVsBnD,KAAK,IAW3BgC,GAAG,CAAC;YAAA;cAAA,OAAAyB,UAAA,CAAAnD,MAAA,WAEF0B,GAAG;YAAA;YAAA;cAAA,OAAAyB,UAAA,CAAAlD,IAAA;UAAA;QAAA,GAAAgD,QAAA;MAAA,CACX;MAAA,SApCKnD,WAAWA,CAAA6D,GAAA;QAAA,OAAAX,YAAA,CAAA7C,KAAA,OAAAlC,SAAA;MAAA;MAAA,OAAX6B,WAAW;IAAA;EAAA;AAAA;AAuCnB,eAAejE,MAAM","ignoreList":[]}