@cloudbase/oauth 1.0.0-alpha.2 → 1.0.0-alpha.3

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.
@@ -1,4 +1,4 @@
1
- import { GetVerificationRequest, GetVerificationResponse, UserProfile, UserInfo, SignInRequest, SignUpRequest, VerifyRequest, VerifyResponse, GenProviderRedirectUriRequest, GenProviderRedirectUriResponse, GrantProviderTokenRequest, GrantProviderTokenResponse, PatchProviderTokenRequest, PatchProviderTokenResponse, SignInWithProviderRequest, BindWithProviderRequest, TransByProviderRequest, GrantTokenRequest, UserProfileProvider, UnbindProviderRequest, CheckPasswordrRequest, BindPhoneRequest, BindEmailRequest, SetPasswordRequest, ChangeBindedProviderRequest, ChangeBindedProviderResponse, UpdatePasswordRequest, SudoResponse, SudoRequest, GetCustomSignTicketFn, QueryUserProfileRequest, QueryUserProfileResponse, ResetPasswordRequest, DeviceAuthorizeRequest, DeviceAuthorizeResponse, CheckUsernameRequest, CheckIfUserExistRequest, CheckIfUserExistResponse } from './models';
1
+ import { GetVerificationRequest, GetVerificationResponse, UserProfile, UserInfo, SignInRequest, SignUpRequest, VerifyRequest, VerifyResponse, GenProviderRedirectUriRequest, GenProviderRedirectUriResponse, GrantProviderTokenRequest, GrantProviderTokenResponse, PatchProviderTokenRequest, PatchProviderTokenResponse, SignInWithProviderRequest, BindWithProviderRequest, TransByProviderRequest, GrantTokenRequest, UserProfileProvider, UnbindProviderRequest, CheckPasswordrRequest, BindPhoneRequest, BindEmailRequest, SetPasswordRequest, ChangeBindedProviderRequest, ChangeBindedProviderResponse, UpdatePasswordRequest, SudoResponse, SudoRequest, GetCustomSignTicketFn, QueryUserProfileRequest, QueryUserProfileResponse, ResetPasswordRequest, DeviceAuthorizeRequest, DeviceAuthorizeResponse, CheckUsernameRequest, CheckIfUserExistRequest, CheckIfUserExistResponse, WithSudoRequest } from './models';
2
2
  import { SimpleStorage, RequestFunction } from '../oauth2client/interface';
3
3
  import { OAuth2Client } from '../oauth2client/oauth2client';
4
4
  import { Credentials } from '../oauth2client/models';
@@ -26,6 +26,7 @@ export declare class Auth {
26
26
  bindWithProvider(params: BindWithProviderRequest): Promise<void>;
27
27
  getUserProfile(): Promise<UserProfile>;
28
28
  getUserInfo(): Promise<UserInfo>;
29
+ deleteMe(params: WithSudoRequest): Promise<UserProfile>;
29
30
  hasLoginState(): Promise<boolean>;
30
31
  hasLoginStateSync(): Credentials | null;
31
32
  getLoginState(): Promise<Credentials | null>;
@@ -50,4 +51,5 @@ export declare class Auth {
50
51
  checkUsername(params: CheckUsernameRequest): Promise<void>;
51
52
  checkIfUserExist(params: CheckIfUserExistRequest): Promise<CheckIfUserExistResponse>;
52
53
  loginScope(): Promise<string>;
54
+ private static parseParamsToSearch;
53
55
  }
package/dist/auth/apis.js CHANGED
@@ -284,6 +284,18 @@ var Auth = (function () {
284
284
  });
285
285
  });
286
286
  };
287
+ Auth.prototype.deleteMe = function (params) {
288
+ return __awaiter(this, void 0, void 0, function () {
289
+ var url;
290
+ return __generator(this, function (_a) {
291
+ url = consts_1.ApiUrls.USER_ME_URL + "?" + Auth.parseParamsToSearch(params);
292
+ return [2, this._config.request(url, {
293
+ method: 'DELETE',
294
+ withCredentials: true,
295
+ })];
296
+ });
297
+ });
298
+ };
287
299
  Auth.prototype.hasLoginState = function () {
288
300
  return __awaiter(this, void 0, void 0, function () {
289
301
  var error_1;
@@ -497,8 +509,8 @@ var Auth = (function () {
497
509
  Auth.prototype.resetPassword = function (params) {
498
510
  return __awaiter(this, void 0, void 0, function () {
499
511
  return __generator(this, function (_a) {
500
- return [2, this._config.request(consts_1.ApiUrls.AUTH_SET_PASSWORD, {
501
- method: 'POST',
512
+ return [2, this._config.request(consts_1.ApiUrls.AUTH_RESET_PASSWORD, {
513
+ method: 'PATCH',
502
514
  body: params,
503
515
  })];
504
516
  });
@@ -530,7 +542,7 @@ var Auth = (function () {
530
542
  return __awaiter(this, void 0, void 0, function () {
531
543
  return __generator(this, function (_a) {
532
544
  return [2, this._config.request(consts_1.ApiUrls.CHECK_IF_USER_EXIST, {
533
- method: 'POST',
545
+ method: 'GET',
534
546
  body: params,
535
547
  })];
536
548
  });
@@ -543,7 +555,16 @@ var Auth = (function () {
543
555
  });
544
556
  });
545
557
  };
558
+ Auth.parseParamsToSearch = function (params) {
559
+ for (var key in params) {
560
+ if (!params[key]) {
561
+ delete params[key];
562
+ }
563
+ }
564
+ var searchParams = new URLSearchParams(params);
565
+ return searchParams.toString();
566
+ };
546
567
  return Auth;
547
568
  }());
548
569
  exports.Auth = Auth;
549
- //# 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} 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 _config: AuthOptions;\n  private _getCustomSignTicketFn?: GetCustomSignTicketFn;\n\n\n  /**\n   * constructor\n   * @param {AuthOptions} opts\n   */\n  constructor(opts: AuthOptions) {\n    let request = opts.request;\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: 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(\n    params: GetVerificationRequest,\n  ): Promise<GetVerificationResponse> {\n    let withCredentials = false;\n    // 发送短信时，如果时给当前用户发，则需要带上鉴权信息\n    if (params.target == 'CUR_USER') {\n      withCredentials = true\n    } else {\n      const hasLogin = await this.hasLoginState()\n      if (hasLogin) {\n        withCredentials = true\n      }\n    }\n    return this._config.request<GetVerificationResponse>(\n      ApiUrls.VERIFICATION_URL,\n      {\n        method: 'POST',\n        body: params,\n        withCaptcha: true,\n        withCredentials: 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(\n    params: GenProviderRedirectUriRequest,\n  ): Promise<GenProviderRedirectUriResponse> {\n    let url = `${ApiUrls.PROVIDER_URI_URL}?client_id=${this._config.clientId\n      }&provider_id=${params.provider_id}&redirect_uri=${encodeURIComponent(\n        params.provider_redirect_uri,\n      )}&state=${params.state}`;\n    const other_params = params.other_params;\n    if (other_params) {\n      if (\n        typeof other_params.sign_out_uri === 'string' &&\n        other_params.sign_out_uri.length > 0\n      ) {\n        url += `&other_params[sign_out_uri]=${other_params.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(\n    params: GrantProviderTokenRequest,\n  ): 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(\n    params: PatchProviderTokenRequest,\n  ): 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(\n    params: SignInWithProviderRequest,\n  ): 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(\n    params: BindWithProviderRequest,\n  ): 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    if (userInfo.picture) {\n      userInfo.avatarUrl = userInfo.picture;\n    }\n\n    if (userInfo.sub) {\n      userInfo.uid = userInfo.sub\n    }\n\n    return userInfo;\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(\n    params: TransByProviderRequest,\n  ): 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(\n    params: GetVerificationRequest,\n  ): 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(\n    params: ChangeBindedProviderRequest,\n  ): 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(\n    params: QueryUserProfileRequest,\n  ): 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_SET_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    return this._config.request<CheckIfUserExistResponse>(ApiUrls.CHECK_IF_USER_EXIST, {\n      method: 'POST',\n      body: params,\n    });\n  }\n\n  public async loginScope(): Promise<string> {\n    return this._config.credentialsClient.getScope()\n  }\n}\n"]}
570
+ //# 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 _config: AuthOptions;\n  private _getCustomSignTicketFn?: GetCustomSignTicketFn;\n\n\n  /**\n   * constructor\n   * @param {AuthOptions} opts\n   */\n  constructor(opts: AuthOptions) {\n    let request = opts.request;\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: 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(\n    params: GetVerificationRequest,\n  ): Promise<GetVerificationResponse> {\n    let withCredentials = false;\n    // 发送短信时，如果时给当前用户发，则需要带上鉴权信息\n    if (params.target == 'CUR_USER') {\n      withCredentials = true\n    } else {\n      const hasLogin = await this.hasLoginState()\n      if (hasLogin) {\n        withCredentials = true\n      }\n    }\n    return this._config.request<GetVerificationResponse>(\n      ApiUrls.VERIFICATION_URL,\n      {\n        method: 'POST',\n        body: params,\n        withCaptcha: true,\n        withCredentials: 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(\n    params: GenProviderRedirectUriRequest,\n  ): Promise<GenProviderRedirectUriResponse> {\n    let url = `${ApiUrls.PROVIDER_URI_URL}?client_id=${this._config.clientId\n      }&provider_id=${params.provider_id}&redirect_uri=${encodeURIComponent(\n        params.provider_redirect_uri,\n      )}&state=${params.state}`;\n    const other_params = params.other_params;\n    if (other_params) {\n      if (\n        typeof other_params.sign_out_uri === 'string' &&\n        other_params.sign_out_uri.length > 0\n      ) {\n        url += `&other_params[sign_out_uri]=${other_params.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(\n    params: GrantProviderTokenRequest,\n  ): 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(\n    params: PatchProviderTokenRequest,\n  ): 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(\n    params: SignInWithProviderRequest,\n  ): 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(\n    params: BindWithProviderRequest,\n  ): 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    if (userInfo.picture) {\n      userInfo.avatarUrl = userInfo.picture;\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(\n    params: TransByProviderRequest,\n  ): 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(\n    params: GetVerificationRequest,\n  ): 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(\n    params: ChangeBindedProviderRequest,\n  ): 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(\n    params: QueryUserProfileRequest,\n  ): 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: 'PATCH',\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    return this._config.request<CheckIfUserExistResponse>(ApiUrls.CHECK_IF_USER_EXIST, {\n      method: 'GET',\n      body: params,\n    });\n  }\n\n  public async loginScope(): Promise<string> {\n    return this._config.credentialsClient.getScope()\n  }\n\n  private static parseParamsToSearch(params: any): string {\n    for (let key in params) {\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"]}
@@ -65,14 +65,6 @@ export interface PatchProviderTokenResponse {
65
65
  expires_in: number;
66
66
  provider_profile: ProviderProfile;
67
67
  }
68
- export interface GenProviderRedirectUriRequest {
69
- provider_id: string;
70
- provider_redirect_uri: string;
71
- state: string;
72
- other_params?: {
73
- sign_out_uri?: string;
74
- };
75
- }
76
68
  export interface GenProviderRedirectUriResponse {
77
69
  uri: string;
78
70
  signout_uri?: string;
@@ -221,7 +213,7 @@ export interface GenProviderRedirectUriRequest {
221
213
  provider_redirect_uri: string;
222
214
  state: string;
223
215
  other_params?: {
224
- sign_out_uri?: string;
216
+ [key: string]: string;
225
217
  };
226
218
  }
227
219
  export interface GenProviderRedirectUriResponse {
@@ -305,6 +297,9 @@ export interface SudoRequest {
305
297
  export interface SudoResponse {
306
298
  sudo_token?: string;
307
299
  }
300
+ export interface WithSudoRequest {
301
+ sudo_token: string;
302
+ }
308
303
  export interface ChangeBoundProviderRequest {
309
304
  trans_token: string;
310
305
  provider_id: string;
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# 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\nexport 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  avatarUrl?: 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    sign_out_uri?: 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\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"]}
3
+ //# 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  avatarUrl?: 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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cloudbase/oauth",
3
- "version": "1.0.0-alpha.2",
3
+ "version": "1.0.0-alpha.3",
4
4
  "description": "cloudbase javascript sdk auth componets",
5
5
  "main": "./dist/index.js",
6
6
  "module": "dist/esm/index.js",
@@ -26,5 +26,5 @@
26
26
  "rimraf": "^3.0.0",
27
27
  "typescript": "^3.8.3"
28
28
  },
29
- "gitHead": "3b20db4d7eb25fbe7dba9f0866f3e196c33bf0e2"
29
+ "gitHead": "bd152c0325ab3bc6da214281362ef26c4940d4b8"
30
30
  }
package/src/auth/apis.ts CHANGED
@@ -39,7 +39,8 @@ import {
39
39
  DeviceAuthorizeResponse,
40
40
  CheckUsernameRequest,
41
41
  CheckIfUserExistRequest,
42
- CheckIfUserExistResponse
42
+ CheckIfUserExistResponse,
43
+ WithSudoRequest
43
44
  } from './models';
44
45
  import { SimpleStorage, RequestFunction } from '../oauth2client/interface';
45
46
  import { OAuth2Client, defaultStorage } from '../oauth2client/oauth2client';
@@ -325,6 +326,18 @@ export class Auth {
325
326
  return userInfo;
326
327
  }
327
328
 
329
+ /**
330
+ * Delete me
331
+ * @param params
332
+ */
333
+ public async deleteMe(params: WithSudoRequest): Promise<UserProfile> {
334
+ const url = `${ApiUrls.USER_ME_URL}?${Auth.parseParamsToSearch(params)}`;
335
+ return this._config.request<UserProfile>(url, {
336
+ method: 'DELETE',
337
+ withCredentials: true,
338
+ });
339
+ }
340
+
328
341
  /**
329
342
  * hasLoginState check if has login state
330
343
  * @return {Promise<boolean>} A Promise<boolean> object.
@@ -579,8 +592,8 @@ export class Auth {
579
592
  * @memberof Auth
580
593
  */
581
594
  public async resetPassword(params: ResetPasswordRequest): Promise<void> {
582
- return this._config.request(ApiUrls.AUTH_SET_PASSWORD, {
583
- method: 'POST',
595
+ return this._config.request(ApiUrls.AUTH_RESET_PASSWORD, {
596
+ method: 'PATCH',
584
597
  body: params,
585
598
  // withCredentials: true
586
599
  })
@@ -610,7 +623,7 @@ export class Auth {
610
623
 
611
624
  public async checkIfUserExist(params: CheckIfUserExistRequest): Promise<CheckIfUserExistResponse> {
612
625
  return this._config.request<CheckIfUserExistResponse>(ApiUrls.CHECK_IF_USER_EXIST, {
613
- method: 'POST',
626
+ method: 'GET',
614
627
  body: params,
615
628
  });
616
629
  }
@@ -618,4 +631,14 @@ export class Auth {
618
631
  public async loginScope(): Promise<string> {
619
632
  return this._config.credentialsClient.getScope()
620
633
  }
634
+
635
+ private static parseParamsToSearch(params: any): string {
636
+ for (let key in params) {
637
+ if (!params[key]) {
638
+ delete params[key]
639
+ }
640
+ }
641
+ const searchParams = new URLSearchParams(params as any);
642
+ return searchParams.toString();
643
+ }
621
644
  }
@@ -81,14 +81,14 @@ export interface PatchProviderTokenResponse {
81
81
  provider_profile: ProviderProfile;
82
82
  }
83
83
 
84
- export interface GenProviderRedirectUriRequest {
85
- provider_id: string;
86
- provider_redirect_uri: string;
87
- state: string;
88
- other_params?: {
89
- sign_out_uri?: string;
90
- };
91
- }
84
+ // export interface GenProviderRedirectUriRequest {
85
+ // provider_id: string;
86
+ // provider_redirect_uri: string;
87
+ // state: string;
88
+ // other_params?: {
89
+ // sign_out_uri?: string;
90
+ // };
91
+ // }
92
92
 
93
93
  export interface GenProviderRedirectUriResponse {
94
94
  uri: string;
@@ -268,7 +268,7 @@ export interface GenProviderRedirectUriRequest {
268
268
  provider_redirect_uri: string;
269
269
  state: string;
270
270
  other_params?: {
271
- sign_out_uri?: string;
271
+ [key: string]: string
272
272
  };
273
273
  }
274
274
 
@@ -375,6 +375,10 @@ export interface SudoResponse {
375
375
  sudo_token?: string
376
376
  }
377
377
 
378
+ export interface WithSudoRequest {
379
+ sudo_token: string
380
+ }
381
+
378
382
 
379
383
  export interface ChangeBoundProviderRequest {
380
384
  trans_token: string;