ngx-webauthn 0.0.2

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.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ngx-webauthn.mjs","sources":["../tmp-esm2022/lib/models/register-config.models.js","../tmp-esm2022/lib/presets/webauthn.presets.js","../tmp-esm2022/lib/utils/preset.utils.js","../tmp-esm2022/lib/errors/webauthn.errors.js","../tmp-esm2022/lib/config/webauthn.config.js","../tmp-esm2022/lib/utils/webauthn.utils.js","../tmp-esm2022/lib/services/webauthn.service.js","../tmp-esm2022/lib/providers/webauthn.providers.js","../tmp-esm2022/index.js","../tmp-esm2022/ngx-webauthn.js"],"sourcesContent":["/**\n * High-level configuration interfaces for WebAuthn operations\n *\n * These interfaces provide a convenient, preset-driven API while still allowing\n * full customization through override properties. They derive from standard WebAuthn\n * types where possible to reduce duplication and ensure compatibility.\n */\n/**\n * Type guard to check if input is a RegisterConfig\n */\nexport function isRegisterConfig(input) {\n return typeof input === 'object' && input !== null && 'username' in input;\n}\n/**\n * Type guard to check if input is an AuthenticateConfig\n */\nexport function isAuthenticateConfig(input) {\n return (typeof input === 'object' &&\n input !== null &&\n ('username' in input || 'preset' in input) &&\n !('rp' in input) && // WebAuthn options have 'rp'\n !('user' in input)); // WebAuthn options have 'user'\n}\n/**\n * Type guard to check if input is WebAuthn creation options\n */\nexport function isCreationOptions(input) {\n return (typeof input === 'object' &&\n input !== null &&\n 'rp' in input &&\n 'user' in input);\n}\n/**\n * Type guard to check if input is WebAuthn request options\n */\nexport function isRequestOptions(input) {\n return (typeof input === 'object' &&\n input !== null &&\n !('username' in input) &&\n !('rp' in input) &&\n !('user' in input));\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-config.models.js","sourceRoot":"","sources":["../../../../../../libs/ngx-webauthn/src/lib/models/register-config.models.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAsKH;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,KAAc;IAC7C,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,UAAU,IAAI,KAAK,CAAC;AAC5E,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAClC,KAAc;IAEd,OAAO,CACL,OAAO,KAAK,KAAK,QAAQ;QACzB,KAAK,KAAK,IAAI;QACd,CAAC,UAAU,IAAI,KAAK,IAAI,QAAQ,IAAI,KAAK,CAAC;QAC1C,CAAC,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,6BAA6B;QACjD,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,CACnB,CAAC,CAAC,+BAA+B;AACpC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,iBAAiB,CAC/B,KAAc;IAId,OAAO,CACL,OAAO,KAAK,KAAK,QAAQ;QACzB,KAAK,KAAK,IAAI;QACd,IAAI,IAAI,KAAK;QACb,MAAM,IAAI,KAAK,CAChB,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAC9B,KAAc;IAId,OAAO,CACL,OAAO,KAAK,KAAK,QAAQ;QACzB,KAAK,KAAK,IAAI;QACd,CAAC,CAAC,UAAU,IAAI,KAAK,CAAC;QACtB,CAAC,CAAC,IAAI,IAAI,KAAK,CAAC;QAChB,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,CACnB,CAAC;AACJ,CAAC","sourcesContent":["/**\r\n * High-level configuration interfaces for WebAuthn operations\r\n *\r\n * These interfaces provide a convenient, preset-driven API while still allowing\r\n * full customization through override properties. They derive from standard WebAuthn\r\n * types where possible to reduce duplication and ensure compatibility.\r\n */\r\n\r\nimport type { PresetName } from '../presets/webauthn.presets';\r\n\r\n// Re-export PresetName for convenience\r\nexport type { PresetName } from '../presets/webauthn.presets';\r\n\r\n/**\r\n * Relying party configuration using standard WebAuthn type\r\n * No duplication needed - uses PublicKeyCredentialRpEntity directly\r\n */\r\nexport type EnhancedRelyingParty = PublicKeyCredentialRpEntity;\r\n\r\n/**\r\n * Flexible user identifier that can be a string or Uint8Array\r\n * Provides better DX while maintaining compatibility with WebAuthn standards\r\n */\r\nexport type FlexibleUserId = string | Uint8Array;\r\n\r\n/**\r\n * Flexible challenge that can be a string or Uint8Array\r\n * Provides better DX while maintaining compatibility with WebAuthn standards\r\n */\r\nexport type FlexibleChallenge = string | Uint8Array;\r\n\r\n/**\r\n * Flexible credential descriptors that can be either full descriptors or just ID strings\r\n * Provides better DX for common use cases while maintaining full flexibility\r\n */\r\nexport type FlexibleCredentialDescriptors =\r\n  | PublicKeyCredentialDescriptor[]\r\n  | string[];\r\n\r\n/**\r\n * Configuration for WebAuthn credential registration\r\n *\r\n * This interface extends standard WebAuthn types with preset support and enhanced UX.\r\n * It derives from PublicKeyCredentialCreationOptions where possible to avoid duplication.\r\n */\r\nexport interface RegisterConfig\r\n  extends Partial<\r\n    Pick<\r\n      PublicKeyCredentialCreationOptions,\r\n      | 'timeout'\r\n      | 'attestation'\r\n      | 'authenticatorSelection'\r\n      | 'pubKeyCredParams'\r\n      | 'extensions'\r\n    >\r\n  > {\r\n  /**\r\n   * Username for the credential\r\n   * This is used to generate the user.name and user.id if not explicitly provided\r\n   */\r\n  username: string;\r\n\r\n  /**\r\n   * Optional preset to use as base configuration\r\n   * - 'passkey': Modern passwordless, cross-device credentials\r\n   * - 'secondFactor': Security key as second factor after password\r\n   * - 'deviceBound': High-security, device-bound credentials\r\n   */\r\n  preset?: PresetName;\r\n\r\n  /**\r\n   * Display name for the user (optional override)\r\n   * If not provided, defaults to the username\r\n   */\r\n  displayName?: string;\r\n\r\n  /**\r\n   * Relying Party configuration (optional override)\r\n   * If not provided, will need to be set by the application or service\r\n   * Uses standard PublicKeyCredentialRpEntity structure\r\n   */\r\n  rp?: EnhancedRelyingParty;\r\n\r\n  /**\r\n   * Challenge for the registration (optional override)\r\n   * If not provided, a secure random challenge will be generated\r\n   * Can be either base64url string or Uint8Array for better DX\r\n   */\r\n  challenge?: FlexibleChallenge;\r\n\r\n  /**\r\n   * Credentials to exclude from registration (optional override)\r\n   * Can be an array of credential IDs (base64url strings) or full descriptors\r\n   * Enhanced to accept simple string arrays for better DX\r\n   */\r\n  excludeCredentials?: FlexibleCredentialDescriptors;\r\n\r\n  /**\r\n   * User ID override (optional)\r\n   * If not provided, a user ID will be generated from the username\r\n   * Can be either base64url string or Uint8Array for better DX\r\n   */\r\n  userId?: FlexibleUserId;\r\n\r\n  // All other properties (timeout, attestation, authenticatorSelection,\r\n  // pubKeyCredParams, extensions) are inherited from the Partial<Pick<...>>\r\n  // This eliminates duplication while maintaining full type safety\r\n}\r\n\r\n/**\r\n * Configuration for WebAuthn authentication\r\n *\r\n * This interface extends standard WebAuthn types with preset support and enhanced UX.\r\n * It derives from PublicKeyCredentialRequestOptions where possible to avoid duplication.\r\n */\r\nexport interface AuthenticateConfig\r\n  extends Partial<\r\n    Pick<\r\n      PublicKeyCredentialRequestOptions,\r\n      'timeout' | 'userVerification' | 'extensions'\r\n    >\r\n  > {\r\n  /**\r\n   * Optional username hint for discoverable credentials\r\n   * Not required for authentication, but can be used for user experience\r\n   */\r\n  username?: string;\r\n\r\n  /**\r\n   * Optional preset to use as base configuration\r\n   * Affects user verification and other authentication parameters\r\n   */\r\n  preset?: PresetName;\r\n\r\n  /**\r\n   * Challenge for the authentication (optional override)\r\n   * If not provided, a secure random challenge will be generated\r\n   * Can be either base64url string or Uint8Array for better DX\r\n   */\r\n  challenge?: FlexibleChallenge;\r\n\r\n  /**\r\n   * Specific credentials to allow for authentication (optional override)\r\n   * Can be an array of credential IDs (base64url strings) or full descriptors\r\n   * If not provided, allows any credential (discoverable credential flow)\r\n   * Enhanced to accept simple string arrays for better DX\r\n   */\r\n  allowCredentials?: FlexibleCredentialDescriptors;\r\n\r\n  // All other properties (timeout, userVerification, extensions) are inherited\r\n  // from the Partial<Pick<...>> This eliminates duplication while maintaining\r\n  // full type safety and compatibility with standard WebAuthn types\r\n}\r\n\r\n/**\r\n * Union type for all possible register inputs\r\n * Supports both high-level config and direct WebAuthn options\r\n */\r\nexport type RegisterInput =\r\n  | RegisterConfig\r\n  | PublicKeyCredentialCreationOptions\r\n  | PublicKeyCredentialCreationOptionsJSON;\r\n\r\n/**\r\n * Union type for all possible authenticate inputs\r\n * Supports both high-level config and direct WebAuthn options\r\n */\r\nexport type AuthenticateInput =\r\n  | AuthenticateConfig\r\n  | PublicKeyCredentialRequestOptions\r\n  | PublicKeyCredentialRequestOptionsJSON;\r\n\r\n/**\r\n * Type guard to check if input is a RegisterConfig\r\n */\r\nexport function isRegisterConfig(input: unknown): input is RegisterConfig {\r\n  return typeof input === 'object' && input !== null && 'username' in input;\r\n}\r\n\r\n/**\r\n * Type guard to check if input is an AuthenticateConfig\r\n */\r\nexport function isAuthenticateConfig(\r\n  input: unknown\r\n): input is AuthenticateConfig {\r\n  return (\r\n    typeof input === 'object' &&\r\n    input !== null &&\r\n    ('username' in input || 'preset' in input) &&\r\n    !('rp' in input) && // WebAuthn options have 'rp'\r\n    !('user' in input)\r\n  ); // WebAuthn options have 'user'\r\n}\r\n\r\n/**\r\n * Type guard to check if input is WebAuthn creation options\r\n */\r\nexport function isCreationOptions(\r\n  input: unknown\r\n): input is\r\n  | PublicKeyCredentialCreationOptions\r\n  | PublicKeyCredentialCreationOptionsJSON {\r\n  return (\r\n    typeof input === 'object' &&\r\n    input !== null &&\r\n    'rp' in input &&\r\n    'user' in input\r\n  );\r\n}\r\n\r\n/**\r\n * Type guard to check if input is WebAuthn request options\r\n */\r\nexport function isRequestOptions(\r\n  input: unknown\r\n): input is\r\n  | PublicKeyCredentialRequestOptions\r\n  | PublicKeyCredentialRequestOptionsJSON {\r\n  return (\r\n    typeof input === 'object' &&\r\n    input !== null &&\r\n    !('username' in input) &&\r\n    !('rp' in input) &&\r\n    !('user' in input)\r\n  );\r\n}\r\n"]}","/**\n * WebAuthn Preset Configurations\n *\n * This file contains predefined configurations for common WebAuthn use cases.\n * These presets provide sensible defaults while remaining fully customizable.\n */\n/**\n * A shared configuration for common, strong, and widely-supported\n * public key credential algorithms.\n */\nexport const COMMON_PUB_KEY_CRED_PARAMS = {\n pubKeyCredParams: [\n { type: 'public-key', alg: -7 }, // ES256 (ECDSA w/ SHA-256)\n { type: 'public-key', alg: -257 }, // RS256 (RSASSA-PKCS1-v1_5 w/ SHA-256)\n ],\n};\n/**\n * Preset for modern, passwordless, cross-device credentials.\n *\n * Best for: Passkey-based authentication where users can sync credentials\n * across devices and use them for passwordless login.\n *\n * Features:\n * - Requires resident keys (discoverable credentials)\n * - Prefers user verification but doesn't require it\n * - Works with both platform and cross-platform authenticators\n * - Supports credential syncing across devices\n */\nexport const PASSKEY_PRESET = {\n ...COMMON_PUB_KEY_CRED_PARAMS,\n authenticatorSelection: {\n residentKey: 'required',\n userVerification: 'preferred',\n },\n};\n/**\n * Preset for using a security key as a second factor after a password.\n *\n * Best for: Traditional 2FA scenarios where users already have a password\n * and want to add hardware security key as a second factor.\n *\n * Features:\n * - Discourages resident keys (server-side credential storage)\n * - Prefers user verification\n * - Favors cross-platform authenticators (USB/NFC security keys)\n * - Credentials typically not synced between devices\n */\nexport const SECOND_FACTOR_PRESET = {\n ...COMMON_PUB_KEY_CRED_PARAMS,\n authenticatorSelection: {\n residentKey: 'discouraged',\n userVerification: 'preferred',\n authenticatorAttachment: 'cross-platform',\n },\n};\n/**\n * Preset for high-security, non-synced, single-device credentials.\n *\n * Best for: High-security scenarios where credentials must stay on a single\n * device and user verification is mandatory.\n *\n * Features:\n * - Requires platform authenticators (built-in biometrics/PIN)\n * - Requires resident keys for discoverability\n * - Requires user verification (biometric/PIN)\n * - Credentials bound to specific device (no syncing)\n */\nexport const DEVICE_BOUND_PRESET = {\n ...COMMON_PUB_KEY_CRED_PARAMS,\n authenticatorSelection: {\n authenticatorAttachment: 'platform',\n residentKey: 'required',\n userVerification: 'required',\n },\n};\n/**\n * Map of preset names to their configurations\n * Used internally for preset resolution\n */\nexport const PRESET_MAP = {\n passkey: PASSKEY_PRESET,\n secondFactor: SECOND_FACTOR_PRESET,\n deviceBound: DEVICE_BOUND_PRESET,\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViYXV0aG4ucHJlc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmd4LXdlYmF1dGhuL3NyYy9saWIvcHJlc2V0cy93ZWJhdXRobi5wcmVzZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OztHQUtHO0FBRUg7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sMEJBQTBCLEdBQUc7SUFDeEMsZ0JBQWdCLEVBQUU7UUFDaEIsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFLDJCQUEyQjtRQUM1RCxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxFQUFFLEVBQUUsdUNBQXVDO0tBQzNFO0NBQ08sQ0FBQztBQUVYOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHO0lBQzVCLEdBQUcsMEJBQTBCO0lBQzdCLHNCQUFzQixFQUFFO1FBQ3RCLFdBQVcsRUFBRSxVQUFVO1FBQ3ZCLGdCQUFnQixFQUFFLFdBQVc7S0FDOUI7Q0FDTyxDQUFDO0FBRVg7Ozs7Ozs7Ozs7O0dBV0c7QUFDSCxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRztJQUNsQyxHQUFHLDBCQUEwQjtJQUM3QixzQkFBc0IsRUFBRTtRQUN0QixXQUFXLEVBQUUsYUFBYTtRQUMxQixnQkFBZ0IsRUFBRSxXQUFXO1FBQzdCLHVCQUF1QixFQUFFLGdCQUFnQjtLQUMxQztDQUNPLENBQUM7QUFFWDs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHO0lBQ2pDLEdBQUcsMEJBQTBCO0lBQzdCLHNCQUFzQixFQUFFO1FBQ3RCLHVCQUF1QixFQUFFLFVBQVU7UUFDbkMsV0FBVyxFQUFFLFVBQVU7UUFDdkIsZ0JBQWdCLEVBQUUsVUFBVTtLQUM3QjtDQUNPLENBQUM7QUFFWDs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsT0FBTyxFQUFFLGNBQWM7SUFDdkIsWUFBWSxFQUFFLG9CQUFvQjtJQUNsQyxXQUFXLEVBQUUsbUJBQW1CO0NBQ3hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogV2ViQXV0aG4gUHJlc2V0IENvbmZpZ3VyYXRpb25zXHJcbiAqXHJcbiAqIFRoaXMgZmlsZSBjb250YWlucyBwcmVkZWZpbmVkIGNvbmZpZ3VyYXRpb25zIGZvciBjb21tb24gV2ViQXV0aG4gdXNlIGNhc2VzLlxyXG4gKiBUaGVzZSBwcmVzZXRzIHByb3ZpZGUgc2Vuc2libGUgZGVmYXVsdHMgd2hpbGUgcmVtYWluaW5nIGZ1bGx5IGN1c3RvbWl6YWJsZS5cclxuICovXHJcblxyXG4vKipcclxuICogQSBzaGFyZWQgY29uZmlndXJhdGlvbiBmb3IgY29tbW9uLCBzdHJvbmcsIGFuZCB3aWRlbHktc3VwcG9ydGVkXHJcbiAqIHB1YmxpYyBrZXkgY3JlZGVudGlhbCBhbGdvcml0aG1zLlxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IENPTU1PTl9QVUJfS0VZX0NSRURfUEFSQU1TID0ge1xyXG4gIHB1YktleUNyZWRQYXJhbXM6IFtcclxuICAgIHsgdHlwZTogJ3B1YmxpYy1rZXknLCBhbGc6IC03IH0sIC8vIEVTMjU2IChFQ0RTQSB3LyBTSEEtMjU2KVxyXG4gICAgeyB0eXBlOiAncHVibGljLWtleScsIGFsZzogLTI1NyB9LCAvLyBSUzI1NiAoUlNBU1NBLVBLQ1MxLXYxXzUgdy8gU0hBLTI1NilcclxuICBdLFxyXG59IGFzIGNvbnN0O1xyXG5cclxuLyoqXHJcbiAqIFByZXNldCBmb3IgbW9kZXJuLCBwYXNzd29yZGxlc3MsIGNyb3NzLWRldmljZSBjcmVkZW50aWFscy5cclxuICpcclxuICogQmVzdCBmb3I6IFBhc3NrZXktYmFzZWQgYXV0aGVudGljYXRpb24gd2hlcmUgdXNlcnMgY2FuIHN5bmMgY3JlZGVudGlhbHNcclxuICogYWNyb3NzIGRldmljZXMgYW5kIHVzZSB0aGVtIGZvciBwYXNzd29yZGxlc3MgbG9naW4uXHJcbiAqXHJcbiAqIEZlYXR1cmVzOlxyXG4gKiAtIFJlcXVpcmVzIHJlc2lkZW50IGtleXMgKGRpc2NvdmVyYWJsZSBjcmVkZW50aWFscylcclxuICogLSBQcmVmZXJzIHVzZXIgdmVyaWZpY2F0aW9uIGJ1dCBkb2Vzbid0IHJlcXVpcmUgaXRcclxuICogLSBXb3JrcyB3aXRoIGJvdGggcGxhdGZvcm0gYW5kIGNyb3NzLXBsYXRmb3JtIGF1dGhlbnRpY2F0b3JzXHJcbiAqIC0gU3VwcG9ydHMgY3JlZGVudGlhbCBzeW5jaW5nIGFjcm9zcyBkZXZpY2VzXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgUEFTU0tFWV9QUkVTRVQgPSB7XHJcbiAgLi4uQ09NTU9OX1BVQl9LRVlfQ1JFRF9QQVJBTVMsXHJcbiAgYXV0aGVudGljYXRvclNlbGVjdGlvbjoge1xyXG4gICAgcmVzaWRlbnRLZXk6ICdyZXF1aXJlZCcsXHJcbiAgICB1c2VyVmVyaWZpY2F0aW9uOiAncHJlZmVycmVkJyxcclxuICB9LFxyXG59IGFzIGNvbnN0O1xyXG5cclxuLyoqXHJcbiAqIFByZXNldCBmb3IgdXNpbmcgYSBzZWN1cml0eSBrZXkgYXMgYSBzZWNvbmQgZmFjdG9yIGFmdGVyIGEgcGFzc3dvcmQuXHJcbiAqXHJcbiAqIEJlc3QgZm9yOiBUcmFkaXRpb25hbCAyRkEgc2NlbmFyaW9zIHdoZXJlIHVzZXJzIGFscmVhZHkgaGF2ZSBhIHBhc3N3b3JkXHJcbiAqIGFuZCB3YW50IHRvIGFkZCBoYXJkd2FyZSBzZWN1cml0eSBrZXkgYXMgYSBzZWNvbmQgZmFjdG9yLlxyXG4gKlxyXG4gKiBGZWF0dXJlczpcclxuICogLSBEaXNjb3VyYWdlcyByZXNpZGVudCBrZXlzIChzZXJ2ZXItc2lkZSBjcmVkZW50aWFsIHN0b3JhZ2UpXHJcbiAqIC0gUHJlZmVycyB1c2VyIHZlcmlmaWNhdGlvblxyXG4gKiAtIEZhdm9ycyBjcm9zcy1wbGF0Zm9ybSBhdXRoZW50aWNhdG9ycyAoVVNCL05GQyBzZWN1cml0eSBrZXlzKVxyXG4gKiAtIENyZWRlbnRpYWxzIHR5cGljYWxseSBub3Qgc3luY2VkIGJldHdlZW4gZGV2aWNlc1xyXG4gKi9cclxuZXhwb3J0IGNvbnN0IFNFQ09ORF9GQUNUT1JfUFJFU0VUID0ge1xyXG4gIC4uLkNPTU1PTl9QVUJfS0VZX0NSRURfUEFSQU1TLFxyXG4gIGF1dGhlbnRpY2F0b3JTZWxlY3Rpb246IHtcclxuICAgIHJlc2lkZW50S2V5OiAnZGlzY291cmFnZWQnLFxyXG4gICAgdXNlclZlcmlmaWNhdGlvbjogJ3ByZWZlcnJlZCcsXHJcbiAgICBhdXRoZW50aWNhdG9yQXR0YWNobWVudDogJ2Nyb3NzLXBsYXRmb3JtJyxcclxuICB9LFxyXG59IGFzIGNvbnN0O1xyXG5cclxuLyoqXHJcbiAqIFByZXNldCBmb3IgaGlnaC1zZWN1cml0eSwgbm9uLXN5bmNlZCwgc2luZ2xlLWRldmljZSBjcmVkZW50aWFscy5cclxuICpcclxuICogQmVzdCBmb3I6IEhpZ2gtc2VjdXJpdHkgc2NlbmFyaW9zIHdoZXJlIGNyZWRlbnRpYWxzIG11c3Qgc3RheSBvbiBhIHNpbmdsZVxyXG4gKiBkZXZpY2UgYW5kIHVzZXIgdmVyaWZpY2F0aW9uIGlzIG1hbmRhdG9yeS5cclxuICpcclxuICogRmVhdHVyZXM6XHJcbiAqIC0gUmVxdWlyZXMgcGxhdGZvcm0gYXV0aGVudGljYXRvcnMgKGJ1aWx0LWluIGJpb21ldHJpY3MvUElOKVxyXG4gKiAtIFJlcXVpcmVzIHJlc2lkZW50IGtleXMgZm9yIGRpc2NvdmVyYWJpbGl0eVxyXG4gKiAtIFJlcXVpcmVzIHVzZXIgdmVyaWZpY2F0aW9uIChiaW9tZXRyaWMvUElOKVxyXG4gKiAtIENyZWRlbnRpYWxzIGJvdW5kIHRvIHNwZWNpZmljIGRldmljZSAobm8gc3luY2luZylcclxuICovXHJcbmV4cG9ydCBjb25zdCBERVZJQ0VfQk9VTkRfUFJFU0VUID0ge1xyXG4gIC4uLkNPTU1PTl9QVUJfS0VZX0NSRURfUEFSQU1TLFxyXG4gIGF1dGhlbnRpY2F0b3JTZWxlY3Rpb246IHtcclxuICAgIGF1dGhlbnRpY2F0b3JBdHRhY2htZW50OiAncGxhdGZvcm0nLFxyXG4gICAgcmVzaWRlbnRLZXk6ICdyZXF1aXJlZCcsXHJcbiAgICB1c2VyVmVyaWZpY2F0aW9uOiAncmVxdWlyZWQnLFxyXG4gIH0sXHJcbn0gYXMgY29uc3Q7XHJcblxyXG4vKipcclxuICogTWFwIG9mIHByZXNldCBuYW1lcyB0byB0aGVpciBjb25maWd1cmF0aW9uc1xyXG4gKiBVc2VkIGludGVybmFsbHkgZm9yIHByZXNldCByZXNvbHV0aW9uXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgUFJFU0VUX01BUCA9IHtcclxuICBwYXNza2V5OiBQQVNTS0VZX1BSRVNFVCxcclxuICBzZWNvbmRGYWN0b3I6IFNFQ09ORF9GQUNUT1JfUFJFU0VULFxyXG4gIGRldmljZUJvdW5kOiBERVZJQ0VfQk9VTkRfUFJFU0VULFxyXG59IGFzIGNvbnN0O1xyXG5cclxuLyoqXHJcbiAqIEF2YWlsYWJsZSBwcmVzZXQgbmFtZXMgYXMgYSB1bmlvbiB0eXBlXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBQcmVzZXROYW1lID0ga2V5b2YgdHlwZW9mIFBSRVNFVF9NQVA7XHJcbiJdfQ==","/**\n * Utility functions for resolving and merging WebAuthn presets\n *\n * These utilities handle the logic of taking a RegisterConfig or AuthenticateConfig,\n * resolving any preset, and merging it with user overrides to produce final\n * WebAuthn options ready for the browser API.\n */\nimport { PRESET_MAP } from '../presets/webauthn.presets';\n/**\n * Deep merge utility that properly handles nested objects\n * Later properties override earlier ones\n */\nfunction deepMerge(target, ...sources) {\n if (!sources.length)\n return target;\n const source = sources.shift();\n if (isObject(target) && isObject(source)) {\n for (const key in source) {\n if (isObject(source[key])) {\n if (!target[key])\n Object.assign(target, { [key]: {} });\n deepMerge(target[key], source[key]);\n }\n else {\n Object.assign(target, { [key]: source[key] });\n }\n }\n }\n return deepMerge(target, ...sources);\n}\n/**\n * Check if a value is a plain object\n */\nfunction isObject(item) {\n return item && typeof item === 'object' && !Array.isArray(item);\n}\n/**\n * Generate a secure random challenge as Uint8Array\n */\nfunction generateChallenge() {\n return crypto.getRandomValues(new Uint8Array(32));\n}\n/**\n * Generate a user ID from username\n * Uses TextEncoder to convert username to Uint8Array for consistency\n */\nfunction generateUserId(username) {\n return new TextEncoder().encode(username);\n}\n/**\n * Convert challenge to appropriate format\n * Handles both string (base64url) and Uint8Array inputs\n */\nfunction processChallenge(challenge) {\n if (!challenge) {\n return generateChallenge();\n }\n if (typeof challenge === 'string') {\n // Assume base64url string, convert to Uint8Array\n return Uint8Array.from(atob(challenge.replace(/-/g, '+').replace(/_/g, '/')), (c) => c.charCodeAt(0));\n }\n return challenge;\n}\n/**\n * Convert user ID to appropriate format\n * Handles both string (base64url) and Uint8Array inputs\n */\nfunction processUserId(userId, username) {\n if (userId) {\n if (typeof userId === 'string') {\n // Assume base64url string, convert to Uint8Array\n return Uint8Array.from(atob(userId.replace(/-/g, '+').replace(/_/g, '/')), (c) => c.charCodeAt(0));\n }\n return userId;\n }\n if (username) {\n return generateUserId(username);\n }\n // Fallback to random ID\n return crypto.getRandomValues(new Uint8Array(16));\n}\n/**\n * Convert string credential IDs to PublicKeyCredentialDescriptor format\n */\nfunction processCredentialDescriptors(credentials) {\n if (!credentials || credentials.length === 0) {\n return undefined;\n }\n // If already in descriptor format, return as-is\n if (typeof credentials[0] === 'object' && 'type' in credentials[0]) {\n return credentials;\n }\n // Convert string IDs to descriptors\n return credentials.map((id) => ({\n type: 'public-key',\n id: Uint8Array.from(atob(id.replace(/-/g, '+').replace(/_/g, '/')), (c) => c.charCodeAt(0)),\n }));\n}\n/**\n * Resolve a preset configuration by name\n */\nexport function resolvePreset(presetName) {\n const preset = PRESET_MAP[presetName];\n if (!preset) {\n throw new Error(`Unknown preset: ${presetName}`);\n }\n return preset;\n}\n/**\n * Build complete PublicKeyCredentialCreationOptions from RegisterConfig\n * Now uses WebAuthnConfig for better defaults and relying party information\n */\nexport function buildCreationOptionsFromConfig(config, webAuthnConfig) {\n // Start with base configuration from WebAuthnConfig\n let options = {\n timeout: webAuthnConfig.defaultTimeout || 60000,\n attestation: webAuthnConfig.defaultAttestation || 'none',\n };\n // Apply preset if specified\n if (config.preset) {\n const preset = resolvePreset(config.preset);\n options = deepMerge(options, {\n authenticatorSelection: preset.authenticatorSelection,\n pubKeyCredParams: [...preset.pubKeyCredParams], // Convert readonly to mutable\n });\n }\n else {\n // Apply default authenticator selection from config\n if (webAuthnConfig.defaultAuthenticatorSelection) {\n options.authenticatorSelection =\n webAuthnConfig.defaultAuthenticatorSelection;\n }\n }\n // Apply user overrides\n if (config.timeout !== undefined) {\n options.timeout = config.timeout;\n }\n if (config.attestation !== undefined) {\n options.attestation = config.attestation;\n }\n if (config.authenticatorSelection !== undefined) {\n options.authenticatorSelection = deepMerge(options.authenticatorSelection || {}, config.authenticatorSelection);\n }\n if (config.pubKeyCredParams !== undefined) {\n options.pubKeyCredParams = config.pubKeyCredParams;\n }\n if (config.extensions !== undefined) {\n options.extensions = config.extensions;\n }\n // Handle required fields\n const challenge = processChallenge(config.challenge);\n const userId = processUserId(config.userId, config.username);\n // Use relying party from config, with user override capability\n const relyingParty = config.rp || webAuthnConfig.relyingParty;\n // Build final options\n const finalOptions = {\n ...options,\n rp: relyingParty,\n user: {\n id: userId,\n name: config.username,\n displayName: config.displayName || config.username,\n },\n challenge,\n pubKeyCredParams: options.pubKeyCredParams ||\n webAuthnConfig.defaultAlgorithms || [\n { type: 'public-key', alg: -7 }, // ES256\n { type: 'public-key', alg: -257 }, // RS256\n ],\n excludeCredentials: processCredentialDescriptors(config.excludeCredentials),\n };\n return finalOptions;\n}\n/**\n * Build complete PublicKeyCredentialRequestOptions from AuthenticateConfig\n * Now uses WebAuthnConfig for better defaults\n */\nexport function buildRequestOptionsFromConfig(config, webAuthnConfig) {\n // Start with base configuration from WebAuthnConfig\n const options = {\n timeout: webAuthnConfig.defaultTimeout || 60000,\n userVerification: webAuthnConfig.enforceUserVerification\n ? 'required'\n : 'preferred',\n };\n // Apply preset if specified\n if (config.preset) {\n const preset = resolvePreset(config.preset);\n // Extract relevant parts for authentication (userVerification from authenticatorSelection)\n if (preset.authenticatorSelection?.userVerification) {\n options.userVerification = preset.authenticatorSelection.userVerification;\n }\n }\n // Apply user overrides\n if (config.timeout !== undefined) {\n options.timeout = config.timeout;\n }\n if (config.userVerification !== undefined) {\n options.userVerification = config.userVerification;\n }\n if (config.extensions !== undefined) {\n options.extensions = config.extensions;\n }\n // Handle required fields\n const challenge = processChallenge(config.challenge);\n // Build final options\n const finalOptions = {\n ...options,\n challenge,\n allowCredentials: processCredentialDescriptors(config.allowCredentials),\n };\n return finalOptions;\n}\n/**\n * Validate that a RegisterConfig has all required fields\n */\nexport function validateRegisterConfig(config) {\n if (!config.username || typeof config.username !== 'string') {\n throw new Error('RegisterConfig must have a valid username');\n }\n if (config.preset && !PRESET_MAP[config.preset]) {\n throw new Error(`Invalid preset: ${config.preset}. Valid presets are: ${Object.keys(PRESET_MAP).join(', ')}`);\n }\n}\n/**\n * Validate that an AuthenticateConfig has all required fields\n */\nexport function validateAuthenticateConfig(config) {\n if (config.preset && !PRESET_MAP[config.preset]) {\n throw new Error(`Invalid preset: ${config.preset}. Valid presets are: ${Object.keys(PRESET_MAP).join(', ')}`);\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preset.utils.js","sourceRoot":"","sources":["../../../../../../libs/ngx-webauthn/src/lib/utils/preset.utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Utility functions for resolving and merging WebAuthn presets\r\n *\r\n * These utilities handle the logic of taking a RegisterConfig or AuthenticateConfig,\r\n * resolving any preset, and merging it with user overrides to produce final\r\n * WebAuthn options ready for the browser API.\r\n */\r\n\r\nimport { PRESET_MAP, type PresetName } from '../presets/webauthn.presets';\r\nimport type {\r\n  RegisterConfig,\r\n  AuthenticateConfig,\r\n} from '../models/register-config.models';\r\nimport type { WebAuthnConfig } from '../config/webauthn.config';\r\n\r\n/**\r\n * Deep merge utility that properly handles nested objects\r\n * Later properties override earlier ones\r\n */\r\nfunction deepMerge<T extends Record<string, any>>(\r\n  target: T,\r\n  ...sources: any[]\r\n): T {\r\n  if (!sources.length) return target;\r\n  const source = sources.shift();\r\n\r\n  if (isObject(target) && isObject(source)) {\r\n    for (const key in source) {\r\n      if (isObject(source[key])) {\r\n        if (!target[key]) Object.assign(target, { [key]: {} });\r\n        deepMerge(target[key], source[key]);\r\n      } else {\r\n        Object.assign(target, { [key]: source[key] });\r\n      }\r\n    }\r\n  }\r\n\r\n  return deepMerge(target, ...sources);\r\n}\r\n\r\n/**\r\n * Check if a value is a plain object\r\n */\r\nfunction isObject(item: any): item is Record<string, any> {\r\n  return item && typeof item === 'object' && !Array.isArray(item);\r\n}\r\n\r\n/**\r\n * Generate a secure random challenge as Uint8Array\r\n */\r\nfunction generateChallenge(): Uint8Array {\r\n  return crypto.getRandomValues(new Uint8Array(32));\r\n}\r\n\r\n/**\r\n * Generate a user ID from username\r\n * Uses TextEncoder to convert username to Uint8Array for consistency\r\n */\r\nfunction generateUserId(username: string): Uint8Array {\r\n  return new TextEncoder().encode(username);\r\n}\r\n\r\n/**\r\n * Convert challenge to appropriate format\r\n * Handles both string (base64url) and Uint8Array inputs\r\n */\r\nfunction processChallenge(challenge?: string | Uint8Array): Uint8Array {\r\n  if (!challenge) {\r\n    return generateChallenge();\r\n  }\r\n\r\n  if (typeof challenge === 'string') {\r\n    // Assume base64url string, convert to Uint8Array\r\n    return Uint8Array.from(\r\n      atob(challenge.replace(/-/g, '+').replace(/_/g, '/')),\r\n      (c) => c.charCodeAt(0)\r\n    );\r\n  }\r\n\r\n  return challenge;\r\n}\r\n\r\n/**\r\n * Convert user ID to appropriate format\r\n * Handles both string (base64url) and Uint8Array inputs\r\n */\r\nfunction processUserId(\r\n  userId?: string | Uint8Array,\r\n  username?: string\r\n): Uint8Array {\r\n  if (userId) {\r\n    if (typeof userId === 'string') {\r\n      // Assume base64url string, convert to Uint8Array\r\n      return Uint8Array.from(\r\n        atob(userId.replace(/-/g, '+').replace(/_/g, '/')),\r\n        (c) => c.charCodeAt(0)\r\n      );\r\n    }\r\n    return userId;\r\n  }\r\n\r\n  if (username) {\r\n    return generateUserId(username);\r\n  }\r\n\r\n  // Fallback to random ID\r\n  return crypto.getRandomValues(new Uint8Array(16));\r\n}\r\n\r\n/**\r\n * Convert string credential IDs to PublicKeyCredentialDescriptor format\r\n */\r\nfunction processCredentialDescriptors(\r\n  credentials?: PublicKeyCredentialDescriptor[] | string[]\r\n): PublicKeyCredentialDescriptor[] | undefined {\r\n  if (!credentials || credentials.length === 0) {\r\n    return undefined;\r\n  }\r\n\r\n  // If already in descriptor format, return as-is\r\n  if (typeof credentials[0] === 'object' && 'type' in credentials[0]) {\r\n    return credentials as PublicKeyCredentialDescriptor[];\r\n  }\r\n\r\n  // Convert string IDs to descriptors\r\n  return (credentials as string[]).map((id) => ({\r\n    type: 'public-key' as const,\r\n    id: Uint8Array.from(atob(id.replace(/-/g, '+').replace(/_/g, '/')), (c) =>\r\n      c.charCodeAt(0)\r\n    ),\r\n  }));\r\n}\r\n\r\n/**\r\n * Resolve a preset configuration by name\r\n */\r\nexport function resolvePreset(presetName: PresetName) {\r\n  const preset = PRESET_MAP[presetName];\r\n  if (!preset) {\r\n    throw new Error(`Unknown preset: ${presetName}`);\r\n  }\r\n  return preset;\r\n}\r\n\r\n/**\r\n * Build complete PublicKeyCredentialCreationOptions from RegisterConfig\r\n * Now uses WebAuthnConfig for better defaults and relying party information\r\n */\r\nexport function buildCreationOptionsFromConfig(\r\n  config: RegisterConfig,\r\n  webAuthnConfig: WebAuthnConfig\r\n): PublicKeyCredentialCreationOptions {\r\n  // Start with base configuration from WebAuthnConfig\r\n  let options: Partial<PublicKeyCredentialCreationOptions> = {\r\n    timeout: webAuthnConfig.defaultTimeout || 60000,\r\n    attestation: webAuthnConfig.defaultAttestation || 'none',\r\n  };\r\n\r\n  // Apply preset if specified\r\n  if (config.preset) {\r\n    const preset = resolvePreset(config.preset);\r\n    options = deepMerge(options, {\r\n      authenticatorSelection: preset.authenticatorSelection,\r\n      pubKeyCredParams: [...preset.pubKeyCredParams], // Convert readonly to mutable\r\n    });\r\n  } else {\r\n    // Apply default authenticator selection from config\r\n    if (webAuthnConfig.defaultAuthenticatorSelection) {\r\n      options.authenticatorSelection =\r\n        webAuthnConfig.defaultAuthenticatorSelection;\r\n    }\r\n  }\r\n\r\n  // Apply user overrides\r\n  if (config.timeout !== undefined) {\r\n    options.timeout = config.timeout;\r\n  }\r\n\r\n  if (config.attestation !== undefined) {\r\n    options.attestation = config.attestation;\r\n  }\r\n\r\n  if (config.authenticatorSelection !== undefined) {\r\n    options.authenticatorSelection = deepMerge(\r\n      options.authenticatorSelection || {},\r\n      config.authenticatorSelection\r\n    );\r\n  }\r\n\r\n  if (config.pubKeyCredParams !== undefined) {\r\n    options.pubKeyCredParams = config.pubKeyCredParams;\r\n  }\r\n\r\n  if (config.extensions !== undefined) {\r\n    options.extensions = config.extensions;\r\n  }\r\n\r\n  // Handle required fields\r\n  const challenge = processChallenge(config.challenge);\r\n  const userId = processUserId(config.userId, config.username);\r\n\r\n  // Use relying party from config, with user override capability\r\n  const relyingParty = config.rp || webAuthnConfig.relyingParty;\r\n\r\n  // Build final options\r\n  const finalOptions: PublicKeyCredentialCreationOptions = {\r\n    ...options,\r\n    rp: relyingParty,\r\n    user: {\r\n      id: userId,\r\n      name: config.username,\r\n      displayName: config.displayName || config.username,\r\n    },\r\n    challenge,\r\n    pubKeyCredParams: options.pubKeyCredParams ||\r\n      webAuthnConfig.defaultAlgorithms || [\r\n        { type: 'public-key', alg: -7 }, // ES256\r\n        { type: 'public-key', alg: -257 }, // RS256\r\n      ],\r\n    excludeCredentials: processCredentialDescriptors(config.excludeCredentials),\r\n  };\r\n\r\n  return finalOptions;\r\n}\r\n\r\n/**\r\n * Build complete PublicKeyCredentialRequestOptions from AuthenticateConfig\r\n * Now uses WebAuthnConfig for better defaults\r\n */\r\nexport function buildRequestOptionsFromConfig(\r\n  config: AuthenticateConfig,\r\n  webAuthnConfig: WebAuthnConfig\r\n): PublicKeyCredentialRequestOptions {\r\n  // Start with base configuration from WebAuthnConfig\r\n  const options: Partial<PublicKeyCredentialRequestOptions> = {\r\n    timeout: webAuthnConfig.defaultTimeout || 60000,\r\n    userVerification: webAuthnConfig.enforceUserVerification\r\n      ? 'required'\r\n      : 'preferred',\r\n  };\r\n\r\n  // Apply preset if specified\r\n  if (config.preset) {\r\n    const preset = resolvePreset(config.preset);\r\n    // Extract relevant parts for authentication (userVerification from authenticatorSelection)\r\n    if (preset.authenticatorSelection?.userVerification) {\r\n      options.userVerification = preset.authenticatorSelection.userVerification;\r\n    }\r\n  }\r\n\r\n  // Apply user overrides\r\n  if (config.timeout !== undefined) {\r\n    options.timeout = config.timeout;\r\n  }\r\n\r\n  if (config.userVerification !== undefined) {\r\n    options.userVerification = config.userVerification;\r\n  }\r\n\r\n  if (config.extensions !== undefined) {\r\n    options.extensions = config.extensions;\r\n  }\r\n\r\n  // Handle required fields\r\n  const challenge = processChallenge(config.challenge);\r\n\r\n  // Build final options\r\n  const finalOptions: PublicKeyCredentialRequestOptions = {\r\n    ...options,\r\n    challenge,\r\n    allowCredentials: processCredentialDescriptors(config.allowCredentials),\r\n  };\r\n\r\n  return finalOptions;\r\n}\r\n\r\n/**\r\n * Validate that a RegisterConfig has all required fields\r\n */\r\nexport function validateRegisterConfig(config: RegisterConfig): void {\r\n  if (!config.username || typeof config.username !== 'string') {\r\n    throw new Error('RegisterConfig must have a valid username');\r\n  }\r\n\r\n  if (config.preset && !PRESET_MAP[config.preset]) {\r\n    throw new Error(\r\n      `Invalid preset: ${config.preset}. Valid presets are: ${Object.keys(\r\n        PRESET_MAP\r\n      ).join(', ')}`\r\n    );\r\n  }\r\n}\r\n\r\n/**\r\n * Validate that an AuthenticateConfig has all required fields\r\n */\r\nexport function validateAuthenticateConfig(config: AuthenticateConfig): void {\r\n  if (config.preset && !PRESET_MAP[config.preset]) {\r\n    throw new Error(\r\n      `Invalid preset: ${config.preset}. Valid presets are: ${Object.keys(\r\n        PRESET_MAP\r\n      ).join(', ')}`\r\n    );\r\n  }\r\n}\r\n"]}","/**\n * Enhanced WebAuthn Error Classes\n * Provides specific, actionable error types for better developer experience\n */\nexport var WebAuthnErrorType;\n(function (WebAuthnErrorType) {\n WebAuthnErrorType[\"NOT_SUPPORTED\"] = \"NOT_SUPPORTED\";\n WebAuthnErrorType[\"USER_CANCELLED\"] = \"USER_CANCELLED\";\n WebAuthnErrorType[\"AUTHENTICATOR_ERROR\"] = \"AUTHENTICATOR_ERROR\";\n WebAuthnErrorType[\"INVALID_OPTIONS\"] = \"INVALID_OPTIONS\";\n WebAuthnErrorType[\"UNSUPPORTED_OPERATION\"] = \"UNSUPPORTED_OPERATION\";\n WebAuthnErrorType[\"NETWORK_ERROR\"] = \"NETWORK_ERROR\";\n WebAuthnErrorType[\"SECURITY_ERROR\"] = \"SECURITY_ERROR\";\n WebAuthnErrorType[\"TIMEOUT_ERROR\"] = \"TIMEOUT_ERROR\";\n WebAuthnErrorType[\"UNKNOWN\"] = \"UNKNOWN\";\n})(WebAuthnErrorType || (WebAuthnErrorType = {}));\n/**\n * Base WebAuthn error class with additional context\n */\nexport class WebAuthnError extends Error {\n type;\n originalError;\n constructor(type, message, originalError) {\n super(message);\n this.type = type;\n this.originalError = originalError;\n this.name = 'WebAuthnError';\n }\n static fromDOMException(error) {\n const type = WebAuthnError.mapDOMExceptionToType(error.name);\n return new WebAuthnError(type, error.message, error);\n }\n static mapDOMExceptionToType(name) {\n switch (name) {\n case 'NotSupportedError':\n return WebAuthnErrorType.NOT_SUPPORTED;\n case 'NotAllowedError':\n return WebAuthnErrorType.USER_CANCELLED;\n case 'InvalidStateError':\n return WebAuthnErrorType.AUTHENTICATOR_ERROR;\n case 'SecurityError':\n return WebAuthnErrorType.SECURITY_ERROR;\n case 'TimeoutError':\n return WebAuthnErrorType.TIMEOUT_ERROR;\n case 'NetworkError':\n return WebAuthnErrorType.NETWORK_ERROR;\n case 'EncodingError':\n return WebAuthnErrorType.INVALID_OPTIONS;\n default:\n return WebAuthnErrorType.UNKNOWN;\n }\n }\n}\n/**\n * Error thrown when user cancels the WebAuthn operation\n */\nexport class UserCancelledError extends WebAuthnError {\n constructor(originalError) {\n super(WebAuthnErrorType.USER_CANCELLED, 'User cancelled the WebAuthn operation', originalError);\n this.name = 'UserCancelledError';\n }\n}\n/**\n * Error thrown when there's an issue with the authenticator\n */\nexport class AuthenticatorError extends WebAuthnError {\n constructor(message, originalError) {\n super(WebAuthnErrorType.AUTHENTICATOR_ERROR, `Authenticator error: ${message}`, originalError);\n this.name = 'AuthenticatorError';\n }\n}\n/**\n * Error thrown when the provided options are invalid\n */\nexport class InvalidOptionsError extends WebAuthnError {\n constructor(message, originalError) {\n super(WebAuthnErrorType.INVALID_OPTIONS, `Invalid options: ${message}`, originalError);\n this.name = 'InvalidOptionsError';\n }\n}\n/**\n * Error thrown when the requested operation is not supported\n */\nexport class UnsupportedOperationError extends WebAuthnError {\n constructor(message, originalError) {\n super(WebAuthnErrorType.UNSUPPORTED_OPERATION, `Unsupported operation: ${message}`, originalError);\n this.name = 'UnsupportedOperationError';\n }\n}\n/**\n * Error thrown when there's a network-related issue\n */\nexport class NetworkError extends WebAuthnError {\n constructor(message, originalError) {\n super(WebAuthnErrorType.NETWORK_ERROR, `Network error: ${message}`, originalError);\n this.name = 'NetworkError';\n }\n}\n/**\n * Error thrown when there's a security-related issue\n */\nexport class SecurityError extends WebAuthnError {\n constructor(message, originalError) {\n super(WebAuthnErrorType.SECURITY_ERROR, `Security error: ${message}`, originalError);\n this.name = 'SecurityError';\n }\n}\n/**\n * Error thrown when the operation times out\n */\nexport class TimeoutError extends WebAuthnError {\n constructor(message, originalError) {\n super(WebAuthnErrorType.TIMEOUT_ERROR, `Timeout error: ${message}`, originalError);\n this.name = 'TimeoutError';\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webauthn.errors.js","sourceRoot":"","sources":["../../../../../../libs/ngx-webauthn/src/lib/errors/webauthn.errors.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Enhanced WebAuthn Error Classes\n * Provides specific, actionable error types for better developer experience\n */\n\nexport enum WebAuthnErrorType {\n  NOT_SUPPORTED = 'NOT_SUPPORTED',\n  USER_CANCELLED = 'USER_CANCELLED',\n  AUTHENTICATOR_ERROR = 'AUTHENTICATOR_ERROR',\n  INVALID_OPTIONS = 'INVALID_OPTIONS',\n  UNSUPPORTED_OPERATION = 'UNSUPPORTED_OPERATION',\n  NETWORK_ERROR = 'NETWORK_ERROR',\n  SECURITY_ERROR = 'SECURITY_ERROR',\n  TIMEOUT_ERROR = 'TIMEOUT_ERROR',\n  UNKNOWN = 'UNKNOWN',\n}\n\n/**\n * Base WebAuthn error class with additional context\n */\nexport class WebAuthnError extends Error {\n  constructor(\n    public readonly type: WebAuthnErrorType,\n    message: string,\n    public readonly originalError?: Error\n  ) {\n    super(message);\n    this.name = 'WebAuthnError';\n  }\n\n  static fromDOMException(error: DOMException): WebAuthnError {\n    const type = WebAuthnError.mapDOMExceptionToType(error.name);\n    return new WebAuthnError(type, error.message, error);\n  }\n\n  private static mapDOMExceptionToType(name: string): WebAuthnErrorType {\n    switch (name) {\n      case 'NotSupportedError':\n        return WebAuthnErrorType.NOT_SUPPORTED;\n      case 'NotAllowedError':\n        return WebAuthnErrorType.USER_CANCELLED;\n      case 'InvalidStateError':\n        return WebAuthnErrorType.AUTHENTICATOR_ERROR;\n      case 'SecurityError':\n        return WebAuthnErrorType.SECURITY_ERROR;\n      case 'TimeoutError':\n        return WebAuthnErrorType.TIMEOUT_ERROR;\n      case 'NetworkError':\n        return WebAuthnErrorType.NETWORK_ERROR;\n      case 'EncodingError':\n        return WebAuthnErrorType.INVALID_OPTIONS;\n      default:\n        return WebAuthnErrorType.UNKNOWN;\n    }\n  }\n}\n\n/**\n * Error thrown when user cancels the WebAuthn operation\n */\nexport class UserCancelledError extends WebAuthnError {\n  constructor(originalError?: Error) {\n    super(\n      WebAuthnErrorType.USER_CANCELLED,\n      'User cancelled the WebAuthn operation',\n      originalError\n    );\n    this.name = 'UserCancelledError';\n  }\n}\n\n/**\n * Error thrown when there's an issue with the authenticator\n */\nexport class AuthenticatorError extends WebAuthnError {\n  constructor(message: string, originalError?: Error) {\n    super(\n      WebAuthnErrorType.AUTHENTICATOR_ERROR,\n      `Authenticator error: ${message}`,\n      originalError\n    );\n    this.name = 'AuthenticatorError';\n  }\n}\n\n/**\n * Error thrown when the provided options are invalid\n */\nexport class InvalidOptionsError extends WebAuthnError {\n  constructor(message: string, originalError?: Error) {\n    super(\n      WebAuthnErrorType.INVALID_OPTIONS,\n      `Invalid options: ${message}`,\n      originalError\n    );\n    this.name = 'InvalidOptionsError';\n  }\n}\n\n/**\n * Error thrown when the requested operation is not supported\n */\nexport class UnsupportedOperationError extends WebAuthnError {\n  constructor(message: string, originalError?: Error) {\n    super(\n      WebAuthnErrorType.UNSUPPORTED_OPERATION,\n      `Unsupported operation: ${message}`,\n      originalError\n    );\n    this.name = 'UnsupportedOperationError';\n  }\n}\n\n/**\n * Error thrown when there's a network-related issue\n */\nexport class NetworkError extends WebAuthnError {\n  constructor(message: string, originalError?: Error) {\n    super(\n      WebAuthnErrorType.NETWORK_ERROR,\n      `Network error: ${message}`,\n      originalError\n    );\n    this.name = 'NetworkError';\n  }\n}\n\n/**\n * Error thrown when there's a security-related issue\n */\nexport class SecurityError extends WebAuthnError {\n  constructor(message: string, originalError?: Error) {\n    super(\n      WebAuthnErrorType.SECURITY_ERROR,\n      `Security error: ${message}`,\n      originalError\n    );\n    this.name = 'SecurityError';\n  }\n}\n\n/**\n * Error thrown when the operation times out\n */\nexport class TimeoutError extends WebAuthnError {\n  constructor(message: string, originalError?: Error) {\n    super(\n      WebAuthnErrorType.TIMEOUT_ERROR,\n      `Timeout error: ${message}`,\n      originalError\n    );\n    this.name = 'TimeoutError';\n  }\n}\n"]}","/**\n * WebAuthn Configuration\n * Provides configuration interfaces and injection token for WebAuthn service\n */\nimport { InjectionToken } from '@angular/core';\n/**\n * Default configuration for WebAuthn service\n * Note: relyingParty must be provided by the application\n */\nexport const DEFAULT_WEBAUTHN_CONFIG = {\n defaultTimeout: 60000,\n defaultAlgorithms: [\n { type: 'public-key', alg: -7 }, // ES256 (ECDSA w/ SHA-256)\n { type: 'public-key', alg: -257 }, // RS256 (RSASSA-PKCS1-v1_5 w/ SHA-256)\n ],\n enforceUserVerification: false,\n defaultAttestation: 'none',\n defaultAuthenticatorSelection: {\n userVerification: 'preferred',\n },\n};\n/**\n * Injection token for WebAuthn configuration\n */\nexport const WEBAUTHN_CONFIG = new InjectionToken('WEBAUTHN_CONFIG');\n/**\n * Creates a complete WebAuthn configuration with required relying party information\n * @param relyingParty Required relying party configuration\n * @param overrides Optional configuration overrides\n */\nexport function createWebAuthnConfig(relyingParty, overrides) {\n return {\n relyingParty,\n ...DEFAULT_WEBAUTHN_CONFIG,\n ...overrides,\n };\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViYXV0aG4uY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZ3gtd2ViYXV0aG4vc3JjL2xpYi9jb25maWcvd2ViYXV0aG4uY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUE0RC9DOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUF5QztJQUMzRSxjQUFjLEVBQUUsS0FBSztJQUNyQixpQkFBaUIsRUFBRTtRQUNqQixFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsMkJBQTJCO1FBQzVELEVBQUUsSUFBSSxFQUFFLFlBQVksRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRSx1Q0FBdUM7S0FDM0U7SUFDRCx1QkFBdUIsRUFBRSxLQUFLO0lBQzlCLGtCQUFrQixFQUFFLE1BQU07SUFDMUIsNkJBQTZCLEVBQUU7UUFDN0IsZ0JBQWdCLEVBQUUsV0FBVztLQUM5QjtDQUNGLENBQUM7QUFFRjs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxJQUFJLGNBQWMsQ0FDL0MsaUJBQWlCLENBQ2xCLENBQUM7QUFFRjs7OztHQUlHO0FBQ0gsTUFBTSxVQUFVLG9CQUFvQixDQUNsQyxZQUFnQyxFQUNoQyxTQUF5RDtJQUV6RCxPQUFPO1FBQ0wsWUFBWTtRQUNaLEdBQUcsdUJBQXVCO1FBQzFCLEdBQUcsU0FBUztLQUNiLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFdlYkF1dGhuIENvbmZpZ3VyYXRpb25cclxuICogUHJvdmlkZXMgY29uZmlndXJhdGlvbiBpbnRlcmZhY2VzIGFuZCBpbmplY3Rpb24gdG9rZW4gZm9yIFdlYkF1dGhuIHNlcnZpY2VcclxuICovXHJcblxyXG5pbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIFJlcXVpcmVkIHJlbHlpbmcgcGFydHkgY29uZmlndXJhdGlvblxyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBSZWx5aW5nUGFydHlDb25maWcge1xyXG4gIC8qKlxyXG4gICAqIEh1bWFuLXJlYWRhYmxlIGlkZW50aWZpZXIgZm9yIHRoZSBSZWx5aW5nIFBhcnR5XHJcbiAgICogQGV4YW1wbGUgXCJBQ01FIENvcnBvcmF0aW9uXCJcclxuICAgKi9cclxuICBuYW1lOiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIEEgdmFsaWQgZG9tYWluIHN0cmluZyB0aGF0IGlkZW50aWZpZXMgdGhlIFJlbHlpbmcgUGFydHkgb24gd2hvc2UgYmVoYWxmIGEgZ2l2ZW4gcmVnaXN0cmF0aW9uIG9yIGF1dGhlbnRpY2F0aW9uIGNlcmVtb255IGlzIGJlaW5nIHBlcmZvcm1lZFxyXG4gICAqIEBleGFtcGxlIFwibG9naW4uZXhhbXBsZS5jb21cIiBvciBcImV4YW1wbGUuY29tXCJcclxuICAgKi9cclxuICBpZD86IHN0cmluZztcclxufVxyXG5cclxuLyoqXHJcbiAqIENvbmZpZ3VyYXRpb24gaW50ZXJmYWNlIGZvciBXZWJBdXRobiBzZXJ2aWNlXHJcbiAqIE5vdyBpbmNsdWRlcyByZXF1aXJlZCByZWx5aW5nIHBhcnR5IGluZm9ybWF0aW9uIGFuZCBhZHZhbmNlZCBvcHRpb25zXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFdlYkF1dGhuQ29uZmlnIHtcclxuICAvKipcclxuICAgKiBSZXF1aXJlZCByZWx5aW5nIHBhcnR5IGluZm9ybWF0aW9uIGZvciBXZWJBdXRobiBvcGVyYXRpb25zXHJcbiAgICogVGhpcyBpcyBjcml0aWNhbCBmb3Igc2VjdXJpdHkgLSBtdXN0IGJlIGNvbmZpZ3VyZWQgcHJvcGVybHkgZm9yIHByb2R1Y3Rpb24gdXNlXHJcbiAgICovXHJcbiAgcmVseWluZ1BhcnR5OiBSZWx5aW5nUGFydHlDb25maWc7XHJcblxyXG4gIC8qKlxyXG4gICAqIERlZmF1bHQgdGltZW91dCBmb3IgV2ViQXV0aG4gb3BlcmF0aW9ucyBpbiBtaWxsaXNlY29uZHNcclxuICAgKiBAZGVmYXVsdCA2MDAwMFxyXG4gICAqL1xyXG4gIGRlZmF1bHRUaW1lb3V0PzogbnVtYmVyO1xyXG5cclxuICAvKipcclxuICAgKiBEZWZhdWx0IHB1YmxpYyBrZXkgY3JlZGVudGlhbCBhbGdvcml0aG1zIGluIG9yZGVyIG9mIHByZWZlcmVuY2VcclxuICAgKiBAZGVmYXVsdCBbRVMyNTYsIFJTMjU2XVxyXG4gICAqL1xyXG4gIGRlZmF1bHRBbGdvcml0aG1zPzogUHVibGljS2V5Q3JlZGVudGlhbFBhcmFtZXRlcnNbXTtcclxuXHJcbiAgLyoqXHJcbiAgICogV2hldGhlciB0byBlbmZvcmNlIHVzZXIgdmVyaWZpY2F0aW9uIGJ5IGRlZmF1bHRcclxuICAgKiBAZGVmYXVsdCBmYWxzZVxyXG4gICAqL1xyXG4gIGVuZm9yY2VVc2VyVmVyaWZpY2F0aW9uPzogYm9vbGVhbjtcclxuXHJcbiAgLyoqXHJcbiAgICogRGVmYXVsdCBhdHRlc3RhdGlvbiBjb252ZXlhbmNlIHByZWZlcmVuY2VcclxuICAgKiBAZGVmYXVsdCBcIm5vbmVcIlxyXG4gICAqL1xyXG4gIGRlZmF1bHRBdHRlc3RhdGlvbj86IEF0dGVzdGF0aW9uQ29udmV5YW5jZVByZWZlcmVuY2U7XHJcblxyXG4gIC8qKlxyXG4gICAqIERlZmF1bHQgYXV0aGVudGljYXRvciBzZWxlY3Rpb24gY3JpdGVyaWFcclxuICAgKi9cclxuICBkZWZhdWx0QXV0aGVudGljYXRvclNlbGVjdGlvbj86IEF1dGhlbnRpY2F0b3JTZWxlY3Rpb25Dcml0ZXJpYTtcclxufVxyXG5cclxuLyoqXHJcbiAqIERlZmF1bHQgY29uZmlndXJhdGlvbiBmb3IgV2ViQXV0aG4gc2VydmljZVxyXG4gKiBOb3RlOiByZWx5aW5nUGFydHkgbXVzdCBiZSBwcm92aWRlZCBieSB0aGUgYXBwbGljYXRpb25cclxuICovXHJcbmV4cG9ydCBjb25zdCBERUZBVUxUX1dFQkFVVEhOX0NPTkZJRzogT21pdDxXZWJBdXRobkNvbmZpZywgJ3JlbHlpbmdQYXJ0eSc+ID0ge1xyXG4gIGRlZmF1bHRUaW1lb3V0OiA2MDAwMCxcclxuICBkZWZhdWx0QWxnb3JpdGhtczogW1xyXG4gICAgeyB0eXBlOiAncHVibGljLWtleScsIGFsZzogLTcgfSwgLy8gRVMyNTYgKEVDRFNBIHcvIFNIQS0yNTYpXHJcbiAgICB7IHR5cGU6ICdwdWJsaWMta2V5JywgYWxnOiAtMjU3IH0sIC8vIFJTMjU2IChSU0FTU0EtUEtDUzEtdjFfNSB3LyBTSEEtMjU2KVxyXG4gIF0sXHJcbiAgZW5mb3JjZVVzZXJWZXJpZmljYXRpb246IGZhbHNlLFxyXG4gIGRlZmF1bHRBdHRlc3RhdGlvbjogJ25vbmUnLFxyXG4gIGRlZmF1bHRBdXRoZW50aWNhdG9yU2VsZWN0aW9uOiB7XHJcbiAgICB1c2VyVmVyaWZpY2F0aW9uOiAncHJlZmVycmVkJyxcclxuICB9LFxyXG59O1xyXG5cclxuLyoqXHJcbiAqIEluamVjdGlvbiB0b2tlbiBmb3IgV2ViQXV0aG4gY29uZmlndXJhdGlvblxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IFdFQkFVVEhOX0NPTkZJRyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxXZWJBdXRobkNvbmZpZz4oXHJcbiAgJ1dFQkFVVEhOX0NPTkZJRydcclxuKTtcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgY29tcGxldGUgV2ViQXV0aG4gY29uZmlndXJhdGlvbiB3aXRoIHJlcXVpcmVkIHJlbHlpbmcgcGFydHkgaW5mb3JtYXRpb25cclxuICogQHBhcmFtIHJlbHlpbmdQYXJ0eSBSZXF1aXJlZCByZWx5aW5nIHBhcnR5IGNvbmZpZ3VyYXRpb25cclxuICogQHBhcmFtIG92ZXJyaWRlcyBPcHRpb25hbCBjb25maWd1cmF0aW9uIG92ZXJyaWRlc1xyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVdlYkF1dGhuQ29uZmlnKFxyXG4gIHJlbHlpbmdQYXJ0eTogUmVseWluZ1BhcnR5Q29uZmlnLFxyXG4gIG92ZXJyaWRlcz86IFBhcnRpYWw8T21pdDxXZWJBdXRobkNvbmZpZywgJ3JlbHlpbmdQYXJ0eSc+PlxyXG4pOiBXZWJBdXRobkNvbmZpZyB7XHJcbiAgcmV0dXJuIHtcclxuICAgIHJlbHlpbmdQYXJ0eSxcclxuICAgIC4uLkRFRkFVTFRfV0VCQVVUSE5fQ09ORklHLFxyXG4gICAgLi4ub3ZlcnJpZGVzLFxyXG4gIH07XHJcbn1cclxuIl19","/**\n * WebAuthn Utility Functions\n * Centralized utilities for ArrayBuffer conversions and WebAuthn-specific operations\n * This is the single source of truth for data transformation functions\n */\n/**\n * Converts a string to ArrayBuffer\n */\nexport function stringToArrayBuffer(str) {\n const encoder = new TextEncoder();\n return encoder.encode(str);\n}\n/**\n * Converts ArrayBuffer to string\n */\nexport function arrayBufferToString(buffer) {\n const decoder = new TextDecoder();\n return decoder.decode(buffer);\n}\n/**\n * Converts ArrayBuffer to base64 string\n */\nexport function arrayBufferToBase64(buffer) {\n const bytes = new Uint8Array(buffer);\n let binary = '';\n for (let i = 0; i < bytes.byteLength; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n return btoa(binary);\n}\n/**\n * Converts base64 string to ArrayBuffer\n */\nexport function base64ToArrayBuffer(base64) {\n const binary = atob(base64);\n const bytes = new Uint8Array(binary.length);\n for (let i = 0; i < binary.length; i++) {\n bytes[i] = binary.charCodeAt(i);\n }\n return bytes.buffer;\n}\n/**\n * Converts base64url string to ArrayBuffer\n */\nexport function base64urlToArrayBuffer(base64url) {\n // Convert base64url to base64\n const base64 = base64url.replace(/-/g, '+').replace(/_/g, '/');\n // Add padding if necessary\n const padded = base64 + '==='.slice(0, (4 - (base64.length % 4)) % 4);\n return base64ToArrayBuffer(padded);\n}\n/**\n * Converts ArrayBuffer to base64url string\n * This is the canonical implementation used throughout the library\n */\nexport function arrayBufferToBase64url(buffer) {\n const base64 = arrayBufferToBase64(buffer);\n return base64.replace(/\\+/g, '-').replace(/\\//g, '_').replace(/=/g, '');\n}\n/**\n * Generates a random challenge as ArrayBuffer\n */\nexport function generateChallenge(length = 32) {\n const array = new Uint8Array(length);\n crypto.getRandomValues(array);\n return array.buffer;\n}\n/**\n * Generates a random user ID as ArrayBuffer\n */\nexport function generateUserId(length = 32) {\n const array = new Uint8Array(length);\n crypto.getRandomValues(array);\n return array.buffer;\n}\n/**\n * Converts credential ID string to ArrayBuffer for WebAuthn API\n */\nexport function credentialIdToArrayBuffer(credentialId) {\n return base64urlToArrayBuffer(credentialId);\n}\n/**\n * Converts ArrayBuffer credential ID to string\n */\nexport function arrayBufferToCredentialId(buffer) {\n return arrayBufferToBase64url(buffer);\n}\n/**\n * Checks if the current environment supports WebAuthn\n */\nexport function isWebAuthnSupported() {\n return !!(typeof window !== 'undefined' &&\n window.PublicKeyCredential &&\n typeof navigator !== 'undefined' &&\n navigator.credentials &&\n typeof navigator.credentials.create === 'function' &&\n typeof navigator.credentials.get === 'function');\n}\n/**\n * Checks if platform authenticator is available\n */\nexport async function isPlatformAuthenticatorAvailable() {\n if (!isWebAuthnSupported()) {\n return false;\n }\n try {\n return await PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable();\n }\n catch {\n return false;\n }\n}\n/**\n * Gets supported authenticator transports for this platform\n * Enhanced detection with better browser compatibility\n */\nexport function getSupportedTransports() {\n const transports = ['usb', 'internal'];\n // Add NFC support for Android devices\n if (typeof navigator !== 'undefined' &&\n /Android/i.test(navigator.userAgent)) {\n transports.push('nfc');\n }\n // Add BLE support for modern browsers with Web Bluetooth API\n if (typeof navigator !== 'undefined' && navigator.bluetooth) {\n transports.push('ble');\n }\n return transports;\n}\n/**\n * Validates that required WebAuthn options are present\n */\nexport function validateRegistrationOptions(options) {\n if (!options.user) {\n throw new Error('User information is required for registration');\n }\n if (!options.user.id) {\n throw new Error('User ID is required for registration');\n }\n if (!options.user.name) {\n throw new Error('User name is required for registration');\n }\n if (!options.user.displayName) {\n throw new Error('User display name is required for registration');\n }\n if (!options.rp) {\n throw new Error('Relying party information is required for registration');\n }\n if (!options.rp.name) {\n throw new Error('Relying party name is required for registration');\n }\n}\n/**\n * Creates default public key credential parameters\n */\nexport function getDefaultPubKeyCredParams() {\n return [\n {\n type: 'public-key',\n alg: -7, // ES256\n },\n {\n type: 'public-key',\n alg: -257, // RS256\n },\n ];\n}\n/**\n * Enhanced type guard to detect JSON-formatted WebAuthn options\n * More robust than simple challenge type checking\n */\nexport function isJSONOptions(options) {\n if (!options || typeof options !== 'object') {\n return false;\n }\n // Check multiple indicators that this is JSON format (base64url strings)\n return (typeof options.challenge === 'string' ||\n (options.user && typeof options.user.id === 'string') ||\n (options.allowCredentials?.length > 0 &&\n typeof options.allowCredentials[0]?.id === 'string') ||\n (options.excludeCredentials?.length > 0 &&\n typeof options.excludeCredentials[0]?.id === 'string'));\n}\n/**\n * Type guard to check if input is a PublicKeyCredential\n */\nexport function isPublicKeyCredential(credential) {\n return credential !== null && credential.type === 'public-key';\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webauthn.utils.js","sourceRoot":"","sources":["../../../../../../libs/ngx-webauthn/src/lib/utils/webauthn.utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * WebAuthn Utility Functions\r\n * Centralized utilities for ArrayBuffer conversions and WebAuthn-specific operations\r\n * This is the single source of truth for data transformation functions\r\n */\r\n\r\n/**\r\n * Converts a string to ArrayBuffer\r\n */\r\nexport function stringToArrayBuffer(str: string): ArrayBuffer {\r\n  const encoder = new TextEncoder();\r\n  return encoder.encode(str);\r\n}\r\n\r\n/**\r\n * Converts ArrayBuffer to string\r\n */\r\nexport function arrayBufferToString(buffer: ArrayBuffer): string {\r\n  const decoder = new TextDecoder();\r\n  return decoder.decode(buffer);\r\n}\r\n\r\n/**\r\n * Converts ArrayBuffer to base64 string\r\n */\r\nexport function arrayBufferToBase64(buffer: ArrayBuffer): string {\r\n  const bytes = new Uint8Array(buffer);\r\n  let binary = '';\r\n  for (let i = 0; i < bytes.byteLength; i++) {\r\n    binary += String.fromCharCode(bytes[i]);\r\n  }\r\n  return btoa(binary);\r\n}\r\n\r\n/**\r\n * Converts base64 string to ArrayBuffer\r\n */\r\nexport function base64ToArrayBuffer(base64: string): ArrayBuffer {\r\n  const binary = atob(base64);\r\n  const bytes = new Uint8Array(binary.length);\r\n  for (let i = 0; i < binary.length; i++) {\r\n    bytes[i] = binary.charCodeAt(i);\r\n  }\r\n  return bytes.buffer;\r\n}\r\n\r\n/**\r\n * Converts base64url string to ArrayBuffer\r\n */\r\nexport function base64urlToArrayBuffer(base64url: string): ArrayBuffer {\r\n  // Convert base64url to base64\r\n  const base64 = base64url.replace(/-/g, '+').replace(/_/g, '/');\r\n  // Add padding if necessary\r\n  const padded = base64 + '==='.slice(0, (4 - (base64.length % 4)) % 4);\r\n  return base64ToArrayBuffer(padded);\r\n}\r\n\r\n/**\r\n * Converts ArrayBuffer to base64url string\r\n * This is the canonical implementation used throughout the library\r\n */\r\nexport function arrayBufferToBase64url(buffer: ArrayBuffer): string {\r\n  const base64 = arrayBufferToBase64(buffer);\r\n  return base64.replace(/\\+/g, '-').replace(/\\//g, '_').replace(/=/g, '');\r\n}\r\n\r\n/**\r\n * Generates a random challenge as ArrayBuffer\r\n */\r\nexport function generateChallenge(length = 32): ArrayBuffer {\r\n  const array = new Uint8Array(length);\r\n  crypto.getRandomValues(array);\r\n  return array.buffer;\r\n}\r\n\r\n/**\r\n * Generates a random user ID as ArrayBuffer\r\n */\r\nexport function generateUserId(length = 32): ArrayBuffer {\r\n  const array = new Uint8Array(length);\r\n  crypto.getRandomValues(array);\r\n  return array.buffer;\r\n}\r\n\r\n/**\r\n * Converts credential ID string to ArrayBuffer for WebAuthn API\r\n */\r\nexport function credentialIdToArrayBuffer(credentialId: string): ArrayBuffer {\r\n  return base64urlToArrayBuffer(credentialId);\r\n}\r\n\r\n/**\r\n * Converts ArrayBuffer credential ID to string\r\n */\r\nexport function arrayBufferToCredentialId(buffer: ArrayBuffer): string {\r\n  return arrayBufferToBase64url(buffer);\r\n}\r\n\r\n/**\r\n * Checks if the current environment supports WebAuthn\r\n */\r\nexport function isWebAuthnSupported(): boolean {\r\n  return !!(\r\n    typeof window !== 'undefined' &&\r\n    window.PublicKeyCredential &&\r\n    typeof navigator !== 'undefined' &&\r\n    navigator.credentials &&\r\n    typeof navigator.credentials.create === 'function' &&\r\n    typeof navigator.credentials.get === 'function'\r\n  );\r\n}\r\n\r\n/**\r\n * Checks if platform authenticator is available\r\n */\r\nexport async function isPlatformAuthenticatorAvailable(): Promise<boolean> {\r\n  if (!isWebAuthnSupported()) {\r\n    return false;\r\n  }\r\n\r\n  try {\r\n    return await PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable();\r\n  } catch {\r\n    return false;\r\n  }\r\n}\r\n\r\n/**\r\n * Gets supported authenticator transports for this platform\r\n * Enhanced detection with better browser compatibility\r\n */\r\nexport function getSupportedTransports(): AuthenticatorTransport[] {\r\n  const transports: AuthenticatorTransport[] = ['usb', 'internal'];\r\n\r\n  // Add NFC support for Android devices\r\n  if (\r\n    typeof navigator !== 'undefined' &&\r\n    /Android/i.test(navigator.userAgent)\r\n  ) {\r\n    transports.push('nfc');\r\n  }\r\n\r\n  // Add BLE support for modern browsers with Web Bluetooth API\r\n  if (typeof navigator !== 'undefined' && (navigator as any).bluetooth) {\r\n    transports.push('ble');\r\n  }\r\n\r\n  return transports;\r\n}\r\n\r\n/**\r\n * Validates that required WebAuthn options are present\r\n */\r\nexport function validateRegistrationOptions(options: any): void {\r\n  if (!options.user) {\r\n    throw new Error('User information is required for registration');\r\n  }\r\n\r\n  if (!options.user.id) {\r\n    throw new Error('User ID is required for registration');\r\n  }\r\n\r\n  if (!options.user.name) {\r\n    throw new Error('User name is required for registration');\r\n  }\r\n\r\n  if (!options.user.displayName) {\r\n    throw new Error('User display name is required for registration');\r\n  }\r\n\r\n  if (!options.rp) {\r\n    throw new Error('Relying party information is required for registration');\r\n  }\r\n\r\n  if (!options.rp.name) {\r\n    throw new Error('Relying party name is required for registration');\r\n  }\r\n}\r\n\r\n/**\r\n * Creates default public key credential parameters\r\n */\r\nexport function getDefaultPubKeyCredParams(): PublicKeyCredentialParameters[] {\r\n  return [\r\n    {\r\n      type: 'public-key',\r\n      alg: -7, // ES256\r\n    },\r\n    {\r\n      type: 'public-key',\r\n      alg: -257, // RS256\r\n    },\r\n  ];\r\n}\r\n\r\n/**\r\n * Enhanced type guard to detect JSON-formatted WebAuthn options\r\n * More robust than simple challenge type checking\r\n */\r\nexport function isJSONOptions(options: any): boolean {\r\n  if (!options || typeof options !== 'object') {\r\n    return false;\r\n  }\r\n\r\n  // Check multiple indicators that this is JSON format (base64url strings)\r\n  return (\r\n    typeof options.challenge === 'string' ||\r\n    (options.user && typeof options.user.id === 'string') ||\r\n    (options.allowCredentials?.length > 0 &&\r\n      typeof options.allowCredentials[0]?.id === 'string') ||\r\n    (options.excludeCredentials?.length > 0 &&\r\n      typeof options.excludeCredentials[0]?.id === 'string')\r\n  );\r\n}\r\n\r\n/**\r\n * Type guard to check if input is a PublicKeyCredential\r\n */\r\nexport function isPublicKeyCredential(\r\n  credential: Credential | null\r\n): credential is PublicKeyCredential {\r\n  return credential !== null && credential.type === 'public-key';\r\n}\r\n"]}","/**\n * Enhanced WebAuthn Service\n *\n * Provides a clean, high-level API for WebAuthn operations with:\n * - Modern inject() pattern instead of constructor DI\n * - Flexible options (JSON base64url strings OR native ArrayBuffers)\n * - Enhanced error handling with specific error types\n * - Native browser parsing functions for optimal performance\n * - Clean, developer-friendly response objects\n */\nimport { Injectable, inject } from '@angular/core';\nimport { from, throwError } from 'rxjs';\nimport { map, catchError } from 'rxjs/operators';\nimport { isRegisterConfig, isAuthenticateConfig, } from '../models/register-config.models';\nimport { buildCreationOptionsFromConfig, buildRequestOptionsFromConfig, validateRegisterConfig, validateAuthenticateConfig, } from '../utils/preset.utils';\nimport { WebAuthnError, WebAuthnErrorType, UserCancelledError, AuthenticatorError, InvalidOptionsError, UnsupportedOperationError, SecurityError, TimeoutError, } from '../errors/webauthn.errors';\nimport { WEBAUTHN_CONFIG } from '../config/webauthn.config';\n// Import consolidated utility functions\nimport { arrayBufferToBase64url, getSupportedTransports, isJSONOptions, isPublicKeyCredential, isWebAuthnSupported, } from '../utils/webauthn.utils';\nimport * as i0 from \"@angular/core\";\n/**\n * Enhanced Angular service for WebAuthn operations\n * Provides a clean abstraction over the WebAuthn API with RxJS observables\n * and enhanced error handling\n */\nexport class WebAuthnService {\n config = inject(WEBAUTHN_CONFIG);\n /**\n * Checks if WebAuthn is supported in the current browser\n */\n isSupported() {\n return isWebAuthnSupported();\n }\n /**\n * Gets comprehensive WebAuthn support information\n */\n getSupport() {\n if (!this.isSupported()) {\n return throwError(() => new UnsupportedOperationError('WebAuthn is not supported in this browser'));\n }\n return from(PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()).pipe(map((isPlatformAvailable) => ({\n isSupported: true,\n isPlatformAuthenticatorAvailable: isPlatformAvailable,\n supportedTransports: getSupportedTransports(),\n })), catchError((error) => throwError(() => new WebAuthnError(WebAuthnErrorType.UNKNOWN, 'Failed to check WebAuthn support', error))));\n }\n /**\n * Registers a new WebAuthn credential with flexible configuration support\n *\n * @param input Either a high-level RegisterConfig with presets, or direct WebAuthn creation options\n * @returns Observable of RegistrationResponse with clean, developer-friendly format\n *\n * @example\n * ```typescript\n * // Simple preset usage\n * this.webAuthnService.register({ username: 'john.doe', preset: 'passkey' });\n *\n * // Preset with overrides\n * this.webAuthnService.register({\n * username: 'john.doe',\n * preset: 'passkey',\n * authenticatorSelection: { userVerification: 'required' }\n * });\n *\n * // Direct WebAuthn options (native)\n * const nativeOptions: PublicKeyCredentialCreationOptions = {\n * challenge: new Uint8Array([...]),\n * rp: { name: \"My App\" },\n * user: { id: new Uint8Array([...]), name: \"user@example.com\", displayName: \"User\" },\n * pubKeyCredParams: [{ type: \"public-key\", alg: -7 }]\n * };\n * this.webAuthnService.register(nativeOptions);\n *\n * // Direct WebAuthn options (JSON)\n * const jsonOptions: PublicKeyCredentialCreationOptionsJSON = {\n * challenge: \"Y2hhbGxlbmdl\",\n * rp: { name: \"My App\" },\n * user: { id: \"dXNlcklk\", name: \"user@example.com\", displayName: \"User\" },\n * pubKeyCredParams: [{ type: \"public-key\", alg: -7 }]\n * };\n * this.webAuthnService.register(jsonOptions);\n * ```\n */\n register(input) {\n if (!this.isSupported()) {\n return throwError(() => new UnsupportedOperationError('WebAuthn is not supported in this browser'));\n }\n try {\n let creationOptions;\n if (isRegisterConfig(input)) {\n // High-level config path: validate, resolve preset, build options\n validateRegisterConfig(input);\n creationOptions = buildCreationOptionsFromConfig(input, this.config);\n }\n else {\n // Direct options path: use provided options\n creationOptions = input;\n }\n const parsedOptions = this.parseRegistrationOptions(creationOptions);\n return from(navigator.credentials.create({ publicKey: parsedOptions })).pipe(map((credential) => this.processRegistrationResult(credential)), catchError((error) => this.handleWebAuthnError(error)));\n }\n catch (error) {\n return throwError(() => new InvalidOptionsError('Failed to process registration input', error));\n }\n }\n /**\n * Authenticates using an existing WebAuthn credential with flexible configuration support\n *\n * @param input Either a high-level AuthenticateConfig with presets, or direct WebAuthn request options\n * @returns Observable of AuthenticationResponse with clean, developer-friendly format\n *\n * @example\n * ```typescript\n * // Simple preset usage\n * this.webAuthnService.authenticate({ preset: 'passkey' });\n *\n * // Config with credential filtering\n * this.webAuthnService.authenticate({\n * username: 'john.doe',\n * preset: 'secondFactor',\n * allowCredentials: ['credential-id-1', 'credential-id-2']\n * });\n *\n * // Direct WebAuthn options (JSON)\n * const jsonOptions: PublicKeyCredentialRequestOptionsJSON = {\n * challenge: \"Y2hhbGxlbmdl\",\n * allowCredentials: [{\n * type: \"public-key\",\n * id: \"Y3JlZElk\"\n * }]\n * };\n * this.webAuthnService.authenticate(jsonOptions);\n *\n * // Direct WebAuthn options (native)\n * const nativeOptions: PublicKeyCredentialRequestOptions = {\n * challenge: new Uint8Array([...]),\n * allowCredentials: [{\n * type: \"public-key\",\n * id: new Uint8Array([...])\n * }]\n * };\n * this.webAuthnService.authenticate(nativeOptions);\n * ```\n */\n authenticate(input) {\n if (!this.isSupported()) {\n return throwError(() => new UnsupportedOperationError('WebAuthn is not supported in this browser'));\n }\n try {\n let requestOptions;\n if (isAuthenticateConfig(input)) {\n // High-level config path: validate, resolve preset, build options\n validateAuthenticateConfig(input);\n requestOptions = buildRequestOptionsFromConfig(input, this.config);\n }\n else {\n // Direct options path: use provided options\n requestOptions = input;\n }\n const parsedOptions = this.parseAuthenticationOptions(requestOptions);\n return from(navigator.credentials.get({ publicKey: parsedOptions })).pipe(map((credential) => this.processAuthenticationResult(credential)), catchError((error) => this.handleWebAuthnError(error)));\n }\n catch (error) {\n return throwError(() => new InvalidOptionsError('Failed to process authentication input', error));\n }\n }\n /**\n * Parses registration options, handling both JSON and native formats\n */\n parseRegistrationOptions(options) {\n if (isJSONOptions(options)) {\n // Use native browser function for JSON options\n return PublicKeyCredential.parseCreationOptionsFromJSON(options);\n }\n else {\n // Options are already in native format\n return options;\n }\n }\n /**\n * Parses authentication options, handling both JSON and native formats\n */\n parseAuthenticationOptions(options) {\n if (isJSONOptions(options)) {\n // Use native browser function for JSON options\n return PublicKeyCredential.parseRequestOptionsFromJSON(options);\n }\n else {\n // Options are already in native format\n return options;\n }\n }\n /**\n * Processes the raw credential result into a clean RegistrationResponse\n */\n processRegistrationResult(credential) {\n if (!isPublicKeyCredential(credential)) {\n throw new AuthenticatorError('No credential returned from authenticator');\n }\n const response = credential.response;\n // Extract data using the response methods\n const credentialId = arrayBufferToBase64url(credential.rawId);\n const transports = (response.getTransports?.() ||\n []);\n let publicKey;\n try {\n const publicKeyBuffer = response.getPublicKey?.();\n if (publicKeyBuffer) {\n publicKey = arrayBufferToBase64url(publicKeyBuffer);\n }\n }\n catch {\n // Public key extraction failed - this is okay, not all algorithms are supported\n }\n // Create the raw response for backward compatibility\n const rawResponse = {\n credentialId,\n publicKey: publicKey ||\n arrayBufferToBase64url(response.getPublicKey?.() || new ArrayBuffer(0)),\n attestationObject: arrayBufferToBase64url(response.attestationObject),\n clientDataJSON: arrayBufferToBase64url(response.clientDataJSON),\n transports: transports,\n };\n return {\n success: true,\n credentialId,\n publicKey,\n transports,\n rawResponse,\n };\n }\n /**\n * Processes the raw credential result into a clean AuthenticationResponse\n */\n processAuthenticationResult(credential) {\n if (!isPublicKeyCredential(credential)) {\n throw new AuthenticatorError('No credential returned from authenticator');\n }\n const response = credential.response;\n const credentialId = arrayBufferToBase64url(credential.rawId);\n let userHandle;\n if (response.userHandle) {\n userHandle = arrayBufferToBase64url(response.userHandle);\n }\n // Create the raw response for backward compatibility\n const rawResponse = {\n credentialId,\n authenticatorData: arrayBufferToBase64url(response.authenticatorData),\n clientDataJSON: arrayBufferToBase64url(response.clientDataJSON),\n signature: arrayBufferToBase64url(response.signature),\n userHandle,\n };\n return {\n success: true,\n credentialId,\n userHandle,\n rawResponse,\n };\n }\n /**\n * Enhanced error handling that maps DOMExceptions to specific error types\n */\n handleWebAuthnError(error) {\n // Handle DOMExceptions from WebAuthn API\n if (error instanceof DOMException) {\n switch (error.name) {\n case 'NotAllowedError':\n return throwError(() => new UserCancelledError(error));\n case 'InvalidStateError':\n return throwError(() => new AuthenticatorError('Invalid authenticator state', error));\n case 'NotSupportedError':\n return throwError(() => new UnsupportedOperationError('Operation not supported', error));\n case 'SecurityError':\n return throwError(() => new SecurityError('Security error occurred', error));\n case 'TimeoutError':\n return throwError(() => new TimeoutError('Operation timed out', error));\n case 'EncodingError':\n return throwError(() => new InvalidOptionsError('Encoding error in options', error));\n default:\n return throwError(() => new WebAuthnError(WebAuthnErrorType.UNKNOWN, `Unknown WebAuthn error: ${error.message}`, error));\n }\n }\n // Handle JSON parsing errors\n if (error instanceof TypeError &&\n (error.message.includes('parseCreationOptionsFromJSON') ||\n error.message.includes('parseRequestOptionsFromJSON'))) {\n return throwError(() => new InvalidOptionsError('Invalid JSON options format', error));\n }\n // Handle other errors\n return throwError(() => new WebAuthnError(WebAuthnErrorType.UNKNOWN, `Unexpected error: ${error.message}`, error));\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.3\", ngImport: i0, type: WebAuthnService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.3\", ngImport: i0, type: WebAuthnService, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.3\", ngImport: i0, type: WebAuthnService, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webauthn.service.js","sourceRoot":"","sources":["../../../../../../libs/ngx-webauthn/src/lib/services/webauthn.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Enhanced WebAuthn Service\r\n *\r\n * Provides a clean, high-level API for WebAuthn operations with:\r\n * - Modern inject() pattern instead of constructor DI\r\n * - Flexible options (JSON base64url strings OR native ArrayBuffers)\r\n * - Enhanced error handling with specific error types\r\n * - Native browser parsing functions for optimal performance\r\n * - Clean, developer-friendly response objects\r\n */\r\n\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { Observable, from, throwError } from 'rxjs';\r\nimport { map, catchError } from 'rxjs/operators';\r\n\r\nimport {\r\n  WebAuthnSupport,\r\n  RegistrationResponse,\r\n  AuthenticationResponse,\r\n  WebAuthnRegistrationResult,\r\n  WebAuthnAuthenticationResult,\r\n} from '../models/webauthn.models';\r\n\r\nimport {\r\n  RegisterInput,\r\n  AuthenticateInput,\r\n  isRegisterConfig,\r\n  isAuthenticateConfig,\r\n} from '../models/register-config.models';\r\n\r\nimport {\r\n  buildCreationOptionsFromConfig,\r\n  buildRequestOptionsFromConfig,\r\n  validateRegisterConfig,\r\n  validateAuthenticateConfig,\r\n} from '../utils/preset.utils';\r\n\r\nimport {\r\n  WebAuthnError,\r\n  WebAuthnErrorType,\r\n  UserCancelledError,\r\n  AuthenticatorError,\r\n  InvalidOptionsError,\r\n  UnsupportedOperationError,\r\n  SecurityError,\r\n  TimeoutError,\r\n} from '../errors/webauthn.errors';\r\n\r\nimport { WEBAUTHN_CONFIG } from '../config/webauthn.config';\r\n\r\n// Import consolidated utility functions\r\nimport {\r\n  arrayBufferToBase64url,\r\n  getSupportedTransports,\r\n  isJSONOptions,\r\n  isPublicKeyCredential,\r\n  isWebAuthnSupported,\r\n} from '../utils/webauthn.utils';\r\n\r\n/**\r\n * Enhanced Angular service for WebAuthn operations\r\n * Provides a clean abstraction over the WebAuthn API with RxJS observables\r\n * and enhanced error handling\r\n */\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class WebAuthnService {\r\n  private readonly config = inject(WEBAUTHN_CONFIG);\r\n\r\n  /**\r\n   * Checks if WebAuthn is supported in the current browser\r\n   */\r\n  isSupported(): boolean {\r\n    return isWebAuthnSupported();\r\n  }\r\n\r\n  /**\r\n   * Gets comprehensive WebAuthn support information\r\n   */\r\n  getSupport(): Observable<WebAuthnSupport> {\r\n    if (!this.isSupported()) {\r\n      return throwError(\r\n        () =>\r\n          new UnsupportedOperationError(\r\n            'WebAuthn is not supported in this browser'\r\n          )\r\n      );\r\n    }\r\n\r\n    return from(\r\n      PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()\r\n    ).pipe(\r\n      map((isPlatformAvailable) => ({\r\n        isSupported: true,\r\n        isPlatformAuthenticatorAvailable: isPlatformAvailable,\r\n        supportedTransports: getSupportedTransports(),\r\n      })),\r\n      catchError((error) =>\r\n        throwError(\r\n          () =>\r\n            new WebAuthnError(\r\n              WebAuthnErrorType.UNKNOWN,\r\n              'Failed to check WebAuthn support',\r\n              error\r\n            )\r\n        )\r\n      )\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Registers a new WebAuthn credential with flexible configuration support\r\n   *\r\n   * @param input Either a high-level RegisterConfig with presets, or direct WebAuthn creation options\r\n   * @returns Observable of RegistrationResponse with clean, developer-friendly format\r\n   *\r\n   * @example\r\n   * ```typescript\r\n   * // Simple preset usage\r\n   * this.webAuthnService.register({ username: 'john.doe', preset: 'passkey' });\r\n   *\r\n   * // Preset with overrides\r\n   * this.webAuthnService.register({\r\n   *   username: 'john.doe',\r\n   *   preset: 'passkey',\r\n   *   authenticatorSelection: { userVerification: 'required' }\r\n   * });\r\n   *\r\n   * // Direct WebAuthn options (native)\r\n   * const nativeOptions: PublicKeyCredentialCreationOptions = {\r\n   *   challenge: new Uint8Array([...]),\r\n   *   rp: { name: \"My App\" },\r\n   *   user: { id: new Uint8Array([...]), name: \"user@example.com\", displayName: \"User\" },\r\n   *   pubKeyCredParams: [{ type: \"public-key\", alg: -7 }]\r\n   * };\r\n   * this.webAuthnService.register(nativeOptions);\r\n   *\r\n   * // Direct WebAuthn options (JSON)\r\n   * const jsonOptions: PublicKeyCredentialCreationOptionsJSON = {\r\n   *   challenge: \"Y2hhbGxlbmdl\",\r\n   *   rp: { name: \"My App\" },\r\n   *   user: { id: \"dXNlcklk\", name: \"user@example.com\", displayName: \"User\" },\r\n   *   pubKeyCredParams: [{ type: \"public-key\", alg: -7 }]\r\n   * };\r\n   * this.webAuthnService.register(jsonOptions);\r\n   * ```\r\n   */\r\n  register(input: RegisterInput): Observable<RegistrationResponse> {\r\n    if (!this.isSupported()) {\r\n      return throwError(\r\n        () =>\r\n          new UnsupportedOperationError(\r\n            'WebAuthn is not supported in this browser'\r\n          )\r\n      );\r\n    }\r\n\r\n    try {\r\n      let creationOptions:\r\n        | PublicKeyCredentialCreationOptions\r\n        | PublicKeyCredentialCreationOptionsJSON;\r\n\r\n      if (isRegisterConfig(input)) {\r\n        // High-level config path: validate, resolve preset, build options\r\n        validateRegisterConfig(input);\r\n        creationOptions = buildCreationOptionsFromConfig(input, this.config);\r\n      } else {\r\n        // Direct options path: use provided options\r\n        creationOptions = input;\r\n      }\r\n\r\n      const parsedOptions = this.parseRegistrationOptions(creationOptions);\r\n\r\n      return from(\r\n        navigator.credentials.create({ publicKey: parsedOptions })\r\n      ).pipe(\r\n        map((credential) => this.processRegistrationResult(credential)),\r\n        catchError((error) => this.handleWebAuthnError(error))\r\n      );\r\n    } catch (error) {\r\n      return throwError(\r\n        () =>\r\n          new InvalidOptionsError(\r\n            'Failed to process registration input',\r\n            error as Error\r\n          )\r\n      );\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Authenticates using an existing WebAuthn credential with flexible configuration support\r\n   *\r\n   * @param input Either a high-level AuthenticateConfig with presets, or direct WebAuthn request options\r\n   * @returns Observable of AuthenticationResponse with clean, developer-friendly format\r\n   *\r\n   * @example\r\n   * ```typescript\r\n   * // Simple preset usage\r\n   * this.webAuthnService.authenticate({ preset: 'passkey' });\r\n   *\r\n   * // Config with credential filtering\r\n   * this.webAuthnService.authenticate({\r\n   *   username: 'john.doe',\r\n   *   preset: 'secondFactor',\r\n   *   allowCredentials: ['credential-id-1', 'credential-id-2']\r\n   * });\r\n   *\r\n   * // Direct WebAuthn options (JSON)\r\n   * const jsonOptions: PublicKeyCredentialRequestOptionsJSON = {\r\n   *   challenge: \"Y2hhbGxlbmdl\",\r\n   *   allowCredentials: [{\r\n   *     type: \"public-key\",\r\n   *     id: \"Y3JlZElk\"\r\n   *   }]\r\n   * };\r\n   * this.webAuthnService.authenticate(jsonOptions);\r\n   *\r\n   * // Direct WebAuthn options (native)\r\n   * const nativeOptions: PublicKeyCredentialRequestOptions = {\r\n   *   challenge: new Uint8Array([...]),\r\n   *   allowCredentials: [{\r\n   *     type: \"public-key\",\r\n   *     id: new Uint8Array([...])\r\n   *   }]\r\n   * };\r\n   * this.webAuthnService.authenticate(nativeOptions);\r\n   * ```\r\n   */\r\n  authenticate(input: AuthenticateInput): Observable<AuthenticationResponse> {\r\n    if (!this.isSupported()) {\r\n      return throwError(\r\n        () =>\r\n          new UnsupportedOperationError(\r\n            'WebAuthn is not supported in this browser'\r\n          )\r\n      );\r\n    }\r\n\r\n    try {\r\n      let requestOptions:\r\n        | PublicKeyCredentialRequestOptions\r\n        | PublicKeyCredentialRequestOptionsJSON;\r\n\r\n      if (isAuthenticateConfig(input)) {\r\n        // High-level config path: validate, resolve preset, build options\r\n        validateAuthenticateConfig(input);\r\n        requestOptions = buildRequestOptionsFromConfig(input, this.config);\r\n      } else {\r\n        // Direct options path: use provided options\r\n        requestOptions = input;\r\n      }\r\n\r\n      const parsedOptions = this.parseAuthenticationOptions(requestOptions);\r\n\r\n      return from(navigator.credentials.get({ publicKey: parsedOptions })).pipe(\r\n        map((credential) => this.processAuthenticationResult(credential)),\r\n        catchError((error) => this.handleWebAuthnError(error))\r\n      );\r\n    } catch (error) {\r\n      return throwError(\r\n        () =>\r\n          new InvalidOptionsError(\r\n            'Failed to process authentication input',\r\n            error as Error\r\n          )\r\n      );\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Parses registration options, handling both JSON and native formats\r\n   */\r\n  private parseRegistrationOptions(\r\n    options:\r\n      | PublicKeyCredentialCreationOptions\r\n      | PublicKeyCredentialCreationOptionsJSON\r\n  ): PublicKeyCredentialCreationOptions {\r\n    if (isJSONOptions(options)) {\r\n      // Use native browser function for JSON options\r\n      return PublicKeyCredential.parseCreationOptionsFromJSON(\r\n        options as PublicKeyCredentialCreationOptionsJSON\r\n      );\r\n    } else {\r\n      // Options are already in native format\r\n      return options as PublicKeyCredentialCreationOptions;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Parses authentication options, handling both JSON and native formats\r\n   */\r\n  private parseAuthenticationOptions(\r\n    options:\r\n      | PublicKeyCredentialRequestOptions\r\n      | PublicKeyCredentialRequestOptionsJSON\r\n  ): PublicKeyCredentialRequestOptions {\r\n    if (isJSONOptions(options)) {\r\n      // Use native browser function for JSON options\r\n      return PublicKeyCredential.parseRequestOptionsFromJSON(\r\n        options as PublicKeyCredentialRequestOptionsJSON\r\n      );\r\n    } else {\r\n      // Options are already in native format\r\n      return options as PublicKeyCredentialRequestOptions;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Processes the raw credential result into a clean RegistrationResponse\r\n   */\r\n  private processRegistrationResult(\r\n    credential: Credential | null\r\n  ): RegistrationResponse {\r\n    if (!isPublicKeyCredential(credential)) {\r\n      throw new AuthenticatorError('No credential returned from authenticator');\r\n    }\r\n\r\n    const response = credential.response as AuthenticatorAttestationResponse;\r\n\r\n    // Extract data using the response methods\r\n    const credentialId = arrayBufferToBase64url(credential.rawId);\r\n    const transports = (response.getTransports?.() ||\r\n      []) as AuthenticatorTransport[];\r\n\r\n    let publicKey: string | undefined;\r\n    try {\r\n      const publicKeyBuffer = response.getPublicKey?.();\r\n      if (publicKeyBuffer) {\r\n        publicKey = arrayBufferToBase64url(publicKeyBuffer);\r\n      }\r\n    } catch {\r\n      // Public key extraction failed - this is okay, not all algorithms are supported\r\n    }\r\n\r\n    // Create the raw response for backward compatibility\r\n    const rawResponse: WebAuthnRegistrationResult = {\r\n      credentialId,\r\n      publicKey:\r\n        publicKey ||\r\n        arrayBufferToBase64url(response.getPublicKey?.() || new ArrayBuffer(0)),\r\n      attestationObject: arrayBufferToBase64url(response.attestationObject),\r\n      clientDataJSON: arrayBufferToBase64url(response.clientDataJSON),\r\n      transports: transports,\r\n    };\r\n\r\n    return {\r\n      success: true,\r\n      credentialId,\r\n      publicKey,\r\n      transports,\r\n      rawResponse,\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Processes the raw credential result into a clean AuthenticationResponse\r\n   */\r\n  private processAuthenticationResult(\r\n    credential: Credential | null\r\n  ): AuthenticationResponse {\r\n    if (!isPublicKeyCredential(credential)) {\r\n      throw new AuthenticatorError('No credential returned from authenticator');\r\n    }\r\n\r\n    const response = credential.response as AuthenticatorAssertionResponse;\r\n    const credentialId = arrayBufferToBase64url(credential.rawId);\r\n\r\n    let userHandle: string | undefined;\r\n    if (response.userHandle) {\r\n      userHandle = arrayBufferToBase64url(response.userHandle);\r\n    }\r\n\r\n    // Create the raw response for backward compatibility\r\n    const rawResponse: WebAuthnAuthenticationResult = {\r\n      credentialId,\r\n      authenticatorData: arrayBufferToBase64url(response.authenticatorData),\r\n      clientDataJSON: arrayBufferToBase64url(response.clientDataJSON),\r\n      signature: arrayBufferToBase64url(response.signature),\r\n      userHandle,\r\n    };\r\n\r\n    return {\r\n      success: true,\r\n      credentialId,\r\n      userHandle,\r\n      rawResponse,\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Enhanced error handling that maps DOMExceptions to specific error types\r\n   */\r\n  private handleWebAuthnError(error: any): Observable<never> {\r\n    // Handle DOMExceptions from WebAuthn API\r\n    if (error instanceof DOMException) {\r\n      switch (error.name) {\r\n        case 'NotAllowedError':\r\n          return throwError(() => new UserCancelledError(error));\r\n        case 'InvalidStateError':\r\n          return throwError(\r\n            () => new AuthenticatorError('Invalid authenticator state', error)\r\n          );\r\n        case 'NotSupportedError':\r\n          return throwError(\r\n            () =>\r\n              new UnsupportedOperationError('Operation not supported', error)\r\n          );\r\n        case 'SecurityError':\r\n          return throwError(\r\n            () => new SecurityError('Security error occurred', error)\r\n          );\r\n        case 'TimeoutError':\r\n          return throwError(\r\n            () => new TimeoutError('Operation timed out', error)\r\n          );\r\n        case 'EncodingError':\r\n          return throwError(\r\n            () => new InvalidOptionsError('Encoding error in options', error)\r\n          );\r\n        default:\r\n          return throwError(\r\n            () =>\r\n              new WebAuthnError(\r\n                WebAuthnErrorType.UNKNOWN,\r\n                `Unknown WebAuthn error: ${error.message}`,\r\n                error\r\n              )\r\n          );\r\n      }\r\n    }\r\n\r\n    // Handle JSON parsing errors\r\n    if (\r\n      error instanceof TypeError &&\r\n      (error.message.includes('parseCreationOptionsFromJSON') ||\r\n        error.message.includes('parseRequestOptionsFromJSON'))\r\n    ) {\r\n      return throwError(\r\n        () => new InvalidOptionsError('Invalid JSON options format', error)\r\n      );\r\n    }\r\n\r\n    // Handle other errors\r\n    return throwError(\r\n      () =>\r\n        new WebAuthnError(\r\n          WebAuthnErrorType.UNKNOWN,\r\n          `Unexpected error: ${error.message}`,\r\n          error\r\n        )\r\n    );\r\n  }\r\n}\r\n"]}","/**\n * WebAuthn Providers\n * Modern Angular standalone provider function for WebAuthn service\n */\nimport { WebAuthnService } from '../services/webauthn.service';\nimport { WEBAUTHN_CONFIG, createWebAuthnConfig, } from '../config/webauthn.config';\n/**\n * Provides WebAuthn service with required relying party configuration\n *\n * @param relyingParty Required relying party configuration\n * @param config Optional configuration overrides\n * @returns Array of providers for WebAuthn functionality\n *\n * @example\n * ```typescript\n * // main.ts\n * bootstrapApplication(AppComponent, {\n * providers: [\n * provideWebAuthn(\n * { name: 'My App', id: 'myapp.com' },\n * { defaultTimeout: 30000 }\n * )\n * ]\n * });\n * ```\n */\nexport function provideWebAuthn(relyingParty, config = {}) {\n return [\n {\n provide: WEBAUTHN_CONFIG,\n useValue: createWebAuthnConfig(relyingParty, config),\n },\n WebAuthnService,\n ];\n}\n/**\n * @deprecated Use provideWebAuthn(relyingParty, config) instead.\n * This version is kept for backward compatibility but requires relying party information.\n */\nexport function provideWebAuthnLegacy(config) {\n if (!config.relyingParty) {\n throw new Error('WebAuthn configuration must include relying party information. Use provideWebAuthn(relyingParty, config) instead.');\n }\n return [\n {\n provide: WEBAUTHN_CONFIG,\n useValue: config,\n },\n WebAuthnService,\n ];\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViYXV0aG4ucHJvdmlkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZ3gtd2ViYXV0aG4vc3JjL2xpYi9wcm92aWRlcnMvd2ViYXV0aG4ucHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUdILE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMvRCxPQUFPLEVBR0wsZUFBZSxFQUNmLG9CQUFvQixHQUNyQixNQUFNLDJCQUEyQixDQUFDO0FBRW5DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUJHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FDN0IsWUFBZ0MsRUFDaEMsU0FBd0QsRUFBRTtJQUUxRCxPQUFPO1FBQ0w7WUFDRSxPQUFPLEVBQUUsZUFBZTtZQUN4QixRQUFRLEVBQUUsb0JBQW9CLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQztTQUNyRDtRQUNELGVBQWU7S0FDaEIsQ0FBQztBQUNKLENBQUM7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLFVBQVUscUJBQXFCLENBQUMsTUFBc0I7SUFDMUQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUN6QixNQUFNLElBQUksS0FBSyxDQUNiLG1IQUFtSCxDQUNwSCxDQUFDO0lBQ0osQ0FBQztJQUVELE9BQU87UUFDTDtZQUNFLE9BQU8sRUFBRSxlQUFlO1lBQ3hCLFFBQVEsRUFBRSxNQUFNO1NBQ2pCO1FBQ0QsZUFBZTtLQUNoQixDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxyXG4gKiBXZWJBdXRobiBQcm92aWRlcnNcclxuICogTW9kZXJuIEFuZ3VsYXIgc3RhbmRhbG9uZSBwcm92aWRlciBmdW5jdGlvbiBmb3IgV2ViQXV0aG4gc2VydmljZVxyXG4gKi9cclxuXHJcbmltcG9ydCB7IFByb3ZpZGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFdlYkF1dGhuU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3dlYmF1dGhuLnNlcnZpY2UnO1xyXG5pbXBvcnQge1xyXG4gIFdlYkF1dGhuQ29uZmlnLFxyXG4gIFJlbHlpbmdQYXJ0eUNvbmZpZyxcclxuICBXRUJBVVRITl9DT05GSUcsXHJcbiAgY3JlYXRlV2ViQXV0aG5Db25maWcsXHJcbn0gZnJvbSAnLi4vY29uZmlnL3dlYmF1dGhuLmNvbmZpZyc7XHJcblxyXG4vKipcclxuICogUHJvdmlkZXMgV2ViQXV0aG4gc2VydmljZSB3aXRoIHJlcXVpcmVkIHJlbHlpbmcgcGFydHkgY29uZmlndXJhdGlvblxyXG4gKlxyXG4gKiBAcGFyYW0gcmVseWluZ1BhcnR5IFJlcXVpcmVkIHJlbHlpbmcgcGFydHkgY29uZmlndXJhdGlvblxyXG4gKiBAcGFyYW0gY29uZmlnIE9wdGlvbmFsIGNvbmZpZ3VyYXRpb24gb3ZlcnJpZGVzXHJcbiAqIEByZXR1cm5zIEFycmF5IG9mIHByb3ZpZGVycyBmb3IgV2ViQXV0aG4gZnVuY3Rpb25hbGl0eVxyXG4gKlxyXG4gKiBAZXhhbXBsZVxyXG4gKiBgYGB0eXBlc2NyaXB0XHJcbiAqIC8vIG1haW4udHNcclxuICogYm9vdHN0cmFwQXBwbGljYXRpb24oQXBwQ29tcG9uZW50LCB7XHJcbiAqICAgcHJvdmlkZXJzOiBbXHJcbiAqICAgICBwcm92aWRlV2ViQXV0aG4oXHJcbiAqICAgICAgIHsgbmFtZTogJ015IEFwcCcsIGlkOiAnbXlhcHAuY29tJyB9LFxyXG4gKiAgICAgICB7IGRlZmF1bHRUaW1lb3V0OiAzMDAwMCB9XHJcbiAqICAgICApXHJcbiAqICAgXVxyXG4gKiB9KTtcclxuICogYGBgXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVdlYkF1dGhuKFxyXG4gIHJlbHlpbmdQYXJ0eTogUmVseWluZ1BhcnR5Q29uZmlnLFxyXG4gIGNvbmZpZzogUGFydGlhbDxPbWl0PFdlYkF1dGhuQ29uZmlnLCAncmVseWluZ1BhcnR5Jz4+ID0ge31cclxuKTogUHJvdmlkZXJbXSB7XHJcbiAgcmV0dXJuIFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogV0VCQVVUSE5fQ09ORklHLFxyXG4gICAgICB1c2VWYWx1ZTogY3JlYXRlV2ViQXV0aG5Db25maWcocmVseWluZ1BhcnR5LCBjb25maWcpLFxyXG4gICAgfSxcclxuICAgIFdlYkF1dGhuU2VydmljZSxcclxuICBdO1xyXG59XHJcblxyXG4vKipcclxuICogQGRlcHJlY2F0ZWQgVXNlIHByb3ZpZGVXZWJBdXRobihyZWx5aW5nUGFydHksIGNvbmZpZykgaW5zdGVhZC5cclxuICogVGhpcyB2ZXJzaW9uIGlzIGtlcHQgZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHkgYnV0IHJlcXVpcmVzIHJlbHlpbmcgcGFydHkgaW5mb3JtYXRpb24uXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVdlYkF1dGhuTGVnYWN5KGNvbmZpZzogV2ViQXV0aG5Db25maWcpOiBQcm92aWRlcltdIHtcclxuICBpZiAoIWNvbmZpZy5yZWx5aW5nUGFydHkpIHtcclxuICAgIHRocm93IG5ldyBFcnJvcihcclxuICAgICAgJ1dlYkF1dGhuIGNvbmZpZ3VyYXRpb24gbXVzdCBpbmNsdWRlIHJlbHlpbmcgcGFydHkgaW5mb3JtYXRpb24uIFVzZSBwcm92aWRlV2ViQXV0aG4ocmVseWluZ1BhcnR5LCBjb25maWcpIGluc3RlYWQuJ1xyXG4gICAgKTtcclxuICB9XHJcblxyXG4gIHJldHVybiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IFdFQkFVVEhOX0NPTkZJRyxcclxuICAgICAgdXNlVmFsdWU6IGNvbmZpZyxcclxuICAgIH0sXHJcbiAgICBXZWJBdXRoblNlcnZpY2UsXHJcbiAgXTtcclxufVxyXG4iXX0=","// Core service\nexport { WebAuthnService } from './lib/services/webauthn.service';\nexport { WEBAUTHN_CONFIG, createWebAuthnConfig, DEFAULT_WEBAUTHN_CONFIG, } from './lib/config/webauthn.config';\n// Providers\nexport { provideWebAuthn, provideWebAuthnLegacy, } from './lib/providers/webauthn.providers';\n// Error types for enhanced error handling\nexport { WebAuthnError, WebAuthnErrorType, UserCancelledError, AuthenticatorError, InvalidOptionsError, UnsupportedOperationError, SecurityError, TimeoutError, NetworkError, } from './lib/errors/webauthn.errors';\n// Utility functions\nexport { arrayBufferToBase64url, base64urlToArrayBuffer, arrayBufferToBase64, base64ToArrayBuffer, stringToArrayBuffer, arrayBufferToString, generateChallenge, generateUserId, credentialIdToArrayBuffer, arrayBufferToCredentialId, isWebAuthnSupported, isPlatformAuthenticatorAvailable, getSupportedTransports, validateRegistrationOptions, getDefaultPubKeyCredParams, isJSONOptions, isPublicKeyCredential, } from './lib/utils/webauthn.utils';\n// Preset configurations\nexport { PRESET_MAP, PASSKEY_PRESET, SECOND_FACTOR_PRESET, DEVICE_BOUND_PRESET, } from './lib/presets/webauthn.presets';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL25neC13ZWJhdXRobi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsZUFBZTtBQUNmLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQU9sRSxPQUFPLEVBQ0wsZUFBZSxFQUNmLG9CQUFvQixFQUNwQix1QkFBdUIsR0FDeEIsTUFBTSw4QkFBOEIsQ0FBQztBQUV0QyxZQUFZO0FBQ1osT0FBTyxFQUNMLGVBQWUsRUFDZixxQkFBcUIsR0FDdEIsTUFBTSxvQ0FBb0MsQ0FBQztBQXVCNUMsMENBQTBDO0FBQzFDLE9BQU8sRUFDTCxhQUFhLEVBQ2IsaUJBQWlCLEVBQ2pCLGtCQUFrQixFQUNsQixrQkFBa0IsRUFDbEIsbUJBQW1CLEVBQ25CLHlCQUF5QixFQUN6QixhQUFhLEVBQ2IsWUFBWSxFQUNaLFlBQVksR0FDYixNQUFNLDhCQUE4QixDQUFDO0FBRXRDLG9CQUFvQjtBQUNwQixPQUFPLEVBQ0wsc0JBQXNCLEVBQ3RCLHNCQUFzQixFQUN0QixtQkFBbUIsRUFDbkIsbUJBQW1CLEVBQ25CLG1CQUFtQixFQUNuQixtQkFBbUIsRUFDbkIsaUJBQWlCLEVBQ2pCLGNBQWMsRUFDZCx5QkFBeUIsRUFDekIseUJBQXlCLEVBQ3pCLG1CQUFtQixFQUNuQixnQ0FBZ0MsRUFDaEMsc0JBQXNCLEVBQ3RCLDJCQUEyQixFQUMzQiwwQkFBMEIsRUFDMUIsYUFBYSxFQUNiLHFCQUFxQixHQUN0QixNQUFNLDRCQUE0QixDQUFDO0FBRXBDLHdCQUF3QjtBQUN4QixPQUFPLEVBQ0wsVUFBVSxFQUNWLGNBQWMsRUFDZCxvQkFBb0IsRUFDcEIsbUJBQW1CLEdBQ3BCLE1BQU0sZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3JlIHNlcnZpY2VcclxuZXhwb3J0IHsgV2ViQXV0aG5TZXJ2aWNlIH0gZnJvbSAnLi9saWIvc2VydmljZXMvd2ViYXV0aG4uc2VydmljZSc7XHJcblxyXG4vLyBDb25maWd1cmF0aW9uIHN5c3RlbVxyXG5leHBvcnQgdHlwZSB7XHJcbiAgV2ViQXV0aG5Db25maWcsXHJcbiAgUmVseWluZ1BhcnR5Q29uZmlnLFxyXG59IGZyb20gJy4vbGliL2NvbmZpZy93ZWJhdXRobi5jb25maWcnO1xyXG5leHBvcnQge1xyXG4gIFdFQkFVVEhOX0NPTkZJRyxcclxuICBjcmVhdGVXZWJBdXRobkNvbmZpZyxcclxuICBERUZBVUxUX1dFQkFVVEhOX0NPTkZJRyxcclxufSBmcm9tICcuL2xpYi9jb25maWcvd2ViYXV0aG4uY29uZmlnJztcclxuXHJcbi8vIFByb3ZpZGVyc1xyXG5leHBvcnQge1xyXG4gIHByb3ZpZGVXZWJBdXRobixcclxuICBwcm92aWRlV2ViQXV0aG5MZWdhY3ksXHJcbn0gZnJvbSAnLi9saWIvcHJvdmlkZXJzL3dlYmF1dGhuLnByb3ZpZGVycyc7XHJcblxyXG4vLyBDb3JlIG1vZGVscyBhbmQgcmVzcG9uc2UgdHlwZXNcclxuZXhwb3J0IHR5cGUge1xyXG4gIFdlYkF1dGhuUmVnaXN0cmF0aW9uUmVzdWx0LFxyXG4gIFdlYkF1dGhuQXV0aGVudGljYXRpb25SZXN1bHQsXHJcbiAgV2ViQXV0aG5TdXBwb3J0LFxyXG4gIFJlZ2lzdHJhdGlvblJlc3BvbnNlLFxyXG4gIEF1dGhlbnRpY2F0aW9uUmVzcG9uc2UsXHJcbiAgLy8gTmV3IGNvbmZpZ3VyYXRpb24gdHlwZXNcclxuICBSZWdpc3RlckNvbmZpZyxcclxuICBBdXRoZW50aWNhdGVDb25maWcsXHJcbiAgUmVnaXN0ZXJJbnB1dCxcclxuICBBdXRoZW50aWNhdGVJbnB1dCxcclxuICBQcmVzZXROYW1lLFxyXG59IGZyb20gJy4vbGliL21vZGVscy93ZWJhdXRobi5tb2RlbHMnO1xyXG5cclxuLy8gQWRkaXRpb25hbCBjb25maWd1cmF0aW9uIG1vZGVsc1xyXG5leHBvcnQgdHlwZSB7XHJcbiAgUmVnaXN0ZXJDb25maWcgYXMgUmVnaXN0ZXJDb25maWdNb2RlbCxcclxuICBBdXRoZW50aWNhdGVDb25maWcgYXMgQXV0aGVudGljYXRlQ29uZmlnTW9kZWwsXHJcbn0gZnJvbSAnLi9saWIvbW9kZWxzL3JlZ2lzdGVyLWNvbmZpZy5tb2RlbHMnO1xyXG5cclxuLy8gRXJyb3IgdHlwZXMgZm9yIGVuaGFuY2VkIGVycm9yIGhhbmRsaW5nXHJcbmV4cG9ydCB7XHJcbiAgV2ViQXV0aG5FcnJvcixcclxuICBXZWJBdXRobkVycm9yVHlwZSxcclxuICBVc2VyQ2FuY2VsbGVkRXJyb3IsXHJcbiAgQXV0aGVudGljYXRvckVycm9yLFxyXG4gIEludmFsaWRPcHRpb25zRXJyb3IsXHJcbiAgVW5zdXBwb3J0ZWRPcGVyYXRpb25FcnJvcixcclxuICBTZWN1cml0eUVycm9yLFxyXG4gIFRpbWVvdXRFcnJvcixcclxuICBOZXR3b3JrRXJyb3IsXHJcbn0gZnJvbSAnLi9saWIvZXJyb3JzL3dlYmF1dGhuLmVycm9ycyc7XHJcblxyXG4vLyBVdGlsaXR5IGZ1bmN0aW9uc1xyXG5leHBvcnQge1xyXG4gIGFycmF5QnVmZmVyVG9CYXNlNjR1cmwsXHJcbiAgYmFzZTY0dXJsVG9BcnJheUJ1ZmZlcixcclxuICBhcnJheUJ1ZmZlclRvQmFzZTY0LFxyXG4gIGJhc2U2NFRvQXJyYXlCdWZmZXIsXHJcbiAgc3RyaW5nVG9BcnJheUJ1ZmZlcixcclxuICBhcnJheUJ1ZmZlclRvU3RyaW5nLFxyXG4gIGdlbmVyYXRlQ2hhbGxlbmdlLFxyXG4gIGdlbmVyYXRlVXNlcklkLFxyXG4gIGNyZWRlbnRpYWxJZFRvQXJyYXlCdWZmZXIsXHJcbiAgYXJyYXlCdWZmZXJUb0NyZWRlbnRpYWxJZCxcclxuICBpc1dlYkF1dGhuU3VwcG9ydGVkLFxyXG4gIGlzUGxhdGZvcm1BdXRoZW50aWNhdG9yQXZhaWxhYmxlLFxyXG4gIGdldFN1cHBvcnRlZFRyYW5zcG9ydHMsXHJcbiAgdmFsaWRhdGVSZWdpc3RyYXRpb25PcHRpb25zLFxyXG4gIGdldERlZmF1bHRQdWJLZXlDcmVkUGFyYW1zLFxyXG4gIGlzSlNPTk9wdGlvbnMsXHJcbiAgaXNQdWJsaWNLZXlDcmVkZW50aWFsLFxyXG59IGZyb20gJy4vbGliL3V0aWxzL3dlYmF1dGhuLnV0aWxzJztcclxuXHJcbi8vIFByZXNldCBjb25maWd1cmF0aW9uc1xyXG5leHBvcnQge1xyXG4gIFBSRVNFVF9NQVAsXHJcbiAgUEFTU0tFWV9QUkVTRVQsXHJcbiAgU0VDT05EX0ZBQ1RPUl9QUkVTRVQsXHJcbiAgREVWSUNFX0JPVU5EX1BSRVNFVCxcclxufSBmcm9tICcuL2xpYi9wcmVzZXRzL3dlYmF1dGhuLnByZXNldHMnO1xyXG4iXX0=","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LXdlYmF1dGhuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy9uZ3gtd2ViYXV0aG4vc3JjL25neC13ZWJhdXRobi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":["generateChallenge","generateUserId"],"mappings":"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"}