@cloudbase/oauth 3.0.3 → 3.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -31,6 +31,7 @@ export interface AuthOptions {
31
31
  eventBus?: any;
32
32
  detectSessionInUrl?: boolean;
33
33
  debug?: boolean;
34
+ auth?: ICloudbaseConfig['auth'];
34
35
  }
35
36
  export declare class Auth {
36
37
  private static parseParamsToSearch;
@@ -1265,4 +1265,4 @@ var Auth = (function () {
1265
1265
  return Auth;
1266
1266
  }());
1267
1267
  exports.Auth = Auth;
1268
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apis.js","sourceRoot":"","sources":["../../../src/auth/apis.ts"],"names":[],"mappings":"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","sourcesContent":["'use strict'\n\nimport { ApiUrls, ApiUrlsV2, AUTH_STATE_CHANGED_TYPE, ErrorType, EVENTS, OAUTH_TYPE } from './consts'\nimport {\n  GetVerificationRequest,\n  GetVerificationResponse,\n  UserProfile,\n  UserInfo,\n  SignInRequest,\n  SignUpRequest,\n  VerifyRequest,\n  VerifyResponse,\n  GenProviderRedirectUriRequest,\n  GenProviderRedirectUriResponse,\n  GrantProviderTokenRequest,\n  GrantProviderTokenResponse,\n  PatchProviderTokenRequest,\n  PatchProviderTokenResponse,\n  SignInWithProviderRequest,\n  SignInCustomRequest,\n  BindWithProviderRequest,\n  TransByProviderRequest,\n  GrantTokenRequest,\n  UnbindProviderRequest,\n  CheckPasswordRequest,\n  SetPasswordRequest,\n  ChangeBoundProviderRequest,\n  ChangeBoundProviderResponse,\n  UpdatePasswordRequest,\n  SudoResponse,\n  SudoRequest,\n  GetCustomSignTicketFn,\n  QueryUserProfileRequest,\n  QueryUserProfileResponse,\n  ResetPasswordRequest,\n  DeviceAuthorizeRequest,\n  DeviceAuthorizeResponse,\n  CheckUsernameRequest,\n  CheckIfUserExistRequest,\n  CheckIfUserExistResponse,\n  WithSudoRequest,\n  PublicKey,\n  EncryptParams,\n  ProviderSubType,\n  GetMiniProgramQrCodeRequest,\n  GetMiniProgramQrCodeStatusRequest,\n  GetMiniProgramQrCodeResponse,\n  GetMiniProgramQrCodeStatusResponse,\n  ModifyUserBasicInfoRequest,\n  EditContactRequest,\n  AuthorizeInfoRequest,\n  AuthorizeInfoResponse,\n  AuthorizeDeviceRequest,\n  AuthorizeRequest,\n  AuthorizeResponse,\n  GetUserBehaviorLog,\n  GetUserBehaviorLogRes,\n  RevokeDeviceRequest,\n  SignoutResponse,\n  ProvidersResponse,\n  SignoutRequest,\n  ModifyPasswordWithoutLoginRequest,\n} from './models'\nimport { SimpleStorage, RequestFunction } from '../oauth2client/interface'\nimport { OAuth2Client, defaultStorage } from '../oauth2client/oauth2client'\nimport { Credentials } from '../oauth2client/models'\nimport { Captcha, CaptchaOptions } from '../captcha/captcha'\nimport { deepClone } from '../utils'\nimport MyURLSearchParams from '../utils/urlSearchParams'\nimport { SDKAdapterInterface } from '@cloudbase/adapter-interface'\nimport { ICloudbaseConfig } from '@cloudbase/types'\nimport { AuthError } from './auth-error'\n\nasync function getEncryptUtils(isEncrypt, adapter: SDKAdapterInterface) {\n  const getUtils = async () => {\n    try {\n      /* eslint-disable */\n      // @ts-ignore\n      const utils = require('../utils/encrypt')\n      /* eslint-enable */\n      return utils\n    } catch (error) {\n      try {\n        // @ts-ignore\n        const utils = await import('../utils/encrypt')\n        return utils\n      } catch (error) {\n        return\n      }\n    }\n  }\n\n  try {\n    if ((adapter?.root?.globalThis || globalThis).IS_MP_BUILD) {\n      return\n    }\n\n    if (!process.env.IS_MP_BUILD && isEncrypt) {\n      return getUtils()\n    }\n  } catch (error) {\n    if (isEncrypt) {\n      return getUtils()\n    }\n  }\n}\n\nexport interface AuthOptions {\n  apiOrigin: string\n  apiPath?: string\n  clientId: string\n  /**\n   * basic auth\n   */\n  clientSecret?: string\n  credentialsClient?: OAuth2Client\n  request?: RequestFunction\n  baseRequest?: RequestFunction\n  storage?: SimpleStorage\n  anonymousSignInFunc?: (Credentials) => Promise<Credentials | void>\n  captchaOptions?: Partial<CaptchaOptions>\n  env?: string\n  wxCloud?: any\n  adapter?: SDKAdapterInterface\n  onCredentialsError?: (data: { msg: string; eventType?: 'credentials_error' }) => void\n  headers?: { [key: string]: string }\n  i18n?: ICloudbaseConfig['i18n']\n  useWxCloud?: boolean\n  eventBus?: any\n  /**\n   * Set to true if you want to automatically detect OAuth grants in the URL\n   * and exchange the code for credentials.\n   */\n  detectSessionInUrl?: boolean\n  /**\n   * Enable debug logging\n   */\n  debug?: boolean\n}\n\n/**\n * Auth\n */\nexport class Auth {\n  private static parseParamsToSearch(params: any): string {\n    Object.keys(params).forEach((key) => {\n      if (!params[key]) {\n        delete params[key]\n      }\n    })\n    const searchParams = new MyURLSearchParams(params as any)\n    return searchParams.toString()\n  }\n\n  private config: AuthOptions\n  private getCustomSignTicketFn?: GetCustomSignTicketFn\n\n  /**\n   * constructor\n   * @param {AuthOptions} opts\n   */\n  constructor(opts: AuthOptions) {\n    let { request } = opts\n    let oAuth2Client = opts.credentialsClient\n    if (!oAuth2Client) {\n      const initOptions = {\n        apiOrigin: opts.apiOrigin,\n        apiPath: opts.apiPath,\n        clientId: opts.clientId,\n        storage: opts.storage,\n        env: opts.env,\n        baseRequest: opts.baseRequest /* || opts.request */, // opts.request 废弃不用来表示 oauth rquest\n        anonymousSignInFunc: opts.anonymousSignInFunc,\n        wxCloud: opts.wxCloud,\n        onCredentialsError: opts.onCredentialsError,\n        headers: opts.headers || {},\n        i18n: opts.i18n,\n        debug: opts.debug,\n      }\n      oAuth2Client = new OAuth2Client(initOptions)\n    }\n    if (!request) {\n      const baseRequest = oAuth2Client.request.bind(oAuth2Client)\n      const captcha = new Captcha({\n        env: opts.env,\n        clientId: opts.clientId,\n        request: baseRequest,\n        storage: opts.storage,\n        adapter: opts.adapter,\n        oauthInstance: this,\n        ...opts.captchaOptions,\n      })\n      request = captcha.request.bind(captcha)\n    }\n    this.config = {\n      env: opts.env,\n      apiOrigin: opts.apiOrigin,\n      apiPath: opts.apiPath,\n      clientId: opts.clientId,\n      request,\n      credentialsClient: oAuth2Client,\n      storage: opts.storage || defaultStorage,\n      adapter: opts.adapter,\n    }\n  }\n\n  /**\n   * 根据版本标识，处理待请求的url和params\n   * @param params\n   * @param key\n   * @returns\n   */\n  public getParamsByVersion(params: any, key: string) {\n    const paramsTemp = deepClone(params)\n    const url = { v2: ApiUrlsV2 }[paramsTemp?.version]?.[key] || ApiUrls[key]\n\n    if (paramsTemp) {\n      delete paramsTemp.version\n    }\n\n    return { params: paramsTemp, url }\n  }\n\n  /**\n   * Sign in.\n   * @param {SignInRequest} params A SignInRequest Object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signIn(params: SignInRequest): Promise<Credentials> {\n    const version = params.version || 'v1'\n    const res = this.getParamsByVersion(params, 'AUTH_SIGN_IN_URL')\n    if (res.params.query) {\n      delete res.params.query\n    }\n\n    const body = await this.getEncryptParams(res.params)\n    const credentials: Credentials = await this.config.request<Credentials>(res.url, {\n      method: 'POST',\n      body,\n    })\n    await this.config.credentialsClient.setCredentials({\n      ...credentials,\n      version,\n    })\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * Sign in Anonymously\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInAnonymously(\n    data: {\n      provider_token?: string\n    } = {},\n    useWxCloud = false,\n  ): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_IN_ANONYMOUSLY_URL, {\n      method: 'POST',\n      body: data,\n      useWxCloud,\n    })\n    await this.config.credentialsClient.setCredentials(credentials)\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * Sign up.\n   * @param {SignUpRequest} params A SignUpRequest Object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signUp(params: SignUpRequest): Promise<Credentials> {\n    const data: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_UP_URL, {\n      method: 'POST',\n      body: params,\n    })\n    await this.config.credentialsClient.setCredentials(data)\n    return Promise.resolve(data)\n  }\n\n  /**\n   * Sign out.\n   * @return {Object} A Promise<SignoutRequest> object.\n   */\n  public async signOut(params?: SignoutRequest): Promise<SignoutResponse> {\n    let resp: SignoutResponse = {}\n    if (params) {\n      try {\n        resp = await this.config.request<SignoutResponse>(ApiUrls.AUTH_SIGNOUT_URL, {\n          method: 'POST',\n          withCredentials: true,\n          body: params,\n        })\n      } catch (err) {\n        if (err.error !== ErrorType.UNAUTHENTICATED) {\n          console.log('sign_out_error', err)\n        }\n      }\n      await this.config.credentialsClient.setCredentials()\n      return resp\n    }\n    const accessToken: string = await this.config.credentialsClient.getAccessToken()\n    const data = await this.config.request(ApiUrls.AUTH_REVOKE_URL, {\n      method: 'POST',\n      body: {\n        token: accessToken,\n      },\n    })\n    await this.config.credentialsClient.setCredentials()\n    return Promise.resolve(data)\n  }\n\n  /**\n   * Revoke All Devices\n   * @return {Object} A Promise<void> object.\n   */\n  public async revokeAllDevices(): Promise<void> {\n    await this.config.request<void>(ApiUrls.AUTH_REVOKE_ALL_URL, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Revoke Device\n   * @return {Object} A Promise<void> object.\n   */\n  public async revokeDevice(params: RevokeDeviceRequest): Promise<void> {\n    await this.config.request<void>(ApiUrls.AUTHORIZED_DEVICES_DELETE_URL + params.device_id, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Get the verification.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async getVerification(\n    params: GetVerificationRequest,\n    options?: { withCaptcha: boolean },\n  ): Promise<GetVerificationResponse> {\n    let withCredentials = false\n    // 发送短信时，如果时给当前用户发，则需要带上鉴权信息\n    if (params.target === 'CUR_USER') {\n      withCredentials = true\n    } else {\n      const hasLogin = await this.hasLoginState()\n      if (hasLogin) {\n        withCredentials = true\n      }\n    }\n\n    const body = deepClone(params)\n\n    if (body.phone_number && !/^\\+\\d{1,3}\\s+\\d+/.test(body.phone_number)) {\n      body.phone_number = `+86 ${body.phone_number}`\n    }\n\n    return this.config.request<GetVerificationResponse>(ApiUrls.VERIFICATION_URL, {\n      method: 'POST',\n      body,\n      withCaptcha: options?.withCaptcha || false,\n      withCredentials,\n    })\n  }\n\n  /**\n   *  Verify the code\n   * @param {VerifyRequest} params A VerifyRequest Object.\n   * @return {Promise<VerifyResponse>} A Promise<VerifyResponse> object.\n   */\n  public async verify(params: VerifyRequest): Promise<VerifyResponse> {\n    const res = this.getParamsByVersion(params, 'VERIFY_URL')\n    const data = await this.config.request<VerifyResponse>(res.url, {\n      method: 'POST',\n      body: res.params,\n    })\n\n    if (params?.version === 'v2') {\n      await this.config.credentialsClient.setCredentials({\n        ...data,\n        version: 'v2',\n      })\n    }\n\n    return data\n  }\n\n  /**\n   * Gen provider redirect uri.\n   * @param {GenProviderRedirectUriRequest} params A GenProviderRedirectUriRequest object.\n   * @return {Promise<GenProviderRedirectUriResponse>} A Promise<GenProviderRedirectUriResponse> object.\n   */\n  public async genProviderRedirectUri(params: GenProviderRedirectUriRequest): Promise<GenProviderRedirectUriResponse> {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const { provider_redirect_uri: redirect_uri, other_params: otherParams = {}, ...restParams } = params\n    if (redirect_uri && !restParams.redirect_uri) {\n      restParams.redirect_uri = redirect_uri\n    }\n\n    let url = `${ApiUrls.PROVIDER_URI_URL}?${Auth.parseParamsToSearch(restParams)}`\n    Object.keys(otherParams).forEach((key) => {\n      const value = otherParams[key]\n      if (key === 'sign_out_uri' && !(value?.length > 0)) {\n        return\n      }\n      url += `&other_params[${key}]=${encodeURIComponent(value)}`\n    })\n\n    return this.config.request<GenProviderRedirectUriResponse>(url, {\n      method: 'GET',\n    })\n  }\n\n  /**\n   * Grant provider token.\n   * @param {GrantProviderTokenRequest} params A GrantProviderTokenRequest object.\n   * @return {Promise<GrantProviderTokenResponse>} A Promise<GrantProviderTokenResponse> object.\n   */\n  public async grantProviderToken(\n    params: GrantProviderTokenRequest,\n    useWxCloud = false,\n  ): Promise<GrantProviderTokenResponse> {\n    return this.config.request<GrantProviderTokenResponse>(ApiUrls.PROVIDER_TOKEN_URL, {\n      method: 'POST',\n      body: params,\n      useWxCloud,\n    })\n  }\n\n  /**\n   * Grant provider token.\n   * @param {PatchProviderTokenRequest} params A PatchProviderTokenRequest object.\n   * @return {Promise<PatchProviderTokenResponse>} A Promise<PatchProviderTokenResponse> object.\n   */\n  public async patchProviderToken(params: PatchProviderTokenRequest): Promise<PatchProviderTokenResponse> {\n    return this.config.request<PatchProviderTokenResponse>(ApiUrls.PROVIDER_TOKEN_URL, {\n      method: 'PATCH',\n      body: params,\n    })\n  }\n\n  /**\n   * Signin with provider request.\n   * @param {SignInWithProviderRequest} params A SignInWithProviderRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInWithProvider(params: SignInWithProviderRequest, useWxCloud = false): Promise<Credentials> {\n    const res = this.getParamsByVersion(params, 'AUTH_SIGN_IN_WITH_PROVIDER_URL')\n\n    const credentials: Credentials = await this.config.request<Credentials>(res.url, {\n      method: 'POST',\n      body: res.params,\n      useWxCloud,\n    })\n\n    await this.config.credentialsClient.setCredentials({\n      ...credentials,\n      version: params?.version || 'v1',\n    })\n    return Promise.resolve(credentials)\n  }\n\n  public async toBindIdentity(params: {\n    provider_token: string\n    provider: string\n    credentials?: Credentials\n    fireEvent?: boolean\n  }) {\n    const credentials = params.credentials || (await this.config.credentialsClient.localCredentials.getCredentials())\n    let res: any\n    try {\n      await this.bindWithProvider(\n        {\n          provider_token: params.provider_token,\n        },\n        credentials,\n      )\n      res = { data: { type: OAUTH_TYPE.BIND_IDENTITY, provider: params.provider }, error: null }\n    } catch (error) {\n      res = { data: { type: OAUTH_TYPE.BIND_IDENTITY }, error: new AuthError(error) }\n    }\n\n    if (params.fireEvent) {\n      this.config.eventBus?.fire?.(EVENTS.AUTH_STATE_CHANGED, {\n        event: AUTH_STATE_CHANGED_TYPE.BIND_IDENTITY,\n        info: res,\n      })\n    }\n\n    return res\n  }\n\n  /**\n   * 获取初始 session（如从 URL 中的 OAuth 回调）。\n   * 用于 OAuth2Client.initialize() 回调。\n   * 内部处理 URL 检测、OAuth 验证，返回 credentials 和 user。\n   * 不调用 setCredentials，由 OAuth2Client 负责保存。\n   *\n   * @returns { data: { session: Credentials; user?: any } | null, error: Error | null }\n   */\n  public async getInitialSession(): Promise<{\n    data: { session: Credentials; user?: any } | null\n    error: Error | null\n  }> {\n    let data: any = {}\n    try {\n      // Check if running in browser\n      if (typeof window === 'undefined' || typeof document === 'undefined') {\n        return { data: null, error: null }\n      }\n\n      // Parse URL parameters\n      const localSearch = new URLSearchParams(location?.search)\n      const code = localSearch.get('code')\n      const state = localSearch.get('state')\n\n      // No OAuth callback detected\n      if (!code || !state) {\n        return { data: null, error: null }\n      }\n\n      // Get provider from sessionStorage (saved during signInWithOAuth)\n      let cacheData: {\n        provider?: string\n        search?: string\n        hash?: string\n        type?: (typeof OAUTH_TYPE)[keyof typeof OAUTH_TYPE]\n      } | null = null\n      try {\n        cacheData = JSON.parse(sessionStorage.getItem(state) || 'null')\n      } catch {\n        // ignore\n      }\n      data = { type: cacheData?.type }\n      // Check for error in URL\n      const errorParam = localSearch.get('error')\n      const errorDescription = localSearch.get('error_description')\n      if (errorParam || errorDescription) {\n        return {\n          data,\n          error: new AuthError({ message: errorDescription || errorParam || 'Unknown error from OAuth provider' }),\n        }\n      }\n\n      const provider = cacheData?.provider || localSearch.get('provider')\n\n      if (!provider) {\n        return { data, error: new AuthError({ message: 'Provider is required for OAuth verification' }) }\n      }\n\n      // 获取当前页面的 redirect_uri\n      const redirectUri = location.origin + location.pathname\n\n      // Step 1: 获取 provider token\n      const { provider_token: providerToken } = await this.grantProviderToken({\n        provider_id: provider,\n        provider_redirect_uri: redirectUri,\n        provider_code: code,\n      })\n\n      let credentials: Credentials\n      let user: any = null\n      let res: any\n\n      if (cacheData.type === OAUTH_TYPE.BIND_IDENTITY) {\n        credentials = await this.config.credentialsClient.localCredentials.getCredentials()\n        res = await this.toBindIdentity({ provider, provider_token: providerToken, credentials })\n      } else if (cacheData.type === OAUTH_TYPE.SIGN_IN) {\n        res = this.getParamsByVersion({ provider }, 'AUTH_SIGN_IN_WITH_PROVIDER_URL')\n\n        // Step 2: 用 provider token 换取 credentials（直接调用 API，不触发 setCredentials）\n        credentials = await this.config.request<Credentials>(res.url, {\n          method: 'POST',\n          body: { provider_token: providerToken },\n        })\n\n        // Step 3: 获取 user info，传入 getCredentials 函数避免死锁\n        // 不调用 setCredentials，由 OAuth2Client._initialize 负责保存\n        try {\n          user = await this.getUserInfo({ credentials })\n        } catch (e) {\n          console.error('get user info error', e)\n          // 获取 user 失败不影响登录流程\n        }\n\n        res = { data: { ...data, session: credentials, user }, error: null }\n      }\n\n      // Clean up URL parameters and restore original URL state\n      localSearch.delete('code')\n      localSearch.delete('state')\n      localSearch.delete('provider')\n      this.restoreUrlState(\n        cacheData?.search === undefined ? `?${localSearch.toString()}` : cacheData.search,\n        cacheData?.hash || location.hash,\n      )\n\n      // Remove session storage\n      try {\n        sessionStorage.removeItem(state)\n      } catch {\n        // ignore\n      }\n\n      return res\n    } catch (error) {\n      return { data, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * Signin with custom.\n   * @param {SignInCustomRequest} params A SignInCustomRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInCustom(params: SignInCustomRequest): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_IN_CUSTOM, {\n      method: 'POST',\n      body: params,\n    })\n\n    await this.config.credentialsClient.setCredentials(credentials)\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * sign in with wechat idendify\n   * 需要结合 http overcallFunction 使用\n   */\n  public async signInWithWechat(params: any = {}): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_IN_WITH_WECHAT_URL, {\n      method: 'POST',\n      body: params,\n    })\n    await this.config.credentialsClient.setCredentials(credentials)\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * Bind with provider\n   * @param {BindWithProviderRequest} params A BindWithProviderRequest object.\n   * @return {Promise<void>} A Promise<any> object.\n   */\n  public async bindWithProvider(params: BindWithProviderRequest, credentials?: Credentials): Promise<void> {\n    return this.config.request<any>(ApiUrls.PROVIDER_BIND_URL, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n      getCredentials: credentials ? () => credentials : undefined,\n    })\n  }\n\n  /**\n   * Get the user profile.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async getUserProfile(params: { version?: string }): Promise<UserProfile> {\n    return this.getUserInfo(params)\n  }\n\n  /**\n   * Get the user info.\n   * @param params.getCredentials Optional custom getCredentials function to bypass default getCredentials() and avoid deadlock\n   * @return {Promise<UserInfo>} A Promise<UserProfile> object.\n   */\n  public async getUserInfo(params: {\n    version?: string\n    query?: string\n    credentials?: Credentials\n  } = {},): Promise<UserInfo> {\n    const res = this.getParamsByVersion(params, 'USER_ME_URL')\n\n    if (res.params?.query) {\n      const searchParams = new MyURLSearchParams(res.params.query as any)\n      res.url += `?${searchParams.toString()}`\n    }\n\n    const userInfo = await this.config.request<UserInfo>(res.url, {\n      method: 'GET',\n      withCredentials: true,\n      getCredentials: params.credentials ? () => params.credentials : undefined,\n    })\n\n    if (userInfo.sub) {\n      userInfo.uid = userInfo.sub\n    }\n\n    return userInfo\n  }\n\n  /**\n   * Get the user info by weda plugin.\n   * @return {Promise<any>} A Promise<any> object.\n   */\n  public async getWedaUserInfo(): Promise<any> {\n    const userInfo = await this.config.request<any>(ApiUrls.WEDA_USER_URL, {\n      method: 'GET',\n      withCredentials: true,\n    })\n    return userInfo\n  }\n\n  /**\n   * Delete me\n   * @param params\n   */\n  public async deleteMe(params: WithSudoRequest): Promise<UserProfile> {\n    const res = this.getParamsByVersion(params, 'USER_ME_URL')\n    const url = `${res.url}?${Auth.parseParamsToSearch(res.params)}`\n    return this.config.request<UserProfile>(url, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * hasLoginState check if has login state\n   * @return {Promise<boolean>} A Promise<boolean> object.\n   */\n  public async hasLoginState(): Promise<boolean> {\n    try {\n      await this.config.credentialsClient.getAccessToken()\n      return true\n    } catch (error) {\n      return false\n    }\n  }\n\n  public hasLoginStateSync(): Credentials | null {\n    const credentials = this.config.credentialsClient.getCredentialsSync()\n    return credentials\n  }\n\n  public async getLoginState(): Promise<Credentials | null> {\n    return this.config.credentialsClient.getCredentialsAsync()\n  }\n\n  /**\n   * Trans by provider.\n   * @param {TransByProviderRequest} params A TransByProviderRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async transByProvider(params: TransByProviderRequest): Promise<Credentials> {\n    return this.config.request<Credentials>(ApiUrls.USER_TRANS_BY_PROVIDER_URL, {\n      method: 'PATCH',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Grant token.\n   * @param {GrantTokenRequest} params A GrantTokenRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async grantToken(params: GrantTokenRequest): Promise<Credentials> {\n    const res = this.getParamsByVersion(params, 'AUTH_TOKEN_URL')\n    return this.config.request<Credentials>(res.url, {\n      method: 'POST',\n      body: res.params,\n    })\n  }\n\n  /**\n   * Get the provide list.\n   * @return {Promise<ProvidersResponse>} A Promise<ProvidersResponse> object.\n   */\n  public async getProviders(): Promise<ProvidersResponse> {\n    return this.config.request<ProvidersResponse>(ApiUrls.PROVIDER_LIST, {\n      method: 'GET',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * unbind provider.\n   * @param {UnbindProviderRequest} params\n   * @return {Promise<any>}\n   */\n  public async unbindProvider(params: UnbindProviderRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.PROVIDER_UNBIND_URL}/${params.provider_id}`, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * check Password.\n   * @param {CheckPasswordRequest} params\n   * @return {Promise<any>}\n   */\n  public async checkPassword(params: CheckPasswordRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.CHECK_PWD_URL}`, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Edit Contact 修改 手机号 或 邮箱\n   * @param {EditContactRequest} params\n   * @return {Promise<void>}\n   */\n  public async editContact(params: EditContactRequest): Promise<void> {\n    return this.config.request<void>(`${ApiUrls.BIND_CONTACT_URL}`, {\n      method: 'PATCH',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Set Password.\n   * @param {SetPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async setPassword(params: SetPasswordRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.AUTH_SET_PASSWORD}`, {\n      method: 'PATCH',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * updatePasswordByOld 使用旧密码修改密码，如果已经绑定手机号，请先：sudo，再修改密码\n   * @param {SetPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async updatePasswordByOld(params: UpdatePasswordRequest): Promise<void> {\n    const sudoToken = await this.sudo({ password: params.old_password })\n    return this.setPassword({\n      sudo_token: sudoToken.sudo_token,\n      new_password: params.new_password,\n    })\n  }\n\n  /**\n   * sudo\n   * @param {sudo} params\n   * @return {Promise<any>}\n   */\n  public async sudo(params: SudoRequest): Promise<SudoResponse> {\n    return this.config.request<SudoResponse>(`${ApiUrls.SUDO_URL}`, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Get the current user verification.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async sendVerificationCodeToCurrentUser(params: GetVerificationRequest): Promise<GetVerificationResponse> {\n    params.target = 'CUR_USER'\n    return this.config.request<GetVerificationResponse>(ApiUrls.VERIFICATION_URL, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n      withCaptcha: true,\n    })\n  }\n\n  /**\n   * change Bound provider.\n   * @param {ChangeBoundProviderRequest} params A GetVerificationRequest Object.\n   * @return {Promise<ChangeBoundProviderResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async changeBoundProvider(params: ChangeBoundProviderRequest): Promise<ChangeBoundProviderResponse> {\n    return this.config.request<ChangeBoundProviderResponse>(`${ApiUrls.PROVIDER_LIST}/${params.provider_id}/trans`, {\n      method: 'POST',\n      body: {\n        provider_trans_token: params.trans_token,\n      },\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Patch the user profile. 没有和数据源同步\n   * @deprecated use updateUserBasicInfo\n   * @param {UserProfile} params A UserProfile Object.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async setUserProfile(params: UserProfile): Promise<UserProfile> {\n    return this.config.request<UserProfile>(ApiUrls.USER_PRIFILE_URL, {\n      method: 'PATCH',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Update user basic info\n   * @return {Promise<void>}\n   */\n  public async updateUserBasicInfo(params: ModifyUserBasicInfoRequest): Promise<void> {\n    return this.config.request(ApiUrls.USER_BASIC_EDIT_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Patch the user profile.\n   * @param {QueryUserProfileReq} appended_params A QueryUserProfileReq Object.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async queryUserProfile(params: QueryUserProfileRequest): Promise<QueryUserProfileResponse> {\n    // let url = new URL(ApiUrls.USER_QUERY_URL);\n    const searchParams = new MyURLSearchParams(params as any)\n    // url.search = searchParams.toString();\n    return this.config.request<QueryUserProfileResponse>(`${ApiUrls.USER_QUERY_URL}?${searchParams.toString()}`, {\n      method: 'GET',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * setCustomSignFunc set the get ticket function\n   * @param getTickFn\n   */\n  public setCustomSignFunc(getTickFn: GetCustomSignTicketFn) {\n    this.getCustomSignTicketFn = getTickFn\n  }\n\n  /**\n   * SignInWithCustomTicket custom signIn\n   * @constructor\n   */\n  // public async signInWithCustomTicket(params?: { version?: string }): Promise<Credentials> {\n  //   const customSignTicketFn = this.getCustomSignTicketFn\n  //   if (!customSignTicketFn) {\n  //     return Promise.reject({\n  //     })\n  //   }\n  //   const customTicket = await customSignTicketFn()\n  //   return this.signInWithProvider({\n  //     ...params,\n  //     provider_id: 'custom',\n  //     provider_token: customTicket,\n  //   })\n  // }\n  public async signInWithCustomTicket(): Promise<Credentials> {\n    const customSignTicketFn = this.getCustomSignTicketFn\n    if (!customSignTicketFn) {\n      return Promise.reject({\n        error: 'failed_precondition',\n        error_description: 'please use setCustomSignFunc to set custom sign function',\n      })\n    }\n    const customTicket = await customSignTicketFn()\n    return this.signInCustom({\n      provider_id: 'custom',\n      ticket: customTicket,\n    })\n  }\n\n  /**\n   * Reset password\n   * @param {ResetPasswordRequest} params\n   * @returns {Promise<void>}\n   * @memberof Auth\n   */\n  public async resetPassword(params: ResetPasswordRequest): Promise<void> {\n    return this.config.request(ApiUrls.AUTH_RESET_PASSWORD, {\n      method: 'POST',\n      body: params,\n      // withCredentials: true\n    })\n  }\n\n  /**\n   * Authorize oauth Authorize\n   * @param params\n   * @constructor\n   */\n  public async authorize(params: AuthorizeRequest): Promise<AuthorizeResponse> {\n    return this.config.request<AuthorizeResponse>(ApiUrls.AUTHORIZE_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * authorize device\n   * @param params\n   */\n  public async authorizeDevice(params: AuthorizeDeviceRequest): Promise<void> {\n    return this.config.request<void>(ApiUrls.AUTHORIZE_DEVICE_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * device authorization\n   * @param {DeviceAuthorizeRequest} params\n   * @returns {Promise<DeviceAuthorizeResponse>}\n   * @memberof Auth\n   */\n  public async deviceAuthorize(params: DeviceAuthorizeRequest): Promise<DeviceAuthorizeResponse> {\n    return this.config.request(ApiUrls.AUTH_GET_DEVICE_CODE, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * OAuth get authorize info\n   * @param params\n   * @constructor\n   */\n  public async authorizeInfo(params: AuthorizeInfoRequest): Promise<AuthorizeInfoResponse> {\n    const url = `${ApiUrls.AUTHORIZE_INFO_URL}?${Auth.parseParamsToSearch(params)}`\n    let withBasicAuth = true\n    let withCredentials = false\n    const hasLogin = await this.hasLoginState()\n    if (hasLogin) {\n      withCredentials = true\n      withBasicAuth = false\n    }\n    return this.config.request<AuthorizeInfoResponse>(url, {\n      method: 'GET',\n      withBasicAuth,\n      withCredentials,\n    })\n  }\n\n  public async checkUsername(params: CheckUsernameRequest): Promise<void> {\n    return this.config.request(ApiUrls.CHECK_USERNAME, {\n      method: 'GET',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  public async checkIfUserExist(params: CheckIfUserExistRequest): Promise<CheckIfUserExistResponse> {\n    const searchParams = new MyURLSearchParams(params as any)\n\n    return this.config.request<CheckIfUserExistResponse>(`${ApiUrls.CHECK_IF_USER_EXIST}?${searchParams.toString()}`, {\n      method: 'GET',\n    })\n  }\n\n  public async loginScope(): Promise<string> {\n    return this.config.credentialsClient.getScope()\n  }\n\n  public async loginGroups(): Promise<string[]> {\n    return this.config.credentialsClient.getGroups()\n  }\n\n  public async refreshTokenForce(params: { version?: string }) {\n    const credentials: Credentials = await this.config.credentialsClient.getCredentials()\n    return await this.config.credentialsClient.refreshToken({\n      ...credentials,\n      version: params?.version || 'v1',\n    })\n  }\n\n  public async getCredentials() {\n    return this.config.credentialsClient.getCredentials()\n  }\n\n  /**\n   * get public key for request params encryption\n   * @returns\n   */\n  public async getPublicKey(): Promise<PublicKey> {\n    return this.config.request<PublicKey>(ApiUrlsV2.AUTH_PUBLIC_KEY, {\n      method: 'POST',\n      body: {},\n    })\n  }\n\n  /**\n   * encrypt request params\n   * @param params\n   * @returns\n   */\n  public async getEncryptParams(params: Record<any, any>): Promise<EncryptParams> {\n    const { isEncrypt } = params\n    delete params.isEncrypt\n\n    const payload = deepClone(params)\n\n    const encryptUtils = await getEncryptUtils(isEncrypt, this.config.adapter)\n\n    if (!encryptUtils) {\n      return params\n    }\n\n    let publicKey = ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    let public_key_thumbprint = ''\n\n    try {\n      const res = await this.getPublicKey()\n      publicKey = res.public_key\n      public_key_thumbprint = res.public_key_thumbprint\n\n      if (!publicKey || !public_key_thumbprint) {\n        throw res\n      }\n    } catch (error) {\n      throw error\n    }\n    return {\n      params: encryptUtils.getEncryptInfo({ publicKey, payload }),\n      public_key_thumbprint,\n    }\n  }\n\n  /**\n   * get provider sub type\n   * @returns\n   */\n  public async getProviderSubType(): Promise<ProviderSubType> {\n    return this.config.request<ProviderSubType>(ApiUrls.GET_PROVIDER_TYPE, {\n      method: 'POST',\n      body: {\n        provider_id: 'weda',\n      },\n    })\n  }\n\n  /**\n   * get provider sub type\n   * @returns\n   */\n  public async verifyCaptchaData({ token, key }: { token: string; key: string }) {\n    return this.config.request<{ captcha_token: string; expires_in: number }>(ApiUrls.VERIFY_CAPTCHA_DATA_URL, {\n      method: 'POST',\n      body: { token, key },\n      withCredentials: false,\n    })\n  }\n\n  public async createCaptchaData({ state, redirect_uri = undefined }) {\n    return this.config.request<{ token: string; data: string }>(ApiUrls.CAPTCHA_DATA_URL, {\n      method: 'POST',\n      body: { state, redirect_uri },\n      withCredentials: false,\n    })\n  }\n\n  /**\n   * mini-program scan code\n   * @returns\n   */\n  public async getMiniProgramCode(params: GetMiniProgramQrCodeRequest): Promise<GetMiniProgramQrCodeResponse> {\n    return this.config.request<GetMiniProgramQrCodeResponse>(ApiUrls.GET_MINIPROGRAM_QRCODE, {\n      method: 'POST',\n      body: params,\n    })\n  }\n\n  /**\n   * mini-program scan code status\n   * @returns\n   */\n  public async getMiniProgramQrCodeStatus(params: GetMiniProgramQrCodeStatusRequest,): Promise<GetMiniProgramQrCodeStatusResponse> {\n    return this.config.request<GetMiniProgramQrCodeStatusResponse>(ApiUrls.GET_MINIPROGRAM_QRCODE_STATUS, {\n      method: 'POST',\n      body: params,\n    })\n  }\n\n  /**\n   * get user behavior log\n   * @param params\n   */\n  public async getUserBehaviorLog(params: GetUserBehaviorLog): Promise<GetUserBehaviorLogRes> {\n    const action = { LOGIN: 'query[action]=USER_LOGIN', MODIFY: 'ne_query[action]=USER_LOGIN' }\n    const url = `${ApiUrls.GET_USER_BEHAVIOR_LOG}?${action[params.type]}&limit=${params.limit}${\n      params.page_token ? `&page_token=${params.page_token}` : ''\n    }`\n    return this.config.request(url, {\n      method: 'GET',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * 这个方法是用户自己修改自己的密码，不同于/auth/v1/user/password接口，该接口是管理员修改个人的\n   * @param {ModifyUserBasicInfoRequest} params A ModifyUserBasicInfoRequest Object.\n   * @return {Promise<void>} A Promise<void> object.\n   */\n  public async modifyPassword(params: ModifyUserBasicInfoRequest): Promise<void> {\n    let publicKey = ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    let public_key_thumbprint = ''\n\n    const encryptUtils = await getEncryptUtils(true, this.config.adapter)\n\n    if (!encryptUtils) {\n      throw new Error('do not support encrypt, a encrypt util required.')\n    }\n\n    try {\n      const res = await this.getPublicKey()\n      publicKey = res.public_key\n      public_key_thumbprint = res.public_key_thumbprint\n\n      if (!publicKey || !public_key_thumbprint) {\n        throw res\n      }\n    } catch (error) {\n      throw error\n    }\n\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_password = params.password ? encryptUtils.getEncryptInfo({ publicKey, payload: params.password }) : ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_new_password = encryptUtils.getEncryptInfo({ publicKey, payload: params.new_password })\n    return this.config.request(ApiUrls.USER_BASIC_EDIT_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: {\n        user_id: params.user_id,\n        encrypt_password,\n        encrypt_new_password,\n        public_key_thumbprint,\n      },\n    })\n  }\n\n  /**\n   * 重置密码，该接口无需登录就可以重置密码\n   * @param {ModifyPasswordWithoutLoginRequest} params A ModifyPasswordWithoutLoginRequest Object.\n   * @return {Promise<void>} A Promise<void> object.\n   */\n  public async modifyPasswordWithoutLogin(params: ModifyPasswordWithoutLoginRequest): Promise<void> {\n    let publicKey = ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    let public_key_thumbprint = ''\n\n    const encryptUtils = await getEncryptUtils(true, this.config.adapter)\n\n    if (!encryptUtils) {\n      throw new Error('do not support encrypt, a encrypt util required.')\n    }\n\n    try {\n      const res = await this.getPublicKey()\n      publicKey = res.public_key\n      public_key_thumbprint = res.public_key_thumbprint\n\n      if (!publicKey || !public_key_thumbprint) {\n        throw res\n      }\n    } catch (error) {\n      throw error\n    }\n\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_password = params.password ? encryptUtils.getEncryptInfo({ publicKey, payload: params.password }) : ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_new_password = encryptUtils.getEncryptInfo({ publicKey, payload: params.new_password })\n    return this.config.request(ApiUrlsV2.AUTH_RESET_PASSWORD, {\n      method: 'POST',\n      body: {\n        username: params.username,\n        password: encrypt_password,\n        new_password: encrypt_new_password,\n        public_key_thumbprint,\n      },\n    })\n  }\n\n  /**\n   * Restore URL state after OAuth callback\n   */\n  private restoreUrlState(search?: string, hash?: string): void {\n    if (search === undefined) return\n    try {\n      const url = new URL(window.location.href)\n      url.search = search\n      url.hash = hash || ''\n      window.history.replaceState(null, '', url.toString())\n    } catch {\n      // ignore\n    }\n  }\n}\n"]}
1268
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apis.js","sourceRoot":"","sources":["../../../src/auth/apis.ts"],"names":[],"mappings":"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","sourcesContent":["'use strict'\n\nimport { ApiUrls, ApiUrlsV2, AUTH_STATE_CHANGED_TYPE, ErrorType, EVENTS, OAUTH_TYPE } from './consts'\nimport {\n  GetVerificationRequest,\n  GetVerificationResponse,\n  UserProfile,\n  UserInfo,\n  SignInRequest,\n  SignUpRequest,\n  VerifyRequest,\n  VerifyResponse,\n  GenProviderRedirectUriRequest,\n  GenProviderRedirectUriResponse,\n  GrantProviderTokenRequest,\n  GrantProviderTokenResponse,\n  PatchProviderTokenRequest,\n  PatchProviderTokenResponse,\n  SignInWithProviderRequest,\n  SignInCustomRequest,\n  BindWithProviderRequest,\n  TransByProviderRequest,\n  GrantTokenRequest,\n  UnbindProviderRequest,\n  CheckPasswordRequest,\n  SetPasswordRequest,\n  ChangeBoundProviderRequest,\n  ChangeBoundProviderResponse,\n  UpdatePasswordRequest,\n  SudoResponse,\n  SudoRequest,\n  GetCustomSignTicketFn,\n  QueryUserProfileRequest,\n  QueryUserProfileResponse,\n  ResetPasswordRequest,\n  DeviceAuthorizeRequest,\n  DeviceAuthorizeResponse,\n  CheckUsernameRequest,\n  CheckIfUserExistRequest,\n  CheckIfUserExistResponse,\n  WithSudoRequest,\n  PublicKey,\n  EncryptParams,\n  ProviderSubType,\n  GetMiniProgramQrCodeRequest,\n  GetMiniProgramQrCodeStatusRequest,\n  GetMiniProgramQrCodeResponse,\n  GetMiniProgramQrCodeStatusResponse,\n  ModifyUserBasicInfoRequest,\n  EditContactRequest,\n  AuthorizeInfoRequest,\n  AuthorizeInfoResponse,\n  AuthorizeDeviceRequest,\n  AuthorizeRequest,\n  AuthorizeResponse,\n  GetUserBehaviorLog,\n  GetUserBehaviorLogRes,\n  RevokeDeviceRequest,\n  SignoutResponse,\n  ProvidersResponse,\n  SignoutRequest,\n  ModifyPasswordWithoutLoginRequest,\n} from './models'\nimport { SimpleStorage, RequestFunction } from '../oauth2client/interface'\nimport { OAuth2Client, defaultStorage } from '../oauth2client/oauth2client'\nimport { Credentials } from '../oauth2client/models'\nimport { Captcha, CaptchaOptions } from '../captcha/captcha'\nimport { deepClone } from '../utils'\nimport MyURLSearchParams from '../utils/urlSearchParams'\nimport { SDKAdapterInterface } from '@cloudbase/adapter-interface'\nimport { ICloudbaseConfig } from '@cloudbase/types'\nimport { AuthError } from './auth-error'\n\nasync function getEncryptUtils(isEncrypt, adapter: SDKAdapterInterface) {\n  const getUtils = async () => {\n    try {\n      /* eslint-disable */\n      // @ts-ignore\n      const utils = require('../utils/encrypt')\n      /* eslint-enable */\n      return utils\n    } catch (error) {\n      try {\n        // @ts-ignore\n        const utils = await import('../utils/encrypt')\n        return utils\n      } catch (error) {\n        return\n      }\n    }\n  }\n\n  try {\n    if ((adapter?.root?.globalThis || globalThis).IS_MP_BUILD) {\n      return\n    }\n\n    if (!process.env.IS_MP_BUILD && isEncrypt) {\n      return getUtils()\n    }\n  } catch (error) {\n    if (isEncrypt) {\n      return getUtils()\n    }\n  }\n}\n\nexport interface AuthOptions {\n  apiOrigin: string\n  apiPath?: string\n  clientId: string\n  /**\n   * basic auth\n   */\n  clientSecret?: string\n  credentialsClient?: OAuth2Client\n  request?: RequestFunction\n  baseRequest?: RequestFunction\n  storage?: SimpleStorage\n  anonymousSignInFunc?: (Credentials) => Promise<Credentials | void>\n  captchaOptions?: Partial<CaptchaOptions>\n  env?: string\n  wxCloud?: any\n  adapter?: SDKAdapterInterface\n  onCredentialsError?: (data: { msg: string; eventType?: 'credentials_error' }) => void\n  headers?: { [key: string]: string }\n  i18n?: ICloudbaseConfig['i18n']\n  useWxCloud?: boolean\n  eventBus?: any\n  /**\n   * Set to true if you want to automatically detect OAuth grants in the URL\n   * and exchange the code for credentials.\n   */\n  detectSessionInUrl?: boolean\n  /**\n   * Enable debug logging\n   */\n  debug?: boolean\n  auth?: ICloudbaseConfig['auth']\n}\n\n/**\n * Auth\n */\nexport class Auth {\n  private static parseParamsToSearch(params: any): string {\n    Object.keys(params).forEach((key) => {\n      if (!params[key]) {\n        delete params[key]\n      }\n    })\n    const searchParams = new MyURLSearchParams(params as any)\n    return searchParams.toString()\n  }\n\n  private config: AuthOptions\n  private getCustomSignTicketFn?: GetCustomSignTicketFn\n\n  /**\n   * constructor\n   * @param {AuthOptions} opts\n   */\n  constructor(opts: AuthOptions) {\n    let { request } = opts\n    let oAuth2Client = opts.credentialsClient\n    if (!oAuth2Client) {\n      const initOptions = {\n        apiOrigin: opts.apiOrigin,\n        apiPath: opts.apiPath,\n        clientId: opts.clientId,\n        storage: opts.storage,\n        env: opts.env,\n        baseRequest: opts.baseRequest /* || opts.request */, // opts.request 废弃不用来表示 oauth rquest\n        anonymousSignInFunc: opts.anonymousSignInFunc,\n        wxCloud: opts.wxCloud,\n        onCredentialsError: opts.onCredentialsError,\n        headers: opts.headers || {},\n        i18n: opts.i18n,\n        debug: opts.debug,\n      }\n      oAuth2Client = new OAuth2Client(initOptions)\n    }\n    if (!request) {\n      const baseRequest = oAuth2Client.request.bind(oAuth2Client)\n      const captcha = new Captcha({\n        env: opts.env,\n        clientId: opts.clientId,\n        request: baseRequest,\n        storage: opts.storage,\n        adapter: opts.adapter,\n        oauthInstance: this,\n        ...opts.captchaOptions,\n      })\n      request = captcha.request.bind(captcha)\n    }\n    this.config = {\n      env: opts.env,\n      apiOrigin: opts.apiOrigin,\n      apiPath: opts.apiPath,\n      clientId: opts.clientId,\n      request,\n      credentialsClient: oAuth2Client,\n      storage: opts.storage || defaultStorage,\n      adapter: opts.adapter,\n    }\n  }\n\n  /**\n   * 根据版本标识，处理待请求的url和params\n   * @param params\n   * @param key\n   * @returns\n   */\n  public getParamsByVersion(params: any, key: string) {\n    const paramsTemp = deepClone(params)\n    const url = { v2: ApiUrlsV2 }[paramsTemp?.version]?.[key] || ApiUrls[key]\n\n    if (paramsTemp) {\n      delete paramsTemp.version\n    }\n\n    return { params: paramsTemp, url }\n  }\n\n  /**\n   * Sign in.\n   * @param {SignInRequest} params A SignInRequest Object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signIn(params: SignInRequest): Promise<Credentials> {\n    const version = params.version || 'v1'\n    const res = this.getParamsByVersion(params, 'AUTH_SIGN_IN_URL')\n    if (res.params.query) {\n      delete res.params.query\n    }\n\n    const body = await this.getEncryptParams(res.params)\n    const credentials: Credentials = await this.config.request<Credentials>(res.url, {\n      method: 'POST',\n      body,\n    })\n    await this.config.credentialsClient.setCredentials({\n      ...credentials,\n      version,\n    })\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * Sign in Anonymously\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInAnonymously(\n    data: {\n      provider_token?: string\n    } = {},\n    useWxCloud = false,\n  ): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_IN_ANONYMOUSLY_URL, {\n      method: 'POST',\n      body: data,\n      useWxCloud,\n    })\n    await this.config.credentialsClient.setCredentials(credentials)\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * Sign up.\n   * @param {SignUpRequest} params A SignUpRequest Object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signUp(params: SignUpRequest): Promise<Credentials> {\n    const data: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_UP_URL, {\n      method: 'POST',\n      body: params,\n    })\n    await this.config.credentialsClient.setCredentials(data)\n    return Promise.resolve(data)\n  }\n\n  /**\n   * Sign out.\n   * @return {Object} A Promise<SignoutRequest> object.\n   */\n  public async signOut(params?: SignoutRequest): Promise<SignoutResponse> {\n    let resp: SignoutResponse = {}\n    if (params) {\n      try {\n        resp = await this.config.request<SignoutResponse>(ApiUrls.AUTH_SIGNOUT_URL, {\n          method: 'POST',\n          withCredentials: true,\n          body: params,\n        })\n      } catch (err) {\n        if (err.error !== ErrorType.UNAUTHENTICATED) {\n          console.log('sign_out_error', err)\n        }\n      }\n      await this.config.credentialsClient.setCredentials()\n      return resp\n    }\n    const accessToken: string = await this.config.credentialsClient.getAccessToken()\n    const data = await this.config.request(ApiUrls.AUTH_REVOKE_URL, {\n      method: 'POST',\n      body: {\n        token: accessToken,\n      },\n    })\n    await this.config.credentialsClient.setCredentials()\n    return Promise.resolve(data)\n  }\n\n  /**\n   * Revoke All Devices\n   * @return {Object} A Promise<void> object.\n   */\n  public async revokeAllDevices(): Promise<void> {\n    await this.config.request<void>(ApiUrls.AUTH_REVOKE_ALL_URL, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Revoke Device\n   * @return {Object} A Promise<void> object.\n   */\n  public async revokeDevice(params: RevokeDeviceRequest): Promise<void> {\n    await this.config.request<void>(ApiUrls.AUTHORIZED_DEVICES_DELETE_URL + params.device_id, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Get the verification.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async getVerification(\n    params: GetVerificationRequest,\n    options?: { withCaptcha: boolean },\n  ): Promise<GetVerificationResponse> {\n    let withCredentials = false\n    // 发送短信时，如果时给当前用户发，则需要带上鉴权信息\n    if (params.target === 'CUR_USER') {\n      withCredentials = true\n    } else {\n      const hasLogin = await this.hasLoginState()\n      if (hasLogin) {\n        withCredentials = true\n      }\n    }\n\n    const body = deepClone(params)\n\n    if (body.phone_number && !/^\\+\\d{1,3}\\s+\\d+/.test(body.phone_number)) {\n      body.phone_number = `+86 ${body.phone_number}`\n    }\n\n    return this.config.request<GetVerificationResponse>(ApiUrls.VERIFICATION_URL, {\n      method: 'POST',\n      body,\n      withCaptcha: options?.withCaptcha || false,\n      withCredentials,\n    })\n  }\n\n  /**\n   *  Verify the code\n   * @param {VerifyRequest} params A VerifyRequest Object.\n   * @return {Promise<VerifyResponse>} A Promise<VerifyResponse> object.\n   */\n  public async verify(params: VerifyRequest): Promise<VerifyResponse> {\n    const res = this.getParamsByVersion(params, 'VERIFY_URL')\n    const data = await this.config.request<VerifyResponse>(res.url, {\n      method: 'POST',\n      body: res.params,\n    })\n\n    if (params?.version === 'v2') {\n      await this.config.credentialsClient.setCredentials({\n        ...data,\n        version: 'v2',\n      })\n    }\n\n    return data\n  }\n\n  /**\n   * Gen provider redirect uri.\n   * @param {GenProviderRedirectUriRequest} params A GenProviderRedirectUriRequest object.\n   * @return {Promise<GenProviderRedirectUriResponse>} A Promise<GenProviderRedirectUriResponse> object.\n   */\n  public async genProviderRedirectUri(params: GenProviderRedirectUriRequest): Promise<GenProviderRedirectUriResponse> {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const { provider_redirect_uri: redirect_uri, other_params: otherParams = {}, ...restParams } = params\n    if (redirect_uri && !restParams.redirect_uri) {\n      restParams.redirect_uri = redirect_uri\n    }\n\n    let url = `${ApiUrls.PROVIDER_URI_URL}?${Auth.parseParamsToSearch(restParams)}`\n    Object.keys(otherParams).forEach((key) => {\n      const value = otherParams[key]\n      if (key === 'sign_out_uri' && !(value?.length > 0)) {\n        return\n      }\n      url += `&other_params[${key}]=${encodeURIComponent(value)}`\n    })\n\n    return this.config.request<GenProviderRedirectUriResponse>(url, {\n      method: 'GET',\n    })\n  }\n\n  /**\n   * Grant provider token.\n   * @param {GrantProviderTokenRequest} params A GrantProviderTokenRequest object.\n   * @return {Promise<GrantProviderTokenResponse>} A Promise<GrantProviderTokenResponse> object.\n   */\n  public async grantProviderToken(\n    params: GrantProviderTokenRequest,\n    useWxCloud = false,\n  ): Promise<GrantProviderTokenResponse> {\n    return this.config.request<GrantProviderTokenResponse>(ApiUrls.PROVIDER_TOKEN_URL, {\n      method: 'POST',\n      body: params,\n      useWxCloud,\n    })\n  }\n\n  /**\n   * Grant provider token.\n   * @param {PatchProviderTokenRequest} params A PatchProviderTokenRequest object.\n   * @return {Promise<PatchProviderTokenResponse>} A Promise<PatchProviderTokenResponse> object.\n   */\n  public async patchProviderToken(params: PatchProviderTokenRequest): Promise<PatchProviderTokenResponse> {\n    return this.config.request<PatchProviderTokenResponse>(ApiUrls.PROVIDER_TOKEN_URL, {\n      method: 'PATCH',\n      body: params,\n    })\n  }\n\n  /**\n   * Signin with provider request.\n   * @param {SignInWithProviderRequest} params A SignInWithProviderRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInWithProvider(params: SignInWithProviderRequest, useWxCloud = false): Promise<Credentials> {\n    const res = this.getParamsByVersion(params, 'AUTH_SIGN_IN_WITH_PROVIDER_URL')\n\n    const credentials: Credentials = await this.config.request<Credentials>(res.url, {\n      method: 'POST',\n      body: res.params,\n      useWxCloud,\n    })\n\n    await this.config.credentialsClient.setCredentials({\n      ...credentials,\n      version: params?.version || 'v1',\n    })\n    return Promise.resolve(credentials)\n  }\n\n  public async toBindIdentity(params: {\n    provider_token: string\n    provider: string\n    credentials?: Credentials\n    fireEvent?: boolean\n  }) {\n    const credentials = params.credentials || (await this.config.credentialsClient.localCredentials.getCredentials())\n    let res: any\n    try {\n      await this.bindWithProvider(\n        {\n          provider_token: params.provider_token,\n        },\n        credentials,\n      )\n      res = { data: { type: OAUTH_TYPE.BIND_IDENTITY, provider: params.provider }, error: null }\n    } catch (error) {\n      res = { data: { type: OAUTH_TYPE.BIND_IDENTITY }, error: new AuthError(error) }\n    }\n\n    if (params.fireEvent) {\n      this.config.eventBus?.fire?.(EVENTS.AUTH_STATE_CHANGED, {\n        event: AUTH_STATE_CHANGED_TYPE.BIND_IDENTITY,\n        info: res,\n      })\n    }\n\n    return res\n  }\n\n  /**\n   * 获取初始 session（如从 URL 中的 OAuth 回调）。\n   * 用于 OAuth2Client.initialize() 回调。\n   * 内部处理 URL 检测、OAuth 验证，返回 credentials 和 user。\n   * 不调用 setCredentials，由 OAuth2Client 负责保存。\n   *\n   * @returns { data: { session: Credentials; user?: any } | null, error: Error | null }\n   */\n  public async getInitialSession(): Promise<{\n    data: { session: Credentials; user?: any } | null\n    error: Error | null\n  }> {\n    let data: any = {}\n    try {\n      // Check if running in browser\n      if (typeof window === 'undefined' || typeof document === 'undefined') {\n        return { data: null, error: null }\n      }\n\n      // Parse URL parameters\n      const localSearch = new URLSearchParams(location?.search)\n      const code = localSearch.get('code')\n      const state = localSearch.get('state')\n\n      // No OAuth callback detected\n      if (!code || !state) {\n        return { data: null, error: null }\n      }\n\n      // Get provider from sessionStorage (saved during signInWithOAuth)\n      let cacheData: {\n        provider?: string\n        search?: string\n        hash?: string\n        type?: (typeof OAUTH_TYPE)[keyof typeof OAUTH_TYPE]\n      } | null = null\n      try {\n        cacheData = JSON.parse(sessionStorage.getItem(state) || 'null')\n      } catch {\n        // ignore\n      }\n      data = { type: cacheData?.type }\n      // Check for error in URL\n      const errorParam = localSearch.get('error')\n      const errorDescription = localSearch.get('error_description')\n      if (errorParam || errorDescription) {\n        return {\n          data,\n          error: new AuthError({ message: errorDescription || errorParam || 'Unknown error from OAuth provider' }),\n        }\n      }\n\n      const provider = cacheData?.provider || localSearch.get('provider')\n\n      if (!provider) {\n        return { data, error: new AuthError({ message: 'Provider is required for OAuth verification' }) }\n      }\n\n      // 获取当前页面的 redirect_uri\n      const redirectUri = location.origin + location.pathname\n\n      // Step 1: 获取 provider token\n      const { provider_token: providerToken } = await this.grantProviderToken({\n        provider_id: provider,\n        provider_redirect_uri: redirectUri,\n        provider_code: code,\n      })\n\n      let credentials: Credentials\n      let user: any = null\n      let res: any\n\n      if (cacheData.type === OAUTH_TYPE.BIND_IDENTITY) {\n        credentials = await this.config.credentialsClient.localCredentials.getCredentials()\n        res = await this.toBindIdentity({ provider, provider_token: providerToken, credentials })\n      } else if (cacheData.type === OAUTH_TYPE.SIGN_IN) {\n        res = this.getParamsByVersion({ provider }, 'AUTH_SIGN_IN_WITH_PROVIDER_URL')\n\n        // Step 2: 用 provider token 换取 credentials（直接调用 API，不触发 setCredentials）\n        credentials = await this.config.request<Credentials>(res.url, {\n          method: 'POST',\n          body: { provider_token: providerToken },\n        })\n\n        // Step 3: 获取 user info，传入 getCredentials 函数避免死锁\n        // 不调用 setCredentials，由 OAuth2Client._initialize 负责保存\n        try {\n          user = await this.getUserInfo({ credentials })\n        } catch (e) {\n          console.error('get user info error', e)\n          // 获取 user 失败不影响登录流程\n        }\n\n        res = { data: { ...data, session: credentials, user }, error: null }\n      }\n\n      // Clean up URL parameters and restore original URL state\n      localSearch.delete('code')\n      localSearch.delete('state')\n      localSearch.delete('provider')\n      this.restoreUrlState(\n        cacheData?.search === undefined ? `?${localSearch.toString()}` : cacheData.search,\n        cacheData?.hash || location.hash,\n      )\n\n      // Remove session storage\n      try {\n        sessionStorage.removeItem(state)\n      } catch {\n        // ignore\n      }\n\n      return res\n    } catch (error) {\n      return { data, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * Signin with custom.\n   * @param {SignInCustomRequest} params A SignInCustomRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInCustom(params: SignInCustomRequest): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_IN_CUSTOM, {\n      method: 'POST',\n      body: params,\n    })\n\n    await this.config.credentialsClient.setCredentials(credentials)\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * sign in with wechat idendify\n   * 需要结合 http overcallFunction 使用\n   */\n  public async signInWithWechat(params: any = {}): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(ApiUrls.AUTH_SIGN_IN_WITH_WECHAT_URL, {\n      method: 'POST',\n      body: params,\n    })\n    await this.config.credentialsClient.setCredentials(credentials)\n    return Promise.resolve(credentials)\n  }\n\n  /**\n   * Bind with provider\n   * @param {BindWithProviderRequest} params A BindWithProviderRequest object.\n   * @return {Promise<void>} A Promise<any> object.\n   */\n  public async bindWithProvider(params: BindWithProviderRequest, credentials?: Credentials): Promise<void> {\n    return this.config.request<any>(ApiUrls.PROVIDER_BIND_URL, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n      getCredentials: credentials ? () => credentials : undefined,\n    })\n  }\n\n  /**\n   * Get the user profile.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async getUserProfile(params: { version?: string }): Promise<UserProfile> {\n    return this.getUserInfo(params)\n  }\n\n  /**\n   * Get the user info.\n   * @param params.getCredentials Optional custom getCredentials function to bypass default getCredentials() and avoid deadlock\n   * @return {Promise<UserInfo>} A Promise<UserProfile> object.\n   */\n  public async getUserInfo(params: {\n    version?: string\n    query?: string\n    credentials?: Credentials\n  } = {},): Promise<UserInfo> {\n    const res = this.getParamsByVersion(params, 'USER_ME_URL')\n\n    if (res.params?.query) {\n      const searchParams = new MyURLSearchParams(res.params.query as any)\n      res.url += `?${searchParams.toString()}`\n    }\n\n    const userInfo = await this.config.request<UserInfo>(res.url, {\n      method: 'GET',\n      withCredentials: true,\n      getCredentials: params.credentials ? () => params.credentials : undefined,\n    })\n\n    if (userInfo.sub) {\n      userInfo.uid = userInfo.sub\n    }\n\n    return userInfo\n  }\n\n  /**\n   * Get the user info by weda plugin.\n   * @return {Promise<any>} A Promise<any> object.\n   */\n  public async getWedaUserInfo(): Promise<any> {\n    const userInfo = await this.config.request<any>(ApiUrls.WEDA_USER_URL, {\n      method: 'GET',\n      withCredentials: true,\n    })\n    return userInfo\n  }\n\n  /**\n   * Delete me\n   * @param params\n   */\n  public async deleteMe(params: WithSudoRequest): Promise<UserProfile> {\n    const res = this.getParamsByVersion(params, 'USER_ME_URL')\n    const url = `${res.url}?${Auth.parseParamsToSearch(res.params)}`\n    return this.config.request<UserProfile>(url, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * hasLoginState check if has login state\n   * @return {Promise<boolean>} A Promise<boolean> object.\n   */\n  public async hasLoginState(): Promise<boolean> {\n    try {\n      await this.config.credentialsClient.getAccessToken()\n      return true\n    } catch (error) {\n      return false\n    }\n  }\n\n  public hasLoginStateSync(): Credentials | null {\n    const credentials = this.config.credentialsClient.getCredentialsSync()\n    return credentials\n  }\n\n  public async getLoginState(): Promise<Credentials | null> {\n    return this.config.credentialsClient.getCredentialsAsync()\n  }\n\n  /**\n   * Trans by provider.\n   * @param {TransByProviderRequest} params A TransByProviderRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async transByProvider(params: TransByProviderRequest): Promise<Credentials> {\n    return this.config.request<Credentials>(ApiUrls.USER_TRANS_BY_PROVIDER_URL, {\n      method: 'PATCH',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Grant token.\n   * @param {GrantTokenRequest} params A GrantTokenRequest object.\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async grantToken(params: GrantTokenRequest): Promise<Credentials> {\n    const res = this.getParamsByVersion(params, 'AUTH_TOKEN_URL')\n    return this.config.request<Credentials>(res.url, {\n      method: 'POST',\n      body: res.params,\n    })\n  }\n\n  /**\n   * Get the provide list.\n   * @return {Promise<ProvidersResponse>} A Promise<ProvidersResponse> object.\n   */\n  public async getProviders(): Promise<ProvidersResponse> {\n    return this.config.request<ProvidersResponse>(ApiUrls.PROVIDER_LIST, {\n      method: 'GET',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * unbind provider.\n   * @param {UnbindProviderRequest} params\n   * @return {Promise<any>}\n   */\n  public async unbindProvider(params: UnbindProviderRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.PROVIDER_UNBIND_URL}/${params.provider_id}`, {\n      method: 'DELETE',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * check Password.\n   * @param {CheckPasswordRequest} params\n   * @return {Promise<any>}\n   */\n  public async checkPassword(params: CheckPasswordRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.CHECK_PWD_URL}`, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Edit Contact 修改 手机号 或 邮箱\n   * @param {EditContactRequest} params\n   * @return {Promise<void>}\n   */\n  public async editContact(params: EditContactRequest): Promise<void> {\n    return this.config.request<void>(`${ApiUrls.BIND_CONTACT_URL}`, {\n      method: 'PATCH',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Set Password.\n   * @param {SetPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async setPassword(params: SetPasswordRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.AUTH_SET_PASSWORD}`, {\n      method: 'PATCH',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * updatePasswordByOld 使用旧密码修改密码，如果已经绑定手机号，请先：sudo，再修改密码\n   * @param {SetPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async updatePasswordByOld(params: UpdatePasswordRequest): Promise<void> {\n    const sudoToken = await this.sudo({ password: params.old_password })\n    return this.setPassword({\n      sudo_token: sudoToken.sudo_token,\n      new_password: params.new_password,\n    })\n  }\n\n  /**\n   * sudo\n   * @param {sudo} params\n   * @return {Promise<any>}\n   */\n  public async sudo(params: SudoRequest): Promise<SudoResponse> {\n    return this.config.request<SudoResponse>(`${ApiUrls.SUDO_URL}`, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Get the current user verification.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async sendVerificationCodeToCurrentUser(params: GetVerificationRequest): Promise<GetVerificationResponse> {\n    params.target = 'CUR_USER'\n    return this.config.request<GetVerificationResponse>(ApiUrls.VERIFICATION_URL, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n      withCaptcha: true,\n    })\n  }\n\n  /**\n   * change Bound provider.\n   * @param {ChangeBoundProviderRequest} params A GetVerificationRequest Object.\n   * @return {Promise<ChangeBoundProviderResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async changeBoundProvider(params: ChangeBoundProviderRequest): Promise<ChangeBoundProviderResponse> {\n    return this.config.request<ChangeBoundProviderResponse>(`${ApiUrls.PROVIDER_LIST}/${params.provider_id}/trans`, {\n      method: 'POST',\n      body: {\n        provider_trans_token: params.trans_token,\n      },\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Patch the user profile. 没有和数据源同步\n   * @deprecated use updateUserBasicInfo\n   * @param {UserProfile} params A UserProfile Object.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async setUserProfile(params: UserProfile): Promise<UserProfile> {\n    return this.config.request<UserProfile>(ApiUrls.USER_PRIFILE_URL, {\n      method: 'PATCH',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Update user basic info\n   * @return {Promise<void>}\n   */\n  public async updateUserBasicInfo(params: ModifyUserBasicInfoRequest): Promise<void> {\n    return this.config.request(ApiUrls.USER_BASIC_EDIT_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * Patch the user profile.\n   * @param {QueryUserProfileReq} appended_params A QueryUserProfileReq Object.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async queryUserProfile(params: QueryUserProfileRequest): Promise<QueryUserProfileResponse> {\n    // let url = new URL(ApiUrls.USER_QUERY_URL);\n    const searchParams = new MyURLSearchParams(params as any)\n    // url.search = searchParams.toString();\n    return this.config.request<QueryUserProfileResponse>(`${ApiUrls.USER_QUERY_URL}?${searchParams.toString()}`, {\n      method: 'GET',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * setCustomSignFunc set the get ticket function\n   * @param getTickFn\n   */\n  public setCustomSignFunc(getTickFn: GetCustomSignTicketFn) {\n    this.getCustomSignTicketFn = getTickFn\n  }\n\n  /**\n   * SignInWithCustomTicket custom signIn\n   * @constructor\n   */\n  // public async signInWithCustomTicket(params?: { version?: string }): Promise<Credentials> {\n  //   const customSignTicketFn = this.getCustomSignTicketFn\n  //   if (!customSignTicketFn) {\n  //     return Promise.reject({\n  //     })\n  //   }\n  //   const customTicket = await customSignTicketFn()\n  //   return this.signInWithProvider({\n  //     ...params,\n  //     provider_id: 'custom',\n  //     provider_token: customTicket,\n  //   })\n  // }\n  public async signInWithCustomTicket(): Promise<Credentials> {\n    const customSignTicketFn = this.getCustomSignTicketFn\n    if (!customSignTicketFn) {\n      return Promise.reject({\n        error: 'failed_precondition',\n        error_description: 'please use setCustomSignFunc to set custom sign function',\n      })\n    }\n    const customTicket = await customSignTicketFn()\n    return this.signInCustom({\n      provider_id: 'custom',\n      ticket: customTicket,\n    })\n  }\n\n  /**\n   * Reset password\n   * @param {ResetPasswordRequest} params\n   * @returns {Promise<void>}\n   * @memberof Auth\n   */\n  public async resetPassword(params: ResetPasswordRequest): Promise<void> {\n    return this.config.request(ApiUrls.AUTH_RESET_PASSWORD, {\n      method: 'POST',\n      body: params,\n      // withCredentials: true\n    })\n  }\n\n  /**\n   * Authorize oauth Authorize\n   * @param params\n   * @constructor\n   */\n  public async authorize(params: AuthorizeRequest): Promise<AuthorizeResponse> {\n    return this.config.request<AuthorizeResponse>(ApiUrls.AUTHORIZE_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * authorize device\n   * @param params\n   */\n  public async authorizeDevice(params: AuthorizeDeviceRequest): Promise<void> {\n    return this.config.request<void>(ApiUrls.AUTHORIZE_DEVICE_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * device authorization\n   * @param {DeviceAuthorizeRequest} params\n   * @returns {Promise<DeviceAuthorizeResponse>}\n   * @memberof Auth\n   */\n  public async deviceAuthorize(params: DeviceAuthorizeRequest): Promise<DeviceAuthorizeResponse> {\n    return this.config.request(ApiUrls.AUTH_GET_DEVICE_CODE, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * OAuth get authorize info\n   * @param params\n   * @constructor\n   */\n  public async authorizeInfo(params: AuthorizeInfoRequest): Promise<AuthorizeInfoResponse> {\n    const url = `${ApiUrls.AUTHORIZE_INFO_URL}?${Auth.parseParamsToSearch(params)}`\n    let withBasicAuth = true\n    let withCredentials = false\n    const hasLogin = await this.hasLoginState()\n    if (hasLogin) {\n      withCredentials = true\n      withBasicAuth = false\n    }\n    return this.config.request<AuthorizeInfoResponse>(url, {\n      method: 'GET',\n      withBasicAuth,\n      withCredentials,\n    })\n  }\n\n  public async checkUsername(params: CheckUsernameRequest): Promise<void> {\n    return this.config.request(ApiUrls.CHECK_USERNAME, {\n      method: 'GET',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  public async checkIfUserExist(params: CheckIfUserExistRequest): Promise<CheckIfUserExistResponse> {\n    const searchParams = new MyURLSearchParams(params as any)\n\n    return this.config.request<CheckIfUserExistResponse>(`${ApiUrls.CHECK_IF_USER_EXIST}?${searchParams.toString()}`, {\n      method: 'GET',\n    })\n  }\n\n  public async loginScope(): Promise<string> {\n    return this.config.credentialsClient.getScope()\n  }\n\n  public async loginGroups(): Promise<string[]> {\n    return this.config.credentialsClient.getGroups()\n  }\n\n  public async refreshTokenForce(params: { version?: string }) {\n    const credentials: Credentials = await this.config.credentialsClient.getCredentials()\n    return await this.config.credentialsClient.refreshToken({\n      ...credentials,\n      version: params?.version || 'v1',\n    })\n  }\n\n  public async getCredentials() {\n    return this.config.credentialsClient.getCredentials()\n  }\n\n  /**\n   * get public key for request params encryption\n   * @returns\n   */\n  public async getPublicKey(): Promise<PublicKey> {\n    return this.config.request<PublicKey>(ApiUrlsV2.AUTH_PUBLIC_KEY, {\n      method: 'POST',\n      body: {},\n    })\n  }\n\n  /**\n   * encrypt request params\n   * @param params\n   * @returns\n   */\n  public async getEncryptParams(params: Record<any, any>): Promise<EncryptParams> {\n    const { isEncrypt } = params\n    delete params.isEncrypt\n\n    const payload = deepClone(params)\n\n    const encryptUtils = await getEncryptUtils(isEncrypt, this.config.adapter)\n\n    if (!encryptUtils) {\n      return params\n    }\n\n    let publicKey = ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    let public_key_thumbprint = ''\n\n    try {\n      const res = await this.getPublicKey()\n      publicKey = res.public_key\n      public_key_thumbprint = res.public_key_thumbprint\n\n      if (!publicKey || !public_key_thumbprint) {\n        throw res\n      }\n    } catch (error) {\n      throw error\n    }\n    return {\n      params: encryptUtils.getEncryptInfo({ publicKey, payload }),\n      public_key_thumbprint,\n    }\n  }\n\n  /**\n   * get provider sub type\n   * @returns\n   */\n  public async getProviderSubType(): Promise<ProviderSubType> {\n    return this.config.request<ProviderSubType>(ApiUrls.GET_PROVIDER_TYPE, {\n      method: 'POST',\n      body: {\n        provider_id: 'weda',\n      },\n    })\n  }\n\n  /**\n   * get provider sub type\n   * @returns\n   */\n  public async verifyCaptchaData({ token, key }: { token: string; key: string }) {\n    return this.config.request<{ captcha_token: string; expires_in: number }>(ApiUrls.VERIFY_CAPTCHA_DATA_URL, {\n      method: 'POST',\n      body: { token, key },\n      withCredentials: false,\n    })\n  }\n\n  public async createCaptchaData({ state, redirect_uri = undefined }) {\n    return this.config.request<{ token: string; data: string }>(ApiUrls.CAPTCHA_DATA_URL, {\n      method: 'POST',\n      body: { state, redirect_uri },\n      withCredentials: false,\n    })\n  }\n\n  /**\n   * mini-program scan code\n   * @returns\n   */\n  public async getMiniProgramCode(params: GetMiniProgramQrCodeRequest): Promise<GetMiniProgramQrCodeResponse> {\n    return this.config.request<GetMiniProgramQrCodeResponse>(ApiUrls.GET_MINIPROGRAM_QRCODE, {\n      method: 'POST',\n      body: params,\n    })\n  }\n\n  /**\n   * mini-program scan code status\n   * @returns\n   */\n  public async getMiniProgramQrCodeStatus(params: GetMiniProgramQrCodeStatusRequest,): Promise<GetMiniProgramQrCodeStatusResponse> {\n    return this.config.request<GetMiniProgramQrCodeStatusResponse>(ApiUrls.GET_MINIPROGRAM_QRCODE_STATUS, {\n      method: 'POST',\n      body: params,\n    })\n  }\n\n  /**\n   * get user behavior log\n   * @param params\n   */\n  public async getUserBehaviorLog(params: GetUserBehaviorLog): Promise<GetUserBehaviorLogRes> {\n    const action = { LOGIN: 'query[action]=USER_LOGIN', MODIFY: 'ne_query[action]=USER_LOGIN' }\n    const url = `${ApiUrls.GET_USER_BEHAVIOR_LOG}?${action[params.type]}&limit=${params.limit}${\n      params.page_token ? `&page_token=${params.page_token}` : ''\n    }`\n    return this.config.request(url, {\n      method: 'GET',\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * 这个方法是用户自己修改自己的密码，不同于/auth/v1/user/password接口，该接口是管理员修改个人的\n   * @param {ModifyUserBasicInfoRequest} params A ModifyUserBasicInfoRequest Object.\n   * @return {Promise<void>} A Promise<void> object.\n   */\n  public async modifyPassword(params: ModifyUserBasicInfoRequest): Promise<void> {\n    let publicKey = ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    let public_key_thumbprint = ''\n\n    const encryptUtils = await getEncryptUtils(true, this.config.adapter)\n\n    if (!encryptUtils) {\n      throw new Error('do not support encrypt, a encrypt util required.')\n    }\n\n    try {\n      const res = await this.getPublicKey()\n      publicKey = res.public_key\n      public_key_thumbprint = res.public_key_thumbprint\n\n      if (!publicKey || !public_key_thumbprint) {\n        throw res\n      }\n    } catch (error) {\n      throw error\n    }\n\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_password = params.password ? encryptUtils.getEncryptInfo({ publicKey, payload: params.password }) : ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_new_password = encryptUtils.getEncryptInfo({ publicKey, payload: params.new_password })\n    return this.config.request(ApiUrls.USER_BASIC_EDIT_URL, {\n      method: 'POST',\n      withCredentials: true,\n      body: {\n        user_id: params.user_id,\n        encrypt_password,\n        encrypt_new_password,\n        public_key_thumbprint,\n      },\n    })\n  }\n\n  /**\n   * 重置密码，该接口无需登录就可以重置密码\n   * @param {ModifyPasswordWithoutLoginRequest} params A ModifyPasswordWithoutLoginRequest Object.\n   * @return {Promise<void>} A Promise<void> object.\n   */\n  public async modifyPasswordWithoutLogin(params: ModifyPasswordWithoutLoginRequest): Promise<void> {\n    let publicKey = ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    let public_key_thumbprint = ''\n\n    const encryptUtils = await getEncryptUtils(true, this.config.adapter)\n\n    if (!encryptUtils) {\n      throw new Error('do not support encrypt, a encrypt util required.')\n    }\n\n    try {\n      const res = await this.getPublicKey()\n      publicKey = res.public_key\n      public_key_thumbprint = res.public_key_thumbprint\n\n      if (!publicKey || !public_key_thumbprint) {\n        throw res\n      }\n    } catch (error) {\n      throw error\n    }\n\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_password = params.password ? encryptUtils.getEncryptInfo({ publicKey, payload: params.password }) : ''\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    const encrypt_new_password = encryptUtils.getEncryptInfo({ publicKey, payload: params.new_password })\n    return this.config.request(ApiUrlsV2.AUTH_RESET_PASSWORD, {\n      method: 'POST',\n      body: {\n        username: params.username,\n        password: encrypt_password,\n        new_password: encrypt_new_password,\n        public_key_thumbprint,\n      },\n    })\n  }\n\n  /**\n   * Restore URL state after OAuth callback\n   */\n  private restoreUrlState(search?: string, hash?: string): void {\n    if (search === undefined) return\n    try {\n      const url = new URL(window.location.href)\n      url.search = search\n      url.hash = hash || ''\n      window.history.replaceState(null, '', url.toString())\n    } catch {\n      // ignore\n    }\n  }\n}\n"]}
@@ -130,3 +130,4 @@ export declare const OAUTH_TYPE: {
130
130
  SIGN_IN: string;
131
131
  BIND_IDENTITY: string;
132
132
  };
133
+ export declare const DEFAULT_NODE_ACCESS_SCOPE = "node-sdk-scope";
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.OAUTH_TYPE = exports.EVENTS = exports.AUTH_STATE_CHANGED_TYPE = exports.LOGIN_STATE_CHANGED_TYPE = exports.ErrorType = exports.VerificationUsages = exports.ApiUrlsV2 = exports.ApiUrls = exports.AUTH_API_PREFIX = void 0;
3
+ exports.DEFAULT_NODE_ACCESS_SCOPE = exports.OAUTH_TYPE = exports.EVENTS = exports.AUTH_STATE_CHANGED_TYPE = exports.LOGIN_STATE_CHANGED_TYPE = exports.ErrorType = exports.VerificationUsages = exports.ApiUrlsV2 = exports.ApiUrls = exports.AUTH_API_PREFIX = void 0;
4
4
  exports.AUTH_API_PREFIX = '/auth';
5
5
  var ApiUrls;
6
6
  (function (ApiUrls) {
@@ -137,4 +137,5 @@ exports.OAUTH_TYPE = {
137
137
  SIGN_IN: 'sign_in',
138
138
  BIND_IDENTITY: 'bind_identity',
139
139
  };
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../src/auth/consts.ts"],"names":[],"mappings":"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","sourcesContent":["export const AUTH_API_PREFIX = '/auth'\n\nexport enum ApiUrls {\n  AUTH_SIGN_UP_URL = '/v1/signup',\n  AUTH_TOKEN_URL = '/v1/token',\n  AUTH_REVOKE_URL = '/v1/revoke',\n  WEDA_USER_URL = '/v1/plugin/weda/userinfo',\n  AUTH_RESET_PASSWORD = '/v1/reset',\n  AUTH_GET_DEVICE_CODE = '/v1/device/code',\n  CHECK_USERNAME = '/v1/checkUsername',\n  CHECK_IF_USER_EXIST = '/v1/checkIfUserExist',\n  GET_PROVIDER_TYPE = '/v1/mgr/provider/providerSubType',\n\n  AUTH_SIGN_IN_URL = '/v1/signin',\n  AUTH_SIGN_IN_ANONYMOUSLY_URL = '/v1/signin/anonymously',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v1/signin/with/provider',\n  AUTH_SIGN_IN_WITH_WECHAT_URL = '/v1/signin/wechat/noauth',\n  AUTH_SIGN_IN_CUSTOM = '/v1/signin/custom',\n\n  PROVIDER_TOKEN_URL = '/v1/provider/token',\n  PROVIDER_URI_URL = '/v1/provider/uri',\n\n  USER_ME_URL = '/v1/user/me',\n  AUTH_SIGNOUT_URL = '/v1/user/signout',\n  USER_QUERY_URL = '/v1/user/query',\n  USER_PRIFILE_URL = '/v1/user/profile',\n  USER_BASIC_EDIT_URL = '/v1/user/basic/edit',\n  USER_TRANS_BY_PROVIDER_URL = '/v1/user/trans/by/provider',\n  PROVIDER_LIST = '/v1/user/provider',\n  PROVIDER_BIND_URL = '/v1/user/provider/bind',\n  PROVIDER_UNBIND_URL = '/v1/user/provider',\n  CHECK_PWD_URL = '/v1/user/sudo',\n  SUDO_URL = '/v1/user/sudo',\n  BIND_CONTACT_URL = '/v1/user/contact',\n  AUTH_SET_PASSWORD = '/v1/user/password',\n  AUTHORIZE_DEVICE_URL = '/v1/user/device/authorize',\n  AUTHORIZE_URL = '/v1/user/authorize',\n  AUTHORIZE_INFO_URL = '/v1/user/authorize/info',\n  AUTHORIZED_DEVICES_DELETE_URL = '/v1/user/authorized/devices/',\n  AUTH_REVOKE_ALL_URL = '/v1/user/revoke/all',\n  GET_USER_BEHAVIOR_LOG = '/v1/user/security/history',\n\n  VERIFICATION_URL = '/v1/verification',\n  VERIFY_URL = '/v1/verification/verify',\n\n  CAPTCHA_DATA_URL = '/v1/captcha/data',\n  VERIFY_CAPTCHA_DATA_URL = '/v1/captcha/data/verify',\n  GET_CAPTCHA_URL = '/v1/captcha/init',\n\n  GET_MINIPROGRAM_QRCODE = '/v1/qrcode/generate',\n  GET_MINIPROGRAM_QRCODE_STATUS = '/v1/qrcode/get/status',\n}\n\nexport enum ApiUrlsV2 {\n  AUTH_SIGN_IN_URL = '/v2/signin/username',\n  AUTH_TOKEN_URL = '/v2/token',\n  USER_ME_URL = '/v2/user/me',\n  VERIFY_URL = '/v2/signin/verificationcode',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v2/signin/with/provider',\n  AUTH_PUBLIC_KEY = '/v2/signin/publichkey',\n  AUTH_RESET_PASSWORD = '/v2/signin/password/update'\n}\n\nexport enum VerificationUsages {\n  REGISTER = 'REGISTER',\n  SIGN_IN = 'SIGN_IN',\n  PASSWORD_RESET = 'PASSWORD_RESET',\n  EMAIL_ADDRESS_CHANGE = 'EMAIL_ADDRESS_CHANGE',\n  PHONE_NUMBER_CHANGE = 'PHONE_NUMBER_CHANGE',\n}\n\nexport enum ErrorType {\n  UNREACHABLE = 'unreachable',\n  LOCAL = 'local',\n  CANCELLED = 'cancelled',\n  UNKNOWN = 'unknown',\n  UNAUTHENTICATED = 'unauthenticated',\n  RESOURCE_EXHAUSTED = 'resource_exhausted',\n  FAILED_PRECONDITION = 'failed_precondition',\n  INVALID_ARGUMENT = 'invalid_argument',\n  DEADLINE_EXCEEDED = 'deadline_exceeded',\n  NOT_FOUND = 'not_found',\n  ALREADY_EXISTS = 'already_exists',\n  PERMISSION_DENIED = 'permission_denied',\n  ABORTED = 'aborted',\n  OUT_OF_RANGE = 'out_of_range',\n  UNIMPLEMENTED = 'unimplemented',\n  INTERNAL = 'internal',\n  UNAVAILABLE = 'unavailable',\n  DATA_LOSS = 'data_loss',\n  // CommonError\n  INVALID_PASSWORD = 'invalid_password',\n  PASSWORD_NOT_SET = 'password_not_set',\n  INVALID_STATUS = 'invalid_status',\n  USER_PENDING = 'user_pending',\n  USER_BLOCKED = 'user_blocked',\n  INVALID_VERIFICATION_CODE = 'invalid_verification_code',\n  TWO_FACTOR_REQUIRED = 'two_factor_required',\n  INVALID_TWO_FACTOR = 'invalid_two_factor',\n  INVALID_TWO_FACTOR_RECOVERY = 'invalid_two_factor_recovery',\n  UNDER_REVIEW = 'under_review',\n  INVALID_REQUEST = 'invalid_request',\n  UNAUTHORIZED_CLIENT = 'unauthorized_client',\n  ACCESS_DENIED = 'access_denied',\n  UNSUPPORTED_RESPONSE_TYPE = 'unsupported_response_type',\n  INVALID_SCOPE = 'invalid_scope',\n  INVALID_GRANT = 'invalid_grant',\n  SERVER_ERROR = 'server_error',\n  TEMPORARILY_UNAVAILABLE = 'temporarily_unavailable',\n  INTERACTION_REQUIRED = 'interaction_required',\n  LOGIN_REQUIRED = 'login_required',\n  ACCOUNT_SELECTION_REQUIRED = 'account_selection_required',\n  CONSENT_REQUIRED = 'consent_required',\n  INVALID_REQUEST_URI = 'invalid_request_uri',\n  INVALID_REQUEST_OBJECT = 'invalid_request_object',\n  REQUEST_NOT_SUPPORTED = 'request_not_supported',\n  REQUEST_URI_NOT_SUPPORTED = 'request_uri_not_supported',\n  REGISTRATION_NOT_SUPPORTED = 'registration_not_supported',\n  CAPTCHA_REQUIRED = 'captcha_required',\n  CAPTCHA_INVALID = 'captcha_invalid',\n}\n\nexport const LOGIN_STATE_CHANGED_TYPE = {\n  SIGN_OUT: 'sign_out',\n  SIGN_IN: 'sign_in',\n  CREDENTIALS_ERROR: 'credentials_error',\n}\n\nexport const AUTH_STATE_CHANGED_TYPE = {\n  SIGNED_OUT: 'SIGNED_OUT',\n  SIGNED_IN: 'SIGNED_IN',\n  INITIAL_SESSION: 'INITIAL_SESSION',\n  PASSWORD_RECOVERY: 'PASSWORD_RECOVERY',\n  TOKEN_REFRESHED: 'TOKEN_REFRESHED',\n  USER_UPDATED: 'USER_UPDATED',\n  BIND_IDENTITY: 'BIND_IDENTITY',\n}\n\nexport const EVENTS = {\n  // 登录态改变后触发\n  LOGIN_STATE_CHANGED: 'loginStateChanged',\n  // 授权态改变后触发\n  AUTH_STATE_CHANGED: 'authStateChanged',\n}\n\nexport const OAUTH_TYPE = {\n  SIGN_IN: 'sign_in',\n  BIND_IDENTITY: 'bind_identity',\n}\n"]}
140
+ exports.DEFAULT_NODE_ACCESS_SCOPE = 'node-sdk-scope';
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../src/auth/consts.ts"],"names":[],"mappings":"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","sourcesContent":["export const AUTH_API_PREFIX = '/auth'\n\nexport enum ApiUrls {\n  AUTH_SIGN_UP_URL = '/v1/signup',\n  AUTH_TOKEN_URL = '/v1/token',\n  AUTH_REVOKE_URL = '/v1/revoke',\n  WEDA_USER_URL = '/v1/plugin/weda/userinfo',\n  AUTH_RESET_PASSWORD = '/v1/reset',\n  AUTH_GET_DEVICE_CODE = '/v1/device/code',\n  CHECK_USERNAME = '/v1/checkUsername',\n  CHECK_IF_USER_EXIST = '/v1/checkIfUserExist',\n  GET_PROVIDER_TYPE = '/v1/mgr/provider/providerSubType',\n\n  AUTH_SIGN_IN_URL = '/v1/signin',\n  AUTH_SIGN_IN_ANONYMOUSLY_URL = '/v1/signin/anonymously',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v1/signin/with/provider',\n  AUTH_SIGN_IN_WITH_WECHAT_URL = '/v1/signin/wechat/noauth',\n  AUTH_SIGN_IN_CUSTOM = '/v1/signin/custom',\n\n  PROVIDER_TOKEN_URL = '/v1/provider/token',\n  PROVIDER_URI_URL = '/v1/provider/uri',\n\n  USER_ME_URL = '/v1/user/me',\n  AUTH_SIGNOUT_URL = '/v1/user/signout',\n  USER_QUERY_URL = '/v1/user/query',\n  USER_PRIFILE_URL = '/v1/user/profile',\n  USER_BASIC_EDIT_URL = '/v1/user/basic/edit',\n  USER_TRANS_BY_PROVIDER_URL = '/v1/user/trans/by/provider',\n  PROVIDER_LIST = '/v1/user/provider',\n  PROVIDER_BIND_URL = '/v1/user/provider/bind',\n  PROVIDER_UNBIND_URL = '/v1/user/provider',\n  CHECK_PWD_URL = '/v1/user/sudo',\n  SUDO_URL = '/v1/user/sudo',\n  BIND_CONTACT_URL = '/v1/user/contact',\n  AUTH_SET_PASSWORD = '/v1/user/password',\n  AUTHORIZE_DEVICE_URL = '/v1/user/device/authorize',\n  AUTHORIZE_URL = '/v1/user/authorize',\n  AUTHORIZE_INFO_URL = '/v1/user/authorize/info',\n  AUTHORIZED_DEVICES_DELETE_URL = '/v1/user/authorized/devices/',\n  AUTH_REVOKE_ALL_URL = '/v1/user/revoke/all',\n  GET_USER_BEHAVIOR_LOG = '/v1/user/security/history',\n\n  VERIFICATION_URL = '/v1/verification',\n  VERIFY_URL = '/v1/verification/verify',\n\n  CAPTCHA_DATA_URL = '/v1/captcha/data',\n  VERIFY_CAPTCHA_DATA_URL = '/v1/captcha/data/verify',\n  GET_CAPTCHA_URL = '/v1/captcha/init',\n\n  GET_MINIPROGRAM_QRCODE = '/v1/qrcode/generate',\n  GET_MINIPROGRAM_QRCODE_STATUS = '/v1/qrcode/get/status',\n}\n\nexport enum ApiUrlsV2 {\n  AUTH_SIGN_IN_URL = '/v2/signin/username',\n  AUTH_TOKEN_URL = '/v2/token',\n  USER_ME_URL = '/v2/user/me',\n  VERIFY_URL = '/v2/signin/verificationcode',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v2/signin/with/provider',\n  AUTH_PUBLIC_KEY = '/v2/signin/publichkey',\n  AUTH_RESET_PASSWORD = '/v2/signin/password/update',\n}\n\nexport enum VerificationUsages {\n  REGISTER = 'REGISTER',\n  SIGN_IN = 'SIGN_IN',\n  PASSWORD_RESET = 'PASSWORD_RESET',\n  EMAIL_ADDRESS_CHANGE = 'EMAIL_ADDRESS_CHANGE',\n  PHONE_NUMBER_CHANGE = 'PHONE_NUMBER_CHANGE',\n}\n\nexport enum ErrorType {\n  UNREACHABLE = 'unreachable',\n  LOCAL = 'local',\n  CANCELLED = 'cancelled',\n  UNKNOWN = 'unknown',\n  UNAUTHENTICATED = 'unauthenticated',\n  RESOURCE_EXHAUSTED = 'resource_exhausted',\n  FAILED_PRECONDITION = 'failed_precondition',\n  INVALID_ARGUMENT = 'invalid_argument',\n  DEADLINE_EXCEEDED = 'deadline_exceeded',\n  NOT_FOUND = 'not_found',\n  ALREADY_EXISTS = 'already_exists',\n  PERMISSION_DENIED = 'permission_denied',\n  ABORTED = 'aborted',\n  OUT_OF_RANGE = 'out_of_range',\n  UNIMPLEMENTED = 'unimplemented',\n  INTERNAL = 'internal',\n  UNAVAILABLE = 'unavailable',\n  DATA_LOSS = 'data_loss',\n  // CommonError\n  INVALID_PASSWORD = 'invalid_password',\n  PASSWORD_NOT_SET = 'password_not_set',\n  INVALID_STATUS = 'invalid_status',\n  USER_PENDING = 'user_pending',\n  USER_BLOCKED = 'user_blocked',\n  INVALID_VERIFICATION_CODE = 'invalid_verification_code',\n  TWO_FACTOR_REQUIRED = 'two_factor_required',\n  INVALID_TWO_FACTOR = 'invalid_two_factor',\n  INVALID_TWO_FACTOR_RECOVERY = 'invalid_two_factor_recovery',\n  UNDER_REVIEW = 'under_review',\n  INVALID_REQUEST = 'invalid_request',\n  UNAUTHORIZED_CLIENT = 'unauthorized_client',\n  ACCESS_DENIED = 'access_denied',\n  UNSUPPORTED_RESPONSE_TYPE = 'unsupported_response_type',\n  INVALID_SCOPE = 'invalid_scope',\n  INVALID_GRANT = 'invalid_grant',\n  SERVER_ERROR = 'server_error',\n  TEMPORARILY_UNAVAILABLE = 'temporarily_unavailable',\n  INTERACTION_REQUIRED = 'interaction_required',\n  LOGIN_REQUIRED = 'login_required',\n  ACCOUNT_SELECTION_REQUIRED = 'account_selection_required',\n  CONSENT_REQUIRED = 'consent_required',\n  INVALID_REQUEST_URI = 'invalid_request_uri',\n  INVALID_REQUEST_OBJECT = 'invalid_request_object',\n  REQUEST_NOT_SUPPORTED = 'request_not_supported',\n  REQUEST_URI_NOT_SUPPORTED = 'request_uri_not_supported',\n  REGISTRATION_NOT_SUPPORTED = 'registration_not_supported',\n  CAPTCHA_REQUIRED = 'captcha_required',\n  CAPTCHA_INVALID = 'captcha_invalid',\n}\n\nexport const LOGIN_STATE_CHANGED_TYPE = {\n  SIGN_OUT: 'sign_out',\n  SIGN_IN: 'sign_in',\n  CREDENTIALS_ERROR: 'credentials_error',\n}\n\nexport const AUTH_STATE_CHANGED_TYPE = {\n  SIGNED_OUT: 'SIGNED_OUT',\n  SIGNED_IN: 'SIGNED_IN',\n  INITIAL_SESSION: 'INITIAL_SESSION',\n  PASSWORD_RECOVERY: 'PASSWORD_RECOVERY',\n  TOKEN_REFRESHED: 'TOKEN_REFRESHED',\n  USER_UPDATED: 'USER_UPDATED',\n  BIND_IDENTITY: 'BIND_IDENTITY',\n}\n\nexport const EVENTS = {\n  // 登录态改变后触发\n  LOGIN_STATE_CHANGED: 'loginStateChanged',\n  // 授权态改变后触发\n  AUTH_STATE_CHANGED: 'authStateChanged',\n}\n\nexport const OAUTH_TYPE = {\n  SIGN_IN: 'sign_in',\n  BIND_IDENTITY: 'bind_identity',\n}\n\nexport const DEFAULT_NODE_ACCESS_SCOPE = 'node-sdk-scope'\n"]}
@@ -2,14 +2,13 @@ import { OAuth2Client } from './oauth2client/oauth2client';
2
2
  import { AuthOptions, Auth } from './auth/apis';
3
3
  import { Credentials } from './oauth2client/models';
4
4
  export { Auth } from './auth/apis';
5
- export { AUTH_API_PREFIX, OAUTH_TYPE } from './auth/consts';
6
5
  export { AuthError } from './auth/auth-error';
7
6
  export * as authModels from './auth/models';
8
7
  export type { ProviderProfile, UserInfo, ModifyUserBasicInfoRequest } from './auth/models';
9
8
  export type { Credentials, OAuth2ClientOptions, ResponseError, AuthClientRequestOptions } from './oauth2client/models';
10
9
  export type { AuthOptions } from './auth/apis';
11
10
  export { weAppJwtDecodeAll } from './utils/base64';
12
- export { LOGIN_STATE_CHANGED_TYPE, EVENTS, AUTH_STATE_CHANGED_TYPE } from './auth/consts';
11
+ export { AUTH_API_PREFIX, OAUTH_TYPE, DEFAULT_NODE_ACCESS_SCOPE, LOGIN_STATE_CHANGED_TYPE, EVENTS, AUTH_STATE_CHANGED_TYPE } from './auth/consts';
13
12
  export declare class CloudbaseOAuth {
14
13
  oauth2client: OAuth2Client;
15
14
  authApi: Auth;
package/dist/cjs/index.js CHANGED
@@ -34,24 +34,24 @@ var __importStar = (this && this.__importStar) || function (mod) {
34
34
  return result;
35
35
  };
36
36
  Object.defineProperty(exports, "__esModule", { value: true });
37
- exports.CloudbaseOAuth = exports.AUTH_STATE_CHANGED_TYPE = exports.EVENTS = exports.LOGIN_STATE_CHANGED_TYPE = exports.weAppJwtDecodeAll = exports.authModels = exports.AuthError = exports.OAUTH_TYPE = exports.AUTH_API_PREFIX = exports.Auth = void 0;
37
+ exports.CloudbaseOAuth = exports.AUTH_STATE_CHANGED_TYPE = exports.EVENTS = exports.LOGIN_STATE_CHANGED_TYPE = exports.DEFAULT_NODE_ACCESS_SCOPE = exports.OAUTH_TYPE = exports.AUTH_API_PREFIX = exports.weAppJwtDecodeAll = exports.authModels = exports.AuthError = exports.Auth = void 0;
38
38
  var oauth2client_1 = require("./oauth2client/oauth2client");
39
39
  var apis_1 = require("./auth/apis");
40
40
  var consts_1 = require("./auth/consts");
41
41
  var apis_2 = require("./auth/apis");
42
42
  Object.defineProperty(exports, "Auth", { enumerable: true, get: function () { return apis_2.Auth; } });
43
- var consts_2 = require("./auth/consts");
44
- Object.defineProperty(exports, "AUTH_API_PREFIX", { enumerable: true, get: function () { return consts_2.AUTH_API_PREFIX; } });
45
- Object.defineProperty(exports, "OAUTH_TYPE", { enumerable: true, get: function () { return consts_2.OAUTH_TYPE; } });
46
43
  var auth_error_1 = require("./auth/auth-error");
47
44
  Object.defineProperty(exports, "AuthError", { enumerable: true, get: function () { return auth_error_1.AuthError; } });
48
45
  exports.authModels = __importStar(require("./auth/models"));
49
46
  var base64_1 = require("./utils/base64");
50
47
  Object.defineProperty(exports, "weAppJwtDecodeAll", { enumerable: true, get: function () { return base64_1.weAppJwtDecodeAll; } });
51
- var consts_3 = require("./auth/consts");
52
- Object.defineProperty(exports, "LOGIN_STATE_CHANGED_TYPE", { enumerable: true, get: function () { return consts_3.LOGIN_STATE_CHANGED_TYPE; } });
53
- Object.defineProperty(exports, "EVENTS", { enumerable: true, get: function () { return consts_3.EVENTS; } });
54
- Object.defineProperty(exports, "AUTH_STATE_CHANGED_TYPE", { enumerable: true, get: function () { return consts_3.AUTH_STATE_CHANGED_TYPE; } });
48
+ var consts_2 = require("./auth/consts");
49
+ Object.defineProperty(exports, "AUTH_API_PREFIX", { enumerable: true, get: function () { return consts_2.AUTH_API_PREFIX; } });
50
+ Object.defineProperty(exports, "OAUTH_TYPE", { enumerable: true, get: function () { return consts_2.OAUTH_TYPE; } });
51
+ Object.defineProperty(exports, "DEFAULT_NODE_ACCESS_SCOPE", { enumerable: true, get: function () { return consts_2.DEFAULT_NODE_ACCESS_SCOPE; } });
52
+ Object.defineProperty(exports, "LOGIN_STATE_CHANGED_TYPE", { enumerable: true, get: function () { return consts_2.LOGIN_STATE_CHANGED_TYPE; } });
53
+ Object.defineProperty(exports, "EVENTS", { enumerable: true, get: function () { return consts_2.EVENTS; } });
54
+ Object.defineProperty(exports, "AUTH_STATE_CHANGED_TYPE", { enumerable: true, get: function () { return consts_2.AUTH_STATE_CHANGED_TYPE; } });
55
55
  var CloudbaseOAuth = (function () {
56
56
  function CloudbaseOAuth(authOptions) {
57
57
  var apiOrigin = authOptions.apiOrigin, _a = authOptions.apiPath, apiPath = _a === void 0 ? consts_1.AUTH_API_PREFIX : _a, clientId = authOptions.clientId, env = authOptions.env, storage = authOptions.storage, request = authOptions.request, baseRequest = authOptions.baseRequest, anonymousSignInFunc = authOptions.anonymousSignInFunc, wxCloud = authOptions.wxCloud, adapter = authOptions.adapter, onCredentialsError = authOptions.onCredentialsError, headers = authOptions.headers, i18n = authOptions.i18n, useWxCloud = authOptions.useWxCloud, eventBus = authOptions.eventBus, detectSessionInUrl = authOptions.detectSessionInUrl, debug = authOptions.debug;
@@ -88,4 +88,4 @@ var CloudbaseOAuth = (function () {
88
88
  return CloudbaseOAuth;
89
89
  }());
90
90
  exports.CloudbaseOAuth = CloudbaseOAuth;
91
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDREQUEwRDtBQUMxRCxvQ0FBK0M7QUFDL0Msd0NBQStDO0FBRS9DLG9DQUFrQztBQUF6Qiw0RkFBQSxJQUFJLE9BQUE7QUFDYix3Q0FBMkQ7QUFBbEQseUdBQUEsZUFBZSxPQUFBO0FBQUUsb0dBQUEsVUFBVSxPQUFBO0FBQ3BDLGdEQUE2QztBQUFwQyx1R0FBQSxTQUFTLE9BQUE7QUFDbEIsNERBQTJDO0FBSTNDLHlDQUFrRDtBQUF6QywyR0FBQSxpQkFBaUIsT0FBQTtBQUMxQix3Q0FBeUY7QUFBaEYsa0hBQUEsd0JBQXdCLE9BQUE7QUFBRSxnR0FBQSxNQUFNLE9BQUE7QUFBRSxpSEFBQSx1QkFBdUIsT0FBQTtBQUVsRTtJQUtFLHdCQUFZLFdBQXdCO1FBR2hDLElBQUEsU0FBUyxHQWlCUCxXQUFXLFVBakJKLEVBQ1QsS0FnQkUsV0FBVyxRQWhCWSxFQUF6QixPQUFPLG1CQUFHLHdCQUFlLEtBQUEsRUFDekIsUUFBUSxHQWVOLFdBQVcsU0FmTCxFQUNSLEdBQUcsR0FjRCxXQUFXLElBZFYsRUFDSCxPQUFPLEdBYUwsV0FBVyxRQWJOLEVBQ1AsT0FBTyxHQVlMLFdBQVcsUUFaTixFQUNQLFdBQVcsR0FXVCxXQUFXLFlBWEYsRUFDWCxtQkFBbUIsR0FVakIsV0FBVyxvQkFWTSxFQUNuQixPQUFPLEdBU0wsV0FBVyxRQVROLEVBQ1AsT0FBTyxHQVFMLFdBQVcsUUFSTixFQUNQLGtCQUFrQixHQU9oQixXQUFXLG1CQVBLLEVBQ2xCLE9BQU8sR0FNTCxXQUFXLFFBTk4sRUFDUCxJQUFJLEdBS0YsV0FBVyxLQUxULEVBQ0osVUFBVSxHQUlSLFdBQVcsV0FKSCxFQUNWLFFBQVEsR0FHTixXQUFXLFNBSEwsRUFDUixrQkFBa0IsR0FFaEIsV0FBVyxtQkFGSyxFQUNsQixLQUFLLEdBQ0gsV0FBVyxNQURSLENBQ1E7UUFDZixJQUFJLENBQUMsa0JBQWtCLEdBQUcsa0JBQWtCLGFBQWxCLGtCQUFrQixjQUFsQixrQkFBa0IsR0FBSSxLQUFLLENBQUE7UUFDckQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLDJCQUFZLENBQUM7WUFDbkMsU0FBUyxXQUFBO1lBQ1QsT0FBTyxTQUFBO1lBQ1AsUUFBUSxVQUFBO1lBQ1IsR0FBRyxLQUFBO1lBQ0gsT0FBTyxTQUFBO1lBQ1AsV0FBVyxFQUFFLFdBQVcsSUFBSSxPQUFPO1lBQ25DLG1CQUFtQixxQkFBQTtZQUNuQixPQUFPLFNBQUE7WUFDUCxrQkFBa0Isb0JBQUE7WUFDbEIsT0FBTyxFQUFFLE9BQU8sSUFBSSxFQUFFO1lBQ3RCLElBQUksTUFBQTtZQUNKLFVBQVUsWUFBQTtZQUNWLFFBQVEsVUFBQTtZQUNSLEtBQUssT0FBQTtTQUNOLENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxXQUFJLHFCQUNyQixpQkFBaUIsRUFBRSxJQUFJLENBQUMsWUFBWSxJQUNqQyxXQUFXLEtBRWQsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUNoRixPQUFPLFNBQUEsSUFDUCxDQUFBO1FBSUYsSUFBSSxrQkFBa0IsRUFBRTtZQUN0QixJQUFJLENBQUMsWUFBWSxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFBO1NBQzFGO0lBR0gsQ0FBQztJQU9NLDBDQUFpQixHQUF4QixVQUF5QixjQUFpSDtRQUN4SSxJQUFJLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFO1lBQzVCLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFBO1lBQzlELE9BQU07U0FDUDtRQUNELElBQUksQ0FBQyxZQUFZLENBQUMsMkJBQTJCLENBQUMsY0FBYyxDQUFDLENBQUE7UUFFN0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLEVBQUUsQ0FBQTtJQUNoQyxDQUFDO0lBQ0gscUJBQUM7QUFBRCxDQUFDLEFBM0VELElBMkVDO0FBM0VZLHdDQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT0F1dGgyQ2xpZW50IH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvb2F1dGgyY2xpZW50J1xuaW1wb3J0IHsgQXV0aE9wdGlvbnMsIEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcbmltcG9ydCB7IEFVVEhfQVBJX1BSRUZJWCB9IGZyb20gJy4vYXV0aC9jb25zdHMnXG5pbXBvcnQgeyBDcmVkZW50aWFscyB9IGZyb20gJy4vb2F1dGgyY2xpZW50L21vZGVscydcbmV4cG9ydCB7IEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcbmV4cG9ydCB7IEFVVEhfQVBJX1BSRUZJWCwgT0FVVEhfVFlQRSB9IGZyb20gJy4vYXV0aC9jb25zdHMnXG5leHBvcnQgeyBBdXRoRXJyb3IgfSBmcm9tICcuL2F1dGgvYXV0aC1lcnJvcidcbmV4cG9ydCAqIGFzIGF1dGhNb2RlbHMgZnJvbSAnLi9hdXRoL21vZGVscydcbmV4cG9ydCB0eXBlIHsgUHJvdmlkZXJQcm9maWxlLCBVc2VySW5mbywgTW9kaWZ5VXNlckJhc2ljSW5mb1JlcXVlc3QgfSBmcm9tICcuL2F1dGgvbW9kZWxzJ1xuZXhwb3J0IHR5cGUgeyBDcmVkZW50aWFscywgT0F1dGgyQ2xpZW50T3B0aW9ucywgUmVzcG9uc2VFcnJvciwgQXV0aENsaWVudFJlcXVlc3RPcHRpb25zIH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvbW9kZWxzJ1xuZXhwb3J0IHR5cGUgeyBBdXRoT3B0aW9ucyB9IGZyb20gJy4vYXV0aC9hcGlzJ1xuZXhwb3J0IHsgd2VBcHBKd3REZWNvZGVBbGwgfSBmcm9tICcuL3V0aWxzL2Jhc2U2NCdcbmV4cG9ydCB7IExPR0lOX1NUQVRFX0NIQU5HRURfVFlQRSwgRVZFTlRTLCBBVVRIX1NUQVRFX0NIQU5HRURfVFlQRSB9IGZyb20gJy4vYXV0aC9jb25zdHMnXG5cbmV4cG9ydCBjbGFzcyBDbG91ZGJhc2VPQXV0aCB7XG4gIHB1YmxpYyBvYXV0aDJjbGllbnQ6IE9BdXRoMkNsaWVudFxuICBwdWJsaWMgYXV0aEFwaTogQXV0aFxuICBwcml2YXRlIGRldGVjdFNlc3Npb25JblVybDogYm9vbGVhblxuXG4gIGNvbnN0cnVjdG9yKGF1dGhPcHRpb25zOiBBdXRoT3B0aW9ucykge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBtYXgtbGVuXG4gICAgY29uc3Qge1xuICAgICAgYXBpT3JpZ2luLFxuICAgICAgYXBpUGF0aCA9IEFVVEhfQVBJX1BSRUZJWCxcbiAgICAgIGNsaWVudElkLFxuICAgICAgZW52LFxuICAgICAgc3RvcmFnZSxcbiAgICAgIHJlcXVlc3QsXG4gICAgICBiYXNlUmVxdWVzdCxcbiAgICAgIGFub255bW91c1NpZ25JbkZ1bmMsXG4gICAgICB3eENsb3VkLFxuICAgICAgYWRhcHRlcixcbiAgICAgIG9uQ3JlZGVudGlhbHNFcnJvcixcbiAgICAgIGhlYWRlcnMsXG4gICAgICBpMThuLFxuICAgICAgdXNlV3hDbG91ZCxcbiAgICAgIGV2ZW50QnVzLFxuICAgICAgZGV0ZWN0U2Vzc2lvbkluVXJsLFxuICAgICAgZGVidWcsXG4gICAgfSA9IGF1dGhPcHRpb25zXG4gICAgdGhpcy5kZXRlY3RTZXNzaW9uSW5VcmwgPSBkZXRlY3RTZXNzaW9uSW5VcmwgPz8gZmFsc2VcbiAgICB0aGlzLm9hdXRoMmNsaWVudCA9IG5ldyBPQXV0aDJDbGllbnQoe1xuICAgICAgYXBpT3JpZ2luLFxuICAgICAgYXBpUGF0aCxcbiAgICAgIGNsaWVudElkLFxuICAgICAgZW52LFxuICAgICAgc3RvcmFnZSxcbiAgICAgIGJhc2VSZXF1ZXN0OiBiYXNlUmVxdWVzdCB8fCByZXF1ZXN0LFxuICAgICAgYW5vbnltb3VzU2lnbkluRnVuYyxcbiAgICAgIHd4Q2xvdWQsXG4gICAgICBvbkNyZWRlbnRpYWxzRXJyb3IsXG4gICAgICBoZWFkZXJzOiBoZWFkZXJzIHx8IHt9LFxuICAgICAgaTE4bixcbiAgICAgIHVzZVd4Q2xvdWQsXG4gICAgICBldmVudEJ1cyxcbiAgICAgIGRlYnVnLFxuICAgIH0pXG5cbiAgICB0aGlzLmF1dGhBcGkgPSBuZXcgQXV0aCh7XG4gICAgICBjcmVkZW50aWFsc0NsaWVudDogdGhpcy5vYXV0aDJjbGllbnQsXG4gICAgICAuLi5hdXRoT3B0aW9ucyxcbiAgICAgIC8vIOWFvOWuueiAgemAu+i+ke+8jOacieWAvOS8oOWFpeWImeS4jei1sEF1dGjlhoXnmoTpqozor4HnoIHor7fmsYLpgLvovpFcbiAgICAgIHJlcXVlc3Q6IHJlcXVlc3QgPyB0aGlzLm9hdXRoMmNsaWVudC5yZXF1ZXN0LmJpbmQodGhpcy5vYXV0aDJjbGllbnQpIDogdW5kZWZpbmVkLFxuICAgICAgYWRhcHRlcixcbiAgICB9KVxuXG4gICAgLy8gU2V0IHRoZSBnZXRJbml0aWFsU2Vzc2lvbiBjYWxsYmFjayBhZnRlciBBdXRoIGlzIGNyZWF0ZWRcbiAgICAvLyBUaGlzIGFsbG93cyBBdXRoLmdldEluaXRpYWxTZXNzaW9uIHRvIGhhbmRsZSBVUkwgZGV0ZWN0aW9uIGFuZCBPQXV0aCB2ZXJpZmljYXRpb25cbiAgICBpZiAoZGV0ZWN0U2Vzc2lvbkluVXJsKSB7XG4gICAgICB0aGlzLm9hdXRoMmNsaWVudC5zZXRHZXRJbml0aWFsU2Vzc2lvbih0aGlzLmF1dGhBcGkuZ2V0SW5pdGlhbFNlc3Npb24uYmluZCh0aGlzLmF1dGhBcGkpKVxuICAgIH1cbiAgICAvLyBOb3RlOiBEbyBOT1QgYXV0by1jYWxsIGluaXRpYWxpemUoKSBoZXJlLlxuICAgIC8vIFVwcGVyIGxheWVyIChwYWNrYWdlcy9hdXRoKSBzaG91bGQgY2FsbCBpbml0aWFsaXplU2Vzc2lvbigpIGFmdGVyIHNldHRpbmcgdXAgb25Jbml0aWFsU2Vzc2lvbk9idGFpbmVkIGNhbGxiYWNrXG4gIH1cblxuICAvKipcbiAgICogU2V0dXAgdGhlIG9uSW5pdGlhbFNlc3Npb25PYnRhaW5lZCBjYWxsYmFjayBhbmQgdHJpZ2dlciBpbml0aWFsaXphdGlvbi5cbiAgICogVGhpcyBzaG91bGQgYmUgY2FsbGVkIGJ5IHVwcGVyIGxheWVyIChwYWNrYWdlcy9hdXRoKSBhZnRlciBjcmVhdGluZyBBdXRoIGluc3RhbmNlLlxuICAgKiBAcGFyYW0gb25Vc2VyT2J0YWluZWQgQ2FsbGJhY2sgdG8gaGFuZGxlIHVzZXIgaW5mbyBzdG9yYWdlIGFmdGVyIHNlc3Npb24gaXMgb2J0YWluZWRcbiAgICovXG4gIHB1YmxpYyBpbml0aWFsaXplU2Vzc2lvbihvblVzZXJPYnRhaW5lZD86IChkYXRhOiB7IHNlc3Npb246IENyZWRlbnRpYWxzOyB1c2VyPzogYW55OyB0eXBlPzogc3RyaW5nIH0sIGVycm9yPzogYW55KSA9PiB2b2lkIHwgUHJvbWlzZTx2b2lkPik6IHZvaWQge1xuICAgIGlmICghdGhpcy5kZXRlY3RTZXNzaW9uSW5VcmwpIHtcbiAgICAgIHRoaXMub2F1dGgyY2xpZW50LmluaXRpYWxpemUoUHJvbWlzZS5yZXNvbHZlKHsgZXJyb3I6IG51bGwgfSkpXG4gICAgICByZXR1cm5cbiAgICB9XG4gICAgdGhpcy5vYXV0aDJjbGllbnQuc2V0T25Jbml0aWFsU2Vzc2lvbk9idGFpbmVkKG9uVXNlck9idGFpbmVkKVxuICAgIC8vIFBhc3MgY2FsbGJhY2sgZGlyZWN0bHkgdG8gaW5pdGlhbGl6ZSgpIHRvIGVuc3VyZSBpdCdzIHNldCBiZWZvcmUgaW5pdGlhbGl6YXRpb24gc3RhcnRzXG4gICAgdGhpcy5vYXV0aDJjbGllbnQuaW5pdGlhbGl6ZSgpXG4gIH1cbn1cbiJdfQ==
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDREQUEwRDtBQUMxRCxvQ0FBK0M7QUFDL0Msd0NBQStDO0FBRS9DLG9DQUFrQztBQUF6Qiw0RkFBQSxJQUFJLE9BQUE7QUFDYixnREFBNkM7QUFBcEMsdUdBQUEsU0FBUyxPQUFBO0FBQ2xCLDREQUEyQztBQUkzQyx5Q0FBa0Q7QUFBekMsMkdBQUEsaUJBQWlCLE9BQUE7QUFDMUIsd0NBQWlKO0FBQXhJLHlHQUFBLGVBQWUsT0FBQTtBQUFFLG9HQUFBLFVBQVUsT0FBQTtBQUFFLG1IQUFBLHlCQUF5QixPQUFBO0FBQUUsa0hBQUEsd0JBQXdCLE9BQUE7QUFBRSxnR0FBQSxNQUFNLE9BQUE7QUFBRSxpSEFBQSx1QkFBdUIsT0FBQTtBQUUxSDtJQUtFLHdCQUFZLFdBQXdCO1FBR2hDLElBQUEsU0FBUyxHQWlCUCxXQUFXLFVBakJKLEVBQ1QsS0FnQkUsV0FBVyxRQWhCWSxFQUF6QixPQUFPLG1CQUFHLHdCQUFlLEtBQUEsRUFDekIsUUFBUSxHQWVOLFdBQVcsU0FmTCxFQUNSLEdBQUcsR0FjRCxXQUFXLElBZFYsRUFDSCxPQUFPLEdBYUwsV0FBVyxRQWJOLEVBQ1AsT0FBTyxHQVlMLFdBQVcsUUFaTixFQUNQLFdBQVcsR0FXVCxXQUFXLFlBWEYsRUFDWCxtQkFBbUIsR0FVakIsV0FBVyxvQkFWTSxFQUNuQixPQUFPLEdBU0wsV0FBVyxRQVROLEVBQ1AsT0FBTyxHQVFMLFdBQVcsUUFSTixFQUNQLGtCQUFrQixHQU9oQixXQUFXLG1CQVBLLEVBQ2xCLE9BQU8sR0FNTCxXQUFXLFFBTk4sRUFDUCxJQUFJLEdBS0YsV0FBVyxLQUxULEVBQ0osVUFBVSxHQUlSLFdBQVcsV0FKSCxFQUNWLFFBQVEsR0FHTixXQUFXLFNBSEwsRUFDUixrQkFBa0IsR0FFaEIsV0FBVyxtQkFGSyxFQUNsQixLQUFLLEdBQ0gsV0FBVyxNQURSLENBQ1E7UUFDZixJQUFJLENBQUMsa0JBQWtCLEdBQUcsa0JBQWtCLGFBQWxCLGtCQUFrQixjQUFsQixrQkFBa0IsR0FBSSxLQUFLLENBQUE7UUFDckQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLDJCQUFZLENBQUM7WUFDbkMsU0FBUyxXQUFBO1lBQ1QsT0FBTyxTQUFBO1lBQ1AsUUFBUSxVQUFBO1lBQ1IsR0FBRyxLQUFBO1lBQ0gsT0FBTyxTQUFBO1lBQ1AsV0FBVyxFQUFFLFdBQVcsSUFBSSxPQUFPO1lBQ25DLG1CQUFtQixxQkFBQTtZQUNuQixPQUFPLFNBQUE7WUFDUCxrQkFBa0Isb0JBQUE7WUFDbEIsT0FBTyxFQUFFLE9BQU8sSUFBSSxFQUFFO1lBQ3RCLElBQUksTUFBQTtZQUNKLFVBQVUsWUFBQTtZQUNWLFFBQVEsVUFBQTtZQUNSLEtBQUssT0FBQTtTQUNOLENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxXQUFJLHFCQUNyQixpQkFBaUIsRUFBRSxJQUFJLENBQUMsWUFBWSxJQUNqQyxXQUFXLEtBRWQsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUNoRixPQUFPLFNBQUEsSUFDUCxDQUFBO1FBSUYsSUFBSSxrQkFBa0IsRUFBRTtZQUN0QixJQUFJLENBQUMsWUFBWSxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFBO1NBQzFGO0lBR0gsQ0FBQztJQU9NLDBDQUFpQixHQUF4QixVQUF5QixjQUFpSDtRQUN4SSxJQUFJLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFO1lBQzVCLElBQUksQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFBO1lBQzlELE9BQU07U0FDUDtRQUNELElBQUksQ0FBQyxZQUFZLENBQUMsMkJBQTJCLENBQUMsY0FBYyxDQUFDLENBQUE7UUFFN0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLEVBQUUsQ0FBQTtJQUNoQyxDQUFDO0lBQ0gscUJBQUM7QUFBRCxDQUFDLEFBM0VELElBMkVDO0FBM0VZLHdDQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT0F1dGgyQ2xpZW50IH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvb2F1dGgyY2xpZW50J1xuaW1wb3J0IHsgQXV0aE9wdGlvbnMsIEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcbmltcG9ydCB7IEFVVEhfQVBJX1BSRUZJWCB9IGZyb20gJy4vYXV0aC9jb25zdHMnXG5pbXBvcnQgeyBDcmVkZW50aWFscyB9IGZyb20gJy4vb2F1dGgyY2xpZW50L21vZGVscydcbmV4cG9ydCB7IEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcbmV4cG9ydCB7IEF1dGhFcnJvciB9IGZyb20gJy4vYXV0aC9hdXRoLWVycm9yJ1xuZXhwb3J0ICogYXMgYXV0aE1vZGVscyBmcm9tICcuL2F1dGgvbW9kZWxzJ1xuZXhwb3J0IHR5cGUgeyBQcm92aWRlclByb2ZpbGUsIFVzZXJJbmZvLCBNb2RpZnlVc2VyQmFzaWNJbmZvUmVxdWVzdCB9IGZyb20gJy4vYXV0aC9tb2RlbHMnXG5leHBvcnQgdHlwZSB7IENyZWRlbnRpYWxzLCBPQXV0aDJDbGllbnRPcHRpb25zLCBSZXNwb25zZUVycm9yLCBBdXRoQ2xpZW50UmVxdWVzdE9wdGlvbnMgfSBmcm9tICcuL29hdXRoMmNsaWVudC9tb2RlbHMnXG5leHBvcnQgdHlwZSB7IEF1dGhPcHRpb25zIH0gZnJvbSAnLi9hdXRoL2FwaXMnXG5leHBvcnQgeyB3ZUFwcEp3dERlY29kZUFsbCB9IGZyb20gJy4vdXRpbHMvYmFzZTY0J1xuZXhwb3J0IHsgQVVUSF9BUElfUFJFRklYLCBPQVVUSF9UWVBFLCBERUZBVUxUX05PREVfQUNDRVNTX1NDT1BFLCBMT0dJTl9TVEFURV9DSEFOR0VEX1RZUEUsIEVWRU5UUywgQVVUSF9TVEFURV9DSEFOR0VEX1RZUEUgfSBmcm9tICcuL2F1dGgvY29uc3RzJ1xuXG5leHBvcnQgY2xhc3MgQ2xvdWRiYXNlT0F1dGgge1xuICBwdWJsaWMgb2F1dGgyY2xpZW50OiBPQXV0aDJDbGllbnRcbiAgcHVibGljIGF1dGhBcGk6IEF1dGhcbiAgcHJpdmF0ZSBkZXRlY3RTZXNzaW9uSW5Vcmw6IGJvb2xlYW5cblxuICBjb25zdHJ1Y3RvcihhdXRoT3B0aW9uczogQXV0aE9wdGlvbnMpIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbWF4LWxlblxuICAgIGNvbnN0IHtcbiAgICAgIGFwaU9yaWdpbixcbiAgICAgIGFwaVBhdGggPSBBVVRIX0FQSV9QUkVGSVgsXG4gICAgICBjbGllbnRJZCxcbiAgICAgIGVudixcbiAgICAgIHN0b3JhZ2UsXG4gICAgICByZXF1ZXN0LFxuICAgICAgYmFzZVJlcXVlc3QsXG4gICAgICBhbm9ueW1vdXNTaWduSW5GdW5jLFxuICAgICAgd3hDbG91ZCxcbiAgICAgIGFkYXB0ZXIsXG4gICAgICBvbkNyZWRlbnRpYWxzRXJyb3IsXG4gICAgICBoZWFkZXJzLFxuICAgICAgaTE4bixcbiAgICAgIHVzZVd4Q2xvdWQsXG4gICAgICBldmVudEJ1cyxcbiAgICAgIGRldGVjdFNlc3Npb25JblVybCxcbiAgICAgIGRlYnVnLFxuICAgIH0gPSBhdXRoT3B0aW9uc1xuICAgIHRoaXMuZGV0ZWN0U2Vzc2lvbkluVXJsID0gZGV0ZWN0U2Vzc2lvbkluVXJsID8/IGZhbHNlXG4gICAgdGhpcy5vYXV0aDJjbGllbnQgPSBuZXcgT0F1dGgyQ2xpZW50KHtcbiAgICAgIGFwaU9yaWdpbixcbiAgICAgIGFwaVBhdGgsXG4gICAgICBjbGllbnRJZCxcbiAgICAgIGVudixcbiAgICAgIHN0b3JhZ2UsXG4gICAgICBiYXNlUmVxdWVzdDogYmFzZVJlcXVlc3QgfHwgcmVxdWVzdCxcbiAgICAgIGFub255bW91c1NpZ25JbkZ1bmMsXG4gICAgICB3eENsb3VkLFxuICAgICAgb25DcmVkZW50aWFsc0Vycm9yLFxuICAgICAgaGVhZGVyczogaGVhZGVycyB8fCB7fSxcbiAgICAgIGkxOG4sXG4gICAgICB1c2VXeENsb3VkLFxuICAgICAgZXZlbnRCdXMsXG4gICAgICBkZWJ1ZyxcbiAgICB9KVxuXG4gICAgdGhpcy5hdXRoQXBpID0gbmV3IEF1dGgoe1xuICAgICAgY3JlZGVudGlhbHNDbGllbnQ6IHRoaXMub2F1dGgyY2xpZW50LFxuICAgICAgLi4uYXV0aE9wdGlvbnMsXG4gICAgICAvLyDlhbzlrrnogIHpgLvovpHvvIzmnInlgLzkvKDlhaXliJnkuI3otbBBdXRo5YaF55qE6aqM6K+B56CB6K+35rGC6YC76L6RXG4gICAgICByZXF1ZXN0OiByZXF1ZXN0ID8gdGhpcy5vYXV0aDJjbGllbnQucmVxdWVzdC5iaW5kKHRoaXMub2F1dGgyY2xpZW50KSA6IHVuZGVmaW5lZCxcbiAgICAgIGFkYXB0ZXIsXG4gICAgfSlcblxuICAgIC8vIFNldCB0aGUgZ2V0SW5pdGlhbFNlc3Npb24gY2FsbGJhY2sgYWZ0ZXIgQXV0aCBpcyBjcmVhdGVkXG4gICAgLy8gVGhpcyBhbGxvd3MgQXV0aC5nZXRJbml0aWFsU2Vzc2lvbiB0byBoYW5kbGUgVVJMIGRldGVjdGlvbiBhbmQgT0F1dGggdmVyaWZpY2F0aW9uXG4gICAgaWYgKGRldGVjdFNlc3Npb25JblVybCkge1xuICAgICAgdGhpcy5vYXV0aDJjbGllbnQuc2V0R2V0SW5pdGlhbFNlc3Npb24odGhpcy5hdXRoQXBpLmdldEluaXRpYWxTZXNzaW9uLmJpbmQodGhpcy5hdXRoQXBpKSlcbiAgICB9XG4gICAgLy8gTm90ZTogRG8gTk9UIGF1dG8tY2FsbCBpbml0aWFsaXplKCkgaGVyZS5cbiAgICAvLyBVcHBlciBsYXllciAocGFja2FnZXMvYXV0aCkgc2hvdWxkIGNhbGwgaW5pdGlhbGl6ZVNlc3Npb24oKSBhZnRlciBzZXR0aW5nIHVwIG9uSW5pdGlhbFNlc3Npb25PYnRhaW5lZCBjYWxsYmFja1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHVwIHRoZSBvbkluaXRpYWxTZXNzaW9uT2J0YWluZWQgY2FsbGJhY2sgYW5kIHRyaWdnZXIgaW5pdGlhbGl6YXRpb24uXG4gICAqIFRoaXMgc2hvdWxkIGJlIGNhbGxlZCBieSB1cHBlciBsYXllciAocGFja2FnZXMvYXV0aCkgYWZ0ZXIgY3JlYXRpbmcgQXV0aCBpbnN0YW5jZS5cbiAgICogQHBhcmFtIG9uVXNlck9idGFpbmVkIENhbGxiYWNrIHRvIGhhbmRsZSB1c2VyIGluZm8gc3RvcmFnZSBhZnRlciBzZXNzaW9uIGlzIG9idGFpbmVkXG4gICAqL1xuICBwdWJsaWMgaW5pdGlhbGl6ZVNlc3Npb24ob25Vc2VyT2J0YWluZWQ/OiAoZGF0YTogeyBzZXNzaW9uOiBDcmVkZW50aWFsczsgdXNlcj86IGFueTsgdHlwZT86IHN0cmluZyB9LCBlcnJvcj86IGFueSkgPT4gdm9pZCB8IFByb21pc2U8dm9pZD4pOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuZGV0ZWN0U2Vzc2lvbkluVXJsKSB7XG4gICAgICB0aGlzLm9hdXRoMmNsaWVudC5pbml0aWFsaXplKFByb21pc2UucmVzb2x2ZSh7IGVycm9yOiBudWxsIH0pKVxuICAgICAgcmV0dXJuXG4gICAgfVxuICAgIHRoaXMub2F1dGgyY2xpZW50LnNldE9uSW5pdGlhbFNlc3Npb25PYnRhaW5lZChvblVzZXJPYnRhaW5lZClcbiAgICAvLyBQYXNzIGNhbGxiYWNrIGRpcmVjdGx5IHRvIGluaXRpYWxpemUoKSB0byBlbnN1cmUgaXQncyBzZXQgYmVmb3JlIGluaXRpYWxpemF0aW9uIHN0YXJ0c1xuICAgIHRoaXMub2F1dGgyY2xpZW50LmluaXRpYWxpemUoKVxuICB9XG59XG4iXX0=