ngx-webauthn 0.0.2 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +922 -412
- package/fesm2022/ngx-webauthn.mjs +1117 -190
- package/fesm2022/ngx-webauthn.mjs.map +1 -1
- package/index.d.ts +841 -165
- package/package.json +2 -1
|
@@ -1 +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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"}
|
|
1
|
+
{"version":3,"file":"ngx-webauthn.mjs","sources":["../tmp-esm2022/lib/utils/type-guards.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/model/service-config.js","../tmp-esm2022/lib/utils/webauthn.utils.js","../tmp-esm2022/lib/utils/remote.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 * Type guard utilities for WebAuthn operations\n *\n * These functions help determine the type of input provided to WebAuthn operations,\n * enabling proper handling of different input formats (high-level configs vs native WebAuthn options).\n */\n/**\n * Type guard to determine if input is a high-level RegisterConfig object.\n * Distinguishes between RegisterConfig and direct WebAuthn creation options.\n *\n * @param input The input to check\n * @returns True if the input is a RegisterConfig, false otherwise\n *\n * @example\n * ```typescript\n * if (isRegisterConfig(input)) {\n * // Handle high-level config with preset support\n * const options = buildCreationOptionsFromConfig(input, config);\n * } else {\n * // Handle direct WebAuthn options\n * const options = parseRegistrationOptions(input);\n * }\n * ```\n */\nexport function isRegisterConfig(input) {\n return typeof input === 'object' && input !== null && 'username' in input;\n}\n/**\n * Type guard to determine if input is a high-level AuthenticateConfig object.\n * Distinguishes between AuthenticateConfig and direct WebAuthn request options.\n *\n * Uses the presence of 'username' or 'preset' fields and absence of WebAuthn-specific\n * fields ('rp', 'user') to identify AuthenticateConfig objects.\n *\n * @param input The input to check\n * @returns True if the input is an AuthenticateConfig, false otherwise\n *\n * @example\n * ```typescript\n * if (isAuthenticateConfig(input)) {\n * // Handle high-level config with preset support\n * const options = buildRequestOptionsFromConfig(input, config);\n * } else {\n * // Handle direct WebAuthn options\n * const options = parseAuthenticationOptions(input);\n * }\n * ```\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 contains WebAuthn creation options.\n * Identifies objects that have the structure of PublicKeyCredentialCreationOptions\n * by checking for required fields like 'rp' and 'user'.\n *\n * @param input The input to check\n * @returns True if the input has creation options structure, false otherwise\n *\n * @example\n * ```typescript\n * if (isCreationOptions(input)) {\n * // Input is already in WebAuthn format\n * return navigator.credentials.create({ publicKey: input });\n * }\n * ```\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 contains WebAuthn request options.\n * Identifies objects that have the structure of PublicKeyCredentialRequestOptions\n * by checking for the required 'challenge' field.\n *\n * @param input The input to check\n * @returns True if the input has request options structure, false otherwise\n *\n * @example\n * ```typescript\n * if (isRequestOptions(input)) {\n * // Input is already in WebAuthn format\n * return navigator.credentials.get({ publicKey: input });\n * }\n * ```\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZS1ndWFyZHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25neC13ZWJhdXRobi9zcmMvbGliL3V0aWxzL3R5cGUtZ3VhcmRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OztHQUtHO0FBT0g7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBaUJHO0FBQ0gsTUFBTSxVQUFVLGdCQUFnQixDQUFDLEtBQWM7SUFDN0MsT0FBTyxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxVQUFVLElBQUksS0FBSyxDQUFDO0FBQzVFLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7QUFDSCxNQUFNLFVBQVUsb0JBQW9CLENBQ2xDLEtBQWM7SUFFZCxPQUFPLENBQ0wsT0FBTyxLQUFLLEtBQUssUUFBUTtRQUN6QixLQUFLLEtBQUssSUFBSTtRQUNkLENBQUMsVUFBVSxJQUFJLEtBQUssSUFBSSxRQUFRLElBQUksS0FBSyxDQUFDO1FBQzFDLENBQUMsQ0FBQyxJQUFJLElBQUksS0FBSyxDQUFDLElBQUksNkJBQTZCO1FBQ2pELENBQUMsQ0FBQyxNQUFNLElBQUksS0FBSyxDQUFDLENBQ25CLENBQUMsQ0FBQywrQkFBK0I7QUFDcEMsQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILE1BQU0sVUFBVSxpQkFBaUIsQ0FDL0IsS0FBYztJQUlkLE9BQU8sQ0FDTCxPQUFPLEtBQUssS0FBSyxRQUFRO1FBQ3pCLEtBQUssS0FBSyxJQUFJO1FBQ2QsSUFBSSxJQUFJLEtBQUs7UUFDYixNQUFNLElBQUksS0FBSyxDQUNoQixDQUFDO0FBQ0osQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILE1BQU0sVUFBVSxnQkFBZ0IsQ0FDOUIsS0FBYztJQUlkLE9BQU8sQ0FDTCxPQUFPLEtBQUssS0FBSyxRQUFRO1FBQ3pCLEtBQUssS0FBSyxJQUFJO1FBQ2QsQ0FBQyxDQUFDLFVBQVUsSUFBSSxLQUFLLENBQUM7UUFDdEIsQ0FBQyxDQUFDLElBQUksSUFBSSxLQUFLLENBQUM7UUFDaEIsQ0FBQyxDQUFDLE1BQU0sSUFBSSxLQUFLLENBQUMsQ0FDbkIsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFR5cGUgZ3VhcmQgdXRpbGl0aWVzIGZvciBXZWJBdXRobiBvcGVyYXRpb25zXG4gKlxuICogVGhlc2UgZnVuY3Rpb25zIGhlbHAgZGV0ZXJtaW5lIHRoZSB0eXBlIG9mIGlucHV0IHByb3ZpZGVkIHRvIFdlYkF1dGhuIG9wZXJhdGlvbnMsXG4gKiBlbmFibGluZyBwcm9wZXIgaGFuZGxpbmcgb2YgZGlmZmVyZW50IGlucHV0IGZvcm1hdHMgKGhpZ2gtbGV2ZWwgY29uZmlncyB2cyBuYXRpdmUgV2ViQXV0aG4gb3B0aW9ucykuXG4gKi9cblxuaW1wb3J0IHR5cGUge1xuICBSZWdpc3RlckNvbmZpZyxcbiAgQXV0aGVudGljYXRlQ29uZmlnLFxufSBmcm9tICcuLi9tb2RlbC9vcGVyYXRpb24tY29uZmlnJztcblxuLyoqXG4gKiBUeXBlIGd1YXJkIHRvIGRldGVybWluZSBpZiBpbnB1dCBpcyBhIGhpZ2gtbGV2ZWwgUmVnaXN0ZXJDb25maWcgb2JqZWN0LlxuICogRGlzdGluZ3Vpc2hlcyBiZXR3ZWVuIFJlZ2lzdGVyQ29uZmlnIGFuZCBkaXJlY3QgV2ViQXV0aG4gY3JlYXRpb24gb3B0aW9ucy5cbiAqXG4gKiBAcGFyYW0gaW5wdXQgVGhlIGlucHV0IHRvIGNoZWNrXG4gKiBAcmV0dXJucyBUcnVlIGlmIHRoZSBpbnB1dCBpcyBhIFJlZ2lzdGVyQ29uZmlnLCBmYWxzZSBvdGhlcndpc2VcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaWYgKGlzUmVnaXN0ZXJDb25maWcoaW5wdXQpKSB7XG4gKiAgIC8vIEhhbmRsZSBoaWdoLWxldmVsIGNvbmZpZyB3aXRoIHByZXNldCBzdXBwb3J0XG4gKiAgIGNvbnN0IG9wdGlvbnMgPSBidWlsZENyZWF0aW9uT3B0aW9uc0Zyb21Db25maWcoaW5wdXQsIGNvbmZpZyk7XG4gKiB9IGVsc2Uge1xuICogICAvLyBIYW5kbGUgZGlyZWN0IFdlYkF1dGhuIG9wdGlvbnNcbiAqICAgY29uc3Qgb3B0aW9ucyA9IHBhcnNlUmVnaXN0cmF0aW9uT3B0aW9ucyhpbnB1dCk7XG4gKiB9XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzUmVnaXN0ZXJDb25maWcoaW5wdXQ6IHVua25vd24pOiBpbnB1dCBpcyBSZWdpc3RlckNvbmZpZyB7XG4gIHJldHVybiB0eXBlb2YgaW5wdXQgPT09ICdvYmplY3QnICYmIGlucHV0ICE9PSBudWxsICYmICd1c2VybmFtZScgaW4gaW5wdXQ7XG59XG5cbi8qKlxuICogVHlwZSBndWFyZCB0byBkZXRlcm1pbmUgaWYgaW5wdXQgaXMgYSBoaWdoLWxldmVsIEF1dGhlbnRpY2F0ZUNvbmZpZyBvYmplY3QuXG4gKiBEaXN0aW5ndWlzaGVzIGJldHdlZW4gQXV0aGVudGljYXRlQ29uZmlnIGFuZCBkaXJlY3QgV2ViQXV0aG4gcmVxdWVzdCBvcHRpb25zLlxuICpcbiAqIFVzZXMgdGhlIHByZXNlbmNlIG9mICd1c2VybmFtZScgb3IgJ3ByZXNldCcgZmllbGRzIGFuZCBhYnNlbmNlIG9mIFdlYkF1dGhuLXNwZWNpZmljXG4gKiBmaWVsZHMgKCdycCcsICd1c2VyJykgdG8gaWRlbnRpZnkgQXV0aGVudGljYXRlQ29uZmlnIG9iamVjdHMuXG4gKlxuICogQHBhcmFtIGlucHV0IFRoZSBpbnB1dCB0byBjaGVja1xuICogQHJldHVybnMgVHJ1ZSBpZiB0aGUgaW5wdXQgaXMgYW4gQXV0aGVudGljYXRlQ29uZmlnLCBmYWxzZSBvdGhlcndpc2VcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaWYgKGlzQXV0aGVudGljYXRlQ29uZmlnKGlucHV0KSkge1xuICogICAvLyBIYW5kbGUgaGlnaC1sZXZlbCBjb25maWcgd2l0aCBwcmVzZXQgc3VwcG9ydFxuICogICBjb25zdCBvcHRpb25zID0gYnVpbGRSZXF1ZXN0T3B0aW9uc0Zyb21Db25maWcoaW5wdXQsIGNvbmZpZyk7XG4gKiB9IGVsc2Uge1xuICogICAvLyBIYW5kbGUgZGlyZWN0IFdlYkF1dGhuIG9wdGlvbnNcbiAqICAgY29uc3Qgb3B0aW9ucyA9IHBhcnNlQXV0aGVudGljYXRpb25PcHRpb25zKGlucHV0KTtcbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNBdXRoZW50aWNhdGVDb25maWcoXG4gIGlucHV0OiB1bmtub3duXG4pOiBpbnB1dCBpcyBBdXRoZW50aWNhdGVDb25maWcge1xuICByZXR1cm4gKFxuICAgIHR5cGVvZiBpbnB1dCA9PT0gJ29iamVjdCcgJiZcbiAgICBpbnB1dCAhPT0gbnVsbCAmJlxuICAgICgndXNlcm5hbWUnIGluIGlucHV0IHx8ICdwcmVzZXQnIGluIGlucHV0KSAmJlxuICAgICEoJ3JwJyBpbiBpbnB1dCkgJiYgLy8gV2ViQXV0aG4gb3B0aW9ucyBoYXZlICdycCdcbiAgICAhKCd1c2VyJyBpbiBpbnB1dClcbiAgKTsgLy8gV2ViQXV0aG4gb3B0aW9ucyBoYXZlICd1c2VyJ1xufVxuXG4vKipcbiAqIFR5cGUgZ3VhcmQgdG8gY2hlY2sgaWYgaW5wdXQgY29udGFpbnMgV2ViQXV0aG4gY3JlYXRpb24gb3B0aW9ucy5cbiAqIElkZW50aWZpZXMgb2JqZWN0cyB0aGF0IGhhdmUgdGhlIHN0cnVjdHVyZSBvZiBQdWJsaWNLZXlDcmVkZW50aWFsQ3JlYXRpb25PcHRpb25zXG4gKiBieSBjaGVja2luZyBmb3IgcmVxdWlyZWQgZmllbGRzIGxpa2UgJ3JwJyBhbmQgJ3VzZXInLlxuICpcbiAqIEBwYXJhbSBpbnB1dCBUaGUgaW5wdXQgdG8gY2hlY2tcbiAqIEByZXR1cm5zIFRydWUgaWYgdGhlIGlucHV0IGhhcyBjcmVhdGlvbiBvcHRpb25zIHN0cnVjdHVyZSwgZmFsc2Ugb3RoZXJ3aXNlXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGlmIChpc0NyZWF0aW9uT3B0aW9ucyhpbnB1dCkpIHtcbiAqICAgLy8gSW5wdXQgaXMgYWxyZWFkeSBpbiBXZWJBdXRobiBmb3JtYXRcbiAqICAgcmV0dXJuIG5hdmlnYXRvci5jcmVkZW50aWFscy5jcmVhdGUoeyBwdWJsaWNLZXk6IGlucHV0IH0pO1xuICogfVxuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc0NyZWF0aW9uT3B0aW9ucyhcbiAgaW5wdXQ6IHVua25vd25cbik6IGlucHV0IGlzXG4gIHwgUHVibGljS2V5Q3JlZGVudGlhbENyZWF0aW9uT3B0aW9uc1xuICB8IFB1YmxpY0tleUNyZWRlbnRpYWxDcmVhdGlvbk9wdGlvbnNKU09OIHtcbiAgcmV0dXJuIChcbiAgICB0eXBlb2YgaW5wdXQgPT09ICdvYmplY3QnICYmXG4gICAgaW5wdXQgIT09IG51bGwgJiZcbiAgICAncnAnIGluIGlucHV0ICYmXG4gICAgJ3VzZXInIGluIGlucHV0XG4gICk7XG59XG5cbi8qKlxuICogVHlwZSBndWFyZCB0byBjaGVjayBpZiBpbnB1dCBjb250YWlucyBXZWJBdXRobiByZXF1ZXN0IG9wdGlvbnMuXG4gKiBJZGVudGlmaWVzIG9iamVjdHMgdGhhdCBoYXZlIHRoZSBzdHJ1Y3R1cmUgb2YgUHVibGljS2V5Q3JlZGVudGlhbFJlcXVlc3RPcHRpb25zXG4gKiBieSBjaGVja2luZyBmb3IgdGhlIHJlcXVpcmVkICdjaGFsbGVuZ2UnIGZpZWxkLlxuICpcbiAqIEBwYXJhbSBpbnB1dCBUaGUgaW5wdXQgdG8gY2hlY2tcbiAqIEByZXR1cm5zIFRydWUgaWYgdGhlIGlucHV0IGhhcyByZXF1ZXN0IG9wdGlvbnMgc3RydWN0dXJlLCBmYWxzZSBvdGhlcndpc2VcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaWYgKGlzUmVxdWVzdE9wdGlvbnMoaW5wdXQpKSB7XG4gKiAgIC8vIElucHV0IGlzIGFscmVhZHkgaW4gV2ViQXV0aG4gZm9ybWF0XG4gKiAgIHJldHVybiBuYXZpZ2F0b3IuY3JlZGVudGlhbHMuZ2V0KHsgcHVibGljS2V5OiBpbnB1dCB9KTtcbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNSZXF1ZXN0T3B0aW9ucyhcbiAgaW5wdXQ6IHVua25vd25cbik6IGlucHV0IGlzXG4gIHwgUHVibGljS2V5Q3JlZGVudGlhbFJlcXVlc3RPcHRpb25zXG4gIHwgUHVibGljS2V5Q3JlZGVudGlhbFJlcXVlc3RPcHRpb25zSlNPTiB7XG4gIHJldHVybiAoXG4gICAgdHlwZW9mIGlucHV0ID09PSAnb2JqZWN0JyAmJlxuICAgIGlucHV0ICE9PSBudWxsICYmXG4gICAgISgndXNlcm5hbWUnIGluIGlucHV0KSAmJlxuICAgICEoJ3JwJyBpbiBpbnB1dCkgJiZcbiAgICAhKCd1c2VyJyBpbiBpbnB1dClcbiAgKTtcbn1cbiJdfQ==","/**\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 an external 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 EXTERNAL_SECURITY_KEY_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, platform authenticator credentials.\n *\n * Best for: High-security scenarios where credentials must stay on a single\n * device and user verification is mandatory using built-in platform authenticators.\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 PLATFORM_AUTHENTICATOR_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 externalSecurityKey: EXTERNAL_SECURITY_KEY_PRESET,\n platformAuthenticator: PLATFORM_AUTHENTICATOR_PRESET,\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViYXV0aG4ucHJlc2V0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmd4LXdlYmF1dGhuL3NyYy9saWIvcHJlc2V0cy93ZWJhdXRobi5wcmVzZXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OztHQUtHO0FBRUg7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sMEJBQTBCLEdBQUc7SUFDeEMsZ0JBQWdCLEVBQUU7UUFDaEIsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFLDJCQUEyQjtRQUM1RCxFQUFFLElBQUksRUFBRSxZQUFZLEVBQUUsR0FBRyxFQUFFLENBQUMsR0FBRyxFQUFFLEVBQUUsdUNBQXVDO0tBQzNFO0NBQ08sQ0FBQztBQUVYOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHO0lBQzVCLEdBQUcsMEJBQTBCO0lBQzdCLHNCQUFzQixFQUFFO1FBQ3RCLFdBQVcsRUFBRSxVQUFVO1FBQ3ZCLGdCQUFnQixFQUFFLFdBQVc7S0FDOUI7Q0FDTyxDQUFDO0FBRVg7Ozs7Ozs7Ozs7O0dBV0c7QUFDSCxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRztJQUMxQyxHQUFHLDBCQUEwQjtJQUM3QixzQkFBc0IsRUFBRTtRQUN0QixXQUFXLEVBQUUsYUFBYTtRQUMxQixnQkFBZ0IsRUFBRSxXQUFXO1FBQzdCLHVCQUF1QixFQUFFLGdCQUFnQjtLQUMxQztDQUNPLENBQUM7QUFFWDs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHO0lBQzNDLEdBQUcsMEJBQTBCO0lBQzdCLHNCQUFzQixFQUFFO1FBQ3RCLHVCQUF1QixFQUFFLFVBQVU7UUFDbkMsV0FBVyxFQUFFLFVBQVU7UUFDdkIsZ0JBQWdCLEVBQUUsVUFBVTtLQUM3QjtDQUNPLENBQUM7QUFFWDs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsT0FBTyxFQUFFLGNBQWM7SUFDdkIsbUJBQW1CLEVBQUUsNEJBQTRCO0lBQ2pELHFCQUFxQixFQUFFLDZCQUE2QjtDQUM1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIFdlYkF1dGhuIFByZXNldCBDb25maWd1cmF0aW9uc1xyXG4gKlxyXG4gKiBUaGlzIGZpbGUgY29udGFpbnMgcHJlZGVmaW5lZCBjb25maWd1cmF0aW9ucyBmb3IgY29tbW9uIFdlYkF1dGhuIHVzZSBjYXNlcy5cclxuICogVGhlc2UgcHJlc2V0cyBwcm92aWRlIHNlbnNpYmxlIGRlZmF1bHRzIHdoaWxlIHJlbWFpbmluZyBmdWxseSBjdXN0b21pemFibGUuXHJcbiAqL1xyXG5cclxuLyoqXHJcbiAqIEEgc2hhcmVkIGNvbmZpZ3VyYXRpb24gZm9yIGNvbW1vbiwgc3Ryb25nLCBhbmQgd2lkZWx5LXN1cHBvcnRlZFxyXG4gKiBwdWJsaWMga2V5IGNyZWRlbnRpYWwgYWxnb3JpdGhtcy5cclxuICovXHJcbmV4cG9ydCBjb25zdCBDT01NT05fUFVCX0tFWV9DUkVEX1BBUkFNUyA9IHtcclxuICBwdWJLZXlDcmVkUGFyYW1zOiBbXHJcbiAgICB7IHR5cGU6ICdwdWJsaWMta2V5JywgYWxnOiAtNyB9LCAvLyBFUzI1NiAoRUNEU0Egdy8gU0hBLTI1NilcclxuICAgIHsgdHlwZTogJ3B1YmxpYy1rZXknLCBhbGc6IC0yNTcgfSwgLy8gUlMyNTYgKFJTQVNTQS1QS0NTMS12MV81IHcvIFNIQS0yNTYpXHJcbiAgXSxcclxufSBhcyBjb25zdDtcclxuXHJcbi8qKlxyXG4gKiBQcmVzZXQgZm9yIG1vZGVybiwgcGFzc3dvcmRsZXNzLCBjcm9zcy1kZXZpY2UgY3JlZGVudGlhbHMuXHJcbiAqXHJcbiAqIEJlc3QgZm9yOiBQYXNza2V5LWJhc2VkIGF1dGhlbnRpY2F0aW9uIHdoZXJlIHVzZXJzIGNhbiBzeW5jIGNyZWRlbnRpYWxzXHJcbiAqIGFjcm9zcyBkZXZpY2VzIGFuZCB1c2UgdGhlbSBmb3IgcGFzc3dvcmRsZXNzIGxvZ2luLlxyXG4gKlxyXG4gKiBGZWF0dXJlczpcclxuICogLSBSZXF1aXJlcyByZXNpZGVudCBrZXlzIChkaXNjb3ZlcmFibGUgY3JlZGVudGlhbHMpXHJcbiAqIC0gUHJlZmVycyB1c2VyIHZlcmlmaWNhdGlvbiBidXQgZG9lc24ndCByZXF1aXJlIGl0XHJcbiAqIC0gV29ya3Mgd2l0aCBib3RoIHBsYXRmb3JtIGFuZCBjcm9zcy1wbGF0Zm9ybSBhdXRoZW50aWNhdG9yc1xyXG4gKiAtIFN1cHBvcnRzIGNyZWRlbnRpYWwgc3luY2luZyBhY3Jvc3MgZGV2aWNlc1xyXG4gKi9cclxuZXhwb3J0IGNvbnN0IFBBU1NLRVlfUFJFU0VUID0ge1xyXG4gIC4uLkNPTU1PTl9QVUJfS0VZX0NSRURfUEFSQU1TLFxyXG4gIGF1dGhlbnRpY2F0b3JTZWxlY3Rpb246IHtcclxuICAgIHJlc2lkZW50S2V5OiAncmVxdWlyZWQnLFxyXG4gICAgdXNlclZlcmlmaWNhdGlvbjogJ3ByZWZlcnJlZCcsXHJcbiAgfSxcclxufSBhcyBjb25zdDtcclxuXHJcbi8qKlxyXG4gKiBQcmVzZXQgZm9yIHVzaW5nIGFuIGV4dGVybmFsIHNlY3VyaXR5IGtleSBhcyBhIHNlY29uZCBmYWN0b3IgYWZ0ZXIgYSBwYXNzd29yZC5cclxuICpcclxuICogQmVzdCBmb3I6IFRyYWRpdGlvbmFsIDJGQSBzY2VuYXJpb3Mgd2hlcmUgdXNlcnMgYWxyZWFkeSBoYXZlIGEgcGFzc3dvcmRcclxuICogYW5kIHdhbnQgdG8gYWRkIGhhcmR3YXJlIHNlY3VyaXR5IGtleSBhcyBhIHNlY29uZCBmYWN0b3IuXHJcbiAqXHJcbiAqIEZlYXR1cmVzOlxyXG4gKiAtIERpc2NvdXJhZ2VzIHJlc2lkZW50IGtleXMgKHNlcnZlci1zaWRlIGNyZWRlbnRpYWwgc3RvcmFnZSlcclxuICogLSBQcmVmZXJzIHVzZXIgdmVyaWZpY2F0aW9uXHJcbiAqIC0gRmF2b3JzIGNyb3NzLXBsYXRmb3JtIGF1dGhlbnRpY2F0b3JzIChVU0IvTkZDIHNlY3VyaXR5IGtleXMpXHJcbiAqIC0gQ3JlZGVudGlhbHMgdHlwaWNhbGx5IG5vdCBzeW5jZWQgYmV0d2VlbiBkZXZpY2VzXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgRVhURVJOQUxfU0VDVVJJVFlfS0VZX1BSRVNFVCA9IHtcclxuICAuLi5DT01NT05fUFVCX0tFWV9DUkVEX1BBUkFNUyxcclxuICBhdXRoZW50aWNhdG9yU2VsZWN0aW9uOiB7XHJcbiAgICByZXNpZGVudEtleTogJ2Rpc2NvdXJhZ2VkJyxcclxuICAgIHVzZXJWZXJpZmljYXRpb246ICdwcmVmZXJyZWQnLFxyXG4gICAgYXV0aGVudGljYXRvckF0dGFjaG1lbnQ6ICdjcm9zcy1wbGF0Zm9ybScsXHJcbiAgfSxcclxufSBhcyBjb25zdDtcclxuXHJcbi8qKlxyXG4gKiBQcmVzZXQgZm9yIGhpZ2gtc2VjdXJpdHksIG5vbi1zeW5jZWQsIHBsYXRmb3JtIGF1dGhlbnRpY2F0b3IgY3JlZGVudGlhbHMuXHJcbiAqXHJcbiAqIEJlc3QgZm9yOiBIaWdoLXNlY3VyaXR5IHNjZW5hcmlvcyB3aGVyZSBjcmVkZW50aWFscyBtdXN0IHN0YXkgb24gYSBzaW5nbGVcclxuICogZGV2aWNlIGFuZCB1c2VyIHZlcmlmaWNhdGlvbiBpcyBtYW5kYXRvcnkgdXNpbmcgYnVpbHQtaW4gcGxhdGZvcm0gYXV0aGVudGljYXRvcnMuXHJcbiAqXHJcbiAqIEZlYXR1cmVzOlxyXG4gKiAtIFJlcXVpcmVzIHBsYXRmb3JtIGF1dGhlbnRpY2F0b3JzIChidWlsdC1pbiBiaW9tZXRyaWNzL1BJTilcclxuICogLSBSZXF1aXJlcyByZXNpZGVudCBrZXlzIGZvciBkaXNjb3ZlcmFiaWxpdHlcclxuICogLSBSZXF1aXJlcyB1c2VyIHZlcmlmaWNhdGlvbiAoYmlvbWV0cmljL1BJTilcclxuICogLSBDcmVkZW50aWFscyBib3VuZCB0byBzcGVjaWZpYyBkZXZpY2UgKG5vIHN5bmNpbmcpXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgUExBVEZPUk1fQVVUSEVOVElDQVRPUl9QUkVTRVQgPSB7XHJcbiAgLi4uQ09NTU9OX1BVQl9LRVlfQ1JFRF9QQVJBTVMsXHJcbiAgYXV0aGVudGljYXRvclNlbGVjdGlvbjoge1xyXG4gICAgYXV0aGVudGljYXRvckF0dGFjaG1lbnQ6ICdwbGF0Zm9ybScsXHJcbiAgICByZXNpZGVudEtleTogJ3JlcXVpcmVkJyxcclxuICAgIHVzZXJWZXJpZmljYXRpb246ICdyZXF1aXJlZCcsXHJcbiAgfSxcclxufSBhcyBjb25zdDtcclxuXHJcbi8qKlxyXG4gKiBNYXAgb2YgcHJlc2V0IG5hbWVzIHRvIHRoZWlyIGNvbmZpZ3VyYXRpb25zXHJcbiAqIFVzZWQgaW50ZXJuYWxseSBmb3IgcHJlc2V0IHJlc29sdXRpb25cclxuICovXHJcbmV4cG9ydCBjb25zdCBQUkVTRVRfTUFQID0ge1xyXG4gIHBhc3NrZXk6IFBBU1NLRVlfUFJFU0VULFxyXG4gIGV4dGVybmFsU2VjdXJpdHlLZXk6IEVYVEVSTkFMX1NFQ1VSSVRZX0tFWV9QUkVTRVQsXHJcbiAgcGxhdGZvcm1BdXRoZW50aWNhdG9yOiBQTEFURk9STV9BVVRIRU5USUNBVE9SX1BSRVNFVCxcclxufSBhcyBjb25zdDtcclxuXHJcbi8qKlxyXG4gKiBBdmFpbGFibGUgcHJlc2V0IG5hbWVzIGFzIGEgdW5pb24gdHlwZVxyXG4gKi9cclxuZXhwb3J0IHR5cGUgUHJlc2V0TmFtZSA9IGtleW9mIHR5cGVvZiBQUkVTRVRfTUFQO1xyXG4iXX0=","/**\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, with recursive merging for nested objects.\n *\n * @param target The target object to merge into\n * @param sources Source objects to merge from (processed left to right)\n * @returns The merged target object\n * @example\n * ```typescript\n * const result = deepMerge(\n * { a: 1, b: { x: 1 } },\n * { b: { y: 2 } },\n * { c: 3 }\n * );\n * // Result: { a: 1, b: { x: 1, y: 2 }, c: 3 }\n * ```\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 * Type guard to check if a value is a plain object (not array, null, or primitive).\n *\n * @param item The value to check\n * @returns True if the item is a plain object, false otherwise\n */\nfunction isObject(item) {\n return item && typeof item === 'object' && !Array.isArray(item);\n}\n/**\n * Generates a cryptographically secure random challenge for WebAuthn operations.\n * Uses the Web Crypto API for secure random number generation.\n *\n * @returns A 32-byte Uint8Array containing the random challenge\n */\nfunction generateChallenge() {\n return crypto.getRandomValues(new Uint8Array(32));\n}\n/**\n * Generates a unique user ID based on the username.\n * Creates a consistent, URL-safe identifier for the user.\n *\n * @param username The username to generate an ID from\n * @returns A Uint8Array containing the encoded user ID\n */\nfunction generateUserId(username) {\n return new TextEncoder().encode(username);\n}\n/**\n * Processes and normalizes challenge values from various input formats.\n * Handles string (base64url), Uint8Array, or generates a new challenge if none provided.\n *\n * @param challenge Optional challenge as string or Uint8Array\n * @returns Normalized Uint8Array challenge ready for WebAuthn API\n * @throws {Error} When provided string challenge is not valid base64url\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 * Processes and normalizes user ID values from various input formats.\n * Handles string (base64url), Uint8Array, or generates from username if none provided.\n *\n * @param userId Optional user ID as string or Uint8Array\n * @param username Username to generate ID from if userId not provided\n * @returns Normalized Uint8Array user ID ready for WebAuthn API\n * @throws {Error} When no userId provided and no username available for generation\n * @throws {Error} When provided string userId is not valid base64url\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 * Processes and normalizes credential descriptors from various input formats.\n * Converts string credential IDs to proper PublicKeyCredentialDescriptor objects.\n *\n * @param credentials Optional array of credential IDs (strings) or full descriptors\n * @returns Array of normalized PublicKeyCredentialDescriptor objects, or undefined if none provided\n * @throws {Error} When a credential ID string is not valid base64url\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 * Resolves a preset configuration by name.\n * Returns the complete preset configuration object for the specified preset.\n *\n * @param presetName The name of the preset to resolve\n * @returns The preset configuration object\n * @throws {Error} When the preset name is not found in PRESET_MAP\n *\n * @example\n * ```typescript\n * const preset = resolvePreset('passkey');\n * console.log(preset.authenticatorSelection.userVerification); // 'preferred'\n * ```\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 * Creates base creation options from WebAuthn service configuration.\n * Establishes default timeout and attestation settings that can be overridden later.\n *\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Partial creation options with base settings applied\n */\nfunction createBaseCreationOptions(webAuthnConfig) {\n return {\n timeout: webAuthnConfig.defaultTimeout || 60000,\n attestation: webAuthnConfig.defaultAttestation || 'none',\n };\n}\n/**\n * Applies preset configuration to base creation options.\n * Merges preset-specific authenticator selection and public key parameters into the options.\n *\n * @param config The register configuration containing preset information\n * @param baseOptions The base options to apply preset configuration to\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Options with preset configuration applied\n */\nfunction applyPresetConfiguration(config, baseOptions, webAuthnConfig) {\n if (config.preset) {\n const preset = resolvePreset(config.preset);\n return deepMerge(baseOptions, {\n authenticatorSelection: preset.authenticatorSelection,\n pubKeyCredParams: [...preset.pubKeyCredParams], // Convert readonly to mutable\n });\n }\n // Apply default authenticator selection from config when no preset\n if (webAuthnConfig.defaultAuthenticatorSelection) {\n return {\n ...baseOptions,\n authenticatorSelection: webAuthnConfig.defaultAuthenticatorSelection,\n };\n }\n return baseOptions;\n}\n/**\n * Applies user-specified overrides to creation options.\n * Allows users to override any preset or default settings with their own values.\n *\n * @param config The register configuration containing user overrides\n * @param options The options to apply user overrides to\n * @returns Options with user overrides applied\n */\nfunction applyUserOverrides(config, options) {\n const result = { ...options };\n if (config.timeout !== undefined) {\n result.timeout = config.timeout;\n }\n if (config.attestation !== undefined) {\n result.attestation = config.attestation;\n }\n if (config.authenticatorSelection !== undefined) {\n result.authenticatorSelection = deepMerge(result.authenticatorSelection || {}, config.authenticatorSelection);\n }\n if (config.pubKeyCredParams !== undefined) {\n result.pubKeyCredParams = config.pubKeyCredParams;\n }\n if (config.extensions !== undefined) {\n result.extensions = config.extensions;\n }\n return result;\n}\n/**\n * Assembles final creation options with all required WebAuthn fields.\n * Processes user information, challenge, and applies final service configuration.\n *\n * @param options The partially built options from previous steps\n * @param config The register configuration containing user and RP information\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Complete PublicKeyCredentialCreationOptions ready for WebAuthn API\n */\nfunction assembleFinalCreationOptions(options, config, webAuthnConfig) {\n const challenge = processChallenge(config.challenge);\n const userId = processUserId(config.userId, config.username);\n const relyingParty = config.rp || webAuthnConfig.relyingParty;\n return {\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}\n/**\n * Builds complete WebAuthn creation options from a high-level register configuration.\n *\n * This function orchestrates the creation option building process by:\n * 1. Creating base options from service configuration\n * 2. Applying preset-specific settings if specified\n * 3. Applying user overrides for customization\n * 4. Assembling final options with all required fields\n *\n * @param config The high-level register configuration with preset support\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Complete PublicKeyCredentialCreationOptions ready for navigator.credentials.create()\n *\n * @example\n * ```typescript\n * const config: RegisterConfig = {\n * preset: 'passkey',\n * user: {\n * id: 'user123',\n * name: 'user@example.com',\n * displayName: 'John Doe'\n * },\n * challenge: 'custom-challenge'\n * };\n *\n * const options = buildCreationOptionsFromConfig(config, webAuthnConfig);\n * // Returns complete creation options ready for WebAuthn API\n * ```\n */\nexport function buildCreationOptionsFromConfig(config, webAuthnConfig) {\n const baseOptions = createBaseCreationOptions(webAuthnConfig);\n const presetOptions = applyPresetConfiguration(config, baseOptions, webAuthnConfig);\n const finalOptions = applyUserOverrides(config, presetOptions);\n return assembleFinalCreationOptions(finalOptions, config, webAuthnConfig);\n}\n/**\n * Builds complete WebAuthn request options from a high-level authenticate configuration.\n *\n * Handles preset resolution, user overrides, and proper field processing to create\n * request options suitable for navigator.credentials.get().\n *\n * @param config The high-level authenticate configuration with preset support\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Complete PublicKeyCredentialRequestOptions ready for navigator.credentials.get()\n *\n * @example\n * ```typescript\n * const config: AuthenticateConfig = {\n * preset: 'passkey',\n * challenge: 'auth-challenge',\n * allowCredentials: ['cred-id-1', 'cred-id-2']\n * };\n *\n * const options = buildRequestOptionsFromConfig(config, webAuthnConfig);\n * // Returns complete request options ready for WebAuthn API\n * ```\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 * Validates a register configuration for completeness and correctness.\n * Ensures all required fields are present and properly formatted.\n *\n * @param config The register configuration to validate\n * @throws {Error} When required fields are missing or invalid\n *\n * @example\n * ```typescript\n * try {\n * validateRegisterConfig(config);\n * // Config is valid, proceed with registration\n * } catch (error) {\n * console.error('Invalid register config:', error.message);\n * }\n * ```\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 * Validates an authenticate configuration for completeness and correctness.\n * Ensures all required fields are present and properly formatted.\n *\n * @param config The authenticate configuration to validate\n * @throws {Error} When required fields are missing or invalid\n *\n * @example\n * ```typescript\n * try {\n * validateAuthenticateConfig(config);\n * // Config is valid, proceed with authentication\n * } catch (error) {\n * console.error('Invalid authenticate config:', error.message);\n * }\n * ```\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":["/**\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 */\n\nimport { PRESET_MAP, type PresetName } from '../presets/webauthn.presets';\nimport type { RegisterConfig, AuthenticateConfig } from '../model';\nimport type { WebAuthnConfig } from '../model/service-config';\n\n/**\n * Deep merge utility that properly handles nested objects.\n * Later properties override earlier ones, with recursive merging for nested objects.\n *\n * @param target The target object to merge into\n * @param sources Source objects to merge from (processed left to right)\n * @returns The merged target object\n * @example\n * ```typescript\n * const result = deepMerge(\n *   { a: 1, b: { x: 1 } },\n *   { b: { y: 2 } },\n *   { c: 3 }\n * );\n * // Result: { a: 1, b: { x: 1, y: 2 }, c: 3 }\n * ```\n */\nfunction deepMerge<T extends Record<string, any>>(\n  target: T,\n  ...sources: any[]\n): T {\n  if (!sources.length) return target;\n  const source = sources.shift();\n\n  if (isObject(target) && isObject(source)) {\n    for (const key in source) {\n      if (isObject(source[key])) {\n        if (!target[key]) Object.assign(target, { [key]: {} });\n        deepMerge(target[key], source[key]);\n      } else {\n        Object.assign(target, { [key]: source[key] });\n      }\n    }\n  }\n\n  return deepMerge(target, ...sources);\n}\n\n/**\n * Type guard to check if a value is a plain object (not array, null, or primitive).\n *\n * @param item The value to check\n * @returns True if the item is a plain object, false otherwise\n */\nfunction isObject(item: any): item is Record<string, any> {\n  return item && typeof item === 'object' && !Array.isArray(item);\n}\n\n/**\n * Generates a cryptographically secure random challenge for WebAuthn operations.\n * Uses the Web Crypto API for secure random number generation.\n *\n * @returns A 32-byte Uint8Array containing the random challenge\n */\nfunction generateChallenge(): Uint8Array {\n  return crypto.getRandomValues(new Uint8Array(32));\n}\n\n/**\n * Generates a unique user ID based on the username.\n * Creates a consistent, URL-safe identifier for the user.\n *\n * @param username The username to generate an ID from\n * @returns A Uint8Array containing the encoded user ID\n */\nfunction generateUserId(username: string): Uint8Array {\n  return new TextEncoder().encode(username);\n}\n\n/**\n * Processes and normalizes challenge values from various input formats.\n * Handles string (base64url), Uint8Array, or generates a new challenge if none provided.\n *\n * @param challenge Optional challenge as string or Uint8Array\n * @returns Normalized Uint8Array challenge ready for WebAuthn API\n * @throws {Error} When provided string challenge is not valid base64url\n */\nfunction processChallenge(challenge?: string | Uint8Array): Uint8Array {\n  if (!challenge) {\n    return generateChallenge();\n  }\n\n  if (typeof challenge === 'string') {\n    // Assume base64url string, convert to Uint8Array\n    return Uint8Array.from(\n      atob(challenge.replace(/-/g, '+').replace(/_/g, '/')),\n      (c) => c.charCodeAt(0)\n    );\n  }\n\n  return challenge;\n}\n\n/**\n * Processes and normalizes user ID values from various input formats.\n * Handles string (base64url), Uint8Array, or generates from username if none provided.\n *\n * @param userId Optional user ID as string or Uint8Array\n * @param username Username to generate ID from if userId not provided\n * @returns Normalized Uint8Array user ID ready for WebAuthn API\n * @throws {Error} When no userId provided and no username available for generation\n * @throws {Error} When provided string userId is not valid base64url\n */\nfunction processUserId(\n  userId?: string | Uint8Array,\n  username?: string\n): Uint8Array {\n  if (userId) {\n    if (typeof userId === 'string') {\n      // Assume base64url string, convert to Uint8Array\n      return Uint8Array.from(\n        atob(userId.replace(/-/g, '+').replace(/_/g, '/')),\n        (c) => c.charCodeAt(0)\n      );\n    }\n    return userId;\n  }\n\n  if (username) {\n    return generateUserId(username);\n  }\n\n  // Fallback to random ID\n  return crypto.getRandomValues(new Uint8Array(16));\n}\n\n/**\n * Processes and normalizes credential descriptors from various input formats.\n * Converts string credential IDs to proper PublicKeyCredentialDescriptor objects.\n *\n * @param credentials Optional array of credential IDs (strings) or full descriptors\n * @returns Array of normalized PublicKeyCredentialDescriptor objects, or undefined if none provided\n * @throws {Error} When a credential ID string is not valid base64url\n */\nfunction processCredentialDescriptors(\n  credentials?: PublicKeyCredentialDescriptor[] | string[]\n): PublicKeyCredentialDescriptor[] | undefined {\n  if (!credentials || credentials.length === 0) {\n    return undefined;\n  }\n\n  // If already in descriptor format, return as-is\n  if (typeof credentials[0] === 'object' && 'type' in credentials[0]) {\n    return credentials as PublicKeyCredentialDescriptor[];\n  }\n\n  // Convert string IDs to descriptors\n  return (credentials as string[]).map((id) => ({\n    type: 'public-key' as const,\n    id: Uint8Array.from(atob(id.replace(/-/g, '+').replace(/_/g, '/')), (c) =>\n      c.charCodeAt(0)\n    ),\n  }));\n}\n\n/**\n * Resolves a preset configuration by name.\n * Returns the complete preset configuration object for the specified preset.\n *\n * @param presetName The name of the preset to resolve\n * @returns The preset configuration object\n * @throws {Error} When the preset name is not found in PRESET_MAP\n *\n * @example\n * ```typescript\n * const preset = resolvePreset('passkey');\n * console.log(preset.authenticatorSelection.userVerification); // 'preferred'\n * ```\n */\nexport function resolvePreset(presetName: PresetName) {\n  const preset = PRESET_MAP[presetName];\n  if (!preset) {\n    throw new Error(`Unknown preset: ${presetName}`);\n  }\n  return preset;\n}\n\n/**\n * Creates base creation options from WebAuthn service configuration.\n * Establishes default timeout and attestation settings that can be overridden later.\n *\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Partial creation options with base settings applied\n */\nfunction createBaseCreationOptions(\n  webAuthnConfig: WebAuthnConfig\n): Partial<PublicKeyCredentialCreationOptions> {\n  return {\n    timeout: webAuthnConfig.defaultTimeout || 60000,\n    attestation: webAuthnConfig.defaultAttestation || 'none',\n  };\n}\n\n/**\n * Applies preset configuration to base creation options.\n * Merges preset-specific authenticator selection and public key parameters into the options.\n *\n * @param config The register configuration containing preset information\n * @param baseOptions The base options to apply preset configuration to\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Options with preset configuration applied\n */\nfunction applyPresetConfiguration(\n  config: RegisterConfig,\n  baseOptions: Partial<PublicKeyCredentialCreationOptions>,\n  webAuthnConfig: WebAuthnConfig\n): Partial<PublicKeyCredentialCreationOptions> {\n  if (config.preset) {\n    const preset = resolvePreset(config.preset);\n    return deepMerge(baseOptions, {\n      authenticatorSelection: preset.authenticatorSelection,\n      pubKeyCredParams: [...preset.pubKeyCredParams], // Convert readonly to mutable\n    });\n  }\n\n  // Apply default authenticator selection from config when no preset\n  if (webAuthnConfig.defaultAuthenticatorSelection) {\n    return {\n      ...baseOptions,\n      authenticatorSelection: webAuthnConfig.defaultAuthenticatorSelection,\n    };\n  }\n\n  return baseOptions;\n}\n\n/**\n * Applies user-specified overrides to creation options.\n * Allows users to override any preset or default settings with their own values.\n *\n * @param config The register configuration containing user overrides\n * @param options The options to apply user overrides to\n * @returns Options with user overrides applied\n */\nfunction applyUserOverrides(\n  config: RegisterConfig,\n  options: Partial<PublicKeyCredentialCreationOptions>\n): Partial<PublicKeyCredentialCreationOptions> {\n  const result = { ...options };\n\n  if (config.timeout !== undefined) {\n    result.timeout = config.timeout;\n  }\n\n  if (config.attestation !== undefined) {\n    result.attestation = config.attestation;\n  }\n\n  if (config.authenticatorSelection !== undefined) {\n    result.authenticatorSelection = deepMerge(\n      result.authenticatorSelection || {},\n      config.authenticatorSelection\n    );\n  }\n\n  if (config.pubKeyCredParams !== undefined) {\n    result.pubKeyCredParams = config.pubKeyCredParams;\n  }\n\n  if (config.extensions !== undefined) {\n    result.extensions = config.extensions;\n  }\n\n  return result;\n}\n\n/**\n * Assembles final creation options with all required WebAuthn fields.\n * Processes user information, challenge, and applies final service configuration.\n *\n * @param options The partially built options from previous steps\n * @param config The register configuration containing user and RP information\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Complete PublicKeyCredentialCreationOptions ready for WebAuthn API\n */\nfunction assembleFinalCreationOptions(\n  options: Partial<PublicKeyCredentialCreationOptions>,\n  config: RegisterConfig,\n  webAuthnConfig: WebAuthnConfig\n): PublicKeyCredentialCreationOptions {\n  const challenge = processChallenge(config.challenge);\n  const userId = processUserId(config.userId, config.username);\n  const relyingParty = config.rp || webAuthnConfig.relyingParty;\n\n  return {\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}\n\n/**\n * Builds complete WebAuthn creation options from a high-level register configuration.\n *\n * This function orchestrates the creation option building process by:\n * 1. Creating base options from service configuration\n * 2. Applying preset-specific settings if specified\n * 3. Applying user overrides for customization\n * 4. Assembling final options with all required fields\n *\n * @param config The high-level register configuration with preset support\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Complete PublicKeyCredentialCreationOptions ready for navigator.credentials.create()\n *\n * @example\n * ```typescript\n * const config: RegisterConfig = {\n *   preset: 'passkey',\n *   user: {\n *     id: 'user123',\n *     name: 'user@example.com',\n *     displayName: 'John Doe'\n *   },\n *   challenge: 'custom-challenge'\n * };\n *\n * const options = buildCreationOptionsFromConfig(config, webAuthnConfig);\n * // Returns complete creation options ready for WebAuthn API\n * ```\n */\nexport function buildCreationOptionsFromConfig(\n  config: RegisterConfig,\n  webAuthnConfig: WebAuthnConfig\n): PublicKeyCredentialCreationOptions {\n  const baseOptions = createBaseCreationOptions(webAuthnConfig);\n  const presetOptions = applyPresetConfiguration(\n    config,\n    baseOptions,\n    webAuthnConfig\n  );\n  const finalOptions = applyUserOverrides(config, presetOptions);\n  return assembleFinalCreationOptions(finalOptions, config, webAuthnConfig);\n}\n\n/**\n * Builds complete WebAuthn request options from a high-level authenticate configuration.\n *\n * Handles preset resolution, user overrides, and proper field processing to create\n * request options suitable for navigator.credentials.get().\n *\n * @param config The high-level authenticate configuration with preset support\n * @param webAuthnConfig The global WebAuthn service configuration\n * @returns Complete PublicKeyCredentialRequestOptions ready for navigator.credentials.get()\n *\n * @example\n * ```typescript\n * const config: AuthenticateConfig = {\n *   preset: 'passkey',\n *   challenge: 'auth-challenge',\n *   allowCredentials: ['cred-id-1', 'cred-id-2']\n * };\n *\n * const options = buildRequestOptionsFromConfig(config, webAuthnConfig);\n * // Returns complete request options ready for WebAuthn API\n * ```\n */\nexport function buildRequestOptionsFromConfig(\n  config: AuthenticateConfig,\n  webAuthnConfig: WebAuthnConfig\n): PublicKeyCredentialRequestOptions {\n  // Start with base configuration from WebAuthnConfig\n  const options: Partial<PublicKeyCredentialRequestOptions> = {\n    timeout: webAuthnConfig.defaultTimeout || 60000,\n    userVerification: webAuthnConfig.enforceUserVerification\n      ? 'required'\n      : 'preferred',\n  };\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\n  // Apply user overrides\n  if (config.timeout !== undefined) {\n    options.timeout = config.timeout;\n  }\n\n  if (config.userVerification !== undefined) {\n    options.userVerification = config.userVerification;\n  }\n\n  if (config.extensions !== undefined) {\n    options.extensions = config.extensions;\n  }\n\n  // Handle required fields\n  const challenge = processChallenge(config.challenge);\n\n  // Build final options\n  const finalOptions: PublicKeyCredentialRequestOptions = {\n    ...options,\n    challenge,\n    allowCredentials: processCredentialDescriptors(config.allowCredentials),\n  };\n\n  return finalOptions;\n}\n\n/**\n * Validates a register configuration for completeness and correctness.\n * Ensures all required fields are present and properly formatted.\n *\n * @param config The register configuration to validate\n * @throws {Error} When required fields are missing or invalid\n *\n * @example\n * ```typescript\n * try {\n *   validateRegisterConfig(config);\n *   // Config is valid, proceed with registration\n * } catch (error) {\n *   console.error('Invalid register config:', error.message);\n * }\n * ```\n */\nexport function validateRegisterConfig(config: RegisterConfig): void {\n  if (!config.username || typeof config.username !== 'string') {\n    throw new Error('RegisterConfig must have a valid username');\n  }\n\n  if (config.preset && !PRESET_MAP[config.preset]) {\n    throw new Error(\n      `Invalid preset: ${config.preset}. Valid presets are: ${Object.keys(\n        PRESET_MAP\n      ).join(', ')}`\n    );\n  }\n}\n\n/**\n * Validates an authenticate configuration for completeness and correctness.\n * Ensures all required fields are present and properly formatted.\n *\n * @param config The authenticate configuration to validate\n * @throws {Error} When required fields are missing or invalid\n *\n * @example\n * ```typescript\n * try {\n *   validateAuthenticateConfig(config);\n *   // Config is valid, proceed with authentication\n * } catch (error) {\n *   console.error('Invalid authenticate config:', error.message);\n * }\n * ```\n */\nexport function validateAuthenticateConfig(config: AuthenticateConfig): void {\n  if (config.preset && !PRESET_MAP[config.preset]) {\n    throw new Error(\n      `Invalid preset: ${config.preset}. Valid presets are: ${Object.keys(\n        PRESET_MAP\n      ).join(', ')}`\n    );\n  }\n}\n"]}","/**\n * Enhanced WebAuthn Error Classes\n * Provides specific, actionable error types for better developer experience\n */\n/**\n * Enumeration of WebAuthn error types for categorizing different failure scenarios.\n * Provides semantic error classification for better error handling and user 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[\"REMOTE_ENDPOINT_ERROR\"] = \"REMOTE_ENDPOINT_ERROR\";\n WebAuthnErrorType[\"INVALID_REMOTE_OPTIONS\"] = \"INVALID_REMOTE_OPTIONS\";\n WebAuthnErrorType[\"UNKNOWN\"] = \"UNKNOWN\";\n})(WebAuthnErrorType || (WebAuthnErrorType = {}));\n/**\n * Base WebAuthn error class that provides enhanced error information.\n * All WebAuthn-specific errors extend from this class for consistent error handling.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.register(config);\n * } catch (error) {\n * if (error instanceof WebAuthnError) {\n * console.log('Error type:', error.type);\n * console.log('Original error:', error.originalError);\n * }\n * }\n * ```\n */\nexport class WebAuthnError extends Error {\n type;\n originalError;\n /**\n * Creates a new WebAuthnError instance.\n *\n * @param type The semantic error type\n * @param message Human-readable error message\n * @param originalError The original error that caused this WebAuthn error (optional)\n */\n constructor(type, message, originalError) {\n super(message);\n this.type = type;\n this.originalError = originalError;\n this.name = 'WebAuthnError';\n }\n /**\n * Factory method to create WebAuthnError from DOMException.\n * Maps browser DOMException types to semantic WebAuthn error types.\n *\n * @param error The DOMException thrown by WebAuthn API\n * @returns Appropriate WebAuthnError subclass based on the DOMException type\n */\n static fromDOMException(error) {\n const type = WebAuthnError.mapDOMExceptionToType(error.name);\n return new WebAuthnError(type, error.message, error);\n }\n /**\n * Maps DOMException names to WebAuthn error types.\n * Provides semantic classification of browser-level errors.\n *\n * @param name The DOMException name\n * @returns Corresponding WebAuthnErrorType\n * @private\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 the user cancels a WebAuthn operation.\n * This is the most common error and typically requires no action from the developer.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.register(config);\n * } catch (error) {\n * if (error instanceof UserCancelledError) {\n * // User chose not to proceed - this is normal behavior\n * console.log('User cancelled the operation');\n * }\n * }\n * ```\n */\nexport class UserCancelledError extends WebAuthnError {\n /**\n * Creates a new UserCancelledError.\n *\n * @param originalError The original DOMException that triggered this error (optional)\n */\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 device.\n * This could indicate hardware problems, invalid state, or other device-specific issues.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.authenticate(config);\n * } catch (error) {\n * if (error instanceof AuthenticatorError) {\n * // Show user-friendly message about trying again or using different authenticator\n * console.log('Authenticator issue:', error.message);\n * }\n * }\n * ```\n */\nexport class AuthenticatorError extends WebAuthnError {\n /**\n * Creates a new AuthenticatorError.\n *\n * @param message Descriptive error message\n * @param originalError The original error that caused this authenticator error (optional)\n */\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 WebAuthn options are invalid or malformed.\n * This typically indicates a programming error in option construction.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.register(invalidConfig);\n * } catch (error) {\n * if (error instanceof InvalidOptionsError) {\n * // Check your configuration and options\n * console.error('Invalid options provided:', error.message);\n * }\n * }\n * ```\n */\nexport class InvalidOptionsError extends WebAuthnError {\n /**\n * Creates a new InvalidOptionsError.\n *\n * @param message Descriptive error message explaining what's invalid\n * @param originalError The original error that revealed the invalid options (optional)\n */\n constructor(message, originalError) {\n super(WebAuthnErrorType.INVALID_OPTIONS, `Invalid options: ${message}`, originalError);\n this.name = 'InvalidOptionsError';\n }\n}\n/**\n * Error thrown when a WebAuthn operation is not supported in the current environment.\n * This could be due to browser limitations or missing hardware capabilities.\n *\n * @example\n * ```typescript\n * if (!webAuthnService.isSupported()) {\n * // Handle unsupported environment\n * }\n *\n * try {\n * await webAuthnService.register(config);\n * } catch (error) {\n * if (error instanceof UnsupportedOperationError) {\n * // Show fallback authentication method\n * console.log('WebAuthn not supported, using fallback');\n * }\n * }\n * ```\n */\nexport class UnsupportedOperationError extends WebAuthnError {\n /**\n * Creates a new UnsupportedOperationError.\n *\n * @param message Descriptive error message explaining what's not supported\n * @param originalError The original error that indicated lack of support (optional)\n */\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 during WebAuthn operations.\n * This is rare but can occur in certain network conditions.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.authenticate(config);\n * } catch (error) {\n * if (error instanceof NetworkError) {\n * // Suggest user check connection and retry\n * console.log('Network issue during authentication:', error.message);\n * }\n * }\n * ```\n */\nexport class NetworkError extends WebAuthnError {\n /**\n * Creates a new NetworkError.\n *\n * @param message Descriptive error message about the network issue\n * @param originalError The original network-related error (optional)\n */\n constructor(message, originalError) {\n super(WebAuthnErrorType.NETWORK_ERROR, `Network error: ${message}`, originalError);\n this.name = 'NetworkError';\n }\n}\n/**\n * Error thrown when a security violation occurs during WebAuthn operations.\n * This typically indicates issues with origin validation or other security checks.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.register(config);\n * } catch (error) {\n * if (error instanceof SecurityError) {\n * // Security issue - check origin, HTTPS, etc.\n * console.error('Security violation:', error.message);\n * }\n * }\n * ```\n */\nexport class SecurityError extends WebAuthnError {\n /**\n * Creates a new SecurityError.\n *\n * @param message Descriptive error message about the security issue\n * @param originalError The original security-related error (optional)\n */\n constructor(message, originalError) {\n super(WebAuthnErrorType.SECURITY_ERROR, `Security error: ${message}`, originalError);\n this.name = 'SecurityError';\n }\n}\n/**\n * Error thrown when a WebAuthn operation times out.\n * This can happen when the user takes too long to interact with their authenticator.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.register(config);\n * } catch (error) {\n * if (error instanceof TimeoutError) {\n * // Suggest user try again and respond more quickly\n * console.log('Operation timed out - please try again');\n * }\n * }\n * ```\n */\nexport class TimeoutError extends WebAuthnError {\n /**\n * Creates a new TimeoutError.\n *\n * @param message Descriptive error message about the timeout\n * @param originalError The original timeout-related error (optional)\n */\n constructor(message, originalError) {\n super(WebAuthnErrorType.TIMEOUT_ERROR, `Timeout error: ${message}`, originalError);\n this.name = 'TimeoutError';\n }\n}\n/**\n * Error thrown when remote endpoint request fails.\n * Includes network errors, HTTP errors, and timeout errors.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.registerRemote(request);\n * } catch (error) {\n * if (error instanceof RemoteEndpointError) {\n * console.log('Endpoint:', error.context.url);\n * console.log('Status:', error.context.status);\n * }\n * }\n * ```\n */\nexport class RemoteEndpointError extends WebAuthnError {\n context;\n /**\n * Creates a new RemoteEndpointError.\n *\n * @param message Descriptive error message about the remote endpoint failure\n * @param context Contextual information about the failed request\n * @param originalError The original error that caused this remote endpoint error (optional)\n */\n constructor(message, context, originalError) {\n super(WebAuthnErrorType.REMOTE_ENDPOINT_ERROR, `Remote endpoint error: ${message}`, originalError);\n this.context = context;\n this.name = 'RemoteEndpointError';\n }\n}\n/**\n * Error thrown when remote server returns invalid WebAuthn options.\n * This indicates the server response doesn't match expected WebAuthn option format.\n *\n * @example\n * ```typescript\n * try {\n * await webAuthnService.registerRemote(request);\n * } catch (error) {\n * if (error instanceof InvalidRemoteOptionsError) {\n * console.log('Invalid server response:', error.message);\n * }\n * }\n * ```\n */\nexport class InvalidRemoteOptionsError extends WebAuthnError {\n /**\n * Creates a new InvalidRemoteOptionsError.\n *\n * @param message Descriptive error message about the invalid remote options\n * @param originalError The original error that revealed the invalid options (optional)\n */\n constructor(message, originalError) {\n super(WebAuthnErrorType.INVALID_REMOTE_OPTIONS, `Invalid remote options: ${message}`, originalError);\n this.name = 'InvalidRemoteOptionsError';\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\n/**\n * Enumeration of WebAuthn error types for categorizing different failure scenarios.\n * Provides semantic error classification for better error handling and user experience.\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  REMOTE_ENDPOINT_ERROR = 'REMOTE_ENDPOINT_ERROR',\n  INVALID_REMOTE_OPTIONS = 'INVALID_REMOTE_OPTIONS',\n  UNKNOWN = 'UNKNOWN',\n}\n\n/**\n * Base WebAuthn error class that provides enhanced error information.\n * All WebAuthn-specific errors extend from this class for consistent error handling.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.register(config);\n * } catch (error) {\n *   if (error instanceof WebAuthnError) {\n *     console.log('Error type:', error.type);\n *     console.log('Original error:', error.originalError);\n *   }\n * }\n * ```\n */\nexport class WebAuthnError extends Error {\n  /**\n   * Creates a new WebAuthnError instance.\n   *\n   * @param type The semantic error type\n   * @param message Human-readable error message\n   * @param originalError The original error that caused this WebAuthn error (optional)\n   */\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  /**\n   * Factory method to create WebAuthnError from DOMException.\n   * Maps browser DOMException types to semantic WebAuthn error types.\n   *\n   * @param error The DOMException thrown by WebAuthn API\n   * @returns Appropriate WebAuthnError subclass based on the DOMException type\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  /**\n   * Maps DOMException names to WebAuthn error types.\n   * Provides semantic classification of browser-level errors.\n   *\n   * @param name The DOMException name\n   * @returns Corresponding WebAuthnErrorType\n   * @private\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 the user cancels a WebAuthn operation.\n * This is the most common error and typically requires no action from the developer.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.register(config);\n * } catch (error) {\n *   if (error instanceof UserCancelledError) {\n *     // User chose not to proceed - this is normal behavior\n *     console.log('User cancelled the operation');\n *   }\n * }\n * ```\n */\nexport class UserCancelledError extends WebAuthnError {\n  /**\n   * Creates a new UserCancelledError.\n   *\n   * @param originalError The original DOMException that triggered this error (optional)\n   */\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 device.\n * This could indicate hardware problems, invalid state, or other device-specific issues.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.authenticate(config);\n * } catch (error) {\n *   if (error instanceof AuthenticatorError) {\n *     // Show user-friendly message about trying again or using different authenticator\n *     console.log('Authenticator issue:', error.message);\n *   }\n * }\n * ```\n */\nexport class AuthenticatorError extends WebAuthnError {\n  /**\n   * Creates a new AuthenticatorError.\n   *\n   * @param message Descriptive error message\n   * @param originalError The original error that caused this authenticator error (optional)\n   */\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 WebAuthn options are invalid or malformed.\n * This typically indicates a programming error in option construction.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.register(invalidConfig);\n * } catch (error) {\n *   if (error instanceof InvalidOptionsError) {\n *     // Check your configuration and options\n *     console.error('Invalid options provided:', error.message);\n *   }\n * }\n * ```\n */\nexport class InvalidOptionsError extends WebAuthnError {\n  /**\n   * Creates a new InvalidOptionsError.\n   *\n   * @param message Descriptive error message explaining what's invalid\n   * @param originalError The original error that revealed the invalid options (optional)\n   */\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 a WebAuthn operation is not supported in the current environment.\n * This could be due to browser limitations or missing hardware capabilities.\n *\n * @example\n * ```typescript\n * if (!webAuthnService.isSupported()) {\n *   // Handle unsupported environment\n * }\n *\n * try {\n *   await webAuthnService.register(config);\n * } catch (error) {\n *   if (error instanceof UnsupportedOperationError) {\n *     // Show fallback authentication method\n *     console.log('WebAuthn not supported, using fallback');\n *   }\n * }\n * ```\n */\nexport class UnsupportedOperationError extends WebAuthnError {\n  /**\n   * Creates a new UnsupportedOperationError.\n   *\n   * @param message Descriptive error message explaining what's not supported\n   * @param originalError The original error that indicated lack of support (optional)\n   */\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 during WebAuthn operations.\n * This is rare but can occur in certain network conditions.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.authenticate(config);\n * } catch (error) {\n *   if (error instanceof NetworkError) {\n *     // Suggest user check connection and retry\n *     console.log('Network issue during authentication:', error.message);\n *   }\n * }\n * ```\n */\nexport class NetworkError extends WebAuthnError {\n  /**\n   * Creates a new NetworkError.\n   *\n   * @param message Descriptive error message about the network issue\n   * @param originalError The original network-related error (optional)\n   */\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 a security violation occurs during WebAuthn operations.\n * This typically indicates issues with origin validation or other security checks.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.register(config);\n * } catch (error) {\n *   if (error instanceof SecurityError) {\n *     // Security issue - check origin, HTTPS, etc.\n *     console.error('Security violation:', error.message);\n *   }\n * }\n * ```\n */\nexport class SecurityError extends WebAuthnError {\n  /**\n   * Creates a new SecurityError.\n   *\n   * @param message Descriptive error message about the security issue\n   * @param originalError The original security-related error (optional)\n   */\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 a WebAuthn operation times out.\n * This can happen when the user takes too long to interact with their authenticator.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.register(config);\n * } catch (error) {\n *   if (error instanceof TimeoutError) {\n *     // Suggest user try again and respond more quickly\n *     console.log('Operation timed out - please try again');\n *   }\n * }\n * ```\n */\nexport class TimeoutError extends WebAuthnError {\n  /**\n   * Creates a new TimeoutError.\n   *\n   * @param message Descriptive error message about the timeout\n   * @param originalError The original timeout-related error (optional)\n   */\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/**\n * Context information for remote endpoint errors (security-conscious)\n */\nexport interface RemoteErrorContext {\n  readonly url: string;\n  readonly method: string;\n  readonly operation: 'registration' | 'authentication';\n  readonly status?: number;\n  readonly statusText?: string;\n  // Intentionally excludes request/response bodies for security\n}\n\n/**\n * Error thrown when remote endpoint request fails.\n * Includes network errors, HTTP errors, and timeout errors.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.registerRemote(request);\n * } catch (error) {\n *   if (error instanceof RemoteEndpointError) {\n *     console.log('Endpoint:', error.context.url);\n *     console.log('Status:', error.context.status);\n *   }\n * }\n * ```\n */\nexport class RemoteEndpointError extends WebAuthnError {\n  /**\n   * Creates a new RemoteEndpointError.\n   *\n   * @param message Descriptive error message about the remote endpoint failure\n   * @param context Contextual information about the failed request\n   * @param originalError The original error that caused this remote endpoint error (optional)\n   */\n  constructor(\n    message: string,\n    public readonly context: RemoteErrorContext,\n    originalError?: Error\n  ) {\n    super(\n      WebAuthnErrorType.REMOTE_ENDPOINT_ERROR,\n      `Remote endpoint error: ${message}`,\n      originalError\n    );\n    this.name = 'RemoteEndpointError';\n  }\n}\n\n/**\n * Error thrown when remote server returns invalid WebAuthn options.\n * This indicates the server response doesn't match expected WebAuthn option format.\n *\n * @example\n * ```typescript\n * try {\n *   await webAuthnService.registerRemote(request);\n * } catch (error) {\n *   if (error instanceof InvalidRemoteOptionsError) {\n *     console.log('Invalid server response:', error.message);\n *   }\n * }\n * ```\n */\nexport class InvalidRemoteOptionsError extends WebAuthnError {\n  /**\n   * Creates a new InvalidRemoteOptionsError.\n   *\n   * @param message Descriptive error message about the invalid remote options\n   * @param originalError The original error that revealed the invalid options (optional)\n   */\n  constructor(message: string, originalError?: Error) {\n    super(\n      WebAuthnErrorType.INVALID_REMOTE_OPTIONS,\n      `Invalid remote options: ${message}`,\n      originalError\n    );\n    this.name = 'InvalidRemoteOptionsError';\n  }\n}\n"]}","/**\n * Service-level configuration for WebAuthn operations\n *\n * These interfaces define the global configuration that affects the entire WebAuthn service,\n * including relying party information and default settings.\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL25neC13ZWJhdXRobi9zcmMvbGliL21vZGVsL3NlcnZpY2UtY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OztHQUtHO0FBRUgsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQW1GL0M7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQXlDO0lBQzNFLGNBQWMsRUFBRSxLQUFLO0lBQ3JCLGlCQUFpQixFQUFFO1FBQ2pCLEVBQUUsSUFBSSxFQUFFLFlBQVksRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLEVBQUUsRUFBRSwyQkFBMkI7UUFDNUQsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFLEdBQUcsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLHVDQUF1QztLQUMzRTtJQUNELHVCQUF1QixFQUFFLEtBQUs7SUFDOUIsa0JBQWtCLEVBQUUsTUFBTTtJQUMxQiw2QkFBNkIsRUFBRTtRQUM3QixnQkFBZ0IsRUFBRSxXQUFXO0tBQzlCO0NBQ0YsQ0FBQztBQUVGOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLElBQUksY0FBYyxDQUMvQyxpQkFBaUIsQ0FDbEIsQ0FBQztBQUVGOzs7O0dBSUc7QUFDSCxNQUFNLFVBQVUsb0JBQW9CLENBQ2xDLFlBQWdDLEVBQ2hDLFNBQXlEO0lBRXpELE9BQU87UUFDTCxZQUFZO1FBQ1osR0FBRyx1QkFBdUI7UUFDMUIsR0FBRyxTQUFTO0tBQ2IsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFNlcnZpY2UtbGV2ZWwgY29uZmlndXJhdGlvbiBmb3IgV2ViQXV0aG4gb3BlcmF0aW9uc1xuICpcbiAqIFRoZXNlIGludGVyZmFjZXMgZGVmaW5lIHRoZSBnbG9iYWwgY29uZmlndXJhdGlvbiB0aGF0IGFmZmVjdHMgdGhlIGVudGlyZSBXZWJBdXRobiBzZXJ2aWNlLFxuICogaW5jbHVkaW5nIHJlbHlpbmcgcGFydHkgaW5mb3JtYXRpb24gYW5kIGRlZmF1bHQgc2V0dGluZ3MuXG4gKi9cblxuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBSZXF1aXJlZCByZWx5aW5nIHBhcnR5IGNvbmZpZ3VyYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBSZWx5aW5nUGFydHlDb25maWcge1xuICAvKipcbiAgICogSHVtYW4tcmVhZGFibGUgaWRlbnRpZmllciBmb3IgdGhlIFJlbHlpbmcgUGFydHlcbiAgICogQGV4YW1wbGUgXCJBQ01FIENvcnBvcmF0aW9uXCJcbiAgICovXG4gIG5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogQSB2YWxpZCBkb21haW4gc3RyaW5nIHRoYXQgaWRlbnRpZmllcyB0aGUgUmVseWluZyBQYXJ0eSBvbiB3aG9zZSBiZWhhbGYgYSBnaXZlbiByZWdpc3RyYXRpb24gb3IgYXV0aGVudGljYXRpb24gY2VyZW1vbnkgaXMgYmVpbmcgcGVyZm9ybWVkXG4gICAqIEBleGFtcGxlIFwibG9naW4uZXhhbXBsZS5jb21cIiBvciBcImV4YW1wbGUuY29tXCJcbiAgICovXG4gIGlkPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gaW50ZXJmYWNlIGZvciBXZWJBdXRobiBzZXJ2aWNlXG4gKiBOb3cgaW5jbHVkZXMgcmVxdWlyZWQgcmVseWluZyBwYXJ0eSBpbmZvcm1hdGlvbiBhbmQgYWR2YW5jZWQgb3B0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFdlYkF1dGhuQ29uZmlnIHtcbiAgLyoqXG4gICAqIFJlcXVpcmVkIHJlbHlpbmcgcGFydHkgaW5mb3JtYXRpb24gZm9yIFdlYkF1dGhuIG9wZXJhdGlvbnNcbiAgICogVGhpcyBpcyBjcml0aWNhbCBmb3Igc2VjdXJpdHkgLSBtdXN0IGJlIGNvbmZpZ3VyZWQgcHJvcGVybHkgZm9yIHByb2R1Y3Rpb24gdXNlXG4gICAqL1xuICByZWx5aW5nUGFydHk6IFJlbHlpbmdQYXJ0eUNvbmZpZztcblxuICAvKipcbiAgICogRGVmYXVsdCB0aW1lb3V0IGZvciBXZWJBdXRobiBvcGVyYXRpb25zIGluIG1pbGxpc2Vjb25kc1xuICAgKiBAZGVmYXVsdCA2MDAwMFxuICAgKi9cbiAgZGVmYXVsdFRpbWVvdXQ/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIERlZmF1bHQgcHVibGljIGtleSBjcmVkZW50aWFsIGFsZ29yaXRobXMgaW4gb3JkZXIgb2YgcHJlZmVyZW5jZVxuICAgKiBAZGVmYXVsdCBbRVMyNTYsIFJTMjU2XVxuICAgKi9cbiAgZGVmYXVsdEFsZ29yaXRobXM/OiBQdWJsaWNLZXlDcmVkZW50aWFsUGFyYW1ldGVyc1tdO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIGVuZm9yY2UgdXNlciB2ZXJpZmljYXRpb24gYnkgZGVmYXVsdFxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgZW5mb3JjZVVzZXJWZXJpZmljYXRpb24/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBEZWZhdWx0IGF0dGVzdGF0aW9uIGNvbnZleWFuY2UgcHJlZmVyZW5jZVxuICAgKiBAZGVmYXVsdCBcIm5vbmVcIlxuICAgKi9cbiAgZGVmYXVsdEF0dGVzdGF0aW9uPzogQXR0ZXN0YXRpb25Db252ZXlhbmNlUHJlZmVyZW5jZTtcblxuICAvKipcbiAgICogRGVmYXVsdCBhdXRoZW50aWNhdG9yIHNlbGVjdGlvbiBjcml0ZXJpYVxuICAgKi9cbiAgZGVmYXVsdEF1dGhlbnRpY2F0b3JTZWxlY3Rpb24/OiBBdXRoZW50aWNhdG9yU2VsZWN0aW9uQ3JpdGVyaWE7XG5cbiAgLyoqXG4gICAqIE9wdGlvbmFsIHJlbW90ZSBlbmRwb2ludHMgZm9yIGZldGNoaW5nIFdlYkF1dGhuIG9wdGlvbnMgZnJvbSBzZXJ2ZXJcbiAgICovXG4gIHJlbW90ZUVuZHBvaW50cz86IHtcbiAgICAvKipcbiAgICAgKiBBYnNvbHV0ZSBVUkwgZm9yIGZldGNoaW5nIFB1YmxpY0tleUNyZWRlbnRpYWxDcmVhdGlvbk9wdGlvbnNKU09OXG4gICAgICogQGV4YW1wbGUgXCJodHRwczovL2FwaS5leGFtcGxlLmNvbS93ZWJhdXRobi9yZWdpc3RyYXRpb24vb3B0aW9uc1wiXG4gICAgICovXG4gICAgcmVnaXN0cmF0aW9uPzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQWJzb2x1dGUgVVJMIGZvciBmZXRjaGluZyBQdWJsaWNLZXlDcmVkZW50aWFsUmVxdWVzdE9wdGlvbnNKU09OXG4gICAgICogQGV4YW1wbGUgXCJodHRwczovL2FwaS5leGFtcGxlLmNvbS93ZWJhdXRobi9hdXRoZW50aWNhdGlvbi9vcHRpb25zXCJcbiAgICAgKi9cbiAgICBhdXRoZW50aWNhdGlvbj86IHN0cmluZztcblxuICAgIC8qKiBIVFRQIHJlcXVlc3QgY29uZmlndXJhdGlvbiAqL1xuICAgIHJlcXVlc3RPcHRpb25zPzoge1xuICAgICAgLyoqIE5ldHdvcmsgdGltZW91dCBpbiBtaWxsaXNlY29uZHMgKHNlcGFyYXRlIGZyb20gV2ViQXV0aG4gdGltZW91dCkgKi9cbiAgICAgIHRpbWVvdXQ/OiBudW1iZXI7XG4gICAgfTtcbiAgfTtcbn1cblxuLyoqXG4gKiBEZWZhdWx0IGNvbmZpZ3VyYXRpb24gZm9yIFdlYkF1dGhuIHNlcnZpY2VcbiAqIE5vdGU6IHJlbHlpbmdQYXJ0eSBtdXN0IGJlIHByb3ZpZGVkIGJ5IHRoZSBhcHBsaWNhdGlvblxuICovXG5leHBvcnQgY29uc3QgREVGQVVMVF9XRUJBVVRITl9DT05GSUc6IE9taXQ8V2ViQXV0aG5Db25maWcsICdyZWx5aW5nUGFydHknPiA9IHtcbiAgZGVmYXVsdFRpbWVvdXQ6IDYwMDAwLFxuICBkZWZhdWx0QWxnb3JpdGhtczogW1xuICAgIHsgdHlwZTogJ3B1YmxpYy1rZXknLCBhbGc6IC03IH0sIC8vIEVTMjU2IChFQ0RTQSB3LyBTSEEtMjU2KVxuICAgIHsgdHlwZTogJ3B1YmxpYy1rZXknLCBhbGc6IC0yNTcgfSwgLy8gUlMyNTYgKFJTQVNTQS1QS0NTMS12MV81IHcvIFNIQS0yNTYpXG4gIF0sXG4gIGVuZm9yY2VVc2VyVmVyaWZpY2F0aW9uOiBmYWxzZSxcbiAgZGVmYXVsdEF0dGVzdGF0aW9uOiAnbm9uZScsXG4gIGRlZmF1bHRBdXRoZW50aWNhdG9yU2VsZWN0aW9uOiB7XG4gICAgdXNlclZlcmlmaWNhdGlvbjogJ3ByZWZlcnJlZCcsXG4gIH0sXG59O1xuXG4vKipcbiAqIEluamVjdGlvbiB0b2tlbiBmb3IgV2ViQXV0aG4gY29uZmlndXJhdGlvblxuICovXG5leHBvcnQgY29uc3QgV0VCQVVUSE5fQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPFdlYkF1dGhuQ29uZmlnPihcbiAgJ1dFQkFVVEhOX0NPTkZJRydcbik7XG5cbi8qKlxuICogQ3JlYXRlcyBhIGNvbXBsZXRlIFdlYkF1dGhuIGNvbmZpZ3VyYXRpb24gd2l0aCByZXF1aXJlZCByZWx5aW5nIHBhcnR5IGluZm9ybWF0aW9uXG4gKiBAcGFyYW0gcmVseWluZ1BhcnR5IFJlcXVpcmVkIHJlbHlpbmcgcGFydHkgY29uZmlndXJhdGlvblxuICogQHBhcmFtIG92ZXJyaWRlcyBPcHRpb25hbCBjb25maWd1cmF0aW9uIG92ZXJyaWRlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlV2ViQXV0aG5Db25maWcoXG4gIHJlbHlpbmdQYXJ0eTogUmVseWluZ1BhcnR5Q29uZmlnLFxuICBvdmVycmlkZXM/OiBQYXJ0aWFsPE9taXQ8V2ViQXV0aG5Db25maWcsICdyZWx5aW5nUGFydHknPj5cbik6IFdlYkF1dGhuQ29uZmlnIHtcbiAgcmV0dXJuIHtcbiAgICByZWx5aW5nUGFydHksXG4gICAgLi4uREVGQVVMVF9XRUJBVVRITl9DT05GSUcsXG4gICAgLi4ub3ZlcnJpZGVzLFxuICB9O1xufVxuIl19","/**\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 * Utility functions for remote WebAuthn option validation\n *\n * These utilities provide comprehensive validation of server responses\n * to ensure they contain valid WebAuthn options before processing.\n * All validation is done without external dependencies for minimal\n * bundle size impact.\n */\nimport { InvalidRemoteOptionsError } from '../errors/webauthn.errors';\n/**\n * Validates that server response contains valid WebAuthn creation options.\n * Performs essential validation without external dependencies.\n *\n * @param options Response from registration endpoint\n * @throws {InvalidRemoteOptionsError} When options are invalid or incomplete\n *\n * @example\n * ```typescript\n * try {\n * validateRemoteCreationOptions(serverResponse);\n * // Options are valid, proceed with registration\n * } catch (error) {\n * console.error('Invalid server response:', error.message);\n * }\n * ```\n */\nexport function validateRemoteCreationOptions(options) {\n if (!options || typeof options !== 'object' || Array.isArray(options)) {\n throw new InvalidRemoteOptionsError('Response must be an object');\n }\n const opts = options;\n // Validate relying party (required)\n if (!opts.rp || typeof opts.rp !== 'object') {\n throw new InvalidRemoteOptionsError('Missing or invalid rp (relying party) field');\n }\n if (typeof opts.rp.name !== 'string' || opts.rp.name.trim() === '') {\n throw new InvalidRemoteOptionsError('rp.name must be a non-empty string');\n }\n if (opts.rp.id !== undefined && typeof opts.rp.id !== 'string') {\n throw new InvalidRemoteOptionsError('rp.id must be a string when provided');\n }\n // Validate user (required)\n if (!opts.user || typeof opts.user !== 'object') {\n throw new InvalidRemoteOptionsError('Missing or invalid user field');\n }\n if (typeof opts.user.id !== 'string' || opts.user.id.trim() === '') {\n throw new InvalidRemoteOptionsError('user.id must be a non-empty base64url string');\n }\n if (typeof opts.user.name !== 'string' || opts.user.name.trim() === '') {\n throw new InvalidRemoteOptionsError('user.name must be a non-empty string');\n }\n if (typeof opts.user.displayName !== 'string' ||\n opts.user.displayName.trim() === '') {\n throw new InvalidRemoteOptionsError('user.displayName must be a non-empty string');\n }\n // Validate challenge (required)\n if (!opts.challenge ||\n typeof opts.challenge !== 'string' ||\n opts.challenge.trim() === '') {\n throw new InvalidRemoteOptionsError('Missing or invalid challenge field - must be a non-empty base64url string');\n }\n // Validate pubKeyCredParams (required)\n if (!Array.isArray(opts.pubKeyCredParams)) {\n throw new InvalidRemoteOptionsError('pubKeyCredParams must be an array');\n }\n if (opts.pubKeyCredParams.length === 0) {\n throw new InvalidRemoteOptionsError('pubKeyCredParams cannot be empty');\n }\n // Validate each pubKeyCredParams entry\n for (let i = 0; i < opts.pubKeyCredParams.length; i++) {\n const param = opts.pubKeyCredParams[i];\n if (!param || typeof param !== 'object') {\n throw new InvalidRemoteOptionsError(`pubKeyCredParams[${i}] must be an object`);\n }\n if (param.type !== 'public-key') {\n throw new InvalidRemoteOptionsError(`pubKeyCredParams[${i}].type must be \"public-key\"`);\n }\n if (typeof param.alg !== 'number') {\n throw new InvalidRemoteOptionsError(`pubKeyCredParams[${i}].alg must be a number`);\n }\n }\n // Validate optional fields if present\n if (opts.timeout !== undefined &&\n (typeof opts.timeout !== 'number' || opts.timeout <= 0)) {\n throw new InvalidRemoteOptionsError('timeout must be a positive number when provided');\n }\n if (opts.attestation !== undefined &&\n !['none', 'indirect', 'direct', 'enterprise'].includes(opts.attestation)) {\n throw new InvalidRemoteOptionsError('attestation must be one of: none, indirect, direct, enterprise');\n }\n // Validate authenticatorSelection if present\n if (opts.authenticatorSelection !== undefined) {\n if (typeof opts.authenticatorSelection !== 'object') {\n throw new InvalidRemoteOptionsError('authenticatorSelection must be an object when provided');\n }\n const authSel = opts.authenticatorSelection;\n if (authSel.authenticatorAttachment !== undefined &&\n !['platform', 'cross-platform'].includes(authSel.authenticatorAttachment)) {\n throw new InvalidRemoteOptionsError('authenticatorAttachment must be \"platform\" or \"cross-platform\"');\n }\n if (authSel.userVerification !== undefined &&\n !['required', 'preferred', 'discouraged'].includes(authSel.userVerification)) {\n throw new InvalidRemoteOptionsError('userVerification must be \"required\", \"preferred\", or \"discouraged\"');\n }\n if (authSel.residentKey !== undefined &&\n !['discouraged', 'preferred', 'required'].includes(authSel.residentKey)) {\n throw new InvalidRemoteOptionsError('residentKey must be \"discouraged\", \"preferred\", or \"required\"');\n }\n }\n // Validate excludeCredentials if present\n if (opts.excludeCredentials !== undefined) {\n if (!Array.isArray(opts.excludeCredentials)) {\n throw new InvalidRemoteOptionsError('excludeCredentials must be an array when provided');\n }\n for (let i = 0; i < opts.excludeCredentials.length; i++) {\n const cred = opts.excludeCredentials[i];\n if (!cred || typeof cred !== 'object') {\n throw new InvalidRemoteOptionsError(`excludeCredentials[${i}] must be an object`);\n }\n if (cred.type !== 'public-key') {\n throw new InvalidRemoteOptionsError(`excludeCredentials[${i}].type must be \"public-key\"`);\n }\n if (typeof cred.id !== 'string' || cred.id.trim() === '') {\n throw new InvalidRemoteOptionsError(`excludeCredentials[${i}].id must be a non-empty base64url string`);\n }\n }\n }\n}\n/**\n * Validates that server response contains valid WebAuthn request options.\n * Performs essential validation without external dependencies.\n *\n * @param options Response from authentication endpoint\n * @throws {InvalidRemoteOptionsError} When options are invalid or incomplete\n *\n * @example\n * ```typescript\n * try {\n * validateRemoteRequestOptions(serverResponse);\n * // Options are valid, proceed with authentication\n * } catch (error) {\n * console.error('Invalid server response:', error.message);\n * }\n * ```\n */\nexport function validateRemoteRequestOptions(options) {\n if (!options || typeof options !== 'object' || Array.isArray(options)) {\n throw new InvalidRemoteOptionsError('Response must be an object');\n }\n const opts = options;\n // Validate challenge (required)\n if (!opts.challenge ||\n typeof opts.challenge !== 'string' ||\n opts.challenge.trim() === '') {\n throw new InvalidRemoteOptionsError('Missing or invalid challenge field - must be a non-empty base64url string');\n }\n // Validate optional fields if present\n if (opts.timeout !== undefined &&\n (typeof opts.timeout !== 'number' || opts.timeout <= 0)) {\n throw new InvalidRemoteOptionsError('timeout must be a positive number when provided');\n }\n if (opts.userVerification !== undefined &&\n !['required', 'preferred', 'discouraged'].includes(opts.userVerification)) {\n throw new InvalidRemoteOptionsError('userVerification must be \"required\", \"preferred\", or \"discouraged\"');\n }\n // Validate allowCredentials if present\n if (opts.allowCredentials !== undefined) {\n if (!Array.isArray(opts.allowCredentials)) {\n throw new InvalidRemoteOptionsError('allowCredentials must be an array when provided');\n }\n for (let i = 0; i < opts.allowCredentials.length; i++) {\n const cred = opts.allowCredentials[i];\n if (!cred || typeof cred !== 'object') {\n throw new InvalidRemoteOptionsError(`allowCredentials[${i}] must be an object`);\n }\n if (cred.type !== 'public-key') {\n throw new InvalidRemoteOptionsError(`allowCredentials[${i}].type must be \"public-key\"`);\n }\n if (typeof cred.id !== 'string' || cred.id.trim() === '') {\n throw new InvalidRemoteOptionsError(`allowCredentials[${i}].id must be a non-empty base64url string`);\n }\n // Validate transports if present\n if (cred.transports !== undefined) {\n if (!Array.isArray(cred.transports)) {\n throw new InvalidRemoteOptionsError(`allowCredentials[${i}].transports must be an array when provided`);\n }\n const validTransports = ['usb', 'nfc', 'ble', 'internal'];\n for (let j = 0; j < cred.transports.length; j++) {\n if (!validTransports.includes(cred.transports[j])) {\n throw new InvalidRemoteOptionsError(`allowCredentials[${i}].transports[${j}] must be one of: ${validTransports.join(', ')}`);\n }\n }\n }\n }\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remote.utils.js","sourceRoot":"","sources":["../../../../../../libs/ngx-webauthn/src/lib/utils/remote.utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Utility functions for remote WebAuthn option validation\n *\n * These utilities provide comprehensive validation of server responses\n * to ensure they contain valid WebAuthn options before processing.\n * All validation is done without external dependencies for minimal\n * bundle size impact.\n */\n\nimport { InvalidRemoteOptionsError } from '../errors/webauthn.errors';\n\n/**\n * Validates that server response contains valid WebAuthn creation options.\n * Performs essential validation without external dependencies.\n *\n * @param options Response from registration endpoint\n * @throws {InvalidRemoteOptionsError} When options are invalid or incomplete\n *\n * @example\n * ```typescript\n * try {\n *   validateRemoteCreationOptions(serverResponse);\n *   // Options are valid, proceed with registration\n * } catch (error) {\n *   console.error('Invalid server response:', error.message);\n * }\n * ```\n */\nexport function validateRemoteCreationOptions(\n  options: unknown\n): asserts options is PublicKeyCredentialCreationOptionsJSON {\n  if (!options || typeof options !== 'object' || Array.isArray(options)) {\n    throw new InvalidRemoteOptionsError('Response must be an object');\n  }\n\n  const opts = options as any;\n\n  // Validate relying party (required)\n  if (!opts.rp || typeof opts.rp !== 'object') {\n    throw new InvalidRemoteOptionsError(\n      'Missing or invalid rp (relying party) field'\n    );\n  }\n\n  if (typeof opts.rp.name !== 'string' || opts.rp.name.trim() === '') {\n    throw new InvalidRemoteOptionsError('rp.name must be a non-empty string');\n  }\n\n  if (opts.rp.id !== undefined && typeof opts.rp.id !== 'string') {\n    throw new InvalidRemoteOptionsError('rp.id must be a string when provided');\n  }\n\n  // Validate user (required)\n  if (!opts.user || typeof opts.user !== 'object') {\n    throw new InvalidRemoteOptionsError('Missing or invalid user field');\n  }\n\n  if (typeof opts.user.id !== 'string' || opts.user.id.trim() === '') {\n    throw new InvalidRemoteOptionsError(\n      'user.id must be a non-empty base64url string'\n    );\n  }\n\n  if (typeof opts.user.name !== 'string' || opts.user.name.trim() === '') {\n    throw new InvalidRemoteOptionsError('user.name must be a non-empty string');\n  }\n\n  if (\n    typeof opts.user.displayName !== 'string' ||\n    opts.user.displayName.trim() === ''\n  ) {\n    throw new InvalidRemoteOptionsError(\n      'user.displayName must be a non-empty string'\n    );\n  }\n\n  // Validate challenge (required)\n  if (\n    !opts.challenge ||\n    typeof opts.challenge !== 'string' ||\n    opts.challenge.trim() === ''\n  ) {\n    throw new InvalidRemoteOptionsError(\n      'Missing or invalid challenge field - must be a non-empty base64url string'\n    );\n  }\n\n  // Validate pubKeyCredParams (required)\n  if (!Array.isArray(opts.pubKeyCredParams)) {\n    throw new InvalidRemoteOptionsError('pubKeyCredParams must be an array');\n  }\n\n  if (opts.pubKeyCredParams.length === 0) {\n    throw new InvalidRemoteOptionsError('pubKeyCredParams cannot be empty');\n  }\n\n  // Validate each pubKeyCredParams entry\n  for (let i = 0; i < opts.pubKeyCredParams.length; i++) {\n    const param = opts.pubKeyCredParams[i];\n    if (!param || typeof param !== 'object') {\n      throw new InvalidRemoteOptionsError(\n        `pubKeyCredParams[${i}] must be an object`\n      );\n    }\n    if (param.type !== 'public-key') {\n      throw new InvalidRemoteOptionsError(\n        `pubKeyCredParams[${i}].type must be \"public-key\"`\n      );\n    }\n    if (typeof param.alg !== 'number') {\n      throw new InvalidRemoteOptionsError(\n        `pubKeyCredParams[${i}].alg must be a number`\n      );\n    }\n  }\n\n  // Validate optional fields if present\n  if (\n    opts.timeout !== undefined &&\n    (typeof opts.timeout !== 'number' || opts.timeout <= 0)\n  ) {\n    throw new InvalidRemoteOptionsError(\n      'timeout must be a positive number when provided'\n    );\n  }\n\n  if (\n    opts.attestation !== undefined &&\n    !['none', 'indirect', 'direct', 'enterprise'].includes(opts.attestation)\n  ) {\n    throw new InvalidRemoteOptionsError(\n      'attestation must be one of: none, indirect, direct, enterprise'\n    );\n  }\n\n  // Validate authenticatorSelection if present\n  if (opts.authenticatorSelection !== undefined) {\n    if (typeof opts.authenticatorSelection !== 'object') {\n      throw new InvalidRemoteOptionsError(\n        'authenticatorSelection must be an object when provided'\n      );\n    }\n\n    const authSel = opts.authenticatorSelection;\n\n    if (\n      authSel.authenticatorAttachment !== undefined &&\n      !['platform', 'cross-platform'].includes(authSel.authenticatorAttachment)\n    ) {\n      throw new InvalidRemoteOptionsError(\n        'authenticatorAttachment must be \"platform\" or \"cross-platform\"'\n      );\n    }\n\n    if (\n      authSel.userVerification !== undefined &&\n      !['required', 'preferred', 'discouraged'].includes(\n        authSel.userVerification\n      )\n    ) {\n      throw new InvalidRemoteOptionsError(\n        'userVerification must be \"required\", \"preferred\", or \"discouraged\"'\n      );\n    }\n\n    if (\n      authSel.residentKey !== undefined &&\n      !['discouraged', 'preferred', 'required'].includes(authSel.residentKey)\n    ) {\n      throw new InvalidRemoteOptionsError(\n        'residentKey must be \"discouraged\", \"preferred\", or \"required\"'\n      );\n    }\n  }\n\n  // Validate excludeCredentials if present\n  if (opts.excludeCredentials !== undefined) {\n    if (!Array.isArray(opts.excludeCredentials)) {\n      throw new InvalidRemoteOptionsError(\n        'excludeCredentials must be an array when provided'\n      );\n    }\n\n    for (let i = 0; i < opts.excludeCredentials.length; i++) {\n      const cred = opts.excludeCredentials[i];\n      if (!cred || typeof cred !== 'object') {\n        throw new InvalidRemoteOptionsError(\n          `excludeCredentials[${i}] must be an object`\n        );\n      }\n      if (cred.type !== 'public-key') {\n        throw new InvalidRemoteOptionsError(\n          `excludeCredentials[${i}].type must be \"public-key\"`\n        );\n      }\n      if (typeof cred.id !== 'string' || cred.id.trim() === '') {\n        throw new InvalidRemoteOptionsError(\n          `excludeCredentials[${i}].id must be a non-empty base64url string`\n        );\n      }\n    }\n  }\n}\n\n/**\n * Validates that server response contains valid WebAuthn request options.\n * Performs essential validation without external dependencies.\n *\n * @param options Response from authentication endpoint\n * @throws {InvalidRemoteOptionsError} When options are invalid or incomplete\n *\n * @example\n * ```typescript\n * try {\n *   validateRemoteRequestOptions(serverResponse);\n *   // Options are valid, proceed with authentication\n * } catch (error) {\n *   console.error('Invalid server response:', error.message);\n * }\n * ```\n */\nexport function validateRemoteRequestOptions(\n  options: unknown\n): asserts options is PublicKeyCredentialRequestOptionsJSON {\n  if (!options || typeof options !== 'object' || Array.isArray(options)) {\n    throw new InvalidRemoteOptionsError('Response must be an object');\n  }\n\n  const opts = options as any;\n\n  // Validate challenge (required)\n  if (\n    !opts.challenge ||\n    typeof opts.challenge !== 'string' ||\n    opts.challenge.trim() === ''\n  ) {\n    throw new InvalidRemoteOptionsError(\n      'Missing or invalid challenge field - must be a non-empty base64url string'\n    );\n  }\n\n  // Validate optional fields if present\n  if (\n    opts.timeout !== undefined &&\n    (typeof opts.timeout !== 'number' || opts.timeout <= 0)\n  ) {\n    throw new InvalidRemoteOptionsError(\n      'timeout must be a positive number when provided'\n    );\n  }\n\n  if (\n    opts.userVerification !== undefined &&\n    !['required', 'preferred', 'discouraged'].includes(opts.userVerification)\n  ) {\n    throw new InvalidRemoteOptionsError(\n      'userVerification must be \"required\", \"preferred\", or \"discouraged\"'\n    );\n  }\n\n  // Validate allowCredentials if present\n  if (opts.allowCredentials !== undefined) {\n    if (!Array.isArray(opts.allowCredentials)) {\n      throw new InvalidRemoteOptionsError(\n        'allowCredentials must be an array when provided'\n      );\n    }\n\n    for (let i = 0; i < opts.allowCredentials.length; i++) {\n      const cred = opts.allowCredentials[i];\n      if (!cred || typeof cred !== 'object') {\n        throw new InvalidRemoteOptionsError(\n          `allowCredentials[${i}] must be an object`\n        );\n      }\n      if (cred.type !== 'public-key') {\n        throw new InvalidRemoteOptionsError(\n          `allowCredentials[${i}].type must be \"public-key\"`\n        );\n      }\n      if (typeof cred.id !== 'string' || cred.id.trim() === '') {\n        throw new InvalidRemoteOptionsError(\n          `allowCredentials[${i}].id must be a non-empty base64url string`\n        );\n      }\n\n      // Validate transports if present\n      if (cred.transports !== undefined) {\n        if (!Array.isArray(cred.transports)) {\n          throw new InvalidRemoteOptionsError(\n            `allowCredentials[${i}].transports must be an array when provided`\n          );\n        }\n\n        const validTransports = ['usb', 'nfc', 'ble', 'internal'];\n        for (let j = 0; j < cred.transports.length; j++) {\n          if (!validTransports.includes(cred.transports[j])) {\n            throw new InvalidRemoteOptionsError(\n              `allowCredentials[${i}].transports[${j}] must be one of: ${validTransports.join(\n                ', '\n              )}`\n            );\n          }\n        }\n      }\n    }\n  }\n}\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 { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { from, throwError } from 'rxjs';\nimport { map, catchError, switchMap, timeout } from 'rxjs/operators';\nimport { isRegisterConfig, isAuthenticateConfig } from '../utils/type-guards';\nimport { buildCreationOptionsFromConfig, buildRequestOptionsFromConfig, validateRegisterConfig, validateAuthenticateConfig, } from '../utils/preset.utils';\nimport { WebAuthnError, WebAuthnErrorType, UserCancelledError, AuthenticatorError, InvalidOptionsError, UnsupportedOperationError, SecurityError, TimeoutError, RemoteEndpointError, InvalidRemoteOptionsError, } from '../errors/webauthn.errors';\nimport { WEBAUTHN_CONFIG } from '../model/service-config';\n// Import consolidated utility functions\nimport { arrayBufferToBase64url, getSupportedTransports, isJSONOptions, isPublicKeyCredential, isWebAuthnSupported, } from '../utils/webauthn.utils';\n// Import remote validation utilities\nimport { validateRemoteCreationOptions, validateRemoteRequestOptions, } from '../utils/remote.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 http = inject(HttpClient);\n /**\n * Checks if WebAuthn is supported in the current browser environment.\n *\n * @returns True if WebAuthn is supported, false otherwise\n * @example\n * ```typescript\n * if (this.webAuthnService.isSupported()) {\n * // Proceed with WebAuthn operations\n * } else {\n * // Show fallback authentication method\n * }\n * ```\n */\n isSupported() {\n return isWebAuthnSupported();\n }\n /**\n * Gets detailed WebAuthn support information for the current browser.\n * Provides information about available authenticator types and capabilities.\n *\n * @returns Observable containing WebAuthn support details\n * @example\n * ```typescript\n * this.webAuthnService.getSupport().subscribe(support => {\n * console.log('Platform authenticator:', support.platformAuthenticator);\n * console.log('Cross-platform authenticator:', support.crossPlatformAuthenticator);\n * });\n * ```\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 for a user.\n *\n * Supports two input formats:\n * 1. High-level RegisterConfig with preset support and automatic option building\n * 2. Direct PublicKeyCredentialCreationOptions for full control\n *\n * @param input Either a RegisterConfig object or raw WebAuthn creation options\n * @returns Observable containing the registration response with credential details\n *\n * @throws {UnsupportedOperationError} When WebAuthn is not supported\n * @throws {InvalidOptionsError} When provided options are invalid\n * @throws {UserCancelledError} When user cancels the registration\n * @throws {AuthenticatorError} When authenticator encounters an error\n * @throws {TimeoutError} When the operation times out\n * @throws {SecurityError} When a security violation occurs\n *\n * @example Using high-level config:\n * ```typescript\n * const config: RegisterConfig = {\n * preset: 'passkey',\n * user: {\n * id: 'user123',\n * name: 'user@example.com',\n * displayName: 'John Doe'\n * },\n * challenge: 'random-challenge'\n * };\n *\n * this.webAuthnService.register(config).subscribe({\n * next: (response) => {\n * console.log('Registration successful:', response.credential.id);\n * },\n * error: (error) => {\n * if (error instanceof UserCancelledError) {\n * console.log('User cancelled registration');\n * }\n * }\n * });\n * ```\n *\n * @example Using direct options:\n * ```typescript\n * const options: PublicKeyCredentialCreationOptions = {\n * rp: { name: \"Example Corp\" },\n * user: { id: new Uint8Array([1,2,3]), name: \"user@example.com\", displayName: \"User\" },\n * challenge: new Uint8Array([4,5,6]),\n * pubKeyCredParams: [{ type: \"public-key\", alg: -7 }]\n * };\n * this.webAuthnService.register(options).subscribe(response => {\n * // Handle response\n * });\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 a user using an existing WebAuthn credential.\n *\n * Supports two input formats:\n * 1. High-level AuthenticateConfig with preset support and automatic option building\n * 2. Direct PublicKeyCredentialRequestOptions for full control\n *\n * @param input Either an AuthenticateConfig object or raw WebAuthn request options\n * @returns Observable containing the authentication response with assertion details\n *\n * @throws {UnsupportedOperationError} When WebAuthn is not supported\n * @throws {InvalidOptionsError} When provided options are invalid\n * @throws {UserCancelledError} When user cancels the authentication\n * @throws {AuthenticatorError} When authenticator encounters an error\n * @throws {TimeoutError} When the operation times out\n * @throws {SecurityError} When a security violation occurs\n *\n * @example Using high-level config:\n * ```typescript\n * const config: AuthenticateConfig = {\n * preset: 'passkey',\n * challenge: 'auth-challenge',\n * allowCredentials: ['credential-id-1', 'credential-id-2']\n * };\n *\n * this.webAuthnService.authenticate(config).subscribe({\n * next: (response) => {\n * console.log('Authentication successful:', response.credential.id);\n * },\n * error: (error) => {\n * if (error instanceof UserCancelledError) {\n * console.log('User cancelled authentication');\n * }\n * }\n * });\n * ```\n *\n * @example Using direct options:\n * ```typescript\n * const options: PublicKeyCredentialRequestOptions = {\n * challenge: new Uint8Array([1,2,3]),\n * allowCredentials: [{ type: 'public-key', id: new Uint8Array([4,5,6]) }]\n * };\n * this.webAuthnService.authenticate(options).subscribe(response => {\n * // Handle response\n * });\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 validateAuthenticateConfig(input);\n requestOptions = buildRequestOptionsFromConfig(input, this.config);\n }\n else {\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 * Registers a new WebAuthn credential using options fetched from a remote server.\n *\n * Sends request data via POST to the configured registration endpoint,\n * receives PublicKeyCredentialCreationOptionsJSON, then proceeds with\n * standard WebAuthn registration flow.\n *\n * @param request Data to send to server (can be any object your server expects)\n * @template T Type constraint for the request payload\n * @returns Observable containing the registration response\n *\n * @throws {InvalidOptionsError} When remote registration endpoint is not configured\n * @throws {RemoteEndpointError} When server request fails\n * @throws {InvalidRemoteOptionsError} When server returns invalid options\n *\n * @example\n * ```typescript\n * // Simple request\n * this.webAuthnService.registerRemote({\n * username: 'john.doe@example.com'\n * }).subscribe(response => console.log('Success:', response));\n *\n * // Typed request with additional context\n * interface ServerPayload {\n * tenantId: string;\n * department: string;\n * }\n *\n * this.webAuthnService.registerRemote<ServerPayload>({\n * tenantId: 'acme-corp',\n * department: 'engineering'\n * }).subscribe(response => console.log('Success:', response));\n * ```\n */\n registerRemote(request) {\n this.validateRemoteRegistrationConfig();\n const endpoint = this.config.remoteEndpoints.registration;\n const timeoutMs = this.config.remoteEndpoints?.requestOptions?.timeout || 10000;\n return this.http\n .post(endpoint, request)\n .pipe(timeout(timeoutMs), map((options) => {\n validateRemoteCreationOptions(options);\n return options;\n }), switchMap((options) => this.register(options)), catchError((error) => this.handleRemoteError(error, endpoint, 'registration')));\n }\n /**\n * Authenticates using WebAuthn with options fetched from a remote server.\n *\n * Sends request data via POST to the configured authentication endpoint,\n * receives PublicKeyCredentialRequestOptionsJSON, then proceeds with\n * standard WebAuthn authentication flow.\n *\n * @param request Optional data to send to server (defaults to empty object)\n * @template T Type constraint for the request payload\n * @returns Observable containing the authentication response\n *\n * @throws {InvalidOptionsError} When remote authentication endpoint is not configured\n * @throws {RemoteEndpointError} When server request fails\n * @throws {InvalidRemoteOptionsError} When server returns invalid options\n *\n * @example\n * ```typescript\n * // Simple request\n * this.webAuthnService.authenticateRemote({\n * username: 'john.doe@example.com'\n * }).subscribe(response => console.log('Success:', response));\n *\n * // Request with no payload (server uses session/context)\n * this.webAuthnService.authenticateRemote()\n * .subscribe(response => console.log('Success:', response));\n * ```\n */\n authenticateRemote(request = {}) {\n this.validateRemoteAuthenticationConfig();\n const endpoint = this.config.remoteEndpoints.authentication;\n const timeoutMs = this.config.remoteEndpoints?.requestOptions?.timeout || 10000;\n return this.http\n .post(endpoint, request)\n .pipe(timeout(timeoutMs), map((options) => {\n validateRemoteRequestOptions(options);\n return options;\n }), switchMap((options) => this.authenticate(options)), catchError((error) => this.handleRemoteError(error, endpoint, 'authentication')));\n }\n /**\n * Validates that remote registration endpoint is configured\n * @private\n */\n validateRemoteRegistrationConfig() {\n if (!this.config.remoteEndpoints?.registration) {\n throw new InvalidOptionsError('Remote registration endpoint not configured. Add remoteEndpoints.registration to your WebAuthn config.');\n }\n }\n /**\n * Validates that remote authentication endpoint is configured\n * @private\n */\n validateRemoteAuthenticationConfig() {\n if (!this.config.remoteEndpoints?.authentication) {\n throw new InvalidOptionsError('Remote authentication endpoint not configured. Add remoteEndpoints.authentication to your WebAuthn config.');\n }\n }\n /**\n * Handles errors from remote HTTP requests\n * @private\n */\n handleRemoteError(error, url, operation) {\n if (error instanceof HttpErrorResponse) {\n const context = {\n url,\n method: 'POST',\n operation,\n status: error.status,\n statusText: error.statusText,\n };\n return throwError(() => new RemoteEndpointError(`${operation} request failed`, context, error));\n }\n // Preserve InvalidRemoteOptionsError instances (validation errors)\n if (error instanceof InvalidRemoteOptionsError) {\n return throwError(() => error);\n }\n return throwError(() => new WebAuthnError(WebAuthnErrorType.UNKNOWN, `Unexpected error during remote ${operation}`, error));\n }\n /**\n * Parses and normalizes registration options from either native or JSON format.\n * Converts base64url-encoded strings to Uint8Array where necessary.\n *\n * @param options Registration options in either native or JSON format\n * @returns Normalized PublicKeyCredentialCreationOptions for browser API\n * @private\n */\n parseRegistrationOptions(options) {\n if (isJSONOptions(options)) {\n return PublicKeyCredential.parseCreationOptionsFromJSON(options);\n }\n else {\n return options;\n }\n }\n /**\n * Parses and normalizes authentication options from either native or JSON format.\n * Converts base64url-encoded strings to Uint8Array where necessary.\n *\n * @param options Authentication options in either native or JSON format\n * @returns Normalized PublicKeyCredentialRequestOptions for browser API\n * @private\n */\n parseAuthenticationOptions(options) {\n if (isJSONOptions(options)) {\n return PublicKeyCredential.parseRequestOptionsFromJSON(options);\n }\n else {\n return options;\n }\n }\n /**\n * Validates that the credential is a valid PublicKeyCredential.\n *\n * @param credential Raw credential from navigator.credentials.create()\n * @returns Validated PublicKeyCredential\n * @throws {AuthenticatorError} When credential is invalid or null\n * @private\n */\n validateRegistrationCredential(credential) {\n if (!isPublicKeyCredential(credential)) {\n throw new AuthenticatorError('No credential returned from authenticator');\n }\n return credential;\n }\n /**\n * Extracts basic credential information (ID and transports).\n *\n * @param credential Validated PublicKeyCredential\n * @returns Object containing credential ID and supported transports\n * @private\n */\n extractCredentialInfo(credential) {\n const response = credential.response;\n return {\n credentialId: arrayBufferToBase64url(credential.rawId),\n transports: (response.getTransports?.() ||\n []),\n };\n }\n /**\n * Safely extracts the public key with proper error handling.\n *\n * @param response AuthenticatorAttestationResponse\n * @returns Public key as base64url string, or undefined if extraction fails\n * @private\n */\n extractPublicKey(response) {\n try {\n const publicKeyBuffer = response.getPublicKey?.();\n if (publicKeyBuffer) {\n return arrayBufferToBase64url(publicKeyBuffer);\n }\n }\n catch {\n // Public key extraction failed - this is okay, not all algorithms are supported\n // Some authenticators or algorithms don't provide extractable public keys\n }\n return undefined;\n }\n /**\n * Creates the complete raw WebAuthn response for advanced use cases.\n * Provides access to all WebAuthn data including attestation objects and metadata.\n *\n * @param credential Validated PublicKeyCredential\n * @param credentialId Already extracted credential ID\n * @param publicKey Extracted public key (may be undefined)\n * @returns Complete WebAuthnRegistrationResult with all WebAuthn data\n * @private\n */\n createRawRegistrationResponse(credential, credentialId, publicKey) {\n const response = credential.response;\n return {\n credentialId,\n publicKey: publicKey || arrayBufferToBase64url(new ArrayBuffer(0)), // Clean fallback\n attestationObject: arrayBufferToBase64url(response.attestationObject),\n clientDataJSON: arrayBufferToBase64url(response.clientDataJSON),\n transports: (response.getTransports?.() ||\n []),\n };\n }\n /**\n * Assembles the final registration response.\n * Combines all extracted data into the final response format.\n *\n * @param credentialInfo Basic credential information\n * @param publicKey Extracted public key\n * @param rawResponse Raw WebAuthn response\n * @returns Complete RegistrationResponse\n * @private\n */\n assembleRegistrationResponse(credentialInfo, publicKey, rawResponse) {\n return {\n success: true,\n credentialId: credentialInfo.credentialId,\n publicKey,\n transports: credentialInfo.transports,\n rawResponse,\n };\n }\n /**\n * Processes the result of a WebAuthn registration operation.\n * Converts the browser credential response into a structured RegistrationResponse.\n *\n * @param credential The credential returned by navigator.credentials.create()\n * @returns Structured registration response with parsed credential data\n * @throws {AuthenticatorError} When credential creation fails or returns null\n * @private\n */\n processRegistrationResult(credential) {\n const validCredential = this.validateRegistrationCredential(credential);\n const credentialInfo = this.extractCredentialInfo(validCredential);\n const response = validCredential.response;\n const publicKey = this.extractPublicKey(response);\n const rawResponse = this.createRawRegistrationResponse(validCredential, credentialInfo.credentialId, publicKey);\n return this.assembleRegistrationResponse(credentialInfo, publicKey, rawResponse);\n }\n /**\n * Processes the result of a WebAuthn authentication operation.\n * Converts the browser credential response into a structured AuthenticationResponse.\n *\n * @param credential The credential returned by navigator.credentials.get()\n * @returns Structured authentication response with parsed assertion data\n * @throws {AuthenticatorError} When authentication fails or returns null\n * @private\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 complete raw response for advanced use cases\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 * Central error handling dispatcher for WebAuthn operations.\n * Routes different error types to specialized handlers for proper error classification.\n *\n * @param error The error to handle (can be DOMException, TypeError, or any other error)\n * @returns Observable that throws an appropriate WebAuthnError subclass\n * @private\n */\n handleWebAuthnError(error) {\n if (error instanceof DOMException) {\n return this.handleDOMException(error);\n }\n if (this.isJSONParsingError(error)) {\n return this.handleJSONParsingError(error);\n }\n return this.handleUnknownError(error);\n }\n /**\n * Handles DOMExceptions from the WebAuthn API using a mapping approach.\n * Maps specific DOMException names to appropriate WebAuthnError subclasses.\n *\n * @param error The DOMException thrown by the WebAuthn API\n * @returns Observable that throws an appropriate WebAuthnError subclass\n * @private\n */\n handleDOMException(error) {\n const errorMap = {\n NotAllowedError: () => new UserCancelledError(error),\n InvalidStateError: () => new AuthenticatorError('Invalid authenticator state', error),\n NotSupportedError: () => new UnsupportedOperationError('Operation not supported', error),\n SecurityError: () => new SecurityError('Security error occurred', error),\n TimeoutError: () => new TimeoutError('Operation timed out', error),\n EncodingError: () => new InvalidOptionsError('Encoding error in options', error),\n };\n const errorFactory = errorMap[error.name];\n const webAuthnError = errorFactory\n ? errorFactory()\n : new WebAuthnError(WebAuthnErrorType.UNKNOWN, `Unknown WebAuthn error: ${error.message}`, error);\n return throwError(() => webAuthnError);\n }\n /**\n * Determines if an error is related to JSON parsing issues.\n * Specifically checks for TypeError messages indicating JSON parsing failures.\n *\n * @param error The error to check\n * @returns True if the error is a JSON parsing error, false otherwise\n * @private\n */\n isJSONParsingError(error) {\n return (error instanceof TypeError &&\n (error.message.includes('parseCreationOptionsFromJSON') ||\n error.message.includes('parseRequestOptionsFromJSON')));\n }\n /**\n * Handles JSON parsing errors specifically.\n * These errors occur when invalid JSON format options are provided.\n *\n * @param error The TypeError from JSON parsing\n * @returns Observable that throws an InvalidOptionsError\n * @private\n */\n handleJSONParsingError(error) {\n // At this point we know it's a TypeError from isJSONParsingError check\n return throwError(() => new InvalidOptionsError('Invalid JSON options format', error));\n }\n /**\n * Handles any unexpected errors that don't fall into other categories.\n * Provides a fallback for errors that aren't DOMExceptions or JSON parsing errors.\n *\n * @param error The unexpected error\n * @returns Observable that throws a generic WebAuthnError\n * @private\n */\n handleUnknownError(error) {\n const message = error instanceof Error ? error.message : 'Unknown error occurred';\n return throwError(() => new WebAuthnError(WebAuthnErrorType.UNKNOWN, `Unexpected error: ${message}`, error instanceof Error ? error : new Error(String(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":["/**\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 */\n\nimport { Injectable, inject } from '@angular/core';\nimport { HttpClient, HttpErrorResponse } from '@angular/common/http';\nimport { Observable, from, throwError } from 'rxjs';\nimport { map, catchError, switchMap, timeout } from 'rxjs/operators';\n\nimport {\n  WebAuthnSupport,\n  RegistrationResponse,\n  AuthenticationResponse,\n  WebAuthnRegistrationResult,\n  WebAuthnAuthenticationResult,\n} from '../model';\n\nimport { RegisterInput, AuthenticateInput } from '../model';\nimport {\n  RemoteRegistrationRequest,\n  RemoteAuthenticationRequest,\n} from '../model/remote-config';\n\nimport { isRegisterConfig, isAuthenticateConfig } from '../utils/type-guards';\n\nimport {\n  buildCreationOptionsFromConfig,\n  buildRequestOptionsFromConfig,\n  validateRegisterConfig,\n  validateAuthenticateConfig,\n} from '../utils/preset.utils';\n\nimport {\n  WebAuthnError,\n  WebAuthnErrorType,\n  UserCancelledError,\n  AuthenticatorError,\n  InvalidOptionsError,\n  UnsupportedOperationError,\n  SecurityError,\n  TimeoutError,\n  RemoteEndpointError,\n  InvalidRemoteOptionsError,\n  RemoteErrorContext,\n} from '../errors/webauthn.errors';\n\nimport { WEBAUTHN_CONFIG } from '../model/service-config';\n\n// Import consolidated utility functions\nimport {\n  arrayBufferToBase64url,\n  getSupportedTransports,\n  isJSONOptions,\n  isPublicKeyCredential,\n  isWebAuthnSupported,\n} from '../utils/webauthn.utils';\n\n// Import remote validation utilities\nimport {\n  validateRemoteCreationOptions,\n  validateRemoteRequestOptions,\n} from '../utils/remote.utils';\n\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 */\n@Injectable({\n  providedIn: 'root',\n})\nexport class WebAuthnService {\n  private readonly config = inject(WEBAUTHN_CONFIG);\n  private readonly http = inject(HttpClient);\n\n  /**\n   * Checks if WebAuthn is supported in the current browser environment.\n   *\n   * @returns True if WebAuthn is supported, false otherwise\n   * @example\n   * ```typescript\n   * if (this.webAuthnService.isSupported()) {\n   *   // Proceed with WebAuthn operations\n   * } else {\n   *   // Show fallback authentication method\n   * }\n   * ```\n   */\n  isSupported(): boolean {\n    return isWebAuthnSupported();\n  }\n\n  /**\n   * Gets detailed WebAuthn support information for the current browser.\n   * Provides information about available authenticator types and capabilities.\n   *\n   * @returns Observable containing WebAuthn support details\n   * @example\n   * ```typescript\n   * this.webAuthnService.getSupport().subscribe(support => {\n   *   console.log('Platform authenticator:', support.platformAuthenticator);\n   *   console.log('Cross-platform authenticator:', support.crossPlatformAuthenticator);\n   * });\n   * ```\n   */\n  getSupport(): Observable<WebAuthnSupport> {\n    if (!this.isSupported()) {\n      return throwError(\n        () =>\n          new UnsupportedOperationError(\n            'WebAuthn is not supported in this browser'\n          )\n      );\n    }\n\n    return from(\n      PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()\n    ).pipe(\n      map((isPlatformAvailable) => ({\n        isSupported: true,\n        isPlatformAuthenticatorAvailable: isPlatformAvailable,\n        supportedTransports: getSupportedTransports(),\n      })),\n      catchError((error) =>\n        throwError(\n          () =>\n            new WebAuthnError(\n              WebAuthnErrorType.UNKNOWN,\n              'Failed to check WebAuthn support',\n              error\n            )\n        )\n      )\n    );\n  }\n\n  /**\n   * Registers a new WebAuthn credential for a user.\n   *\n   * Supports two input formats:\n   * 1. High-level RegisterConfig with preset support and automatic option building\n   * 2. Direct PublicKeyCredentialCreationOptions for full control\n   *\n   * @param input Either a RegisterConfig object or raw WebAuthn creation options\n   * @returns Observable containing the registration response with credential details\n   *\n   * @throws {UnsupportedOperationError} When WebAuthn is not supported\n   * @throws {InvalidOptionsError} When provided options are invalid\n   * @throws {UserCancelledError} When user cancels the registration\n   * @throws {AuthenticatorError} When authenticator encounters an error\n   * @throws {TimeoutError} When the operation times out\n   * @throws {SecurityError} When a security violation occurs\n   *\n   * @example Using high-level config:\n   * ```typescript\n   * const config: RegisterConfig = {\n   *   preset: 'passkey',\n   *   user: {\n   *     id: 'user123',\n   *     name: 'user@example.com',\n   *     displayName: 'John Doe'\n   *   },\n   *   challenge: 'random-challenge'\n   * };\n   *\n   * this.webAuthnService.register(config).subscribe({\n   *   next: (response) => {\n   *     console.log('Registration successful:', response.credential.id);\n   *   },\n   *   error: (error) => {\n   *     if (error instanceof UserCancelledError) {\n   *       console.log('User cancelled registration');\n   *     }\n   *   }\n   * });\n   * ```\n   *\n   * @example Using direct options:\n   * ```typescript\n   * const options: PublicKeyCredentialCreationOptions = {\n   *   rp: { name: \"Example Corp\" },\n   *   user: { id: new Uint8Array([1,2,3]), name: \"user@example.com\", displayName: \"User\" },\n   *   challenge: new Uint8Array([4,5,6]),\n   *   pubKeyCredParams: [{ type: \"public-key\", alg: -7 }]\n   * };\n   * this.webAuthnService.register(options).subscribe(response => {\n   *   // Handle response\n   * });\n   * ```\n   */\n  register(input: RegisterInput): Observable<RegistrationResponse> {\n    if (!this.isSupported()) {\n      return throwError(\n        () =>\n          new UnsupportedOperationError(\n            'WebAuthn is not supported in this browser'\n          )\n      );\n    }\n\n    try {\n      let creationOptions:\n        | PublicKeyCredentialCreationOptions\n        | PublicKeyCredentialCreationOptionsJSON;\n\n      if (isRegisterConfig(input)) {\n        // High-level config path: validate, resolve preset, build options\n        validateRegisterConfig(input);\n        creationOptions = buildCreationOptionsFromConfig(input, this.config);\n      } else {\n        // Direct options path: use provided options\n        creationOptions = input;\n      }\n\n      const parsedOptions = this.parseRegistrationOptions(creationOptions);\n\n      return from(\n        navigator.credentials.create({ publicKey: parsedOptions })\n      ).pipe(\n        map((credential) => this.processRegistrationResult(credential)),\n        catchError((error) => this.handleWebAuthnError(error))\n      );\n    } catch (error) {\n      return throwError(\n        () =>\n          new InvalidOptionsError(\n            'Failed to process registration input',\n            error as Error\n          )\n      );\n    }\n  }\n\n  /**\n   * Authenticates a user using an existing WebAuthn credential.\n   *\n   * Supports two input formats:\n   * 1. High-level AuthenticateConfig with preset support and automatic option building\n   * 2. Direct PublicKeyCredentialRequestOptions for full control\n   *\n   * @param input Either an AuthenticateConfig object or raw WebAuthn request options\n   * @returns Observable containing the authentication response with assertion details\n   *\n   * @throws {UnsupportedOperationError} When WebAuthn is not supported\n   * @throws {InvalidOptionsError} When provided options are invalid\n   * @throws {UserCancelledError} When user cancels the authentication\n   * @throws {AuthenticatorError} When authenticator encounters an error\n   * @throws {TimeoutError} When the operation times out\n   * @throws {SecurityError} When a security violation occurs\n   *\n   * @example Using high-level config:\n   * ```typescript\n   * const config: AuthenticateConfig = {\n   *   preset: 'passkey',\n   *   challenge: 'auth-challenge',\n   *   allowCredentials: ['credential-id-1', 'credential-id-2']\n   * };\n   *\n   * this.webAuthnService.authenticate(config).subscribe({\n   *   next: (response) => {\n   *     console.log('Authentication successful:', response.credential.id);\n   *   },\n   *   error: (error) => {\n   *     if (error instanceof UserCancelledError) {\n   *       console.log('User cancelled authentication');\n   *     }\n   *   }\n   * });\n   * ```\n   *\n   * @example Using direct options:\n   * ```typescript\n   * const options: PublicKeyCredentialRequestOptions = {\n   *   challenge: new Uint8Array([1,2,3]),\n   *   allowCredentials: [{ type: 'public-key', id: new Uint8Array([4,5,6]) }]\n   * };\n   * this.webAuthnService.authenticate(options).subscribe(response => {\n   *   // Handle response\n   * });\n   * ```\n   */\n  authenticate(input: AuthenticateInput): Observable<AuthenticationResponse> {\n    if (!this.isSupported()) {\n      return throwError(\n        () =>\n          new UnsupportedOperationError(\n            'WebAuthn is not supported in this browser'\n          )\n      );\n    }\n\n    try {\n      let requestOptions:\n        | PublicKeyCredentialRequestOptions\n        | PublicKeyCredentialRequestOptionsJSON;\n\n      if (isAuthenticateConfig(input)) {\n        validateAuthenticateConfig(input);\n        requestOptions = buildRequestOptionsFromConfig(input, this.config);\n      } else {\n        requestOptions = input;\n      }\n\n      const parsedOptions = this.parseAuthenticationOptions(requestOptions);\n\n      return from(navigator.credentials.get({ publicKey: parsedOptions })).pipe(\n        map((credential) => this.processAuthenticationResult(credential)),\n        catchError((error) => this.handleWebAuthnError(error))\n      );\n    } catch (error) {\n      return throwError(\n        () =>\n          new InvalidOptionsError(\n            'Failed to process authentication input',\n            error as Error\n          )\n      );\n    }\n  }\n\n  /**\n   * Registers a new WebAuthn credential using options fetched from a remote server.\n   *\n   * Sends request data via POST to the configured registration endpoint,\n   * receives PublicKeyCredentialCreationOptionsJSON, then proceeds with\n   * standard WebAuthn registration flow.\n   *\n   * @param request Data to send to server (can be any object your server expects)\n   * @template T Type constraint for the request payload\n   * @returns Observable containing the registration response\n   *\n   * @throws {InvalidOptionsError} When remote registration endpoint is not configured\n   * @throws {RemoteEndpointError} When server request fails\n   * @throws {InvalidRemoteOptionsError} When server returns invalid options\n   *\n   * @example\n   * ```typescript\n   * // Simple request\n   * this.webAuthnService.registerRemote({\n   *   username: 'john.doe@example.com'\n   * }).subscribe(response => console.log('Success:', response));\n   *\n   * // Typed request with additional context\n   * interface ServerPayload {\n   *   tenantId: string;\n   *   department: string;\n   * }\n   *\n   * this.webAuthnService.registerRemote<ServerPayload>({\n   *   tenantId: 'acme-corp',\n   *   department: 'engineering'\n   * }).subscribe(response => console.log('Success:', response));\n   * ```\n   */\n  registerRemote<T extends Record<string, any> = Record<string, any>>(\n    request: RemoteRegistrationRequest<T>\n  ): Observable<RegistrationResponse> {\n    this.validateRemoteRegistrationConfig();\n\n    const endpoint = this.config.remoteEndpoints!.registration!;\n    const timeoutMs =\n      this.config.remoteEndpoints?.requestOptions?.timeout || 10000;\n\n    return this.http\n      .post<PublicKeyCredentialCreationOptionsJSON>(endpoint, request)\n      .pipe(\n        timeout(timeoutMs),\n        map((options) => {\n          validateRemoteCreationOptions(options);\n          return options;\n        }),\n        switchMap((options) => this.register(options)),\n        catchError((error) =>\n          this.handleRemoteError(error, endpoint, 'registration')\n        )\n      );\n  }\n\n  /**\n   * Authenticates using WebAuthn with options fetched from a remote server.\n   *\n   * Sends request data via POST to the configured authentication endpoint,\n   * receives PublicKeyCredentialRequestOptionsJSON, then proceeds with\n   * standard WebAuthn authentication flow.\n   *\n   * @param request Optional data to send to server (defaults to empty object)\n   * @template T Type constraint for the request payload\n   * @returns Observable containing the authentication response\n   *\n   * @throws {InvalidOptionsError} When remote authentication endpoint is not configured\n   * @throws {RemoteEndpointError} When server request fails\n   * @throws {InvalidRemoteOptionsError} When server returns invalid options\n   *\n   * @example\n   * ```typescript\n   * // Simple request\n   * this.webAuthnService.authenticateRemote({\n   *   username: 'john.doe@example.com'\n   * }).subscribe(response => console.log('Success:', response));\n   *\n   * // Request with no payload (server uses session/context)\n   * this.webAuthnService.authenticateRemote()\n   *   .subscribe(response => console.log('Success:', response));\n   * ```\n   */\n  authenticateRemote<T extends Record<string, any> = Record<string, any>>(\n    request: RemoteAuthenticationRequest<T> = {} as T\n  ): Observable<AuthenticationResponse> {\n    this.validateRemoteAuthenticationConfig();\n\n    const endpoint = this.config.remoteEndpoints!.authentication!;\n    const timeoutMs =\n      this.config.remoteEndpoints?.requestOptions?.timeout || 10000;\n\n    return this.http\n      .post<PublicKeyCredentialRequestOptionsJSON>(endpoint, request)\n      .pipe(\n        timeout(timeoutMs),\n        map((options) => {\n          validateRemoteRequestOptions(options);\n          return options;\n        }),\n        switchMap((options) => this.authenticate(options)),\n        catchError((error) =>\n          this.handleRemoteError(error, endpoint, 'authentication')\n        )\n      );\n  }\n\n  /**\n   * Validates that remote registration endpoint is configured\n   * @private\n   */\n  private validateRemoteRegistrationConfig(): void {\n    if (!this.config.remoteEndpoints?.registration) {\n      throw new InvalidOptionsError(\n        'Remote registration endpoint not configured. Add remoteEndpoints.registration to your WebAuthn config.'\n      );\n    }\n  }\n\n  /**\n   * Validates that remote authentication endpoint is configured\n   * @private\n   */\n  private validateRemoteAuthenticationConfig(): void {\n    if (!this.config.remoteEndpoints?.authentication) {\n      throw new InvalidOptionsError(\n        'Remote authentication endpoint not configured. Add remoteEndpoints.authentication to your WebAuthn config.'\n      );\n    }\n  }\n\n  /**\n   * Handles errors from remote HTTP requests\n   * @private\n   */\n  private handleRemoteError(\n    error: any,\n    url: string,\n    operation: 'registration' | 'authentication'\n  ): Observable<never> {\n    if (error instanceof HttpErrorResponse) {\n      const context: RemoteErrorContext = {\n        url,\n        method: 'POST',\n        operation,\n        status: error.status,\n        statusText: error.statusText,\n      };\n\n      return throwError(\n        () =>\n          new RemoteEndpointError(`${operation} request failed`, context, error)\n      );\n    }\n\n    // Preserve InvalidRemoteOptionsError instances (validation errors)\n    if (error instanceof InvalidRemoteOptionsError) {\n      return throwError(() => error);\n    }\n\n    return throwError(\n      () =>\n        new WebAuthnError(\n          WebAuthnErrorType.UNKNOWN,\n          `Unexpected error during remote ${operation}`,\n          error\n        )\n    );\n  }\n\n  /**\n   * Parses and normalizes registration options from either native or JSON format.\n   * Converts base64url-encoded strings to Uint8Array where necessary.\n   *\n   * @param options Registration options in either native or JSON format\n   * @returns Normalized PublicKeyCredentialCreationOptions for browser API\n   * @private\n   */\n  private parseRegistrationOptions(\n    options:\n      | PublicKeyCredentialCreationOptions\n      | PublicKeyCredentialCreationOptionsJSON\n  ): PublicKeyCredentialCreationOptions {\n    if (isJSONOptions(options)) {\n      return PublicKeyCredential.parseCreationOptionsFromJSON(\n        options as PublicKeyCredentialCreationOptionsJSON\n      );\n    } else {\n      return options as PublicKeyCredentialCreationOptions;\n    }\n  }\n\n  /**\n   * Parses and normalizes authentication options from either native or JSON format.\n   * Converts base64url-encoded strings to Uint8Array where necessary.\n   *\n   * @param options Authentication options in either native or JSON format\n   * @returns Normalized PublicKeyCredentialRequestOptions for browser API\n   * @private\n   */\n  private parseAuthenticationOptions(\n    options:\n      | PublicKeyCredentialRequestOptions\n      | PublicKeyCredentialRequestOptionsJSON\n  ): PublicKeyCredentialRequestOptions {\n    if (isJSONOptions(options)) {\n      return PublicKeyCredential.parseRequestOptionsFromJSON(\n        options as PublicKeyCredentialRequestOptionsJSON\n      );\n    } else {\n      return options as PublicKeyCredentialRequestOptions;\n    }\n  }\n\n  /**\n   * Validates that the credential is a valid PublicKeyCredential.\n   *\n   * @param credential Raw credential from navigator.credentials.create()\n   * @returns Validated PublicKeyCredential\n   * @throws {AuthenticatorError} When credential is invalid or null\n   * @private\n   */\n  private validateRegistrationCredential(\n    credential: Credential | null\n  ): PublicKeyCredential {\n    if (!isPublicKeyCredential(credential)) {\n      throw new AuthenticatorError('No credential returned from authenticator');\n    }\n    return credential;\n  }\n\n  /**\n   * Extracts basic credential information (ID and transports).\n   *\n   * @param credential Validated PublicKeyCredential\n   * @returns Object containing credential ID and supported transports\n   * @private\n   */\n  private extractCredentialInfo(credential: PublicKeyCredential): {\n    credentialId: string;\n    transports: AuthenticatorTransport[];\n  } {\n    const response = credential.response as AuthenticatorAttestationResponse;\n\n    return {\n      credentialId: arrayBufferToBase64url(credential.rawId),\n      transports: (response.getTransports?.() ||\n        []) as AuthenticatorTransport[],\n    };\n  }\n\n  /**\n   * Safely extracts the public key with proper error handling.\n   *\n   * @param response AuthenticatorAttestationResponse\n   * @returns Public key as base64url string, or undefined if extraction fails\n   * @private\n   */\n  private extractPublicKey(\n    response: AuthenticatorAttestationResponse\n  ): string | undefined {\n    try {\n      const publicKeyBuffer = response.getPublicKey?.();\n      if (publicKeyBuffer) {\n        return arrayBufferToBase64url(publicKeyBuffer);\n      }\n    } catch {\n      // Public key extraction failed - this is okay, not all algorithms are supported\n      // Some authenticators or algorithms don't provide extractable public keys\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Creates the complete raw WebAuthn response for advanced use cases.\n   * Provides access to all WebAuthn data including attestation objects and metadata.\n   *\n   * @param credential Validated PublicKeyCredential\n   * @param credentialId Already extracted credential ID\n   * @param publicKey Extracted public key (may be undefined)\n   * @returns Complete WebAuthnRegistrationResult with all WebAuthn data\n   * @private\n   */\n  private createRawRegistrationResponse(\n    credential: PublicKeyCredential,\n    credentialId: string,\n    publicKey: string | undefined\n  ): WebAuthnRegistrationResult {\n    const response = credential.response as AuthenticatorAttestationResponse;\n\n    return {\n      credentialId,\n      publicKey: publicKey || arrayBufferToBase64url(new ArrayBuffer(0)), // Clean fallback\n      attestationObject: arrayBufferToBase64url(response.attestationObject),\n      clientDataJSON: arrayBufferToBase64url(response.clientDataJSON),\n      transports: (response.getTransports?.() ||\n        []) as AuthenticatorTransport[],\n    };\n  }\n\n  /**\n   * Assembles the final registration response.\n   * Combines all extracted data into the final response format.\n   *\n   * @param credentialInfo Basic credential information\n   * @param publicKey Extracted public key\n   * @param rawResponse Raw WebAuthn response\n   * @returns Complete RegistrationResponse\n   * @private\n   */\n  private assembleRegistrationResponse(\n    credentialInfo: {\n      credentialId: string;\n      transports: AuthenticatorTransport[];\n    },\n    publicKey: string | undefined,\n    rawResponse: WebAuthnRegistrationResult\n  ): RegistrationResponse {\n    return {\n      success: true,\n      credentialId: credentialInfo.credentialId,\n      publicKey,\n      transports: credentialInfo.transports,\n      rawResponse,\n    };\n  }\n\n  /**\n   * Processes the result of a WebAuthn registration operation.\n   * Converts the browser credential response into a structured RegistrationResponse.\n   *\n   * @param credential The credential returned by navigator.credentials.create()\n   * @returns Structured registration response with parsed credential data\n   * @throws {AuthenticatorError} When credential creation fails or returns null\n   * @private\n   */\n  private processRegistrationResult(\n    credential: Credential | null\n  ): RegistrationResponse {\n    const validCredential = this.validateRegistrationCredential(credential);\n    const credentialInfo = this.extractCredentialInfo(validCredential);\n    const response =\n      validCredential.response as AuthenticatorAttestationResponse;\n    const publicKey = this.extractPublicKey(response);\n    const rawResponse = this.createRawRegistrationResponse(\n      validCredential,\n      credentialInfo.credentialId,\n      publicKey\n    );\n\n    return this.assembleRegistrationResponse(\n      credentialInfo,\n      publicKey,\n      rawResponse\n    );\n  }\n\n  /**\n   * Processes the result of a WebAuthn authentication operation.\n   * Converts the browser credential response into a structured AuthenticationResponse.\n   *\n   * @param credential The credential returned by navigator.credentials.get()\n   * @returns Structured authentication response with parsed assertion data\n   * @throws {AuthenticatorError} When authentication fails or returns null\n   * @private\n   */\n  private processAuthenticationResult(\n    credential: Credential | null\n  ): AuthenticationResponse {\n    if (!isPublicKeyCredential(credential)) {\n      throw new AuthenticatorError('No credential returned from authenticator');\n    }\n\n    const response = credential.response as AuthenticatorAssertionResponse;\n    const credentialId = arrayBufferToBase64url(credential.rawId);\n\n    let userHandle: string | undefined;\n    if (response.userHandle) {\n      userHandle = arrayBufferToBase64url(response.userHandle);\n    }\n\n    // Create the complete raw response for advanced use cases\n    const rawResponse: WebAuthnAuthenticationResult = {\n      credentialId,\n      authenticatorData: arrayBufferToBase64url(response.authenticatorData),\n      clientDataJSON: arrayBufferToBase64url(response.clientDataJSON),\n      signature: arrayBufferToBase64url(response.signature),\n      userHandle,\n    };\n\n    return {\n      success: true,\n      credentialId,\n      userHandle,\n      rawResponse,\n    };\n  }\n\n  /**\n   * Central error handling dispatcher for WebAuthn operations.\n   * Routes different error types to specialized handlers for proper error classification.\n   *\n   * @param error The error to handle (can be DOMException, TypeError, or any other error)\n   * @returns Observable that throws an appropriate WebAuthnError subclass\n   * @private\n   */\n  private handleWebAuthnError(error: unknown): Observable<never> {\n    if (error instanceof DOMException) {\n      return this.handleDOMException(error);\n    }\n\n    if (this.isJSONParsingError(error)) {\n      return this.handleJSONParsingError(error);\n    }\n\n    return this.handleUnknownError(error);\n  }\n\n  /**\n   * Handles DOMExceptions from the WebAuthn API using a mapping approach.\n   * Maps specific DOMException names to appropriate WebAuthnError subclasses.\n   *\n   * @param error The DOMException thrown by the WebAuthn API\n   * @returns Observable that throws an appropriate WebAuthnError subclass\n   * @private\n   */\n  private handleDOMException(error: DOMException): Observable<never> {\n    const errorMap: Record<string, () => WebAuthnError> = {\n      NotAllowedError: () => new UserCancelledError(error),\n      InvalidStateError: () =>\n        new AuthenticatorError('Invalid authenticator state', error),\n      NotSupportedError: () =>\n        new UnsupportedOperationError('Operation not supported', error),\n      SecurityError: () => new SecurityError('Security error occurred', error),\n      TimeoutError: () => new TimeoutError('Operation timed out', error),\n      EncodingError: () =>\n        new InvalidOptionsError('Encoding error in options', error),\n    };\n\n    const errorFactory = errorMap[error.name];\n    const webAuthnError = errorFactory\n      ? errorFactory()\n      : new WebAuthnError(\n          WebAuthnErrorType.UNKNOWN,\n          `Unknown WebAuthn error: ${error.message}`,\n          error\n        );\n\n    return throwError(() => webAuthnError);\n  }\n\n  /**\n   * Determines if an error is related to JSON parsing issues.\n   * Specifically checks for TypeError messages indicating JSON parsing failures.\n   *\n   * @param error The error to check\n   * @returns True if the error is a JSON parsing error, false otherwise\n   * @private\n   */\n  private isJSONParsingError(error: unknown): boolean {\n    return (\n      error instanceof TypeError &&\n      (error.message.includes('parseCreationOptionsFromJSON') ||\n        error.message.includes('parseRequestOptionsFromJSON'))\n    );\n  }\n\n  /**\n   * Handles JSON parsing errors specifically.\n   * These errors occur when invalid JSON format options are provided.\n   *\n   * @param error The TypeError from JSON parsing\n   * @returns Observable that throws an InvalidOptionsError\n   * @private\n   */\n  private handleJSONParsingError(error: unknown): Observable<never> {\n    // At this point we know it's a TypeError from isJSONParsingError check\n    return throwError(\n      () =>\n        new InvalidOptionsError(\n          'Invalid JSON options format',\n          error as TypeError\n        )\n    );\n  }\n\n  /**\n   * Handles any unexpected errors that don't fall into other categories.\n   * Provides a fallback for errors that aren't DOMExceptions or JSON parsing errors.\n   *\n   * @param error The unexpected error\n   * @returns Observable that throws a generic WebAuthnError\n   * @private\n   */\n  private handleUnknownError(error: unknown): Observable<never> {\n    const message =\n      error instanceof Error ? error.message : 'Unknown error occurred';\n    return throwError(\n      () =>\n        new WebAuthnError(\n          WebAuthnErrorType.UNKNOWN,\n          `Unexpected error: ${message}`,\n          error instanceof Error ? error : new Error(String(error))\n        )\n    );\n  }\n}\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 '../model/service-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//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2ViYXV0aG4ucHJvdmlkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZ3gtd2ViYXV0aG4vc3JjL2xpYi9wcm92aWRlcnMvd2ViYXV0aG4ucHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUdILE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMvRCxPQUFPLEVBR0wsZUFBZSxFQUNmLG9CQUFvQixHQUNyQixNQUFNLHlCQUF5QixDQUFDO0FBRWpDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUJHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FDN0IsWUFBZ0MsRUFDaEMsU0FBd0QsRUFBRTtJQUUxRCxPQUFPO1FBQ0w7WUFDRSxPQUFPLEVBQUUsZUFBZTtZQUN4QixRQUFRLEVBQUUsb0JBQW9CLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQztTQUNyRDtRQUNELGVBQWU7S0FDaEIsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFdlYkF1dGhuIFByb3ZpZGVyc1xuICogTW9kZXJuIEFuZ3VsYXIgc3RhbmRhbG9uZSBwcm92aWRlciBmdW5jdGlvbiBmb3IgV2ViQXV0aG4gc2VydmljZVxuICovXG5cbmltcG9ydCB7IFByb3ZpZGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBXZWJBdXRoblNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy93ZWJhdXRobi5zZXJ2aWNlJztcbmltcG9ydCB7XG4gIFdlYkF1dGhuQ29uZmlnLFxuICBSZWx5aW5nUGFydHlDb25maWcsXG4gIFdFQkFVVEhOX0NPTkZJRyxcbiAgY3JlYXRlV2ViQXV0aG5Db25maWcsXG59IGZyb20gJy4uL21vZGVsL3NlcnZpY2UtY29uZmlnJztcblxuLyoqXG4gKiBQcm92aWRlcyBXZWJBdXRobiBzZXJ2aWNlIHdpdGggcmVxdWlyZWQgcmVseWluZyBwYXJ0eSBjb25maWd1cmF0aW9uXG4gKlxuICogQHBhcmFtIHJlbHlpbmdQYXJ0eSBSZXF1aXJlZCByZWx5aW5nIHBhcnR5IGNvbmZpZ3VyYXRpb25cbiAqIEBwYXJhbSBjb25maWcgT3B0aW9uYWwgY29uZmlndXJhdGlvbiBvdmVycmlkZXNcbiAqIEByZXR1cm5zIEFycmF5IG9mIHByb3ZpZGVycyBmb3IgV2ViQXV0aG4gZnVuY3Rpb25hbGl0eVxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiAvLyBtYWluLnRzXG4gKiBib290c3RyYXBBcHBsaWNhdGlvbihBcHBDb21wb25lbnQsIHtcbiAqICAgcHJvdmlkZXJzOiBbXG4gKiAgICAgcHJvdmlkZVdlYkF1dGhuKFxuICogICAgICAgeyBuYW1lOiAnTXkgQXBwJywgaWQ6ICdteWFwcC5jb20nIH0sXG4gKiAgICAgICB7IGRlZmF1bHRUaW1lb3V0OiAzMDAwMCB9XG4gKiAgICAgKVxuICogICBdXG4gKiB9KTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVdlYkF1dGhuKFxuICByZWx5aW5nUGFydHk6IFJlbHlpbmdQYXJ0eUNvbmZpZyxcbiAgY29uZmlnOiBQYXJ0aWFsPE9taXQ8V2ViQXV0aG5Db25maWcsICdyZWx5aW5nUGFydHknPj4gPSB7fVxuKTogUHJvdmlkZXJbXSB7XG4gIHJldHVybiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogV0VCQVVUSE5fQ09ORklHLFxuICAgICAgdXNlVmFsdWU6IGNyZWF0ZVdlYkF1dGhuQ29uZmlnKHJlbHlpbmdQYXJ0eSwgY29uZmlnKSxcbiAgICB9LFxuICAgIFdlYkF1dGhuU2VydmljZSxcbiAgXTtcbn1cbiJdfQ==","// Core service\nexport { WebAuthnService } from './lib/services/webauthn.service';\nexport { WEBAUTHN_CONFIG, createWebAuthnConfig, DEFAULT_WEBAUTHN_CONFIG, } from './lib/model/service-config';\n// Providers\nexport { provideWebAuthn } from './lib/providers/webauthn.providers';\n// Error types for enhanced error handling\nexport { WebAuthnError, WebAuthnErrorType, UserCancelledError, AuthenticatorError, InvalidOptionsError, UnsupportedOperationError, SecurityError, TimeoutError, NetworkError, RemoteEndpointError, InvalidRemoteOptionsError, } 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// Remote validation utilities\nexport { validateRemoteCreationOptions, validateRemoteRequestOptions, } from './lib/utils/remote.utils';\n// Type guards\nexport { isRegisterConfig, isAuthenticateConfig, isCreationOptions, isRequestOptions, } from './lib/utils/type-guards';\n// Preset configurations\nexport { PRESET_MAP, PASSKEY_PRESET, EXTERNAL_SECURITY_KEY_PRESET, PLATFORM_AUTHENTICATOR_PRESET, } from './lib/presets/webauthn.presets';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL25neC13ZWJhdXRobi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsZUFBZTtBQUNmLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQU9sRSxPQUFPLEVBQ0wsZUFBZSxFQUNmLG9CQUFvQixFQUNwQix1QkFBdUIsR0FDeEIsTUFBTSw0QkFBNEIsQ0FBQztBQUVwQyxZQUFZO0FBQ1osT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBc0JyRSwwQ0FBMEM7QUFDMUMsT0FBTyxFQUNMLGFBQWEsRUFDYixpQkFBaUIsRUFDakIsa0JBQWtCLEVBQ2xCLGtCQUFrQixFQUNsQixtQkFBbUIsRUFDbkIseUJBQXlCLEVBQ3pCLGFBQWEsRUFDYixZQUFZLEVBQ1osWUFBWSxFQUNaLG1CQUFtQixFQUNuQix5QkFBeUIsR0FDMUIsTUFBTSw4QkFBOEIsQ0FBQztBQUt0QyxvQkFBb0I7QUFDcEIsT0FBTyxFQUNMLHNCQUFzQixFQUN0QixzQkFBc0IsRUFDdEIsbUJBQW1CLEVBQ25CLG1CQUFtQixFQUNuQixtQkFBbUIsRUFDbkIsbUJBQW1CLEVBQ25CLGlCQUFpQixFQUNqQixjQUFjLEVBQ2QseUJBQXlCLEVBQ3pCLHlCQUF5QixFQUN6QixtQkFBbUIsRUFDbkIsZ0NBQWdDLEVBQ2hDLHNCQUFzQixFQUN0QiwyQkFBMkIsRUFDM0IsMEJBQTBCLEVBQzFCLGFBQWEsRUFDYixxQkFBcUIsR0FDdEIsTUFBTSw0QkFBNEIsQ0FBQztBQUVwQyw4QkFBOEI7QUFDOUIsT0FBTyxFQUNMLDZCQUE2QixFQUM3Qiw0QkFBNEIsR0FDN0IsTUFBTSwwQkFBMEIsQ0FBQztBQUVsQyxjQUFjO0FBQ2QsT0FBTyxFQUNMLGdCQUFnQixFQUNoQixvQkFBb0IsRUFDcEIsaUJBQWlCLEVBQ2pCLGdCQUFnQixHQUNqQixNQUFNLHlCQUF5QixDQUFDO0FBRWpDLHdCQUF3QjtBQUN4QixPQUFPLEVBQ0wsVUFBVSxFQUNWLGNBQWMsRUFDZCw0QkFBNEIsRUFDNUIsNkJBQTZCLEdBQzlCLE1BQU0sZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3JlIHNlcnZpY2VcclxuZXhwb3J0IHsgV2ViQXV0aG5TZXJ2aWNlIH0gZnJvbSAnLi9saWIvc2VydmljZXMvd2ViYXV0aG4uc2VydmljZSc7XHJcblxyXG4vLyBDb25maWd1cmF0aW9uIHN5c3RlbVxyXG5leHBvcnQgdHlwZSB7XHJcbiAgV2ViQXV0aG5Db25maWcsXHJcbiAgUmVseWluZ1BhcnR5Q29uZmlnLFxyXG59IGZyb20gJy4vbGliL21vZGVsL3NlcnZpY2UtY29uZmlnJztcclxuZXhwb3J0IHtcclxuICBXRUJBVVRITl9DT05GSUcsXHJcbiAgY3JlYXRlV2ViQXV0aG5Db25maWcsXHJcbiAgREVGQVVMVF9XRUJBVVRITl9DT05GSUcsXHJcbn0gZnJvbSAnLi9saWIvbW9kZWwvc2VydmljZS1jb25maWcnO1xyXG5cclxuLy8gUHJvdmlkZXJzXHJcbmV4cG9ydCB7IHByb3ZpZGVXZWJBdXRobiB9IGZyb20gJy4vbGliL3Byb3ZpZGVycy93ZWJhdXRobi5wcm92aWRlcnMnO1xyXG5cclxuLy8gQ29yZSBtb2RlbHMgYW5kIHJlc3BvbnNlIHR5cGVzXHJcbmV4cG9ydCB0eXBlIHtcclxuICBXZWJBdXRoblJlZ2lzdHJhdGlvblJlc3VsdCxcclxuICBXZWJBdXRobkF1dGhlbnRpY2F0aW9uUmVzdWx0LFxyXG4gIFdlYkF1dGhuU3VwcG9ydCxcclxuICBSZWdpc3RyYXRpb25SZXNwb25zZSxcclxuICBBdXRoZW50aWNhdGlvblJlc3BvbnNlLFxyXG4gIFJlZ2lzdGVyQ29uZmlnLFxyXG4gIEF1dGhlbnRpY2F0ZUNvbmZpZyxcclxuICBSZWdpc3RlcklucHV0LFxyXG4gIEF1dGhlbnRpY2F0ZUlucHV0LFxyXG4gIFByZXNldE5hbWUsXHJcbiAgRW5oYW5jZWRSZWx5aW5nUGFydHksXHJcbiAgRmxleGlibGVVc2VySWQsXHJcbiAgRmxleGlibGVDaGFsbGVuZ2UsXHJcbiAgRmxleGlibGVDcmVkZW50aWFsRGVzY3JpcHRvcnMsXHJcbiAgUmVtb3RlUmVnaXN0cmF0aW9uUmVxdWVzdCxcclxuICBSZW1vdGVBdXRoZW50aWNhdGlvblJlcXVlc3QsXHJcbn0gZnJvbSAnLi9saWIvbW9kZWwnO1xyXG5cclxuLy8gRXJyb3IgdHlwZXMgZm9yIGVuaGFuY2VkIGVycm9yIGhhbmRsaW5nXHJcbmV4cG9ydCB7XHJcbiAgV2ViQXV0aG5FcnJvcixcclxuICBXZWJBdXRobkVycm9yVHlwZSxcclxuICBVc2VyQ2FuY2VsbGVkRXJyb3IsXHJcbiAgQXV0aGVudGljYXRvckVycm9yLFxyXG4gIEludmFsaWRPcHRpb25zRXJyb3IsXHJcbiAgVW5zdXBwb3J0ZWRPcGVyYXRpb25FcnJvcixcclxuICBTZWN1cml0eUVycm9yLFxyXG4gIFRpbWVvdXRFcnJvcixcclxuICBOZXR3b3JrRXJyb3IsXHJcbiAgUmVtb3RlRW5kcG9pbnRFcnJvcixcclxuICBJbnZhbGlkUmVtb3RlT3B0aW9uc0Vycm9yLFxyXG59IGZyb20gJy4vbGliL2Vycm9ycy93ZWJhdXRobi5lcnJvcnMnO1xyXG5cclxuLy8gUmVtb3RlIGVycm9yIGNvbnRleHQgdHlwZVxyXG5leHBvcnQgdHlwZSB7IFJlbW90ZUVycm9yQ29udGV4dCB9IGZyb20gJy4vbGliL2Vycm9ycy93ZWJhdXRobi5lcnJvcnMnO1xyXG5cclxuLy8gVXRpbGl0eSBmdW5jdGlvbnNcclxuZXhwb3J0IHtcclxuICBhcnJheUJ1ZmZlclRvQmFzZTY0dXJsLFxyXG4gIGJhc2U2NHVybFRvQXJyYXlCdWZmZXIsXHJcbiAgYXJyYXlCdWZmZXJUb0Jhc2U2NCxcclxuICBiYXNlNjRUb0FycmF5QnVmZmVyLFxyXG4gIHN0cmluZ1RvQXJyYXlCdWZmZXIsXHJcbiAgYXJyYXlCdWZmZXJUb1N0cmluZyxcclxuICBnZW5lcmF0ZUNoYWxsZW5nZSxcclxuICBnZW5lcmF0ZVVzZXJJZCxcclxuICBjcmVkZW50aWFsSWRUb0FycmF5QnVmZmVyLFxyXG4gIGFycmF5QnVmZmVyVG9DcmVkZW50aWFsSWQsXHJcbiAgaXNXZWJBdXRoblN1cHBvcnRlZCxcclxuICBpc1BsYXRmb3JtQXV0aGVudGljYXRvckF2YWlsYWJsZSxcclxuICBnZXRTdXBwb3J0ZWRUcmFuc3BvcnRzLFxyXG4gIHZhbGlkYXRlUmVnaXN0cmF0aW9uT3B0aW9ucyxcclxuICBnZXREZWZhdWx0UHViS2V5Q3JlZFBhcmFtcyxcclxuICBpc0pTT05PcHRpb25zLFxyXG4gIGlzUHVibGljS2V5Q3JlZGVudGlhbCxcclxufSBmcm9tICcuL2xpYi91dGlscy93ZWJhdXRobi51dGlscyc7XHJcblxyXG4vLyBSZW1vdGUgdmFsaWRhdGlvbiB1dGlsaXRpZXNcclxuZXhwb3J0IHtcclxuICB2YWxpZGF0ZVJlbW90ZUNyZWF0aW9uT3B0aW9ucyxcclxuICB2YWxpZGF0ZVJlbW90ZVJlcXVlc3RPcHRpb25zLFxyXG59IGZyb20gJy4vbGliL3V0aWxzL3JlbW90ZS51dGlscyc7XHJcblxyXG4vLyBUeXBlIGd1YXJkc1xyXG5leHBvcnQge1xyXG4gIGlzUmVnaXN0ZXJDb25maWcsXHJcbiAgaXNBdXRoZW50aWNhdGVDb25maWcsXHJcbiAgaXNDcmVhdGlvbk9wdGlvbnMsXHJcbiAgaXNSZXF1ZXN0T3B0aW9ucyxcclxufSBmcm9tICcuL2xpYi91dGlscy90eXBlLWd1YXJkcyc7XHJcblxyXG4vLyBQcmVzZXQgY29uZmlndXJhdGlvbnNcclxuZXhwb3J0IHtcclxuICBQUkVTRVRfTUFQLFxyXG4gIFBBU1NLRVlfUFJFU0VULFxyXG4gIEVYVEVSTkFMX1NFQ1VSSVRZX0tFWV9QUkVTRVQsXHJcbiAgUExBVEZPUk1fQVVUSEVOVElDQVRPUl9QUkVTRVQsXHJcbn0gZnJvbSAnLi9saWIvcHJlc2V0cy93ZWJhdXRobi5wcmVzZXRzJztcclxuIl19","/**\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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"}
|