@cloudbase/oauth 2.5.3-beta.1 → 2.5.7-beta.0

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.
@@ -314,6 +314,7 @@ var OAuth2Client = (function () {
314
314
  });
315
315
  this.clientSecret = options.clientSecret;
316
316
  this.refreshTokenFunc = options.refreshTokenFunc || this.defaultRefreshTokenFunc;
317
+ this.anonymousSignInFunc = options.anonymousSignInFunc;
317
318
  }
318
319
  OAuth2Client.prototype.setCredentials = function (credentials) {
319
320
  return this.localCredentials.setCredentials(credentials);
@@ -426,23 +427,37 @@ var OAuth2Client = (function () {
426
427
  };
427
428
  OAuth2Client.prototype.getCredentials = function () {
428
429
  return __awaiter(this, void 0, void 0, function () {
429
- var credentials;
430
- return __generator(this, function (_a) {
431
- switch (_a.label) {
430
+ var credentials, c, _a;
431
+ return __generator(this, function (_b) {
432
+ switch (_b.label) {
432
433
  case 0: return [4, this.localCredentials.getCredentials()];
433
434
  case 1:
434
- credentials = _a.sent();
435
- if (!isCredentialsExpired(credentials)) return [3, 5];
436
- if (!(credentials && credentials.scope === 'anonymous')) return [3, 3];
437
- return [4, this.anonymousSignIn(credentials)];
435
+ credentials = _b.sent();
436
+ if (!isCredentialsExpired(credentials)) return [3, 10];
437
+ if (!(credentials && credentials.scope === 'anonymous')) return [3, 8];
438
+ if (!this.anonymousSignInFunc) return [3, 5];
439
+ return [4, this.anonymousSignInFunc(credentials)];
438
440
  case 2:
439
- credentials = _a.sent();
440
- return [3, 5];
441
- case 3: return [4, this.refreshToken(credentials)];
441
+ c = _b.sent();
442
+ _a = c;
443
+ if (_a) return [3, 4];
444
+ return [4, this.localCredentials.getCredentials()];
445
+ case 3:
446
+ _a = (_b.sent());
447
+ _b.label = 4;
442
448
  case 4:
443
- credentials = _a.sent();
444
- _a.label = 5;
445
- case 5: return [2, credentials];
449
+ credentials = _a;
450
+ return [3, 7];
451
+ case 5: return [4, this.anonymousSignIn(credentials)];
452
+ case 6:
453
+ credentials = _b.sent();
454
+ _b.label = 7;
455
+ case 7: return [3, 10];
456
+ case 8: return [4, this.refreshToken(credentials)];
457
+ case 9:
458
+ credentials = _b.sent();
459
+ _b.label = 10;
460
+ case 10: return [2, credentials];
446
461
  }
447
462
  });
448
463
  });
@@ -653,4 +668,4 @@ var OAuth2Client = (function () {
653
668
  return OAuth2Client;
654
669
  }());
655
670
  exports.OAuth2Client = OAuth2Client;
656
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2client.js","sourceRoot":"","sources":["../../../src/oauth2client/oauth2client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrorType } from './consts'\n\nimport { AuthClient, SimpleStorage } from './interface'\n\nimport {\n  Credentials,\n  ResponseError,\n  RequestOptions,\n  RequestFunction,\n  OAuth2ClientOptions,\n  AuthClientRequestOptions,\n} from './models'\n\nimport { uuidv4 } from '../utils/uuid'\n\nimport { SinglePromise } from '../utils/function/single-promise'\n\nconst RequestIdHeaderName = 'x-request-id'\nconst DeviceIdHeaderName = 'x-device-id'\nconst DeviceIdSectionName = 'device_id'\n\nexport interface ToResponseErrorOptions {\n  error?: ErrorType;\n  error_description?: string | null;\n  error_uri?: string | null;\n  details?: any | null;\n}\n\n\nexport const defaultRequest: RequestFunction = async function <T>(\n  url: string,\n  options?: RequestOptions\n): Promise<T> {\n  let result: T | null = null\n  let responseError: ResponseError | null = null\n  try {\n    // Objects must be copied to prevent modification of data such as body.\n    const copyOptions = Object.assign({}, options)\n    if (!copyOptions.method) {\n      copyOptions.method = 'GET'\n    }\n    if (copyOptions.body && typeof copyOptions.body !== 'string') {\n      copyOptions.body = JSON.stringify(copyOptions.body)\n    }\n    const responseResult: Response = await fetch(url, copyOptions)\n    const jsonResponse = await responseResult.json()\n    if (jsonResponse?.error) {\n      responseError = jsonResponse as ResponseError\n      responseError.error_uri = new URL(url).pathname\n    } else {\n      result = jsonResponse as T\n    }\n  } catch (error) {\n    responseError = {\n      error: ErrorType.UNREACHABLE,\n      error_description: error.message,\n      error_uri: new URL(url).pathname,\n    }\n  }\n  if (responseError) {\n    throw responseError\n  } else {\n    return result\n  }\n}\n\nexport const toResponseError = (\n  error: ResponseError | Error,\n  options?: ToResponseErrorOptions,\n): ResponseError => {\n  let responseError: ResponseError\n  const formatOptions: ToResponseErrorOptions = options || {}\n  if (error instanceof Error) {\n    responseError = {\n      error: formatOptions.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || error.message,\n      error_uri: formatOptions.error_uri,\n      details: formatOptions.details || error.stack,\n    }\n  } else {\n    const formatError: ToResponseErrorOptions = error || {}\n    responseError = {\n      error: formatOptions.error || formatError.error || ErrorType.LOCAL,\n      error_description:\n        formatOptions.error_description || formatError.error_description,\n      error_uri: formatOptions.error_uri || formatError.error_uri,\n      details: formatOptions.details || formatError.details,\n    }\n  }\n  return responseError\n}\n\n/**\n * Generate request id.\n * @return {string}\n */\nexport function generateRequestId(): string {\n  return uuidv4()\n}\n\n\n/**\n * Default Storage.\n */\nclass DefaultStorage implements SimpleStorage {\n  /**\n     * Get item.\n     * @param {string} key\n     */\n  async getItem(key: string): Promise<string | null> {\n    return window.localStorage.getItem(key)\n  }\n\n  /**\n     * Remove item.\n     * @param {string} key\n     */\n  async removeItem(key: string): Promise<void> {\n    window.localStorage.removeItem(key)\n  }\n\n  /**\n     * Set item.\n     * @param {string} key\n     * @param {string} value\n     */\n  async setItem(key: string, value: string): Promise<void> {\n    window.localStorage.setItem(key, value)\n  }\n\n  /**\n     * Get item sync.\n     * @param {string} key\n     */\n  getItemSync(key: string): string | null {\n    return window.localStorage.getItem(key)\n  }\n\n  /**\n     * Remove item sync.\n     * @param {string} key\n     */\n  removeItemSync(key: string): void {\n    window.localStorage.removeItem(key)\n  }\n\n  /**\n     * Set item sync.\n     * @param {string} key\n     * @param {string} value\n     */\n  setItemSync(key: string, value: string): void {\n    window.localStorage.setItem(key, value)\n  }\n}\n\nexport const defaultStorage = new DefaultStorage()\n\ninterface LocalCredentialsOptions {\n  tokenSectionName: string;\n  storage: SimpleStorage;\n}\n\n/**\n * Check if credentials is expired.\n * @param {Credentials} credentials\n * @return {boolean}\n */\nfunction isCredentialsExpired(credentials: Credentials): boolean {\n  let isExpired = true\n  if (credentials?.expires_at && credentials?.access_token) {\n    isExpired = credentials.expires_at < new Date()\n  }\n  return isExpired\n}\n\n/**\n * Local credentials.\n * Local credentials, with memory cache and storage cache.\n * If the memory cache expires, the storage cache is automatically loaded.\n */\nexport class LocalCredentials {\n  private tokenSectionName: string\n\n  private storage: SimpleStorage\n\n  private credentials: Credentials | null = null\n\n  private singlePromise: SinglePromise = new SinglePromise()\n\n  /**\n   * constructor\n   * @param {LocalCredentialsOptions} options\n   */\n  constructor(options: LocalCredentialsOptions) {\n    this.tokenSectionName = options.tokenSectionName\n    this.storage = options.storage\n  }\n\n  public getStorageCredentialsSync(): Credentials | null {\n    let credentials: Credentials = null\n    const tokenStr: string = this.storage.getItemSync(this.tokenSectionName,)\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        credentials = JSON.parse(tokenStr)\n        if (credentials?.expires_at) {\n          credentials.expires_at = new Date(credentials.expires_at)\n        }\n      } catch (error) {\n        this.storage.removeItem(this.tokenSectionName)\n        credentials = null\n      }\n    }\n    return credentials\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   */\n  public async setCredentials(credentials?: Credentials): Promise<void> {\n    if (credentials?.expires_in) {\n      credentials.expires_at = new Date(Date.now() + (credentials.expires_in - 30) * 1000,)\n      if (this.storage) {\n        const tokenStr: string = JSON.stringify(credentials)\n        await this.storage.setItem(this.tokenSectionName, tokenStr)\n      }\n      this.credentials = credentials\n    } else {\n      if (this.storage) {\n        await this.storage.removeItem(this.tokenSectionName)\n      }\n      this.credentials = null\n    }\n  }\n\n  /**\n   * Get credentials.\n   * @return {Promise<Credentials | null>}\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('getCredentials', async () => {\n      if (isCredentialsExpired(this.credentials)) {\n        this.credentials = await this.getStorageCredentials()\n      }\n      return this.credentials\n    })\n  }\n\n  /**\n   * Get storage credentials.\n   */\n  private async getStorageCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('_getStorageCredentials', async () => {\n      let credentials: Credentials = null\n      const tokenStr: string = await this.storage.getItem(this.tokenSectionName,)\n      if (tokenStr !== undefined && tokenStr !== null) {\n        try {\n          credentials = JSON.parse(tokenStr)\n          if (credentials?.expires_at) {\n            credentials.expires_at = new Date(credentials.expires_at)\n          }\n        } catch (error) {\n          await this.storage.removeItem(this.tokenSectionName)\n          credentials = null\n        }\n      }\n      return credentials\n    })\n  }\n}\n\n/**\n * OAuth2Client\n */\nexport class OAuth2Client implements AuthClient {\n  private static defaultRetry = 2\n  private static minRetry = 0\n  private static maxRetry = 5\n  private static retryInterval = 1000\n\n  private apiOrigin: string\n  private clientId: string\n  private retry: number\n  private clientSecret?: string\n  private baseRequest: <T>(\n    url: string,\n    options?: RequestOptions,\n  ) => Promise<T>\n  private localCredentials: LocalCredentials\n  private storage: SimpleStorage\n  private deviceID?: string\n  private tokenInURL?: boolean\n  private refreshTokenFunc: (refreshToken?: string) => Promise<Credentials>\n  private headers?: { [key: string]: string }\n  private singlePromise: SinglePromise = new SinglePromise()\n\n  /**\n   * constructor\n   * @param {OAuth2ClientOptions} options\n   */\n  constructor(options: OAuth2ClientOptions) {\n    this.apiOrigin = options.apiOrigin\n    this.clientId = options.clientId\n    this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry)\n    if (options.baseRequest) {\n      this.baseRequest = options.baseRequest\n    } else {\n      this.baseRequest = defaultRequest\n    }\n    this.tokenInURL = options.tokenInURL\n    this.headers = options.headers\n    // @ts-ignore\n    this.storage = options.storage || defaultStorage\n    this.localCredentials = new LocalCredentials({\n      tokenSectionName: `credentials_${options.clientId}`,\n      storage: this.storage,\n    })\n    this.clientSecret = options.clientSecret\n    this.refreshTokenFunc =      options.refreshTokenFunc || this.defaultRefreshTokenFunc\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   * @return {Promise<void>}\n   */\n  public setCredentials(credentials?: Credentials): Promise<void> {\n    return this.localCredentials.setCredentials(credentials)\n  }\n\n  /**\n   * getAccessToken return a validate access token\n   */\n  public async getAccessToken(): Promise<string> {\n    const credentials: Credentials = await this.getCredentials()\n    if (credentials?.access_token) {\n      return Promise.resolve(credentials.access_token)\n    }\n    const respErr: ResponseError = { error: ErrorType.UNAUTHENTICATED }\n    return Promise.reject(respErr)\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(\n    url: string,\n    options?: AuthClientRequestOptions,\n  ): Promise<T> {\n    if (!options) {\n      options = {}\n    }\n    const retry: number = this.formatRetry(options.retry, this.retry)\n    options.headers = options.headers || {}\n    if (this.headers) {\n      options.headers = {\n        ...this.headers,\n        ...options.headers,\n      }\n    }\n    if (!options.headers[RequestIdHeaderName]) {\n      options.headers[RequestIdHeaderName] = generateRequestId()\n    }\n    if (!options.headers[DeviceIdHeaderName]) {\n      const deviceId = await this.getDeviceId()\n      options.headers[DeviceIdHeaderName] = deviceId\n    }\n    if (options?.withCredentials) {\n      const credentials = await this.getCredentials()\n      if (credentials) {\n        if (this.tokenInURL) {\n          if (url.indexOf('?') < 0) {\n            url += '?'\n          }\n          url += `access_token=${credentials.access_token}`\n        } else {\n          options.headers.Authorization =            `${credentials.token_type} ${credentials.access_token}`\n        }\n      }\n    } else {\n      if (this.clientId && url.indexOf('client_id') < 0) {\n        url += url.indexOf('?') < 0 ? '?' : '&'\n        url += `client_id=${this.clientId}`\n      }\n    }\n    if (url.startsWith('/')) {\n      url = this.apiOrigin + url\n    }\n    let response: T | null = null\n    const maxRequestTimes: number = retry + 1\n    for (\n      let requestTime = 0;\n      requestTime < maxRequestTimes;\n      requestTime++\n    ) {\n      try {\n        response = await this.baseRequest<T>(url, options)\n        break\n      } catch (responseError) {\n        if (options.withCredentials && responseError && responseError.error === ErrorType.UNAUTHENTICATED) {\n          await this.setCredentials(null)\n          return Promise.reject(responseError)\n        }\n\n        if (\n          requestTime === retry\n          || !responseError\n          || responseError.error !== 'unreachable'\n        ) {\n          return Promise.reject(responseError)\n        }\n      }\n      await this.sleep(OAuth2Client.retryInterval)\n    }\n    return response\n  }\n\n\n  /**\n   * Get credentials.\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    let credentials: Credentials = await this.localCredentials.getCredentials()\n    if (isCredentialsExpired(credentials)) {\n      if (credentials && credentials.scope === 'anonymous') {\n        credentials = await this.anonymousSignIn(credentials)\n      } else {\n        credentials = await this.refreshToken(credentials)\n      }\n    }\n    return credentials\n  }\n\n  public getCredentialsSync(): Credentials | null {\n    const credentials: Credentials = this.localCredentials.getStorageCredentialsSync()\n    return credentials\n  }\n\n  public getCredentialsAsync(): Promise<Credentials | null> {\n    return this.localCredentials.getCredentials()\n  }\n\n  public async getScope(): Promise<string> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      return this.unAuthenticatedError('credentials not found')\n    }\n    return credentials.scope\n  }\n\n  public async getGroups(): Promise<string[]> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      return this.unAuthenticatedError('credentials not found')\n    }\n    return credentials.groups\n  }\n\n  /**\n   * Check retry value.\n   * @param {number} retry\n   * @return {number}\n   */\n  private checkRetry(retry: number): number {\n    let responseError: ResponseError | null = null\n    if (\n      typeof retry !== 'number'\n      || retry < OAuth2Client.minRetry\n      || retry > OAuth2Client.maxRetry\n    ) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: 'wrong options param: retry',\n      }\n    }\n    if (responseError) {\n      throw responseError\n    }\n    return retry\n  }\n\n  /**\n   * Format retry value.\n   * @param {number} retry\n   * @param {number} defaultVale\n   * @return {number}\n   */\n  private formatRetry(retry: number, defaultVale: number): number {\n    if (typeof retry === 'undefined') {\n      return defaultVale\n    }\n    return this.checkRetry(retry)\n  }\n\n  /**\n   * Sleep.\n   * @param {number} ms\n   * @return {Promise<void>}\n   */\n  private async sleep(ms: number): Promise<void> {\n    return new Promise<void>((resolve) => {\n      setTimeout(() => {\n        resolve()\n      }, ms)\n    })\n  }\n\n  /**\n   * Refresh expired token.\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async refreshToken(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_refreshToken', async () => {\n      if (!credentials || !credentials.refresh_token) {\n        return this.unAuthenticatedError('no refresh token found in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.refreshTokenFunc(credentials.refresh_token,)\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * anonymous signIn\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async anonymousSignIn(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_anonymous', async () => {\n      if (!credentials || credentials.scope !== 'anonymous') {\n        return this.unAuthenticatedError('no anonymous in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.request('/auth/v1/signin/anonymously', {\n          method: 'POST',\n          body: {\n            client_id: this.clientId,\n            client_secret: this.clientSecret,\n          },\n        })\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * Default refresh token function.\n   * @param {string} refreshToken\n   * @return {Promise<Credentials>}\n   */\n  private defaultRefreshTokenFunc(refreshToken?: string,): Promise<Credentials> {\n    if (refreshToken === undefined || refreshToken === '') {\n      return this.unAuthenticatedError('refresh token not found')\n    }\n    return this.request('/auth/v1/token', {\n      method: 'POST',\n      body: {\n        client_id: this.clientId,\n        client_secret: this.clientSecret,\n        grant_type: 'refresh_token',\n        refresh_token: refreshToken,\n      },\n    })\n  }\n\n  /**\n   * Get deviceId\n   */\n  private async getDeviceId(): Promise<string> {\n    if (this.deviceID) {\n      return this.deviceID\n    }\n    let deviceId: string = await this.storage.getItem(DeviceIdSectionName,)\n    if (!(typeof deviceId === 'string'\n      && deviceId.length >= 16\n      && deviceId.length <= 48)) {\n      deviceId = uuidv4()\n      await this.storage.setItem(DeviceIdSectionName, deviceId)\n    }\n    this.deviceID = deviceId\n    return deviceId\n  }\n  /**\n   * Generate unAuthenticated error.\n   * @param {string} err\n   * @return {Promise<T>}\n   */\n  private unAuthenticatedError<T>(err?: string): Promise<T> {\n    const respErr: ResponseError = {\n      error: ErrorType.UNAUTHENTICATED,\n      error_description: err,\n    }\n    return Promise.reject(respErr)\n  }\n}\n"]}
671
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2client.js","sourceRoot":"","sources":["../../../src/oauth2client/oauth2client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrorType } from './consts'\n\nimport { AuthClient, SimpleStorage } from './interface'\n\nimport {\n  Credentials,\n  ResponseError,\n  RequestOptions,\n  RequestFunction,\n  OAuth2ClientOptions,\n  AuthClientRequestOptions,\n} from './models'\n\nimport { uuidv4 } from '../utils/uuid'\n\nimport { SinglePromise } from '../utils/function/single-promise'\n\nconst RequestIdHeaderName = 'x-request-id'\nconst DeviceIdHeaderName = 'x-device-id'\nconst DeviceIdSectionName = 'device_id'\n\nexport interface ToResponseErrorOptions {\n  error?: ErrorType;\n  error_description?: string | null;\n  error_uri?: string | null;\n  details?: any | null;\n}\n\n\nexport const defaultRequest: RequestFunction = async function <T>(\n  url: string,\n  options?: RequestOptions\n): Promise<T> {\n  let result: T | null = null\n  let responseError: ResponseError | null = null\n  try {\n    // Objects must be copied to prevent modification of data such as body.\n    const copyOptions = Object.assign({}, options)\n    if (!copyOptions.method) {\n      copyOptions.method = 'GET'\n    }\n    if (copyOptions.body && typeof copyOptions.body !== 'string') {\n      copyOptions.body = JSON.stringify(copyOptions.body)\n    }\n    const responseResult: Response = await fetch(url, copyOptions)\n    const jsonResponse = await responseResult.json()\n    if (jsonResponse?.error) {\n      responseError = jsonResponse as ResponseError\n      responseError.error_uri = new URL(url).pathname\n    } else {\n      result = jsonResponse as T\n    }\n  } catch (error) {\n    responseError = {\n      error: ErrorType.UNREACHABLE,\n      error_description: error.message,\n      error_uri: new URL(url).pathname,\n    }\n  }\n  if (responseError) {\n    throw responseError\n  } else {\n    return result\n  }\n}\n\nexport const toResponseError = (\n  error: ResponseError | Error,\n  options?: ToResponseErrorOptions,\n): ResponseError => {\n  let responseError: ResponseError\n  const formatOptions: ToResponseErrorOptions = options || {}\n  if (error instanceof Error) {\n    responseError = {\n      error: formatOptions.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || error.message,\n      error_uri: formatOptions.error_uri,\n      details: formatOptions.details || error.stack,\n    }\n  } else {\n    const formatError: ToResponseErrorOptions = error || {}\n    responseError = {\n      error: formatOptions.error || formatError.error || ErrorType.LOCAL,\n      error_description:\n        formatOptions.error_description || formatError.error_description,\n      error_uri: formatOptions.error_uri || formatError.error_uri,\n      details: formatOptions.details || formatError.details,\n    }\n  }\n  return responseError\n}\n\n/**\n * Generate request id.\n * @return {string}\n */\nexport function generateRequestId(): string {\n  return uuidv4()\n}\n\n\n/**\n * Default Storage.\n */\nclass DefaultStorage implements SimpleStorage {\n  /**\n     * Get item.\n     * @param {string} key\n     */\n  async getItem(key: string): Promise<string | null> {\n    return window.localStorage.getItem(key)\n  }\n\n  /**\n     * Remove item.\n     * @param {string} key\n     */\n  async removeItem(key: string): Promise<void> {\n    window.localStorage.removeItem(key)\n  }\n\n  /**\n     * Set item.\n     * @param {string} key\n     * @param {string} value\n     */\n  async setItem(key: string, value: string): Promise<void> {\n    window.localStorage.setItem(key, value)\n  }\n\n  /**\n     * Get item sync.\n     * @param {string} key\n     */\n  getItemSync(key: string): string | null {\n    return window.localStorage.getItem(key)\n  }\n\n  /**\n     * Remove item sync.\n     * @param {string} key\n     */\n  removeItemSync(key: string): void {\n    window.localStorage.removeItem(key)\n  }\n\n  /**\n     * Set item sync.\n     * @param {string} key\n     * @param {string} value\n     */\n  setItemSync(key: string, value: string): void {\n    window.localStorage.setItem(key, value)\n  }\n}\n\nexport const defaultStorage = new DefaultStorage()\n\ninterface LocalCredentialsOptions {\n  tokenSectionName: string;\n  storage: SimpleStorage;\n}\n\n/**\n * Check if credentials is expired.\n * @param {Credentials} credentials\n * @return {boolean}\n */\nfunction isCredentialsExpired(credentials: Credentials): boolean {\n  let isExpired = true\n  if (credentials?.expires_at && credentials?.access_token) {\n    isExpired = credentials.expires_at < new Date()\n  }\n  return isExpired\n}\n\n/**\n * Local credentials.\n * Local credentials, with memory cache and storage cache.\n * If the memory cache expires, the storage cache is automatically loaded.\n */\nexport class LocalCredentials {\n  private tokenSectionName: string\n\n  private storage: SimpleStorage\n\n  private credentials: Credentials | null = null\n\n  private singlePromise: SinglePromise = new SinglePromise()\n\n  /**\n   * constructor\n   * @param {LocalCredentialsOptions} options\n   */\n  constructor(options: LocalCredentialsOptions) {\n    this.tokenSectionName = options.tokenSectionName\n    this.storage = options.storage\n  }\n\n  public getStorageCredentialsSync(): Credentials | null {\n    let credentials: Credentials = null\n    const tokenStr: string = this.storage.getItemSync(this.tokenSectionName,)\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        credentials = JSON.parse(tokenStr)\n        if (credentials?.expires_at) {\n          credentials.expires_at = new Date(credentials.expires_at)\n        }\n      } catch (error) {\n        this.storage.removeItem(this.tokenSectionName)\n        credentials = null\n      }\n    }\n    return credentials\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   */\n  public async setCredentials(credentials?: Credentials): Promise<void> {\n    if (credentials?.expires_in) {\n      credentials.expires_at = new Date(Date.now() + (credentials.expires_in - 30) * 1000,)\n      if (this.storage) {\n        const tokenStr: string = JSON.stringify(credentials)\n        await this.storage.setItem(this.tokenSectionName, tokenStr)\n      }\n      this.credentials = credentials\n    } else {\n      if (this.storage) {\n        await this.storage.removeItem(this.tokenSectionName)\n      }\n      this.credentials = null\n    }\n  }\n\n  /**\n   * Get credentials.\n   * @return {Promise<Credentials | null>}\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('getCredentials', async () => {\n      if (isCredentialsExpired(this.credentials)) {\n        this.credentials = await this.getStorageCredentials()\n      }\n      return this.credentials\n    })\n  }\n\n  /**\n   * Get storage credentials.\n   */\n  private async getStorageCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('_getStorageCredentials', async () => {\n      let credentials: Credentials = null\n      const tokenStr: string = await this.storage.getItem(this.tokenSectionName,)\n      if (tokenStr !== undefined && tokenStr !== null) {\n        try {\n          credentials = JSON.parse(tokenStr)\n          if (credentials?.expires_at) {\n            credentials.expires_at = new Date(credentials.expires_at)\n          }\n        } catch (error) {\n          await this.storage.removeItem(this.tokenSectionName)\n          credentials = null\n        }\n      }\n      return credentials\n    })\n  }\n}\n\n/**\n * OAuth2Client\n */\nexport class OAuth2Client implements AuthClient {\n  private static defaultRetry = 2\n  private static minRetry = 0\n  private static maxRetry = 5\n  private static retryInterval = 1000\n\n  private apiOrigin: string\n  private clientId: string\n  private retry: number\n  private clientSecret?: string\n  private baseRequest: <T>(\n    url: string,\n    options?: RequestOptions,\n  ) => Promise<T>\n  private localCredentials: LocalCredentials\n  private storage: SimpleStorage\n  private deviceID?: string\n  private tokenInURL?: boolean\n  private refreshTokenFunc: (refreshToken?: string) => Promise<Credentials>\n  private headers?: { [key: string]: string }\n  private singlePromise: SinglePromise = new SinglePromise()\n  private anonymousSignInFunc: (Credentials) => Promise<Credentials | void>\n\n  /**\n   * constructor\n   * @param {OAuth2ClientOptions} options\n   */\n  constructor(options: OAuth2ClientOptions) {\n    this.apiOrigin = options.apiOrigin\n    this.clientId = options.clientId\n    this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry)\n    if (options.baseRequest) {\n      this.baseRequest = options.baseRequest\n    } else {\n      this.baseRequest = defaultRequest\n    }\n    this.tokenInURL = options.tokenInURL\n    this.headers = options.headers\n    // @ts-ignore\n    this.storage = options.storage || defaultStorage\n    this.localCredentials = new LocalCredentials({\n      tokenSectionName: `credentials_${options.clientId}`,\n      storage: this.storage,\n    })\n    this.clientSecret = options.clientSecret\n    this.refreshTokenFunc =      options.refreshTokenFunc || this.defaultRefreshTokenFunc\n    this.anonymousSignInFunc = options.anonymousSignInFunc\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   * @return {Promise<void>}\n   */\n  public setCredentials(credentials?: Credentials): Promise<void> {\n    return this.localCredentials.setCredentials(credentials)\n  }\n\n  /**\n   * getAccessToken return a validate access token\n   */\n  public async getAccessToken(): Promise<string> {\n    const credentials: Credentials = await this.getCredentials()\n    if (credentials?.access_token) {\n      return Promise.resolve(credentials.access_token)\n    }\n    const respErr: ResponseError = { error: ErrorType.UNAUTHENTICATED }\n    return Promise.reject(respErr)\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(\n    url: string,\n    options?: AuthClientRequestOptions,\n  ): Promise<T> {\n    if (!options) {\n      options = {}\n    }\n    const retry: number = this.formatRetry(options.retry, this.retry)\n    options.headers = options.headers || {}\n    if (this.headers) {\n      options.headers = {\n        ...this.headers,\n        ...options.headers,\n      }\n    }\n    if (!options.headers[RequestIdHeaderName]) {\n      options.headers[RequestIdHeaderName] = generateRequestId()\n    }\n    if (!options.headers[DeviceIdHeaderName]) {\n      const deviceId = await this.getDeviceId()\n      options.headers[DeviceIdHeaderName] = deviceId\n    }\n    if (options?.withCredentials) {\n      const credentials = await this.getCredentials()\n      if (credentials) {\n        if (this.tokenInURL) {\n          if (url.indexOf('?') < 0) {\n            url += '?'\n          }\n          url += `access_token=${credentials.access_token}`\n        } else {\n          options.headers.Authorization =            `${credentials.token_type} ${credentials.access_token}`\n        }\n      }\n    } else {\n      if (this.clientId && url.indexOf('client_id') < 0) {\n        url += url.indexOf('?') < 0 ? '?' : '&'\n        url += `client_id=${this.clientId}`\n      }\n    }\n    if (url.startsWith('/')) {\n      url = this.apiOrigin + url\n    }\n    let response: T | null = null\n    const maxRequestTimes: number = retry + 1\n    for (\n      let requestTime = 0;\n      requestTime < maxRequestTimes;\n      requestTime++\n    ) {\n      try {\n        response = await this.baseRequest<T>(url, options)\n        break\n      } catch (responseError) {\n        if (options.withCredentials && responseError && responseError.error === ErrorType.UNAUTHENTICATED) {\n          await this.setCredentials(null)\n          return Promise.reject(responseError)\n        }\n\n        if (\n          requestTime === retry\n          || !responseError\n          || responseError.error !== 'unreachable'\n        ) {\n          return Promise.reject(responseError)\n        }\n      }\n      await this.sleep(OAuth2Client.retryInterval)\n    }\n    return response\n  }\n\n\n  /**\n   * Get credentials.\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    let credentials: Credentials = await this.localCredentials.getCredentials()\n    if (isCredentialsExpired(credentials)) {\n      if (credentials && credentials.scope === 'anonymous') {\n        if (this.anonymousSignInFunc) {\n          const c = await this.anonymousSignInFunc(credentials)\n          credentials = c || await this.localCredentials.getCredentials()\n        } else {\n          credentials = await this.anonymousSignIn(credentials)\n        }\n      } else {\n        credentials = await this.refreshToken(credentials)\n      }\n    }\n    return credentials\n  }\n\n  public getCredentialsSync(): Credentials | null {\n    const credentials: Credentials = this.localCredentials.getStorageCredentialsSync()\n    return credentials\n  }\n\n  public getCredentialsAsync(): Promise<Credentials | null> {\n    return this.localCredentials.getCredentials()\n  }\n\n  public async getScope(): Promise<string> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      return this.unAuthenticatedError('credentials not found')\n    }\n    return credentials.scope\n  }\n\n  public async getGroups(): Promise<string[]> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      return this.unAuthenticatedError('credentials not found')\n    }\n    return credentials.groups\n  }\n\n  /**\n   * Check retry value.\n   * @param {number} retry\n   * @return {number}\n   */\n  private checkRetry(retry: number): number {\n    let responseError: ResponseError | null = null\n    if (\n      typeof retry !== 'number'\n      || retry < OAuth2Client.minRetry\n      || retry > OAuth2Client.maxRetry\n    ) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: 'wrong options param: retry',\n      }\n    }\n    if (responseError) {\n      throw responseError\n    }\n    return retry\n  }\n\n  /**\n   * Format retry value.\n   * @param {number} retry\n   * @param {number} defaultVale\n   * @return {number}\n   */\n  private formatRetry(retry: number, defaultVale: number): number {\n    if (typeof retry === 'undefined') {\n      return defaultVale\n    }\n    return this.checkRetry(retry)\n  }\n\n  /**\n   * Sleep.\n   * @param {number} ms\n   * @return {Promise<void>}\n   */\n  private async sleep(ms: number): Promise<void> {\n    return new Promise<void>((resolve) => {\n      setTimeout(() => {\n        resolve()\n      }, ms)\n    })\n  }\n\n  /**\n   * Refresh expired token.\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async refreshToken(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_refreshToken', async () => {\n      if (!credentials || !credentials.refresh_token) {\n        return this.unAuthenticatedError('no refresh token found in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.refreshTokenFunc(credentials.refresh_token,)\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * anonymous signIn\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async anonymousSignIn(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_anonymous', async () => {\n      if (!credentials || credentials.scope !== 'anonymous') {\n        return this.unAuthenticatedError('no anonymous in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.request('/auth/v1/signin/anonymously', {\n          method: 'POST',\n          body: {\n            client_id: this.clientId,\n            client_secret: this.clientSecret,\n          },\n        })\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * Default refresh token function.\n   * @param {string} refreshToken\n   * @return {Promise<Credentials>}\n   */\n  private defaultRefreshTokenFunc(refreshToken?: string,): Promise<Credentials> {\n    if (refreshToken === undefined || refreshToken === '') {\n      return this.unAuthenticatedError('refresh token not found')\n    }\n    return this.request('/auth/v1/token', {\n      method: 'POST',\n      body: {\n        client_id: this.clientId,\n        client_secret: this.clientSecret,\n        grant_type: 'refresh_token',\n        refresh_token: refreshToken,\n      },\n    })\n  }\n\n  /**\n   * Get deviceId\n   */\n  private async getDeviceId(): Promise<string> {\n    if (this.deviceID) {\n      return this.deviceID\n    }\n    let deviceId: string = await this.storage.getItem(DeviceIdSectionName,)\n    if (!(typeof deviceId === 'string'\n      && deviceId.length >= 16\n      && deviceId.length <= 48)) {\n      deviceId = uuidv4()\n      await this.storage.setItem(DeviceIdSectionName, deviceId)\n    }\n    this.deviceID = deviceId\n    return deviceId\n  }\n  /**\n   * Generate unAuthenticated error.\n   * @param {string} err\n   * @return {Promise<T>}\n   */\n  private unAuthenticatedError<T>(err?: string): Promise<T> {\n    const respErr: ResponseError = {\n      error: ErrorType.UNAUTHENTICATED,\n      error_description: err,\n    }\n    return Promise.reject(respErr)\n  }\n}\n"]}
@@ -8,6 +8,7 @@ export interface AuthOptions {
8
8
  credentialsClient?: OAuth2Client;
9
9
  request?: RequestFunction;
10
10
  storage?: SimpleStorage;
11
+ anonymousSignInFunc?: (Credentials: any) => Promise<Credentials | void>;
11
12
  }
12
13
  export declare class Auth {
13
14
  private static parseParamsToSearch;
@@ -15,7 +16,9 @@ export declare class Auth {
15
16
  private getCustomSignTicketFn?;
16
17
  constructor(opts: AuthOptions);
17
18
  signIn(params: SignInRequest): Promise<Credentials>;
18
- signInAnonymously(): Promise<Credentials>;
19
+ signInAnonymously(data?: {
20
+ provider_token?: string;
21
+ }): Promise<Credentials>;
19
22
  signUp(params: SignUpRequest): Promise<Credentials>;
20
23
  signOut(): Promise<any>;
21
24
  getVerification(params: GetVerificationRequest): Promise<GetVerificationResponse>;
@@ -95,14 +95,15 @@ var Auth = (function () {
95
95
  });
96
96
  });
97
97
  };
98
- Auth.prototype.signInAnonymously = function () {
98
+ Auth.prototype.signInAnonymously = function (data) {
99
+ if (data === void 0) { data = {}; }
99
100
  return __awaiter(this, void 0, void 0, function () {
100
101
  var credentials;
101
102
  return __generator(this, function (_a) {
102
103
  switch (_a.label) {
103
104
  case 0: return [4, this.config.request(ApiUrls.AUTH_SIGN_IN_ANONYMOUSLY_URL, {
104
105
  method: 'POST',
105
- body: {},
106
+ body: data,
106
107
  })];
107
108
  case 1:
108
109
  credentials = _a.sent();
@@ -570,4 +571,4 @@ var Auth = (function () {
570
571
  return Auth;
571
572
  }());
572
573
  export { Auth };
573
- //# 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 } 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  BindWithProviderRequest,\n  TransByProviderRequest,\n  GrantTokenRequest,\n  UserProfileProvider,\n  UnbindProviderRequest,\n  CheckPasswordrRequest,\n  BindPhoneRequest,\n  BindEmailRequest,\n  SetPasswordRequest,\n  ChangeBindedProviderRequest,\n  ChangeBindedProviderResponse,\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} from './models'\nimport { SimpleStorage, RequestFunction } from '../oauth2client/interface'\nimport { OAuth2Client, defaultStorage } from '../oauth2client/oauth2client'\nimport { Credentials } from '../oauth2client/models'\nimport { Captcha } from '../captcha/captcha'\n\n\nexport interface AuthOptions {\n  apiOrigin: string;\n  clientId: string;\n  credentialsClient?: OAuth2Client;\n  request?: RequestFunction;\n  storage?: SimpleStorage;\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 URLSearchParams(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        clientId: opts.clientId,\n        storage: opts.storage,\n      }\n      oAuth2Client = new OAuth2Client(initOptions)\n    }\n    if (!request) {\n      const baseRequest = oAuth2Client.request.bind(oAuth2Client)\n      const captcha = new Captcha({\n        clientId: opts.clientId,\n        request: baseRequest,\n        storage: opts.storage,\n      })\n      request = captcha.request.bind(captcha)\n    }\n    this.config = {\n      apiOrigin: opts.apiOrigin,\n      clientId: opts.clientId,\n      request,\n      credentialsClient: oAuth2Client,\n      storage: opts.storage || defaultStorage,\n    }\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 credentials: Credentials = await this.config.request<Credentials>(\n      ApiUrls.AUTH_SIGN_IN_URL,\n      {\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 Anonymously\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInAnonymously(): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(\n      ApiUrls.AUTH_SIGN_IN_ANONYMOUSLY_URL,\n      {\n        method: 'POST',\n        body: {},\n      },\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>(\n      ApiUrls.AUTH_SIGN_UP_URL,\n      {\n        method: 'POST',\n        body: params,\n      },\n    )\n    await this.config.credentialsClient.setCredentials(data)\n    return Promise.resolve(data)\n  }\n\n  /**\n   * Sign out.\n   * @return {Object} A Promise<void> object.\n   */\n  public async signOut(): Promise<any> {\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   * Get the verification.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async getVerification(params: GetVerificationRequest,): 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    return this.config.request<GetVerificationResponse>(\n      ApiUrls.VERIFICATION_URL,\n      {\n        method: 'POST',\n        body: params,\n        withCaptcha: true,\n        withCredentials,\n      },\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    return this.config.request<VerifyResponse>(ApiUrls.VERIFY_URL, {\n      method: 'POST',\n      body: params,\n    })\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    let url = `${ApiUrls.PROVIDER_URI_URL}?client_id=${this.config.clientId\n    }&provider_id=${params.provider_id}&redirect_uri=${encodeURIComponent(params.provider_redirect_uri,)}&state=${params.state}`\n    const { other_params: otherParams } = params\n    if (otherParams) {\n      if (\n        typeof otherParams.sign_out_uri === 'string'\n        && otherParams.sign_out_uri.length > 0\n      ) {\n        url += `&other_params[sign_out_uri]=${otherParams.sign_out_uri}`\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(params: GrantProviderTokenRequest,): Promise<GrantProviderTokenResponse> {\n    return this.config.request<GrantProviderTokenResponse>(\n      ApiUrls.PROVIDER_TOKEN_URL,\n      {\n        method: 'POST',\n        body: params,\n      },\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>(\n      ApiUrls.PROVIDER_TOKEN_URL,\n      {\n        method: 'PATCH',\n        body: params,\n      },\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,): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(\n      ApiUrls.AUTH_SIGN_IN_WITH_PROVIDER_URL,\n      {\n        method: 'POST',\n        body: params,\n      },\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,): Promise<void> {\n    return this.config.request<any>(ApiUrls.PROVIDER_BIND_URL, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Get the user profile.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async getUserProfile(): Promise<UserProfile> {\n    return this.getUserInfo()\n  }\n\n  /**\n   * Get the user info.\n   * @return {Promise<UserInfo>} A Promise<UserProfile> object.\n   */\n  public async getUserInfo(): Promise<UserInfo> {\n    const userInfo = await this.config.request<UserInfo>(ApiUrls.USER_ME_URL, {\n      method: 'GET',\n      withCredentials: true,\n    })\n\n    if (userInfo.sub) {\n      userInfo.uid = userInfo.sub\n    }\n\n    return userInfo\n  }\n\n  /**\n     * Delete me\n     * @param params\n     */\n  public async deleteMe(params: WithSudoRequest): Promise<UserProfile> {\n    const url = `${ApiUrls.USER_ME_URL}?${Auth.parseParamsToSearch(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>(\n      ApiUrls.USER_TRANS_BY_PROVIDER_URL,\n      {\n        method: 'PATCH',\n        body: params,\n        withCredentials: true,\n      },\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    return this.config.request<Credentials>(ApiUrls.AUTH_TOKEN_URL, {\n      method: 'POST',\n      body: params,\n    })\n  }\n\n  /**\n   * Get the provide list.\n   * @return {Promise<UserProfileProvider>} A Promise<UserProfileProvider> object.\n   */\n  public async getProviders(): Promise<UserProfileProvider> {\n    return this.config.request<UserProfileProvider>(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>(\n      `${ApiUrls.PROVIDER_UNBIND_URL}/${params.provider_id}`,\n      {\n        method: 'DELETE',\n        withCredentials: true,\n      },\n    )\n  }\n\n  /**\n   * check Password.\n   * @param {CheckPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async checkPassword(params: CheckPasswordrRequest): 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   * check Password.\n   * @param {CheckPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async bindPhone(params: BindPhoneRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.BIND_CONTACT_URL}`, {\n      method: 'PATCH',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * check Password.\n   * @param {CheckPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async bindEmail(params: BindEmailRequest): Promise<void> {\n    return this.config.request<any>(`${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  /**\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 getCurUserVerification(params: GetVerificationRequest,): Promise<GetVerificationResponse> {\n    params.target = 'CUR_USER'\n    return this.config.request<GetVerificationResponse>(\n      ApiUrls.VERIFICATION_URL,\n      {\n        method: 'POST',\n        body: params,\n        withCredentials: true,\n        withCaptcha: true,\n      },\n    )\n  }\n\n  /**\n   * change binded provider.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async changeBindedProvider(params: ChangeBindedProviderRequest,): Promise<ChangeBindedProviderResponse> {\n    return this.config.request<ChangeBindedProviderResponse>(\n      `${ApiUrls.PROVIDER_LIST}/${params.provider_id}/trans`,\n      {\n        method: 'POST',\n        body: {\n          provider_trans_token: params.trans_token,\n        },\n        withCredentials: true,\n      },\n    )\n  }\n\n  /**\n   * Patch the user profile.\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   * 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 URLSearchParams(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(): Promise<Credentials> {\n    const customTicket = await this.getCustomSignTicketFn()\n    return this.signInWithProvider({\n      provider_id: 'custom',\n      provider_token: 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   * 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  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 URLSearchParams(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"]}
574
+ //# 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 } 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  BindWithProviderRequest,\n  TransByProviderRequest,\n  GrantTokenRequest,\n  UserProfileProvider,\n  UnbindProviderRequest,\n  CheckPasswordrRequest,\n  BindPhoneRequest,\n  BindEmailRequest,\n  SetPasswordRequest,\n  ChangeBindedProviderRequest,\n  ChangeBindedProviderResponse,\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} from './models'\nimport { SimpleStorage, RequestFunction } from '../oauth2client/interface'\nimport { OAuth2Client, defaultStorage } from '../oauth2client/oauth2client'\nimport { Credentials } from '../oauth2client/models'\nimport { Captcha } from '../captcha/captcha'\n\n\nexport interface AuthOptions {\n  apiOrigin: string;\n  clientId: string;\n  credentialsClient?: OAuth2Client;\n  request?: RequestFunction;\n  storage?: SimpleStorage;\n  anonymousSignInFunc?: (Credentials) => Promise<Credentials | void>\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 URLSearchParams(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        clientId: opts.clientId,\n        storage: opts.storage,\n      }\n      oAuth2Client = new OAuth2Client(initOptions)\n    }\n    if (!request) {\n      const baseRequest = oAuth2Client.request.bind(oAuth2Client)\n      const captcha = new Captcha({\n        clientId: opts.clientId,\n        request: baseRequest,\n        storage: opts.storage,\n      })\n      request = captcha.request.bind(captcha)\n    }\n    this.config = {\n      apiOrigin: opts.apiOrigin,\n      clientId: opts.clientId,\n      request,\n      credentialsClient: oAuth2Client,\n      storage: opts.storage || defaultStorage,\n    }\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 credentials: Credentials = await this.config.request<Credentials>(\n      ApiUrls.AUTH_SIGN_IN_URL,\n      {\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 Anonymously\n   * @return {Promise<Credentials>} A Promise<Credentials> object.\n   */\n  public async signInAnonymously(data: {\n    provider_token?: string\n  } = {}): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(\n      ApiUrls.AUTH_SIGN_IN_ANONYMOUSLY_URL,\n      {\n        method: 'POST',\n        body: data,\n      },\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>(\n      ApiUrls.AUTH_SIGN_UP_URL,\n      {\n        method: 'POST',\n        body: params,\n      },\n    )\n    await this.config.credentialsClient.setCredentials(data)\n    return Promise.resolve(data)\n  }\n\n  /**\n   * Sign out.\n   * @return {Object} A Promise<void> object.\n   */\n  public async signOut(): Promise<any> {\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   * Get the verification.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async getVerification(params: GetVerificationRequest,): 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    return this.config.request<GetVerificationResponse>(\n      ApiUrls.VERIFICATION_URL,\n      {\n        method: 'POST',\n        body: params,\n        withCaptcha: true,\n        withCredentials,\n      },\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    return this.config.request<VerifyResponse>(ApiUrls.VERIFY_URL, {\n      method: 'POST',\n      body: params,\n    })\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    let url = `${ApiUrls.PROVIDER_URI_URL}?client_id=${this.config.clientId\n    }&provider_id=${params.provider_id}&redirect_uri=${encodeURIComponent(params.provider_redirect_uri,)}&state=${params.state}`\n    const { other_params: otherParams } = params\n    if (otherParams) {\n      if (\n        typeof otherParams.sign_out_uri === 'string'\n        && otherParams.sign_out_uri.length > 0\n      ) {\n        url += `&other_params[sign_out_uri]=${otherParams.sign_out_uri}`\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(params: GrantProviderTokenRequest,): Promise<GrantProviderTokenResponse> {\n    return this.config.request<GrantProviderTokenResponse>(\n      ApiUrls.PROVIDER_TOKEN_URL,\n      {\n        method: 'POST',\n        body: params,\n      },\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>(\n      ApiUrls.PROVIDER_TOKEN_URL,\n      {\n        method: 'PATCH',\n        body: params,\n      },\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,): Promise<Credentials> {\n    const credentials: Credentials = await this.config.request<Credentials>(\n      ApiUrls.AUTH_SIGN_IN_WITH_PROVIDER_URL,\n      {\n        method: 'POST',\n        body: params,\n      },\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,): Promise<void> {\n    return this.config.request<any>(ApiUrls.PROVIDER_BIND_URL, {\n      method: 'POST',\n      body: params,\n      withCredentials: true,\n    })\n  }\n\n  /**\n   * Get the user profile.\n   * @return {Promise<UserProfile>} A Promise<UserProfile> object.\n   */\n  public async getUserProfile(): Promise<UserProfile> {\n    return this.getUserInfo()\n  }\n\n  /**\n   * Get the user info.\n   * @return {Promise<UserInfo>} A Promise<UserProfile> object.\n   */\n  public async getUserInfo(): Promise<UserInfo> {\n    const userInfo = await this.config.request<UserInfo>(ApiUrls.USER_ME_URL, {\n      method: 'GET',\n      withCredentials: true,\n    })\n\n    if (userInfo.sub) {\n      userInfo.uid = userInfo.sub\n    }\n\n    return userInfo\n  }\n\n  /**\n     * Delete me\n     * @param params\n     */\n  public async deleteMe(params: WithSudoRequest): Promise<UserProfile> {\n    const url = `${ApiUrls.USER_ME_URL}?${Auth.parseParamsToSearch(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>(\n      ApiUrls.USER_TRANS_BY_PROVIDER_URL,\n      {\n        method: 'PATCH',\n        body: params,\n        withCredentials: true,\n      },\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    return this.config.request<Credentials>(ApiUrls.AUTH_TOKEN_URL, {\n      method: 'POST',\n      body: params,\n    })\n  }\n\n  /**\n   * Get the provide list.\n   * @return {Promise<UserProfileProvider>} A Promise<UserProfileProvider> object.\n   */\n  public async getProviders(): Promise<UserProfileProvider> {\n    return this.config.request<UserProfileProvider>(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>(\n      `${ApiUrls.PROVIDER_UNBIND_URL}/${params.provider_id}`,\n      {\n        method: 'DELETE',\n        withCredentials: true,\n      },\n    )\n  }\n\n  /**\n   * check Password.\n   * @param {CheckPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async checkPassword(params: CheckPasswordrRequest): 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   * check Password.\n   * @param {CheckPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async bindPhone(params: BindPhoneRequest): Promise<void> {\n    return this.config.request<any>(`${ApiUrls.BIND_CONTACT_URL}`, {\n      method: 'PATCH',\n      withCredentials: true,\n      body: params,\n    })\n  }\n\n  /**\n   * check Password.\n   * @param {CheckPasswordrRequest} params\n   * @return {Promise<any>}\n   */\n  public async bindEmail(params: BindEmailRequest): Promise<void> {\n    return this.config.request<any>(`${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  /**\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 getCurUserVerification(params: GetVerificationRequest,): Promise<GetVerificationResponse> {\n    params.target = 'CUR_USER'\n    return this.config.request<GetVerificationResponse>(\n      ApiUrls.VERIFICATION_URL,\n      {\n        method: 'POST',\n        body: params,\n        withCredentials: true,\n        withCaptcha: true,\n      },\n    )\n  }\n\n  /**\n   * change binded provider.\n   * @param {GetVerificationRequest} params A GetVerificationRequest Object.\n   * @return {Promise<GetVerificationResponse>} A Promise<GetVerificationResponse> object.\n   */\n  public async changeBindedProvider(params: ChangeBindedProviderRequest,): Promise<ChangeBindedProviderResponse> {\n    return this.config.request<ChangeBindedProviderResponse>(\n      `${ApiUrls.PROVIDER_LIST}/${params.provider_id}/trans`,\n      {\n        method: 'POST',\n        body: {\n          provider_trans_token: params.trans_token,\n        },\n        withCredentials: true,\n      },\n    )\n  }\n\n  /**\n   * Patch the user profile.\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   * 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 URLSearchParams(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(): Promise<Credentials> {\n    const customTicket = await this.getCustomSignTicketFn()\n    return this.signInWithProvider({\n      provider_id: 'custom',\n      provider_token: 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   * 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  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 URLSearchParams(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"]}
@@ -54,10 +54,12 @@ export interface GrantProviderTokenResponse {
54
54
  expires_in: number;
55
55
  }
56
56
  export interface PatchProviderTokenRequest extends BaseRequest {
57
+ provider_id?: string;
57
58
  provider_token: string;
58
59
  provider_params: {
59
- encryptedData: string;
60
- iv: string;
60
+ encryptedData?: string;
61
+ iv?: string;
62
+ code?: string;
61
63
  };
62
64
  }
63
65
  export interface PatchProviderTokenResponse {
@@ -197,9 +199,11 @@ export interface GrantProviderTokenResponse {
197
199
  }
198
200
  export interface PatchProviderTokenRequest {
199
201
  provider_token: string;
202
+ provider_id?: string;
200
203
  provider_params: {
201
- encryptedData: string;
202
- iv: string;
204
+ encryptedData?: string;
205
+ iv?: string;
206
+ code?: string;
203
207
  };
204
208
  }
205
209
  export interface PatchProviderTokenResponse {
@@ -1 +1 @@
1
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../src/auth/models.ts"],"names":[],"mappings":"","sourcesContent":["interface BaseRequest {\n  client_id?: string;\n}\n\nexport type GetCustomSignTicketFn = () => Promise<string>;\n\nexport interface SignInRequest extends BaseRequest {\n  username?: string;\n  password?: string;\n  verification_token?: string;\n}\n\nexport interface SignInWithProviderRequest extends BaseRequest {\n  provider_token: string;\n}\n\nexport interface SignUpRequest extends BaseRequest {\n  phone_number?: string;\n  email?: string;\n\n  verification_code?: string;\n  verification_token?: string;\n  provider_token?: string;\n\n  password?: string;\n  name?: string;\n  gender?: string;\n  picture?: string;\n  locale?: string;\n}\n\nexport interface GetVerificationRequest extends BaseRequest {\n  phone_number?: string;\n  email?: string;\n  target?: string | 'ANY';\n  usage?: string;\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string;\n  is_user?: boolean | false;\n}\n\nexport interface VerifyResponse {\n  verification_token?: string;\n}\n\nexport interface VerifyRequest extends BaseRequest {\n  verification_code: string;\n  verification_id?: string;\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string;\n}\n\nexport interface GrantProviderTokenRequest extends BaseRequest {\n  provider_id: string;\n  provider_redirect_uri?: string;\n  provider_code?: string;\n  provider_access_token?: string;\n  provider_id_token?: string;\n}\n\nexport interface GrantProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n}\n\nexport interface PatchProviderTokenRequest extends BaseRequest {\n  provider_token: string;\n  provider_params: {\n    encryptedData: string;\n    iv: string;\n  };\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n  provider_profile: ProviderProfile;\n}\n\n// export interface GenProviderRedirectUriRequest {\n//   provider_id: string;\n//   provider_redirect_uri: string;\n//   state: string;\n//   other_params?: {\n//     sign_out_uri?: string;\n//   };\n// }\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string;\n  signout_uri?: string;\n}\n\nexport interface BindWithProviderRequest extends BaseRequest {\n  provider_token: string;\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string;\n}\n\nexport interface UserProfileProvider {\n  id?: string;\n  provider_user_id?: string;\n  name?: string;\n}\n\nexport interface UserProfile {\n  name?: string;\n  picture?: string;\n  username?: string;\n  email?: string;\n  email_verified?: boolean;\n  phone_number?: string;\n  providers?: [UserProfileProvider];\n  gender?: string;\n  birthdate?: string;\n  zoneinfo?: string;\n  locale?: string;\n  created_from?: string;\n  sub?: string\n  uid?: string\n  address?: {\n    formatted?: string,\n    street_address?: string,\n    locality?: string,\n    region?: string,\n    postal_code?: string,\n    country?: string\n  }\n  nickName?: string // TODO:\n  province?: string // TODO:\n  country?: string // TODO:\n  city?: string // TODO:\n}\n\nexport type UserInfo = UserProfile;\n\nexport interface ProviderProfile {\n  provider_id: string;\n  phone_number?: string;\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string;\n}\n\nexport interface GrantTokenRequest extends BaseRequest {\n  client_secret?: string;\n  code?: string;\n  grant_type?: string;\n  redirect_uri?: string;\n  nonce?: string;\n  refresh_token?: string;\n  scope?: string;\n}\n\nexport interface UnbindProviderRequest extends BaseRequest {\n  provider_id: string;\n}\n\nexport interface CheckPasswordrRequest extends BaseRequest {\n  password: string;\n}\n\nexport interface BindPhoneRequest extends BaseRequest {\n  phone_number: string;\n  sudo_token: string;\n  verification_token: string;\n}\n\nexport interface SetPasswordRequest extends BaseRequest {\n  new_password: string;\n  sudo_token: string;\n}\n\nexport interface ChangeBindedProviderRequest extends BaseRequest {\n  trans_token: string;\n  provider_id: string;\n}\n\nexport type ChangeBindedProviderResponse = BaseRequest\n\nexport interface QueryUserProfileReq extends BaseRequest {\n  appended_params: string;\n}\n\nexport interface SignInWithProviderRequest {\n  provider_token: string;\n  provider_id?: string;\n}\n\nexport interface SignUpRequest {\n  phone_number?: string;\n  email?: string;\n\n  verification_code?: string;\n  verification_token?: string;\n  provider_token?: string;\n\n  password?: string;\n  name?: string;\n  gender?: string;\n  picture?: string;\n  locale?: string;\n}\n\nexport interface GetVerificationRequest {\n  phone_number?: string;\n  email?: string;\n  // 可选 ANY，USER，NOT_USER, CUR_USER;\n  target?: string | 'ANY';\n  usage?: string;\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string;\n  is_user?: boolean | false;\n}\n\nexport interface VerifyResponse {\n  verification_token?: string;\n}\n\nexport interface VerifyRequest {\n  verification_code: string;\n  verification_id?: string;\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string;\n}\n\nexport interface GrantProviderTokenRequest {\n  provider_id: string;\n  provider_redirect_uri?: string;\n  provider_code?: string;\n  provider_access_token?: string;\n  provider_id_token?: string;\n}\n\nexport interface GrantProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n}\n\nexport interface PatchProviderTokenRequest {\n  provider_token: string;\n  provider_params: {\n    encryptedData: string;\n    iv: string;\n  };\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n  provider_profile: ProviderProfile;\n}\n\nexport interface GenProviderRedirectUriRequest {\n  provider_id: string;\n  provider_redirect_uri: string;\n  state: string;\n  other_params?: {\n    [key: string]: string\n  };\n}\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string;\n  signout_uri?: string;\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string;\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string;\n}\n\nexport interface UserProfileProvider {\n  id?: string;\n  provider_user_id?: string;\n  name?: string;\n}\n\nexport interface UserProfile {\n  name?: string;\n  picture?: string;\n  username?: string;\n  email?: string;\n  email_verified?: boolean;\n  phone_number?: string;\n  providers?: [UserProfileProvider];\n  gender?: string;\n  birthdate?: string;\n  zoneinfo?: string;\n  locale?: string;\n  created_from?: string;\n}\n\nexport interface ProviderProfile {\n  provider_id: string;\n  phone_number?: string;\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string;\n}\n\nexport interface GrantTokenRequest {\n  client_secret?: string;\n  code?: string;\n  grant_type?: string;\n  redirect_uri?: string;\n  nonce?: string;\n  refresh_token?: string;\n  scope?: string;\n}\n\nexport interface UnbindProviderRequest {\n  provider_id: string;\n}\n\nexport interface CheckPasswordrRequest {\n  password: string;\n}\n\nexport interface BindPhoneRequest {\n  phone_number: string;\n  sudo_token: string;\n  verification_token: string;\n  conflict_resolution: string\n  // 1. DEFAULT 0, 默认提示用户手机号已被绑定\n  // 2. DELETE_ACCOUNT_TRANSFER 1, 标记原账号已被注销，并将手机换绑给自己\n  // 3. TRANSFER 2, 仅换绑手机号，不注销原有账号（换绑后原账号无法登录时，则自动注销原账号）\n}\n\nexport interface BindEmailRequest {\n  email: string;\n  sudo_token: string;\n  verification_token: string;\n}\n\nexport interface SetPasswordRequest {\n  new_password: string;\n  sudo_token: string;\n}\n\n\nexport interface SetPasswordRequest {\n  new_password: string;\n  sudo_token: string;\n}\n\nexport interface UpdatePasswordRequest {\n  old_password: string;\n  new_password: string;\n}\n\n// password 和 verification_token 而选一，如果绑定了手机号，则必须使用verification_token 进行sudo\nexport interface SudoRequest {\n  password?: string;\n  verification_token?: string\n}\n\nexport interface SudoResponse {\n  sudo_token?: string\n}\n\nexport interface WithSudoRequest {\n  sudo_token: string\n}\n\n\nexport interface ChangeBoundProviderRequest {\n  trans_token: string;\n  provider_id: string;\n}\n\nexport interface ChangeBoundProviderResponse {\n  client_id: string;\n}\n\nexport interface QueryUserProfileRequest {\n  id?: [string];\n  username?: string;\n  email?: string;\n  phone_number?: string;\n}\n\nexport interface QueryUserProfileResponse {\n  total: string;\n  data: SimpleUserProfile[]\n}\n\nexport interface ResetPasswordRequest extends BaseRequest {\n  email: string\n  phone_number: string\n  new_password: string\n  verification_token: string\n}\n\nexport interface DeviceAuthorizeRequest extends BaseRequest {\n  scope?: string\n}\n\nexport interface DeviceAuthorizeResponse {\n  device_code: string\n  user_code: string\n  expires_in: number\n  interval: number\n  verification_url: string\n  verification_uri_complete: string\n}\n\n// 简化版用户信息\nexport interface SimpleUserProfile {\n  sub: string;\n  name: string;\n  picture?: string;\n  gender?: string;\n  locale?: string;\n  email?: string;\n  phone_number?: string;\n}\n\nexport interface CheckUsernameRequest {\n  username: string\n}\n\nexport interface CheckIfUserExistRequest {\n  username: string;\n}\n\nexport interface CheckIfUserExistResponse {\n  exist: boolean;\n}\n"]}
1
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../src/auth/models.ts"],"names":[],"mappings":"","sourcesContent":["interface BaseRequest {\n  client_id?: string;\n}\n\nexport type GetCustomSignTicketFn = () => Promise<string>;\n\nexport interface SignInRequest extends BaseRequest {\n  username?: string;\n  password?: string;\n  verification_token?: string;\n}\n\nexport interface SignInWithProviderRequest extends BaseRequest {\n  provider_token: string;\n}\n\nexport interface SignUpRequest extends BaseRequest {\n  phone_number?: string;\n  email?: string;\n\n  verification_code?: string;\n  verification_token?: string;\n  provider_token?: string;\n\n  password?: string;\n  name?: string;\n  gender?: string;\n  picture?: string;\n  locale?: string;\n}\n\nexport interface GetVerificationRequest extends BaseRequest {\n  phone_number?: string;\n  email?: string;\n  target?: string | 'ANY';\n  usage?: string;\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string;\n  is_user?: boolean | false;\n}\n\nexport interface VerifyResponse {\n  verification_token?: string;\n}\n\nexport interface VerifyRequest extends BaseRequest {\n  verification_code: string;\n  verification_id?: string;\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string;\n}\n\nexport interface GrantProviderTokenRequest extends BaseRequest {\n  provider_id: string;\n  provider_redirect_uri?: string;\n  provider_code?: string;\n  provider_access_token?: string;\n  provider_id_token?: string;\n}\n\nexport interface GrantProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n}\n\nexport interface PatchProviderTokenRequest extends BaseRequest {\n  provider_id?: string;\n  provider_token: string;\n  provider_params: {\n    encryptedData?: string;\n    iv?: string;\n    code?: string;\n  };\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n  provider_profile: ProviderProfile;\n}\n\n// export interface GenProviderRedirectUriRequest {\n//   provider_id: string;\n//   provider_redirect_uri: string;\n//   state: string;\n//   other_params?: {\n//     sign_out_uri?: string;\n//   };\n// }\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string;\n  signout_uri?: string;\n}\n\nexport interface BindWithProviderRequest extends BaseRequest {\n  provider_token: string;\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string;\n}\n\nexport interface UserProfileProvider {\n  id?: string;\n  provider_user_id?: string;\n  name?: string;\n}\n\nexport interface UserProfile {\n  name?: string;\n  picture?: string;\n  username?: string;\n  email?: string;\n  email_verified?: boolean;\n  phone_number?: string;\n  providers?: [UserProfileProvider];\n  gender?: string;\n  birthdate?: string;\n  zoneinfo?: string;\n  locale?: string;\n  created_from?: string;\n  sub?: string\n  uid?: string\n  address?: {\n    formatted?: string,\n    street_address?: string,\n    locality?: string,\n    region?: string,\n    postal_code?: string,\n    country?: string\n  }\n  nickName?: string // TODO:\n  province?: string // TODO:\n  country?: string // TODO:\n  city?: string // TODO:\n}\n\nexport type UserInfo = UserProfile;\n\nexport interface ProviderProfile {\n  provider_id: string;\n  phone_number?: string;\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string;\n}\n\nexport interface GrantTokenRequest extends BaseRequest {\n  client_secret?: string;\n  code?: string;\n  grant_type?: string;\n  redirect_uri?: string;\n  nonce?: string;\n  refresh_token?: string;\n  scope?: string;\n}\n\nexport interface UnbindProviderRequest extends BaseRequest {\n  provider_id: string;\n}\n\nexport interface CheckPasswordrRequest extends BaseRequest {\n  password: string;\n}\n\nexport interface BindPhoneRequest extends BaseRequest {\n  phone_number: string;\n  sudo_token: string;\n  verification_token: string;\n}\n\nexport interface SetPasswordRequest extends BaseRequest {\n  new_password: string;\n  sudo_token: string;\n}\n\nexport interface ChangeBindedProviderRequest extends BaseRequest {\n  trans_token: string;\n  provider_id: string;\n}\n\nexport type ChangeBindedProviderResponse = BaseRequest\n\nexport interface QueryUserProfileReq extends BaseRequest {\n  appended_params: string;\n}\n\nexport interface SignInWithProviderRequest {\n  provider_token: string;\n  provider_id?: string;\n}\n\nexport interface SignUpRequest {\n  phone_number?: string;\n  email?: string;\n\n  verification_code?: string;\n  verification_token?: string;\n  provider_token?: string;\n\n  password?: string;\n  name?: string;\n  gender?: string;\n  picture?: string;\n  locale?: string;\n}\n\nexport interface GetVerificationRequest {\n  phone_number?: string;\n  email?: string;\n  // 可选 ANY，USER，NOT_USER, CUR_USER;\n  target?: string | 'ANY';\n  usage?: string;\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string;\n  is_user?: boolean | false;\n}\n\nexport interface VerifyResponse {\n  verification_token?: string;\n}\n\nexport interface VerifyRequest {\n  verification_code: string;\n  verification_id?: string;\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string;\n}\n\nexport interface GrantProviderTokenRequest {\n  provider_id: string;\n  provider_redirect_uri?: string;\n  provider_code?: string;\n  provider_access_token?: string;\n  provider_id_token?: string;\n}\n\nexport interface GrantProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n}\n\nexport interface PatchProviderTokenRequest {\n  provider_token: string;\n  provider_id?: string;\n  provider_params: {\n    encryptedData?: string;\n    iv?: string;\n    code?: string;\n  };\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n  provider_profile: ProviderProfile;\n}\n\nexport interface GenProviderRedirectUriRequest {\n  provider_id: string;\n  provider_redirect_uri: string;\n  state: string;\n  other_params?: {\n    [key: string]: string\n  };\n}\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string;\n  signout_uri?: string;\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string;\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string;\n}\n\nexport interface UserProfileProvider {\n  id?: string;\n  provider_user_id?: string;\n  name?: string;\n}\n\nexport interface UserProfile {\n  name?: string;\n  picture?: string;\n  username?: string;\n  email?: string;\n  email_verified?: boolean;\n  phone_number?: string;\n  providers?: [UserProfileProvider];\n  gender?: string;\n  birthdate?: string;\n  zoneinfo?: string;\n  locale?: string;\n  created_from?: string;\n}\n\nexport interface ProviderProfile {\n  provider_id: string;\n  phone_number?: string;\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string;\n}\n\nexport interface GrantTokenRequest {\n  client_secret?: string;\n  code?: string;\n  grant_type?: string;\n  redirect_uri?: string;\n  nonce?: string;\n  refresh_token?: string;\n  scope?: string;\n}\n\nexport interface UnbindProviderRequest {\n  provider_id: string;\n}\n\nexport interface CheckPasswordrRequest {\n  password: string;\n}\n\nexport interface BindPhoneRequest {\n  phone_number: string;\n  sudo_token: string;\n  verification_token: string;\n  conflict_resolution: string\n  // 1. DEFAULT 0, 默认提示用户手机号已被绑定\n  // 2. DELETE_ACCOUNT_TRANSFER 1, 标记原账号已被注销，并将手机换绑给自己\n  // 3. TRANSFER 2, 仅换绑手机号，不注销原有账号（换绑后原账号无法登录时，则自动注销原账号）\n}\n\nexport interface BindEmailRequest {\n  email: string;\n  sudo_token: string;\n  verification_token: string;\n}\n\nexport interface SetPasswordRequest {\n  new_password: string;\n  sudo_token: string;\n}\n\n\nexport interface SetPasswordRequest {\n  new_password: string;\n  sudo_token: string;\n}\n\nexport interface UpdatePasswordRequest {\n  old_password: string;\n  new_password: string;\n}\n\n// password 和 verification_token 而选一，如果绑定了手机号，则必须使用verification_token 进行sudo\nexport interface SudoRequest {\n  password?: string;\n  verification_token?: string\n}\n\nexport interface SudoResponse {\n  sudo_token?: string\n}\n\nexport interface WithSudoRequest {\n  sudo_token: string\n}\n\n\nexport interface ChangeBoundProviderRequest {\n  trans_token: string;\n  provider_id: string;\n}\n\nexport interface ChangeBoundProviderResponse {\n  client_id: string;\n}\n\nexport interface QueryUserProfileRequest {\n  id?: [string];\n  username?: string;\n  email?: string;\n  phone_number?: string;\n}\n\nexport interface QueryUserProfileResponse {\n  total: string;\n  data: SimpleUserProfile[]\n}\n\nexport interface ResetPasswordRequest extends BaseRequest {\n  email: string\n  phone_number: string\n  new_password: string\n  verification_token: string\n}\n\nexport interface DeviceAuthorizeRequest extends BaseRequest {\n  scope?: string\n}\n\nexport interface DeviceAuthorizeResponse {\n  device_code: string\n  user_code: string\n  expires_in: number\n  interval: number\n  verification_url: string\n  verification_uri_complete: string\n}\n\n// 简化版用户信息\nexport interface SimpleUserProfile {\n  sub: string;\n  name: string;\n  picture?: string;\n  gender?: string;\n  locale?: string;\n  email?: string;\n  phone_number?: string;\n}\n\nexport interface CheckUsernameRequest {\n  username: string\n}\n\nexport interface CheckIfUserExistRequest {\n  username: string;\n}\n\nexport interface CheckIfUserExistResponse {\n  exist: boolean;\n}\n"]}
package/dist/esm/index.js CHANGED
@@ -19,15 +19,17 @@ export { Auth } from './auth/apis';
19
19
  export { authModels };
20
20
  var CloudbaseOAuth = (function () {
21
21
  function CloudbaseOAuth(authOptions) {
22
- var apiOrigin = authOptions.apiOrigin, clientId = authOptions.clientId, storage = authOptions.storage;
22
+ var apiOrigin = authOptions.apiOrigin, clientId = authOptions.clientId, storage = authOptions.storage, request = authOptions.request, anonymousSignInFunc = authOptions.anonymousSignInFunc;
23
23
  this.oauth2client = new OAuth2Client({
24
24
  apiOrigin: apiOrigin,
25
25
  clientId: clientId,
26
26
  storage: storage,
27
+ baseRequest: request,
28
+ anonymousSignInFunc: anonymousSignInFunc,
27
29
  });
28
- this.authApi = new Auth(__assign({ credentialsClient: this.oauth2client }, authOptions));
30
+ this.authApi = new Auth(__assign(__assign({ credentialsClient: this.oauth2client }, authOptions), { request: request ? this.oauth2client.request.bind(this.oauth2client) : undefined }));
29
31
  }
30
32
  return CloudbaseOAuth;
31
33
  }());
32
34
  export { CloudbaseOAuth };
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUE7QUFFMUQsT0FBTyxFQUFlLElBQUksRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUUvQyxPQUFPLEtBQUssVUFBVSxNQUFNLGVBQWUsQ0FBQTtBQUUzQyxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBRXpELE9BQU8sRUFDTCxjQUFjLEVBQ2QsY0FBYyxFQUVkLGVBQWUsRUFDZixpQkFBaUIsRUFDakIsWUFBWSxHQUNiLE1BQU0sNkJBQTZCLENBQUE7QUFFcEMsT0FBTyxFQUFFLFVBQVUsRUFBaUIsTUFBTSwwQkFBMEIsQ0FBQTtBQVNwRSxPQUFPLEVBQWUsSUFBSSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQTtBQUdyQjtJQUlFLHdCQUFZLFdBQXdCO1FBQzFCLElBQUEsU0FBUyxHQUF3QixXQUFXLFVBQW5DLEVBQUUsUUFBUSxHQUFjLFdBQVcsU0FBekIsRUFBRSxPQUFPLEdBQUssV0FBVyxRQUFoQixDQUFnQjtRQUNwRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksWUFBWSxDQUFDO1lBQ25DLFNBQVMsV0FBQTtZQUNULFFBQVEsVUFBQTtZQUNSLE9BQU8sU0FBQTtTQUNSLENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxJQUFJLFlBQ3JCLGlCQUFpQixFQUFFLElBQUksQ0FBQyxZQUFZLElBQ2pDLFdBQVcsRUFDZCxDQUFBO0lBQ0osQ0FBQztJQUNILHFCQUFDO0FBQUQsQ0FBQyxBQWpCRCxJQWlCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9BdXRoMkNsaWVudCB9IGZyb20gJy4vb2F1dGgyY2xpZW50L29hdXRoMmNsaWVudCdcblxuaW1wb3J0IHsgQXV0aE9wdGlvbnMsIEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcblxuaW1wb3J0ICogYXMgYXV0aE1vZGVscyBmcm9tICcuL2F1dGgvbW9kZWxzJ1xuXG5leHBvcnQgeyBTeW50YXgsIEVycm9yVHlwZSB9IGZyb20gJy4vb2F1dGgyY2xpZW50L2NvbnN0cydcblxuZXhwb3J0IHtcbiAgZGVmYXVsdFN0b3JhZ2UsXG4gIGRlZmF1bHRSZXF1ZXN0LFxuICBUb1Jlc3BvbnNlRXJyb3JPcHRpb25zLFxuICB0b1Jlc3BvbnNlRXJyb3IsXG4gIGdlbmVyYXRlUmVxdWVzdElkLFxuICBPQXV0aDJDbGllbnQsXG59IGZyb20gJy4vb2F1dGgyY2xpZW50L29hdXRoMmNsaWVudCdcblxuZXhwb3J0IHsgQXV0aENsaWVudCwgU2ltcGxlU3RvcmFnZSB9IGZyb20gJy4vb2F1dGgyY2xpZW50L2ludGVyZmFjZSdcblxuZXhwb3J0IHtcbiAgQ3JlZGVudGlhbHMsXG4gIFJlc3BvbnNlRXJyb3IsXG4gIE9BdXRoMkNsaWVudE9wdGlvbnMsXG4gIEF1dGhDbGllbnRSZXF1ZXN0T3B0aW9ucyxcbn0gZnJvbSAnLi9vYXV0aDJjbGllbnQvbW9kZWxzJ1xuXG5leHBvcnQgeyBBdXRoT3B0aW9ucywgQXV0aCB9IGZyb20gJy4vYXV0aC9hcGlzJ1xuZXhwb3J0IHsgYXV0aE1vZGVscyB9XG5cblxuZXhwb3J0IGNsYXNzIENsb3VkYmFzZU9BdXRoIHtcbiAgcHVibGljIG9hdXRoMmNsaWVudDogT0F1dGgyQ2xpZW50XG4gIHB1YmxpYyBhdXRoQXBpOiBBdXRoXG5cbiAgY29uc3RydWN0b3IoYXV0aE9wdGlvbnM6IEF1dGhPcHRpb25zKSB7XG4gICAgY29uc3QgeyBhcGlPcmlnaW4sIGNsaWVudElkLCBzdG9yYWdlIH0gPSBhdXRoT3B0aW9uc1xuICAgIHRoaXMub2F1dGgyY2xpZW50ID0gbmV3IE9BdXRoMkNsaWVudCh7XG4gICAgICBhcGlPcmlnaW4sXG4gICAgICBjbGllbnRJZCxcbiAgICAgIHN0b3JhZ2UsXG4gICAgfSlcblxuICAgIHRoaXMuYXV0aEFwaSA9IG5ldyBBdXRoKHtcbiAgICAgIGNyZWRlbnRpYWxzQ2xpZW50OiB0aGlzLm9hdXRoMmNsaWVudCxcbiAgICAgIC4uLmF1dGhPcHRpb25zLFxuICAgIH0pXG4gIH1cbn1cblxuIl19
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUE7QUFFMUQsT0FBTyxFQUFlLElBQUksRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUUvQyxPQUFPLEtBQUssVUFBVSxNQUFNLGVBQWUsQ0FBQTtBQUUzQyxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBRXpELE9BQU8sRUFDTCxjQUFjLEVBQ2QsY0FBYyxFQUVkLGVBQWUsRUFDZixpQkFBaUIsRUFDakIsWUFBWSxHQUNiLE1BQU0sNkJBQTZCLENBQUE7QUFFcEMsT0FBTyxFQUFFLFVBQVUsRUFBaUIsTUFBTSwwQkFBMEIsQ0FBQTtBQVNwRSxPQUFPLEVBQWUsSUFBSSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQTtBQUdyQjtJQUlFLHdCQUFZLFdBQXdCO1FBQzFCLElBQUEsU0FBUyxHQUFzRCxXQUFXLFVBQWpFLEVBQUUsUUFBUSxHQUE0QyxXQUFXLFNBQXZELEVBQUUsT0FBTyxHQUFtQyxXQUFXLFFBQTlDLEVBQUUsT0FBTyxHQUEwQixXQUFXLFFBQXJDLEVBQUUsbUJBQW1CLEdBQUssV0FBVyxvQkFBaEIsQ0FBZ0I7UUFDbEYsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLFlBQVksQ0FBQztZQUNuQyxTQUFTLFdBQUE7WUFDVCxRQUFRLFVBQUE7WUFDUixPQUFPLFNBQUE7WUFDUCxXQUFXLEVBQUUsT0FBTztZQUNwQixtQkFBbUIscUJBQUE7U0FDcEIsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLElBQUkscUJBQ3JCLGlCQUFpQixFQUFFLElBQUksQ0FBQyxZQUFZLElBQ2pDLFdBQVcsS0FFZCxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLElBQ2hGLENBQUE7SUFDSixDQUFDO0lBQ0gscUJBQUM7QUFBRCxDQUFDLEFBckJELElBcUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT0F1dGgyQ2xpZW50IH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvb2F1dGgyY2xpZW50J1xuXG5pbXBvcnQgeyBBdXRoT3B0aW9ucywgQXV0aCB9IGZyb20gJy4vYXV0aC9hcGlzJ1xuXG5pbXBvcnQgKiBhcyBhdXRoTW9kZWxzIGZyb20gJy4vYXV0aC9tb2RlbHMnXG5cbmV4cG9ydCB7IFN5bnRheCwgRXJyb3JUeXBlIH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvY29uc3RzJ1xuXG5leHBvcnQge1xuICBkZWZhdWx0U3RvcmFnZSxcbiAgZGVmYXVsdFJlcXVlc3QsXG4gIFRvUmVzcG9uc2VFcnJvck9wdGlvbnMsXG4gIHRvUmVzcG9uc2VFcnJvcixcbiAgZ2VuZXJhdGVSZXF1ZXN0SWQsXG4gIE9BdXRoMkNsaWVudCxcbn0gZnJvbSAnLi9vYXV0aDJjbGllbnQvb2F1dGgyY2xpZW50J1xuXG5leHBvcnQgeyBBdXRoQ2xpZW50LCBTaW1wbGVTdG9yYWdlIH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvaW50ZXJmYWNlJ1xuXG5leHBvcnQge1xuICBDcmVkZW50aWFscyxcbiAgUmVzcG9uc2VFcnJvcixcbiAgT0F1dGgyQ2xpZW50T3B0aW9ucyxcbiAgQXV0aENsaWVudFJlcXVlc3RPcHRpb25zLFxufSBmcm9tICcuL29hdXRoMmNsaWVudC9tb2RlbHMnXG5cbmV4cG9ydCB7IEF1dGhPcHRpb25zLCBBdXRoIH0gZnJvbSAnLi9hdXRoL2FwaXMnXG5leHBvcnQgeyBhdXRoTW9kZWxzIH1cblxuXG5leHBvcnQgY2xhc3MgQ2xvdWRiYXNlT0F1dGgge1xuICBwdWJsaWMgb2F1dGgyY2xpZW50OiBPQXV0aDJDbGllbnRcbiAgcHVibGljIGF1dGhBcGk6IEF1dGhcblxuICBjb25zdHJ1Y3RvcihhdXRoT3B0aW9uczogQXV0aE9wdGlvbnMpIHtcbiAgICBjb25zdCB7IGFwaU9yaWdpbiwgY2xpZW50SWQsIHN0b3JhZ2UsIHJlcXVlc3QsIGFub255bW91c1NpZ25JbkZ1bmMgfSA9IGF1dGhPcHRpb25zXG4gICAgdGhpcy5vYXV0aDJjbGllbnQgPSBuZXcgT0F1dGgyQ2xpZW50KHtcbiAgICAgIGFwaU9yaWdpbixcbiAgICAgIGNsaWVudElkLFxuICAgICAgc3RvcmFnZSxcbiAgICAgIGJhc2VSZXF1ZXN0OiByZXF1ZXN0LFxuICAgICAgYW5vbnltb3VzU2lnbkluRnVuYyxcbiAgICB9KVxuXG4gICAgdGhpcy5hdXRoQXBpID0gbmV3IEF1dGgoe1xuICAgICAgY3JlZGVudGlhbHNDbGllbnQ6IHRoaXMub2F1dGgyY2xpZW50LFxuICAgICAgLi4uYXV0aE9wdGlvbnMsXG4gICAgICAvLyDlhbzlrrnogIHpgLvovpHvvIzmnInlgLzkvKDlhaXliJnkuI3otbBBdXRo5YaF55qE6aqM6K+B56CB6K+35rGC6YC76L6RXG4gICAgICByZXF1ZXN0OiByZXF1ZXN0ID8gdGhpcy5vYXV0aDJjbGllbnQucmVxdWVzdC5iaW5kKHRoaXMub2F1dGgyY2xpZW50KSA6IHVuZGVmaW5lZCxcbiAgICB9KVxuICB9XG59XG5cbiJdfQ==
@@ -45,4 +45,5 @@ export interface OAuth2ClientOptions {
45
45
  headers?: {
46
46
  [key: string]: string;
47
47
  };
48
+ anonymousSignInFunc?: (Credentials: any) => Promise<Credentials | void>;
48
49
  }