@cloudbase/oauth 2.5.49-beta.2 → 2.5.49-beta.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -78,4 +78,3 @@ export var ErrorType;
78
78
  ErrorType["USER_PENDING"] = "user_pending";
79
79
  ErrorType["USER_BLOCKED"] = "user_blocked";
80
80
  })(ErrorType || (ErrorType = {}));
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F1dGgvY29uc3RzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLE9BMENYO0FBMUNELFdBQVksT0FBTztJQUNqQiwrQ0FBb0MsQ0FBQTtJQUNwQyx1RUFBNEQsQ0FBQTtJQUM1RCwyRUFBZ0UsQ0FBQTtJQUNoRSx5RUFBOEQsQ0FBQTtJQUM5RCwrQ0FBb0MsQ0FBQTtJQUNwQyw0Q0FBaUMsQ0FBQTtJQUNqQyw4Q0FBbUMsQ0FBQTtJQUNuQyw0REFBaUQsQ0FBQTtJQUNqRCx5REFBOEMsQ0FBQTtJQUM5QyxxREFBMEMsQ0FBQTtJQUMxQywyQ0FBZ0MsQ0FBQTtJQUNoQywwREFBK0MsQ0FBQTtJQUMvQyxpREFBc0MsQ0FBQTtJQUN0QyxxREFBMEMsQ0FBQTtJQUMxQywyREFBZ0QsQ0FBQTtJQUNoRCx5RUFBOEQsQ0FBQTtJQUM5RCxxREFBMEMsQ0FBQTtJQUMxQyxzREFBMkMsQ0FBQTtJQUMzQyxxREFBMEMsQ0FBQTtJQUMxQyxtRUFBd0QsQ0FBQTtJQUN4RCxvREFBeUMsQ0FBQTtJQUV6QyxtREFBd0MsQ0FBQTtJQUN4Qyx5REFBOEMsQ0FBQTtJQUM5QywrQ0FBb0MsQ0FBQTtJQUNwQywwQ0FBK0IsQ0FBQTtJQUMvQixxREFBMEMsQ0FBQTtJQUMxQyx1REFBNEMsQ0FBQTtJQUM1QyxpREFBc0MsQ0FBQTtJQUN0Qyx3REFBNkMsQ0FBQTtJQUM3QyxvREFBeUMsQ0FBQTtJQUN6Qyw0REFBaUQsQ0FBQTtJQUNqRCxvREFBeUMsQ0FBQTtJQUN6QyxrRUFBdUQsQ0FBQTtJQUN2RCw4REFBbUQsQ0FBQTtJQUNuRCw4RUFBbUUsQ0FBQTtJQUNuRSwyREFBZ0QsQ0FBQTtJQUNoRCxzRUFBMkQsQ0FBQTtJQUUzRCw4REFBbUQsQ0FBQTtJQUNuRCx1RUFBNEQsQ0FBQTtBQUM5RCxDQUFDLEVBMUNXLE9BQU8sS0FBUCxPQUFPLFFBMENsQjtBQUVELE1BQU0sQ0FBTixJQUFZLFNBT1g7QUFQRCxXQUFZLFNBQVM7SUFDbkIsMERBQTZDLENBQUE7SUFDN0MsOENBQWlDLENBQUE7SUFDakMsNkNBQWdDLENBQUE7SUFDaEMsNERBQStDLENBQUE7SUFDL0MsNkVBQWdFLENBQUE7SUFDaEUsMkRBQThDLENBQUE7QUFDaEQsQ0FBQyxFQVBXLFNBQVMsS0FBVCxTQUFTLFFBT3BCO0FBRUQsTUFBTSxDQUFOLElBQVksa0JBTVg7QUFORCxXQUFZLGtCQUFrQjtJQUM1QiwyQ0FBcUIsQ0FBQTtJQUNyQix5Q0FBbUIsQ0FBQTtJQUNuQix1REFBaUMsQ0FBQTtJQUNqQyxtRUFBNkMsQ0FBQTtJQUM3QyxpRUFBMkMsQ0FBQTtBQUM3QyxDQUFDLEVBTlcsa0JBQWtCLEtBQWxCLGtCQUFrQixRQU03QjtBQUVELE1BQU0sQ0FBTixJQUFZLFNBb0JYO0FBcEJELFdBQVksU0FBUztJQUNuQixrREFBcUMsQ0FBQTtJQUNyQyxvREFBdUMsQ0FBQTtJQUN2QyxvQ0FBdUIsQ0FBQTtJQUN2Qiw4Q0FBaUMsQ0FBQTtJQUNqQyxvREFBdUMsQ0FBQTtJQUN2QyxnQ0FBbUIsQ0FBQTtJQUNuQiwwQ0FBNkIsQ0FBQTtJQUM3Qiw0Q0FBK0IsQ0FBQTtJQUMvQixrQ0FBcUIsQ0FBQTtJQUNyQix3Q0FBMkIsQ0FBQTtJQUMzQixvQ0FBdUIsQ0FBQTtJQUV2QixrREFBcUMsQ0FBQTtJQUNyQyxnREFBbUMsQ0FBQTtJQUNuQyxrREFBcUMsQ0FBQTtJQUNyQyxrREFBcUMsQ0FBQTtJQUNyQyw4Q0FBaUMsQ0FBQTtJQUNqQywwQ0FBNkIsQ0FBQTtJQUM3QiwwQ0FBNkIsQ0FBQTtBQUMvQixDQUFDLEVBcEJXLFNBQVMsS0FBVCxTQUFTLFFBb0JwQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEFwaVVybHMge1xuICBBVVRIX1NJR05fSU5fVVJMID0gJy9hdXRoL3YxL3NpZ25pbicsXG4gIEFVVEhfU0lHTl9JTl9BTk9OWU1PVVNMWV9VUkwgPSAnL2F1dGgvdjEvc2lnbmluL2Fub255bW91c2x5JyxcbiAgQVVUSF9TSUdOX0lOX1dJVEhfUFJPVklERVJfVVJMID0gJy9hdXRoL3YxL3NpZ25pbi93aXRoL3Byb3ZpZGVyJyxcbiAgQVVUSF9TSUdOX0lOX1dJVEhfV0VDSEFUX1VSTCA9ICcvYXV0aC92MS9zaWduaW4vd2VjaGF0L25vYXV0aCcsXG4gIEFVVEhfU0lHTl9VUF9VUkwgPSAnL2F1dGgvdjEvc2lnbnVwJyxcbiAgQVVUSF9UT0tFTl9VUkwgPSAnL2F1dGgvdjEvdG9rZW4nLFxuICBBVVRIX1JFVk9LRV9VUkwgPSAnL2F1dGgvdjEvcmV2b2tlJyxcbiAgUFJPVklERVJfQklORF9VUkwgPSAnL2F1dGgvdjEvdXNlci9wcm92aWRlci9iaW5kJyxcbiAgUFJPVklERVJfVE9LRU5fVVJMID0gJy9hdXRoL3YxL3Byb3ZpZGVyL3Rva2VuJyxcbiAgUFJPVklERVJfVVJJX1VSTCA9ICcvYXV0aC92MS9wcm92aWRlci91cmknLFxuICBVU0VSX01FX1VSTCA9ICcvYXV0aC92MS91c2VyL21lJyxcbiAgV0VEQV9VU0VSX1VSTCA9ICcvYXV0aC92MS9wbHVnaW4vd2VkYS91c2VyaW5mbycsXG4gIFVTRVJfUVVFUllfVVJMID0gJy9hdXRoL3YxL3VzZXIvcXVlcnknLFxuICBVU0VSX1BSSUZJTEVfVVJMID0gJy9hdXRoL3YxL3VzZXIvcHJvZmlsZScsXG4gIFVTRVJfQkFTSUNfRURJVF9VUkwgPSAnL2F1dGgvdjEvdXNlci9iYXNpYy9lZGl0JyxcbiAgVVNFUl9UUkFOU19CWV9QUk9WSURFUl9VUkwgPSAnL2F1dGgvdjEvdXNlci90cmFucy9ieS9wcm92aWRlcicsXG4gIFZFUklGSUNBVElPTl9VUkwgPSAnL2F1dGgvdjEvdmVyaWZpY2F0aW9uJyxcbiAgVkVSSUZZX1VSTCA9ICcvYXV0aC92MS92ZXJpZmljYXRpb24vdmVyaWZ5JyxcbiAgQ0FQVENIQV9EQVRBX1VSTCA9ICcvYXV0aC92MS9jYXB0Y2hhL2RhdGEnLFxuICBWRVJJRllfQ0FQVENIQV9EQVRBX1VSTCA9ICcvYXV0aC92MS9jYXB0Y2hhL2RhdGEvdmVyaWZ5JyxcbiAgR0VUX0NBUFRDSEFfVVJMID0gJy9hdXRoL3YxL2NhcHRjaGEvaW5pdCcsXG5cbiAgUFJPVklERVJfTElTVCA9ICcvYXV0aC92MS91c2VyL3Byb3ZpZGVyJyxcbiAgUFJPVklERVJfVU5CSU5EX1VSTCA9ICcvYXV0aC92MS91c2VyL3Byb3ZpZGVyJyxcbiAgQ0hFQ0tfUFdEX1VSTCA9ICcvYXV0aC92MS91c2VyL3N1ZG8nLFxuICBTVURPX1VSTCA9ICcvYXV0aC92MS91c2VyL3N1ZG8nLFxuICBCSU5EX0NPTlRBQ1RfVVJMID0gJy9hdXRoL3YxL3VzZXIvY29udGFjdCcsXG4gIEFVVEhfU0VUX1BBU1NXT1JEID0gJy9hdXRoL3YxL3VzZXIvcGFzc3dvcmQnLFxuICBBVVRIX1JFU0VUX1BBU1NXT1JEID0gJy9hdXRoL3YxL3Jlc2V0JyxcbiAgQVVUSF9HRVRfREVWSUNFX0NPREUgPSAnL2F1dGgvdjEvZGV2aWNlL2NvZGUnLFxuICBDSEVDS19VU0VSTkFNRSA9ICcvYXV0aC92MS9jaGVja1VzZXJuYW1lJyxcbiAgQ0hFQ0tfSUZfVVNFUl9FWElTVCA9ICcvYXV0aC92MS9jaGVja0lmVXNlckV4aXN0JyxcbiAgQVVUSE9SSVpFX1VSTCA9ICcvYXV0aC92MS91c2VyL2F1dGhvcml6ZScsXG4gIEFVVEhPUklaRV9ERVZJQ0VfVVJMID0gJy9hdXRoL3YxL3VzZXIvZGV2aWNlL2F1dGhvcml6ZScsXG4gIEFVVEhPUklaRV9JTkZPX1VSTCA9ICcvYXV0aC92MS91c2VyL2F1dGhvcml6ZS9pbmZvJyxcbiAgQVVUSE9SSVpFRF9ERVZJQ0VTX0RFTEVURV9VUkwgPSAnL2F1dGgvdjEvdXNlci9hdXRob3JpemVkL2RldmljZXMvJyxcbiAgQVVUSF9SRVZPS0VfQUxMX1VSTCA9ICcvYXV0aC92MS91c2VyL3Jldm9rZS9hbGwnLFxuICBHRVRfUFJPVklERVJfVFlQRSA9ICcvYXV0aC92MS9tZ3IvcHJvdmlkZXIvcHJvdmlkZXJTdWJUeXBlJyxcblxuICBHRVRfTUlOSVBST0dSQU1fUVJDT0RFID0gJy9hdXRoL3YxL3FyY29kZS9nZW5lcmF0ZScsXG4gIEdFVF9NSU5JUFJPR1JBTV9RUkNPREVfU1RBVFVTID0gJy9hdXRoL3YxL3FyY29kZS9nZXQvc3RhdHVzJyxcbn1cblxuZXhwb3J0IGVudW0gQXBpVXJsc1YyIHtcbiAgQVVUSF9TSUdOX0lOX1VSTCA9ICcvYXV0aC92Mi9zaWduaW4vdXNlcm5hbWUnLFxuICBBVVRIX1RPS0VOX1VSTCA9ICcvYXV0aC92Mi90b2tlbicsXG4gIFVTRVJfTUVfVVJMID0gJy9hdXRoL3YyL3VzZXIvbWUnLFxuICBWRVJJRllfVVJMID0gJy9hdXRoL3YyL3NpZ25pbi92ZXJpZmljYXRpb25jb2RlJyxcbiAgQVVUSF9TSUdOX0lOX1dJVEhfUFJPVklERVJfVVJMID0gJy9hdXRoL3YyL3NpZ25pbi93aXRoL3Byb3ZpZGVyJyxcbiAgQVVUSF9QVUJMSUNfS0VZID0gJy9hdXRoL3YyL3NpZ25pbi9wdWJsaWNoa2V5Jyxcbn1cblxuZXhwb3J0IGVudW0gVmVyaWZpY2F0aW9uVXNhZ2VzIHtcbiAgUkVHSVNURVIgPSAnUkVHSVNURVInLFxuICBTSUdOX0lOID0gJ1NJR05fSU4nLFxuICBQQVNTV09SRF9SRVNFVCA9ICdQQVNTV09SRF9SRVNFVCcsXG4gIEVNQUlMX0FERFJFU1NfQ0hBTkdFID0gJ0VNQUlMX0FERFJFU1NfQ0hBTkdFJyxcbiAgUEhPTkVfTlVNQkVSX0NIQU5HRSA9ICdQSE9ORV9OVU1CRVJfQ0hBTkdFJyxcbn1cblxuZXhwb3J0IGVudW0gRXJyb3JUeXBlIHtcbiAgSU5WQUxJRF9BUkdVTUVOVCA9ICdpbnZhbGlkX2FyZ3VtZW50JyxcbiAgREVBRExJTkVfRVhDRUVERUQgPSAnZGVhZGxpbmVfZXhjZWVkZWQnLFxuICBOT1RfRk9VTkQgPSAnbm90X2ZvdW5kJyxcbiAgQUxSRUFEWV9FWElTVFMgPSAnYWxyZWFkeV9leGlzdHMnLFxuICBQRVJNSVNTSU9OX0RFTklFRCA9ICdwZXJtaXNzaW9uX2RlbmllZCcsXG4gIEFCT1JURUQgPSAnYWJvcnRlZCcsXG4gIE9VVF9PRl9SQU5HRSA9ICdvdXRfb2ZfcmFuZ2UnLFxuICBVTklNUExFTUVOVEVEID0gJ3VuaW1wbGVtZW50ZWQnLFxuICBJTlRFUk5BTCA9ICdpbnRlcm5hbCcsXG4gIFVOQVZBSUxBQkxFID0gJ3VuYXZhaWxhYmxlJyxcbiAgREFUQV9MT1NTID0gJ2RhdGFfbG9zcycsXG4gIC8vIENvbW1vbkVycm9yXG4gIENBUFRDSEFfUkVRVUlSRUQgPSAnY2FwdGNoYV9yZXF1aXJlZCcsXG4gIENBUFRDSEFfSU5WQUxJRCA9ICdjYXB0Y2hhX2ludmFsaWQnLFxuICBJTlZBTElEX1BBU1NXT1JEID0gJ2ludmFsaWRfcGFzc3dvcmQnLFxuICBQQVNTV09SRF9OT1RfU0VUID0gJ3Bhc3N3b3JkX25vdF9zZXQnLFxuICBJTlZBTElEX1NUQVRVUyA9ICdpbnZhbGlkX3N0YXR1cycsXG4gIFVTRVJfUEVORElORyA9ICd1c2VyX3BlbmRpbmcnLFxuICBVU0VSX0JMT0NLRUQgPSAndXNlcl9ibG9ja2VkJyxcbn1cbiJdfQ==
@@ -1,2 +1 @@
1
1
  export {};
2
- //# 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, EncryptParams {\n  username?: string;\n  password?: string;\n  verification_token?: string;\n  version?: string;\n  query?: { with_department?: boolean; with_role?: boolean };\n}\n\nexport interface SignInWithProviderRequest extends BaseRequest {\n  provider_token: string;\n  version?: 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  verification_token?: string;\n  version?: 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  code?: string;\n  error_code?: string;\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    provider_code_type?: 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  name?: string;\n  picture?: string;\n  email?: 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 ChangeBoundProviderRequest extends BaseRequest {\n  trans_token: string;\n  provider_id: string;\n}\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  verification_token?: string;\n  version?: 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  provider_params?: {\n    provider_code_type?: string;\n    appid?: string;\n  };\n}\n\nexport interface GrantProviderTokenResponse {\n  provider_token: string;\n  expires_in: number;\n  code?: string;\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    provider_code_type?: 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 EditContactRequest {\n  phone_number?: string;\n  email?: string;\n  sudo_token: string;\n  verification_token: string;\n  // 冲突解决方案\n  // 可选：DEFAULT， 默认解决方案：提示用户该手机号已被其他人绑定\n  //      DELETE_ACCOUNT_TRANSFER，标记原来的账号为已注销，并将手机换绑给自己\n  //     TRANSFER 仅换绑手机号，不注销原有账号。（原有账号无法登录情况下，则自动标记为注销）\n  conflict_resolution?: 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\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  version?: string;\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 AuthorizeRequest extends BaseRequest {\n  response_type?: string;\n  redirect_uri?: string;\n  state?: string;\n  scope?: string;\n  code_challenge?: string;\n  code_challenge_method?: string;\n  sign_out_uri?: string;\n}\n\nexport interface AuthorizeResponse {\n  code?: string;\n  access_token?: string;\n  id_token?: string;\n  token_type?: string;\n  scope?: string;\n  state?: string;\n  expires_in?: number;\n}\n\nexport interface AuthorizeInfoRequest extends BaseRequest {\n  response_type?: string;\n  redirect_uri?: string;\n  state?: string;\n  scope?: string;\n  sign_out_uri?: string;\n  locale?: string;\n}\n\ninterface Scope {\n  id: string;\n  name: string;\n  description?: string;\n  picture?: string;\n  url?: string;\n  children?: Scope[];\n}\nexport interface AuthorizeInfoResponse {\n  client: {\n    id: string;\n    name: string;\n    description?: string;\n    picture?: string;\n    url?: string;\n  };\n  scopes?: Scope[];\n}\n\nexport interface AuthorizeDeviceRequest extends BaseRequest {\n  user_code: string;\n  scope?: string;\n  state?: 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\nexport interface PublicKey {\n  public_key: string; // 加密的公钥\n  public_key_thumbprint: string; // 加密的公钥指纹\n}\n\nexport interface EncryptParams {\n  isEncrypt?: boolean; // 是否需要加密\n  public_key_thumbprint?: string; // 加密的公钥指纹\n  params?: string; // 加密的数据\n}\n\nexport interface ProviderSubType {\n  id: string;\n  provider_sub_type: 'NO_AUTH_LOGIN' | ''; // NO_AUTH_LOGIN-免密登录\n}\n\nexport interface GetMiniProgramQrCodeRequest {\n  envId: string;\n  wxAppId: string;\n}\n\nexport interface GetMiniProgramQrCodeResponse {\n  qr_code: string;\n  qr_code_id: string;\n  expires_in: number;\n}\n\nexport interface GetMiniProgramQrCodeStatusRequest {\n  qrCodeId: string;\n  envId: string;\n  wxAppId: string;\n}\n\nexport interface GetMiniProgramQrCodeStatusResponse {\n  status: string;\n  provider_token: string;\n  expires_in: number;\n}\n\nexport interface ModifyUserBasicInfoRequest {\n  user_id: string;\n  nickname: string;\n  username: string;\n  description: string;\n  avatar_url: string;\n}\n"]}
@@ -1,44 +1,8 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- var __generator = (this && this.__generator) || function (thisArg, body) {
11
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
12
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
13
- function verb(n) { return function (v) { return step([n, v]); }; }
14
- function step(op) {
15
- if (f) throw new TypeError("Generator is already executing.");
16
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
17
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
18
- if (y = 0, t) op = [op[0] & 2, t.value];
19
- switch (op[0]) {
20
- case 0: case 1: t = op; break;
21
- case 4: _.label++; return { value: op[1], done: false };
22
- case 5: _.label++; y = op[1]; op = [0]; continue;
23
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
24
- default:
25
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
26
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
27
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
28
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
29
- if (t[2]) _.ops.pop();
30
- _.trys.pop(); continue;
31
- }
32
- op = body.call(thisArg, _);
33
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
34
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
35
- }
36
- };
37
1
  import { ApiUrls, ErrorType } from '../auth/consts';
38
2
  import { defaultStorage } from '../oauth2client/oauth2client';
39
3
  import { isInMpWebView, isMp } from '../utils/mp';
40
- var Captcha = (function () {
41
- function Captcha(opts) {
4
+ export class Captcha {
5
+ constructor(opts) {
42
6
  if (!opts.openURIWithCallback) {
43
7
  opts.openURIWithCallback = this.getDefaultOpenURIWithCallback();
44
8
  }
@@ -46,240 +10,173 @@ var Captcha = (function () {
46
10
  opts.storage = defaultStorage;
47
11
  }
48
12
  this.config = opts;
49
- this.tokenSectionName = "captcha_".concat(opts.clientId);
13
+ this.tokenSectionName = `captcha_${opts.clientId}`;
50
14
  }
51
- Captcha.prototype.request = function (url, options) {
52
- return __awaiter(this, void 0, void 0, function () {
53
- var state, reqURL, resp, err_1;
54
- return __generator(this, function (_a) {
55
- switch (_a.label) {
56
- case 0:
57
- if (!options) {
58
- options = {};
59
- }
60
- if (!options.method) {
61
- options.method = 'GET';
62
- }
63
- state = "".concat(options.method, ":").concat(url);
64
- reqURL = url;
65
- if (!options.withCaptcha) return [3, 2];
66
- return [4, this.appendCaptchaTokenToURL(url, state, false)];
67
- case 1:
68
- reqURL = _a.sent();
69
- _a.label = 2;
70
- case 2:
71
- _a.trys.push([2, 4, , 7]);
72
- return [4, this.config.request(reqURL, options)];
73
- case 3:
74
- resp = _a.sent();
75
- return [3, 7];
76
- case 4:
77
- err_1 = _a.sent();
78
- if (!(err_1.error === ErrorType.CAPTCHA_REQUIRED || err_1.error === ErrorType.CAPTCHA_INVALID)) return [3, 6];
79
- return [4, this.appendCaptchaTokenToURL(url, state, err_1.error === ErrorType.CAPTCHA_INVALID)];
80
- case 5:
81
- url = _a.sent();
82
- return [2, this.config.request(url, options)];
83
- case 6: return [2, Promise.reject(err_1)];
84
- case 7: return [2, resp];
85
- }
86
- });
87
- });
88
- };
89
- Captcha.prototype.getDefaultOpenURIWithCallback = function () {
15
+ async request(url, options) {
16
+ if (!options) {
17
+ options = {};
18
+ }
19
+ if (!options.method) {
20
+ options.method = 'GET';
21
+ }
22
+ const state = `${options.method}:${url}`;
23
+ let reqURL = url;
24
+ if (options.withCaptcha) {
25
+ reqURL = await this.appendCaptchaTokenToURL(url, state, false);
26
+ }
27
+ let resp;
28
+ try {
29
+ resp = await this.config.request(reqURL, options);
30
+ }
31
+ catch (err) {
32
+ if (err.error === ErrorType.CAPTCHA_REQUIRED || err.error === ErrorType.CAPTCHA_INVALID) {
33
+ url = await this.appendCaptchaTokenToURL(url, state, err.error === ErrorType.CAPTCHA_INVALID);
34
+ return this.config.request(url, options);
35
+ }
36
+ return Promise.reject(err);
37
+ }
38
+ return resp;
39
+ }
40
+ getDefaultOpenURIWithCallback() {
90
41
  if (!isMp() && !isInMpWebView()) {
91
42
  if (window.location.search.indexOf('__captcha') > 0) {
92
43
  document.body.style.display = 'none';
93
44
  }
94
45
  if (document.getElementById('captcha_panel_wrap') === null) {
95
- var elementDiv_1 = document.createElement('div');
96
- elementDiv_1.style.cssText = 'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;';
97
- elementDiv_1.setAttribute('id', 'captcha_panel_wrap');
98
- setTimeout(function () {
99
- document.body.appendChild(elementDiv_1);
46
+ const elementDiv = document.createElement('div');
47
+ elementDiv.style.cssText = 'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;';
48
+ elementDiv.setAttribute('id', 'captcha_panel_wrap');
49
+ setTimeout(() => {
50
+ document.body.appendChild(elementDiv);
100
51
  }, 0);
101
52
  }
102
53
  }
103
54
  return this.defaultOpenURIWithCallback;
104
- };
105
- Captcha.prototype.defaultOpenURIWithCallback = function (url, opts) {
106
- return __awaiter(this, void 0, void 0, function () {
107
- var _a, _b, width, _c, height, matched, target, iframe;
108
- return __generator(this, function (_d) {
109
- _a = opts || {}, _b = _a.width, width = _b === void 0 ? '355px' : _b, _c = _a.height, height = _c === void 0 ? '355px' : _c;
110
- matched = url.match(/^(data:.*)$/);
111
- if (matched) {
112
- return [2, Promise.reject({
113
- error: ErrorType.UNIMPLEMENTED,
114
- error_description: 'need to impl captcha data',
115
- })];
116
- }
117
- target = document.getElementById('captcha_panel_wrap');
118
- iframe = document.createElement('iframe');
119
- target.innerHTML = '';
120
- iframe.setAttribute('src', url);
121
- iframe.setAttribute('id', 'review-panel-iframe');
122
- iframe.style.cssText = "min-width:".concat(width, ";display:block;height:").concat(height, ";margin:0 auto;background-color: rgb(255, 255, 255);border: none;");
123
- target.appendChild(iframe);
124
- target.style.display = 'block';
125
- return [2, new Promise(function (resolve, reject) {
126
- iframe.onload = function () {
127
- try {
128
- var windowLocation = window.location;
129
- var iframeLocation = iframe.contentWindow.location;
130
- if (iframeLocation.host + iframeLocation.pathname === windowLocation.host + windowLocation.pathname) {
131
- target.style.display = 'none';
132
- var iframeUrlParams = new URLSearchParams(iframeLocation.search);
133
- var captchToken = iframeUrlParams.get('captcha_token');
134
- if (captchToken) {
135
- return resolve({
136
- captcha_token: captchToken,
137
- expires_in: Number(iframeUrlParams.get('expires_in')),
138
- });
139
- }
140
- return reject({
141
- error: iframeUrlParams.get('error'),
142
- error_description: iframeUrlParams.get('error_description'),
143
- });
144
- }
145
- target.style.display = 'block';
146
- }
147
- catch (error) {
148
- target.style.display = 'block';
149
- }
150
- };
151
- })];
55
+ }
56
+ async defaultOpenURIWithCallback(url, opts) {
57
+ const { width = '355px', height = '355px' } = opts || {};
58
+ const matched = url.match(/^(data:.*)$/);
59
+ if (matched) {
60
+ return Promise.reject({
61
+ error: ErrorType.UNIMPLEMENTED,
62
+ error_description: 'need to impl captcha data',
152
63
  });
153
- });
154
- };
155
- Captcha.prototype.getCaptchaToken = function (forceNewToken, state) {
156
- return __awaiter(this, void 0, void 0, function () {
157
- var captchaToken_1, captchaTokenResp, redirect_uri, captchaToken_2, captchaDataResp, captchaToken;
158
- return __generator(this, function (_a) {
159
- switch (_a.label) {
160
- case 0:
161
- if (!!forceNewToken) return [3, 2];
162
- return [4, this.findCaptchaToken()];
163
- case 1:
164
- captchaToken_1 = _a.sent();
165
- if (captchaToken_1) {
166
- return [2, captchaToken_1];
167
- }
168
- _a.label = 2;
169
- case 2:
170
- if (!(!isMp() && !isInMpWebView())) return [3, 4];
171
- redirect_uri = "".concat(window.location.origin + window.location.pathname, "?__captcha=on");
172
- return [4, this.config.request(ApiUrls.GET_CAPTCHA_URL, {
173
- method: 'POST',
174
- body: {
175
- client_id: this.config.clientId,
176
- redirect_uri: redirect_uri,
177
- state: state,
178
- },
179
- withCredentials: false,
180
- })];
181
- case 3:
182
- captchaTokenResp = _a.sent();
183
- if (captchaTokenResp.captcha_token) {
184
- captchaToken_2 = {
185
- captcha_token: captchaTokenResp.captcha_token,
186
- expires_in: captchaTokenResp.expires_in,
187
- };
188
- this.saveCaptchaToken(captchaToken_2);
189
- return [2, captchaTokenResp.captcha_token];
64
+ }
65
+ const target = document.getElementById('captcha_panel_wrap');
66
+ const iframe = document.createElement('iframe');
67
+ target.innerHTML = '';
68
+ iframe.setAttribute('src', url);
69
+ iframe.setAttribute('id', 'review-panel-iframe');
70
+ iframe.style.cssText = `min-width:${width};display:block;height:${height};margin:0 auto;background-color: rgb(255, 255, 255);border: none;`;
71
+ target.appendChild(iframe);
72
+ target.style.display = 'block';
73
+ return new Promise((resolve, reject) => {
74
+ iframe.onload = function () {
75
+ try {
76
+ const windowLocation = window.location;
77
+ const iframeLocation = iframe.contentWindow.location;
78
+ if (iframeLocation.host + iframeLocation.pathname === windowLocation.host + windowLocation.pathname) {
79
+ target.style.display = 'none';
80
+ const iframeUrlParams = new URLSearchParams(iframeLocation.search);
81
+ const captchToken = iframeUrlParams.get('captcha_token');
82
+ if (captchToken) {
83
+ return resolve({
84
+ captcha_token: captchToken,
85
+ expires_in: Number(iframeUrlParams.get('expires_in')),
86
+ });
190
87
  }
191
- return [3, 6];
192
- case 4: return [4, this.config.request(ApiUrls.CAPTCHA_DATA_URL, {
193
- method: 'POST',
194
- body: {
195
- state: state,
196
- redirect_uri: '',
197
- },
198
- withCredentials: false,
199
- })];
200
- case 5:
201
- captchaDataResp = _a.sent();
202
- captchaTokenResp = {
203
- url: "".concat(captchaDataResp.data, "?state=").concat(encodeURIComponent(state), "&token=").concat(encodeURIComponent(captchaDataResp.token)),
204
- };
205
- _a.label = 6;
206
- case 6: return [4, this.config.openURIWithCallback(captchaTokenResp.url)];
207
- case 7:
208
- captchaToken = _a.sent();
209
- this.saveCaptchaToken(captchaToken);
210
- return [2, captchaToken.captcha_token];
88
+ return reject({
89
+ error: iframeUrlParams.get('error'),
90
+ error_description: iframeUrlParams.get('error_description'),
91
+ });
92
+ }
93
+ target.style.display = 'block';
211
94
  }
212
- });
213
- });
214
- };
215
- Captcha.prototype.appendCaptchaTokenToURL = function (url, state, forceNewToken) {
216
- return __awaiter(this, void 0, void 0, function () {
217
- var captchaToken;
218
- return __generator(this, function (_a) {
219
- switch (_a.label) {
220
- case 0: return [4, this.getCaptchaToken(forceNewToken, state)];
221
- case 1:
222
- captchaToken = _a.sent();
223
- if (url.indexOf('?') > 0) {
224
- url += "&captcha_token=".concat(captchaToken);
225
- }
226
- else {
227
- url += "?captcha_token=".concat(captchaToken);
228
- }
229
- return [2, url];
95
+ catch (error) {
96
+ target.style.display = 'block';
230
97
  }
231
- });
98
+ };
232
99
  });
233
- };
234
- Captcha.prototype.saveCaptchaToken = function (token) {
235
- return __awaiter(this, void 0, void 0, function () {
236
- var tokenStr;
237
- return __generator(this, function (_a) {
238
- switch (_a.label) {
239
- case 0:
240
- token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000);
241
- tokenStr = JSON.stringify(token);
242
- return [4, this.config.storage.setItem(this.tokenSectionName, tokenStr)];
243
- case 1:
244
- _a.sent();
245
- return [2];
246
- }
100
+ }
101
+ async getCaptchaToken(forceNewToken, state) {
102
+ if (!forceNewToken) {
103
+ const captchaToken = await this.findCaptchaToken();
104
+ if (captchaToken) {
105
+ return captchaToken;
106
+ }
107
+ }
108
+ let captchaTokenResp;
109
+ if (!isMp() && !isInMpWebView()) {
110
+ const redirect_uri = `${window.location.origin + window.location.pathname}?__captcha=on`;
111
+ captchaTokenResp = await this.config.request(ApiUrls.GET_CAPTCHA_URL, {
112
+ method: 'POST',
113
+ body: {
114
+ client_id: this.config.clientId,
115
+ redirect_uri,
116
+ state,
117
+ },
118
+ withCredentials: false,
247
119
  });
248
- });
249
- };
250
- Captcha.prototype.findCaptchaToken = function () {
251
- return __awaiter(this, void 0, void 0, function () {
252
- var tokenStr, captchaToken, isExpired, error_1;
253
- return __generator(this, function (_a) {
254
- switch (_a.label) {
255
- case 0: return [4, this.config.storage.getItem(this.tokenSectionName)];
256
- case 1:
257
- tokenStr = _a.sent();
258
- if (!(tokenStr !== undefined && tokenStr !== null)) return [3, 5];
259
- _a.label = 2;
260
- case 2:
261
- _a.trys.push([2, 3, , 5]);
262
- captchaToken = JSON.parse(tokenStr);
263
- if (captchaToken === null || captchaToken === void 0 ? void 0 : captchaToken.expires_at) {
264
- captchaToken.expires_at = new Date(captchaToken.expires_at);
265
- }
266
- isExpired = captchaToken.expires_at < new Date();
267
- if (isExpired) {
268
- return [2, null];
269
- }
270
- return [2, captchaToken.captcha_token];
271
- case 3:
272
- error_1 = _a.sent();
273
- return [4, this.config.storage.removeItem(this.tokenSectionName)];
274
- case 4:
275
- _a.sent();
276
- return [2, null];
277
- case 5: return [2, null];
278
- }
120
+ if (captchaTokenResp.captcha_token) {
121
+ const captchaToken = {
122
+ captcha_token: captchaTokenResp.captcha_token,
123
+ expires_in: captchaTokenResp.expires_in,
124
+ };
125
+ this.saveCaptchaToken(captchaToken);
126
+ return captchaTokenResp.captcha_token;
127
+ }
128
+ }
129
+ else {
130
+ const captchaDataResp = await this.config.request(ApiUrls.CAPTCHA_DATA_URL, {
131
+ method: 'POST',
132
+ body: {
133
+ state,
134
+ redirect_uri: '',
135
+ },
136
+ withCredentials: false,
279
137
  });
280
- });
281
- };
282
- return Captcha;
283
- }());
284
- export { Captcha };
285
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"captcha.js","sourceRoot":"","sources":["../../../src/captcha/captcha.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApiUrls, ErrorType } from '../auth/consts'\nimport { SimpleStorage, RequestFunction } from '../oauth2client/interface'\nimport { AuthClientRequestOptions } from '../oauth2client/models'\nimport { defaultStorage } from '../oauth2client/oauth2client'\nimport { isInMpWebView, isMp } from '../utils/mp'\n\nexport interface CaptchaOptions {\n  clientId: string\n  request: RequestFunction\n  storage: SimpleStorage\n  // 打开网页并通过URL回调获取 CaptchaToken，针对不通的平台，该函数可以自定义实现, 默认集成浏览器端认证\n  openURIWithCallback?: OpenURIWithCallbackFuction\n}\n\ntype OpenURIWithCallbackFuction = (url: string) => Promise<CaptchaToken>\n\nexport interface CaptchaToken {\n  captcha_token: string\n  expires_in: number\n  expires_at?: Date | null\n}\n\nexport interface CaptchaRequestOptions extends AuthClientRequestOptions {\n  withCaptcha?: boolean\n}\n\nexport interface GetCaptchaResponse {\n  captcha_token?: string\n  expires_in?: number\n  url?: string\n}\n\nexport class Captcha {\n  private config: CaptchaOptions\n  private tokenSectionName: string\n\n  /**\n   * constructor\n   * @param {CaptchaOptions} opts\n   */\n  constructor(opts: CaptchaOptions) {\n    if (!opts.openURIWithCallback) {\n      opts.openURIWithCallback = this.getDefaultOpenURIWithCallback()\n    }\n    if (!opts.storage) {\n      opts.storage = defaultStorage\n    }\n\n    this.config = opts\n    this.tokenSectionName = `captcha_${opts.clientId}`\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>(url: string, options?: CaptchaRequestOptions): Promise<T> {\n    if (!options) {\n      options = {}\n    }\n    if (!options.method) {\n      options.method = 'GET'\n    }\n    const state = `${options.method}:${url}`\n    let reqURL = url\n    if (options.withCaptcha) {\n      reqURL = await this.appendCaptchaTokenToURL(url, state, false)\n    }\n\n    let resp: T\n    try {\n      resp = await this.config.request<T>(reqURL, options)\n    } catch (err) {\n      if (err.error === ErrorType.CAPTCHA_REQUIRED || err.error === ErrorType.CAPTCHA_INVALID) {\n        url = await this.appendCaptchaTokenToURL(url, state, err.error === ErrorType.CAPTCHA_INVALID)\n        return this.config.request<T>(url, options)\n      }\n      return Promise.reject(err)\n    }\n    return resp\n  }\n\n  private getDefaultOpenURIWithCallback(): OpenURIWithCallbackFuction {\n    if (!isMp() && !isInMpWebView()) {\n      if (window.location.search.indexOf('__captcha') > 0) {\n        document.body.style.display = 'none'\n      }\n      if (document.getElementById('captcha_panel_wrap') === null) {\n        const elementDiv = document.createElement('div')\n        elementDiv.style.cssText =          'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;'\n        elementDiv.setAttribute('id', 'captcha_panel_wrap')\n        setTimeout(() => {\n          document.body.appendChild(elementDiv)\n        }, 0)\n      }\n    }\n    return this.defaultOpenURIWithCallback\n  }\n\n  /**\n   * 默认通过浏览器打开网页并获取回调\n   */\n  private async defaultOpenURIWithCallback(\n    url: string,\n    opts?: { width?: string; height?: string },\n  ): Promise<CaptchaToken> {\n    const { width = '355px', height = '355px' } = opts || {}\n\n    const matched = url.match(/^(data:.*)$/)\n    if (matched) {\n      return Promise.reject({\n        error: ErrorType.UNIMPLEMENTED,\n        error_description: 'need to impl captcha data',\n      })\n    }\n\n    const target = document.getElementById('captcha_panel_wrap')\n    const iframe = document.createElement('iframe')\n    target.innerHTML = ''\n\n    iframe.setAttribute('src', url)\n    iframe.setAttribute('id', 'review-panel-iframe')\n    iframe.style.cssText = `min-width:${width};display:block;height:${height};margin:0 auto;background-color: rgb(255, 255, 255);border: none;`\n    target.appendChild(iframe)\n    target.style.display = 'block'\n    return new Promise<CaptchaToken>((resolve, reject) => {\n      iframe.onload = function () {\n        try {\n          const windowLocation = window.location\n          const iframeLocation = iframe.contentWindow.location\n          if (iframeLocation.host + iframeLocation.pathname === windowLocation.host + windowLocation.pathname) {\n            target.style.display = 'none'\n            const iframeUrlParams = new URLSearchParams(iframeLocation.search)\n            const captchToken = iframeUrlParams.get('captcha_token')\n            if (captchToken) {\n              return resolve({\n                captcha_token: captchToken,\n                expires_in: Number(iframeUrlParams.get('expires_in')),\n              })\n            }\n            return reject({\n              error: iframeUrlParams.get('error'),\n              error_description: iframeUrlParams.get('error_description'),\n            })\n          }\n          target.style.display = 'block'\n        } catch (error) {\n          target.style.display = 'block'\n        }\n      }\n    })\n  }\n  /**\n   * getCaptchaToken 获取captchaToken\n   */\n  private async getCaptchaToken(forceNewToken: boolean, state: string): Promise<string> {\n    if (!forceNewToken) {\n      // 如果本地存在，则直接返回\n      const captchaToken = await this.findCaptchaToken()\n      if (captchaToken) {\n        return captchaToken\n      }\n    }\n    let captchaTokenResp: {\n      url?: string\n      captcha_token?: string\n      expires_in?: number\n    }\n    if (!isMp() && !isInMpWebView()) {\n      const redirect_uri = `${window.location.origin + window.location.pathname}?__captcha=on`\n      captchaTokenResp = await this.config.request<GetCaptchaResponse>(ApiUrls.GET_CAPTCHA_URL, {\n        method: 'POST',\n        body: {\n          client_id: this.config.clientId,\n          redirect_uri,\n          state,\n        },\n        withCredentials: false,\n      })\n      if (captchaTokenResp.captcha_token) {\n        const captchaToken = {\n          captcha_token: captchaTokenResp.captcha_token,\n          expires_in: captchaTokenResp.expires_in,\n        }\n        this.saveCaptchaToken(captchaToken)\n        return captchaTokenResp.captcha_token\n      }\n    } else {\n      /**\n       * https://iwiki.woa.com/p/4010699417\n       */\n      const captchaDataResp = await this.config.request<{\n        data: string\n        type: 'image'\n        token: string\n        expires_in: number\n      }>(ApiUrls.CAPTCHA_DATA_URL, {\n        method: 'POST',\n        body: {\n          state,\n          redirect_uri: '',\n        },\n        withCredentials: false,\n      })\n      captchaTokenResp = {\n        url: `${captchaDataResp.data}?state=${encodeURIComponent(state)}&token=${encodeURIComponent(captchaDataResp.token,)}`,\n      }\n    }\n    const captchaToken = await this.config.openURIWithCallback(captchaTokenResp.url)\n    this.saveCaptchaToken(captchaToken)\n    return captchaToken.captcha_token\n  }\n\n  private async appendCaptchaTokenToURL(url: string, state: string, forceNewToken: boolean): Promise<string> {\n    const captchaToken = await this.getCaptchaToken(forceNewToken, state)\n    if (url.indexOf('?') > 0) {\n      url += `&captcha_token=${captchaToken}`\n    } else {\n      url += `?captcha_token=${captchaToken}`\n    }\n    return url\n  }\n\n  private async saveCaptchaToken(token: CaptchaToken) {\n    token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000)\n    const tokenStr: string = JSON.stringify(token)\n    await this.config.storage.setItem(this.tokenSectionName, tokenStr)\n  }\n\n  private async findCaptchaToken(): Promise<string> {\n    const tokenStr: string = await this.config.storage.getItem(this.tokenSectionName)\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        const captchaToken = JSON.parse(tokenStr)\n        if (captchaToken?.expires_at) {\n          captchaToken.expires_at = new Date(captchaToken.expires_at)\n        }\n        const isExpired = captchaToken.expires_at < new Date()\n        if (isExpired) {\n          return null\n        }\n        return captchaToken.captcha_token\n      } catch (error) {\n        await this.config.storage.removeItem(this.tokenSectionName)\n        return null\n      }\n    }\n    return null\n  }\n}\n"]}
138
+ captchaTokenResp = {
139
+ url: `${captchaDataResp.data}?state=${encodeURIComponent(state)}&token=${encodeURIComponent(captchaDataResp.token)}`,
140
+ };
141
+ }
142
+ const captchaToken = await this.config.openURIWithCallback(captchaTokenResp.url);
143
+ this.saveCaptchaToken(captchaToken);
144
+ return captchaToken.captcha_token;
145
+ }
146
+ async appendCaptchaTokenToURL(url, state, forceNewToken) {
147
+ const captchaToken = await this.getCaptchaToken(forceNewToken, state);
148
+ if (url.indexOf('?') > 0) {
149
+ url += `&captcha_token=${captchaToken}`;
150
+ }
151
+ else {
152
+ url += `?captcha_token=${captchaToken}`;
153
+ }
154
+ return url;
155
+ }
156
+ async saveCaptchaToken(token) {
157
+ token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000);
158
+ const tokenStr = JSON.stringify(token);
159
+ await this.config.storage.setItem(this.tokenSectionName, tokenStr);
160
+ }
161
+ async findCaptchaToken() {
162
+ const tokenStr = await this.config.storage.getItem(this.tokenSectionName);
163
+ if (tokenStr !== undefined && tokenStr !== null) {
164
+ try {
165
+ const captchaToken = JSON.parse(tokenStr);
166
+ if (captchaToken?.expires_at) {
167
+ captchaToken.expires_at = new Date(captchaToken.expires_at);
168
+ }
169
+ const isExpired = captchaToken.expires_at < new Date();
170
+ if (isExpired) {
171
+ return null;
172
+ }
173
+ return captchaToken.captcha_token;
174
+ }
175
+ catch (error) {
176
+ await this.config.storage.removeItem(this.tokenSectionName);
177
+ return null;
178
+ }
179
+ }
180
+ return null;
181
+ }
182
+ }
package/dist/esm/index.js CHANGED
@@ -1,14 +1,3 @@
1
- var __assign = (this && this.__assign) || function () {
2
- __assign = Object.assign || function(t) {
3
- for (var s, i = 1, n = arguments.length; i < n; i++) {
4
- s = arguments[i];
5
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
- t[p] = s[p];
7
- }
8
- return t;
9
- };
10
- return __assign.apply(this, arguments);
11
- };
12
1
  import { OAuth2Client } from './oauth2client/oauth2client';
13
2
  import { Auth } from './auth/apis';
14
3
  import * as authModels from './auth/models';
@@ -18,21 +7,22 @@ export { AuthClient } from './oauth2client/interface';
18
7
  export { Auth } from './auth/apis';
19
8
  export { authModels };
20
9
  export { ApiUrls } from './auth/consts';
21
- var CloudbaseOAuth = (function () {
22
- function CloudbaseOAuth(authOptions) {
23
- var apiOrigin = authOptions.apiOrigin, clientId = authOptions.clientId, env = authOptions.env, storage = authOptions.storage, request = authOptions.request, baseRequest = authOptions.baseRequest, anonymousSignInFunc = authOptions.anonymousSignInFunc, wxCloud = authOptions.wxCloud;
10
+ export class CloudbaseOAuth {
11
+ constructor(authOptions) {
12
+ const { apiOrigin, clientId, env, storage, request, baseRequest, anonymousSignInFunc, wxCloud } = authOptions;
24
13
  this.oauth2client = new OAuth2Client({
25
- apiOrigin: apiOrigin,
26
- clientId: clientId,
27
- env: env,
28
- storage: storage,
14
+ apiOrigin,
15
+ clientId,
16
+ env,
17
+ storage,
29
18
  baseRequest: baseRequest || request,
30
- anonymousSignInFunc: anonymousSignInFunc,
31
- wxCloud: wxCloud,
19
+ anonymousSignInFunc,
20
+ wxCloud,
21
+ });
22
+ this.authApi = new Auth({
23
+ credentialsClient: this.oauth2client,
24
+ ...authOptions,
25
+ request: request ? this.oauth2client.request.bind(this.oauth2client) : undefined,
32
26
  });
33
- this.authApi = new Auth(__assign(__assign({ credentialsClient: this.oauth2client }, authOptions), { request: request ? this.oauth2client.request.bind(this.oauth2client) : undefined }));
34
27
  }
35
- return CloudbaseOAuth;
36
- }());
37
- export { CloudbaseOAuth };
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUE7QUFFMUQsT0FBTyxFQUFlLElBQUksRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUUvQyxPQUFPLEtBQUssVUFBVSxNQUFNLGVBQWUsQ0FBQTtBQUUzQyxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBRXpELE9BQU8sRUFDTCxjQUFjLEVBQ2QsY0FBYyxFQUVkLGVBQWUsRUFDZixpQkFBaUIsRUFDakIsWUFBWSxHQUNiLE1BQU0sNkJBQTZCLENBQUE7QUFFcEMsT0FBTyxFQUFFLFVBQVUsRUFBaUIsTUFBTSwwQkFBMEIsQ0FBQTtBQUlwRSxPQUFPLEVBQWUsSUFBSSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQTtBQUNyQixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBR3ZDO0lBSUUsd0JBQVksV0FBd0I7UUFDMUIsSUFBQSxTQUFTLEdBQWlGLFdBQVcsVUFBNUYsRUFBRSxRQUFRLEdBQXVFLFdBQVcsU0FBbEYsRUFBRSxHQUFHLEdBQWtFLFdBQVcsSUFBN0UsRUFBRSxPQUFPLEdBQXlELFdBQVcsUUFBcEUsRUFBRSxPQUFPLEdBQWdELFdBQVcsUUFBM0QsRUFBRSxXQUFXLEdBQW1DLFdBQVcsWUFBOUMsRUFBRSxtQkFBbUIsR0FBYyxXQUFXLG9CQUF6QixFQUFFLE9BQU8sR0FBSyxXQUFXLFFBQWhCLENBQWdCO1FBQzdHLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxZQUFZLENBQUM7WUFDbkMsU0FBUyxXQUFBO1lBQ1QsUUFBUSxVQUFBO1lBQ1IsR0FBRyxLQUFBO1lBQ0gsT0FBTyxTQUFBO1lBQ1AsV0FBVyxFQUFFLFdBQVcsSUFBSSxPQUFPO1lBQ25DLG1CQUFtQixxQkFBQTtZQUNuQixPQUFPLFNBQUE7U0FDUixDQUFDLENBQUE7UUFFRixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksSUFBSSxxQkFDckIsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLFlBQVksSUFDakMsV0FBVyxLQUVkLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsSUFDaEYsQ0FBQTtJQUNKLENBQUM7SUFDSCxxQkFBQztBQUFELENBQUMsQUF2QkQsSUF1QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPQXV0aDJDbGllbnQgfSBmcm9tICcuL29hdXRoMmNsaWVudC9vYXV0aDJjbGllbnQnXG5cbmltcG9ydCB7IEF1dGhPcHRpb25zLCBBdXRoIH0gZnJvbSAnLi9hdXRoL2FwaXMnXG5cbmltcG9ydCAqIGFzIGF1dGhNb2RlbHMgZnJvbSAnLi9hdXRoL21vZGVscydcblxuZXhwb3J0IHsgU3ludGF4LCBFcnJvclR5cGUgfSBmcm9tICcuL29hdXRoMmNsaWVudC9jb25zdHMnXG5cbmV4cG9ydCB7XG4gIGRlZmF1bHRTdG9yYWdlLFxuICBkZWZhdWx0UmVxdWVzdCxcbiAgVG9SZXNwb25zZUVycm9yT3B0aW9ucyxcbiAgdG9SZXNwb25zZUVycm9yLFxuICBnZW5lcmF0ZVJlcXVlc3RJZCxcbiAgT0F1dGgyQ2xpZW50LFxufSBmcm9tICcuL29hdXRoMmNsaWVudC9vYXV0aDJjbGllbnQnXG5cbmV4cG9ydCB7IEF1dGhDbGllbnQsIFNpbXBsZVN0b3JhZ2UgfSBmcm9tICcuL29hdXRoMmNsaWVudC9pbnRlcmZhY2UnXG5cbmV4cG9ydCB7IENyZWRlbnRpYWxzLCBSZXNwb25zZUVycm9yLCBPQXV0aDJDbGllbnRPcHRpb25zLCBBdXRoQ2xpZW50UmVxdWVzdE9wdGlvbnMgfSBmcm9tICcuL29hdXRoMmNsaWVudC9tb2RlbHMnXG5cbmV4cG9ydCB7IEF1dGhPcHRpb25zLCBBdXRoIH0gZnJvbSAnLi9hdXRoL2FwaXMnXG5leHBvcnQgeyBhdXRoTW9kZWxzIH1cbmV4cG9ydCB7IEFwaVVybHMgfSBmcm9tICcuL2F1dGgvY29uc3RzJ1xuZXhwb3J0IHR5cGUgeyBQcm92aWRlclByb2ZpbGUgfSBmcm9tICcuL2F1dGgvbW9kZWxzJ1xuXG5leHBvcnQgY2xhc3MgQ2xvdWRiYXNlT0F1dGgge1xuICBwdWJsaWMgb2F1dGgyY2xpZW50OiBPQXV0aDJDbGllbnRcbiAgcHVibGljIGF1dGhBcGk6IEF1dGhcblxuICBjb25zdHJ1Y3RvcihhdXRoT3B0aW9uczogQXV0aE9wdGlvbnMpIHtcbiAgICBjb25zdCB7IGFwaU9yaWdpbiwgY2xpZW50SWQsIGVudiwgc3RvcmFnZSwgcmVxdWVzdCwgYmFzZVJlcXVlc3QsIGFub255bW91c1NpZ25JbkZ1bmMsIHd4Q2xvdWQgfSA9IGF1dGhPcHRpb25zXG4gICAgdGhpcy5vYXV0aDJjbGllbnQgPSBuZXcgT0F1dGgyQ2xpZW50KHtcbiAgICAgIGFwaU9yaWdpbixcbiAgICAgIGNsaWVudElkLFxuICAgICAgZW52LFxuICAgICAgc3RvcmFnZSxcbiAgICAgIGJhc2VSZXF1ZXN0OiBiYXNlUmVxdWVzdCB8fCByZXF1ZXN0LFxuICAgICAgYW5vbnltb3VzU2lnbkluRnVuYyxcbiAgICAgIHd4Q2xvdWQsXG4gICAgfSlcblxuICAgIHRoaXMuYXV0aEFwaSA9IG5ldyBBdXRoKHtcbiAgICAgIGNyZWRlbnRpYWxzQ2xpZW50OiB0aGlzLm9hdXRoMmNsaWVudCxcbiAgICAgIC4uLmF1dGhPcHRpb25zLFxuICAgICAgLy8g5YW85a656ICB6YC76L6R77yM5pyJ5YC85Lyg5YWl5YiZ5LiN6LWwQXV0aOWGheeahOmqjOivgeeggeivt+axgumAu+i+kVxuICAgICAgcmVxdWVzdDogcmVxdWVzdCA/IHRoaXMub2F1dGgyY2xpZW50LnJlcXVlc3QuYmluZCh0aGlzLm9hdXRoMmNsaWVudCkgOiB1bmRlZmluZWQsXG4gICAgfSlcbiAgfVxufVxuIl19
28
+ }
@@ -67,4 +67,3 @@ export var ErrorType;
67
67
  ErrorType["REQUEST_URI_NOT_SUPPORTED"] = "request_uri_not_supported";
68
68
  ErrorType["REGISTRATION_NOT_SUPPORTED"] = "registration_not_supported";
69
69
  })(ErrorType || (ErrorType = {}));
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL29hdXRoMmNsaWVudC9jb25zdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsTUFBTSxDQUFOLElBQVksTUFrQlg7QUFsQkQsV0FBWSxNQUFNO0lBQ2hCLGlDQUF1QixDQUFBO0lBQ3ZCLHlDQUErQixDQUFBO0lBQy9CLHlDQUErQixDQUFBO0lBQy9CLHlCQUFlLENBQUE7SUFDZix5QkFBZSxDQUFBO0lBQ2YsdUNBQTZCLENBQUE7SUFDN0IseUJBQWUsQ0FBQTtJQUNmLGlEQUF1QyxDQUFBO0lBQ3ZDLGlDQUF1QixDQUFBO0lBQ3ZCLG1DQUF5QixDQUFBO0lBQ3pCLHVCQUFhLENBQUE7SUFDYix1Q0FBNkIsQ0FBQTtJQUM3QixtQ0FBeUIsQ0FBQTtJQUN6QixtQ0FBeUIsQ0FBQTtJQUN6QiwrQkFBcUIsQ0FBQTtJQUNyQiwrQkFBcUIsQ0FBQTtJQUNyQix5Q0FBK0IsQ0FBQTtBQUNqQyxDQUFDLEVBbEJXLE1BQU0sS0FBTixNQUFNLFFBa0JqQjtBQUVELE1BQU0sQ0FBTixJQUFZLFNBZ0RYO0FBaERELFdBQVksU0FBUztJQUNuQix3Q0FBMkIsQ0FBQTtJQUMzQiw0QkFBZSxDQUFBO0lBQ2Ysb0NBQXVCLENBQUE7SUFDdkIsZ0NBQW1CLENBQUE7SUFDbkIsa0RBQXFDLENBQUE7SUFDckMsb0RBQXVDLENBQUE7SUFDdkMsb0NBQXVCLENBQUE7SUFDdkIsOENBQWlDLENBQUE7SUFDakMsb0RBQXVDLENBQUE7SUFDdkMsZ0RBQW1DLENBQUE7SUFDbkMsc0RBQXlDLENBQUE7SUFDekMsd0RBQTJDLENBQUE7SUFDM0MsZ0NBQW1CLENBQUE7SUFDbkIsMENBQTZCLENBQUE7SUFDN0IsNENBQStCLENBQUE7SUFDL0Isa0NBQXFCLENBQUE7SUFDckIsd0NBQTJCLENBQUE7SUFDM0Isb0NBQXVCLENBQUE7SUFFdkIsa0RBQThDLENBQUE7SUFDOUMsZ0RBQTRDLENBQUE7SUFDNUMsa0RBQXFDLENBQUE7SUFDckMsOENBQWlDLENBQUE7SUFDakMsMENBQTZCLENBQUE7SUFDN0IsMENBQTZCLENBQUE7SUFDN0Isb0VBQXVELENBQUE7SUFDdkQsd0RBQTJDLENBQUE7SUFDM0Msc0RBQXlDLENBQUE7SUFDekMsd0VBQTJELENBQUE7SUFDM0QsMENBQTZCLENBQUE7SUFDN0IsZ0RBQW1DLENBQUE7SUFDbkMsd0RBQTJDLENBQUE7SUFDM0MsNENBQStCLENBQUE7SUFDL0Isb0VBQXVELENBQUE7SUFDdkQsNENBQStCLENBQUE7SUFDL0IsNENBQStCLENBQUE7SUFDL0IsMENBQTZCLENBQUE7SUFDN0IsZ0VBQW1ELENBQUE7SUFDbkQsMERBQTZDLENBQUE7SUFDN0MsOENBQWlDLENBQUE7SUFDakMsc0VBQXlELENBQUE7SUFDekQsa0RBQXFDLENBQUE7SUFDckMsd0RBQTJDLENBQUE7SUFDM0MsOERBQWlELENBQUE7SUFDakQsNERBQStDLENBQUE7SUFDL0Msb0VBQXVELENBQUE7SUFDdkQsc0VBQXlELENBQUE7QUFDM0QsQ0FBQyxFQWhEVyxTQUFTLEtBQVQsU0FBUyxRQWdEcEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFcnJvclR5cGUgYXMgX0Vycm9yVHlwZSB9IGZyb20gJy4uL2F1dGgvY29uc3RzJ1xuZXhwb3J0IGVudW0gU3ludGF4IHtcbiAgQ0xJRU5UX0lEID0gJ2NsaWVudF9pZCcsXG4gIENMSUVOVF9TRUNSRVQgPSAnY2xpZW50X3NlY3JldCcsXG4gIFJFU1BPTlNFX1RZUEUgPSAncmVzcG9uc2VfdHlwZScsXG4gIFNDT1BFID0gJ3Njb3BlJyxcbiAgU1RBVEUgPSAnc3RhdGUnLFxuICBSRURJUkVDVF9VUkkgPSAncmVkaXJlY3RfdXJpJyxcbiAgRVJST1IgPSAnZXJyb3InLFxuICBFUlJPUl9ERVNDUklQVElPTiA9ICdlcnJvcl9kZXNjcmlwdGlvbicsXG4gIEVSUk9SX1VSSSA9ICdlcnJvcl91cmknLFxuICBHUkFOVF9UWVBFID0gJ2dyYW50X3R5cGUnLFxuICBDT0RFID0gJ2NvZGUnLFxuICBBQ0NFU1NfVE9LRU4gPSAnYWNjZXNzX3Rva2VuJyxcbiAgVE9LRU5fVFlQRSA9ICd0b2tlbl90eXBlJyxcbiAgRVhQSVJFU19JTiA9ICdleHBpcmVzX2luJyxcbiAgVVNFUk5BTUUgPSAndXNlcm5hbWUnLFxuICBQQVNTV09SRCA9ICdwYXNzd29yZCcsXG4gIFJFRlJFU0hfVE9LRU4gPSAncmVmcmVzaF90b2tlbicsXG59XG5cbmV4cG9ydCBlbnVtIEVycm9yVHlwZSB7XG4gIFVOUkVBQ0hBQkxFID0gJ3VucmVhY2hhYmxlJyxcbiAgTE9DQUwgPSAnbG9jYWwnLFxuICBDQU5DRUxMRUQgPSAnY2FuY2VsbGVkJyxcbiAgVU5LTk9XTiA9ICd1bmtub3duJyxcbiAgSU5WQUxJRF9BUkdVTUVOVCA9ICdpbnZhbGlkX2FyZ3VtZW50JyxcbiAgREVBRExJTkVfRVhDRUVERUQgPSAnZGVhZGxpbmVfZXhjZWVkZWQnLFxuICBOT1RfRk9VTkQgPSAnbm90X2ZvdW5kJyxcbiAgQUxSRUFEWV9FWElTVFMgPSAnYWxyZWFkeV9leGlzdHMnLFxuICBQRVJNSVNTSU9OX0RFTklFRCA9ICdwZXJtaXNzaW9uX2RlbmllZCcsXG4gIFVOQVVUSEVOVElDQVRFRCA9ICd1bmF1dGhlbnRpY2F0ZWQnLFxuICBSRVNPVVJDRV9FWEhBVVNURUQgPSAncmVzb3VyY2VfZXhoYXVzdGVkJyxcbiAgRkFJTEVEX1BSRUNPTkRJVElPTiA9ICdmYWlsZWRfcHJlY29uZGl0aW9uJyxcbiAgQUJPUlRFRCA9ICdhYm9ydGVkJyxcbiAgT1VUX09GX1JBTkdFID0gJ291dF9vZl9yYW5nZScsXG4gIFVOSU1QTEVNRU5URUQgPSAndW5pbXBsZW1lbnRlZCcsXG4gIElOVEVSTkFMID0gJ2ludGVybmFsJyxcbiAgVU5BVkFJTEFCTEUgPSAndW5hdmFpbGFibGUnLFxuICBEQVRBX0xPU1MgPSAnZGF0YV9sb3NzJyxcbiAgLy8gQ29tbW9uRXJyb3JcbiAgQ0FQVENIQV9SRVFVSVJFRCA9IF9FcnJvclR5cGUuQ0FQVENIQV9SRVFVSVJFRCxcbiAgQ0FQVENIQV9JTlZBTElEID0gX0Vycm9yVHlwZS5DQVBUQ0hBX0lOVkFMSUQsXG4gIElOVkFMSURfUEFTU1dPUkQgPSAnaW52YWxpZF9wYXNzd29yZCcsXG4gIElOVkFMSURfU1RBVFVTID0gJ2ludmFsaWRfc3RhdHVzJyxcbiAgVVNFUl9QRU5ESU5HID0gJ3VzZXJfcGVuZGluZycsXG4gIFVTRVJfQkxPQ0tFRCA9ICd1c2VyX2Jsb2NrZWQnLFxuICBJTlZBTElEX1ZFUklGSUNBVElPTl9DT0RFID0gJ2ludmFsaWRfdmVyaWZpY2F0aW9uX2NvZGUnLFxuICBUV09fRkFDVE9SX1JFUVVJUkVEID0gJ3R3b19mYWN0b3JfcmVxdWlyZWQnLFxuICBJTlZBTElEX1RXT19GQUNUT1IgPSAnaW52YWxpZF90d29fZmFjdG9yJyxcbiAgSU5WQUxJRF9UV09fRkFDVE9SX1JFQ09WRVJZID0gJ2ludmFsaWRfdHdvX2ZhY3Rvcl9yZWNvdmVyeScsXG4gIFVOREVSX1JFVklFVyA9ICd1bmRlcl9yZXZpZXcnLFxuICBJTlZBTElEX1JFUVVFU1QgPSAnaW52YWxpZF9yZXF1ZXN0JyxcbiAgVU5BVVRIT1JJWkVEX0NMSUVOVCA9ICd1bmF1dGhvcml6ZWRfY2xpZW50JyxcbiAgQUNDRVNTX0RFTklFRCA9ICdhY2Nlc3NfZGVuaWVkJyxcbiAgVU5TVVBQT1JURURfUkVTUE9OU0VfVFlQRSA9ICd1bnN1cHBvcnRlZF9yZXNwb25zZV90eXBlJyxcbiAgSU5WQUxJRF9TQ09QRSA9ICdpbnZhbGlkX3Njb3BlJyxcbiAgSU5WQUxJRF9HUkFOVCA9ICdpbnZhbGlkX2dyYW50JyxcbiAgU0VSVkVSX0VSUk9SID0gJ3NlcnZlcl9lcnJvcicsXG4gIFRFTVBPUkFSSUxZX1VOQVZBSUxBQkxFID0gJ3RlbXBvcmFyaWx5X3VuYXZhaWxhYmxlJyxcbiAgSU5URVJBQ1RJT05fUkVRVUlSRUQgPSAnaW50ZXJhY3Rpb25fcmVxdWlyZWQnLFxuICBMT0dJTl9SRVFVSVJFRCA9ICdsb2dpbl9yZXF1aXJlZCcsXG4gIEFDQ09VTlRfU0VMRUNUSU9OX1JFUVVJUkVEID0gJ2FjY291bnRfc2VsZWN0aW9uX3JlcXVpcmVkJyxcbiAgQ09OU0VOVF9SRVFVSVJFRCA9ICdjb25zZW50X3JlcXVpcmVkJyxcbiAgSU5WQUxJRF9SRVFVRVNUX1VSSSA9ICdpbnZhbGlkX3JlcXVlc3RfdXJpJyxcbiAgSU5WQUxJRF9SRVFVRVNUX09CSkVDVCA9ICdpbnZhbGlkX3JlcXVlc3Rfb2JqZWN0JyxcbiAgUkVRVUVTVF9OT1RfU1VQUE9SVEVEID0gJ3JlcXVlc3Rfbm90X3N1cHBvcnRlZCcsXG4gIFJFUVVFU1RfVVJJX05PVF9TVVBQT1JURUQgPSAncmVxdWVzdF91cmlfbm90X3N1cHBvcnRlZCcsXG4gIFJFR0lTVFJBVElPTl9OT1RfU1VQUE9SVEVEID0gJ3JlZ2lzdHJhdGlvbl9ub3Rfc3VwcG9ydGVkJyxcbn1cbiJdfQ==