Initiate the process of creating a new Passkey or WebAuthn registration.
return_passkey_credential_options field to true.
After calling this endpoint, the browser will need to call navigator.credentials.create() with the data from public_key_credential_creation_options passed to the navigator.credentials.create() request via the public key argument.
When using built-in browser methods like navigator.credentials.create(), set the use_base64_url_encoding option to true.
See our WebAuthn setup guide for additional usage instructions and example code.Basic authentication header of the form Basic <encoded-value>, where <encoded-value> is the base64-encoded string username:password.
Request type
The user_id of an active user the Passkey or WebAuthn registration should be tied to. You may use an external_id here if one is set for the user.
The domain for Passkeys or WebAuthn. Defaults to window.location.hostname.
The user agent of the client.
The requested authenticator type of the Passkey or WebAuthn device. The two valid values are platform and cross-platform. If no value passed, we assume both values are allowed.
If true, the public_key_credential_creation_options returned will be optimized for Passkeys with residentKey set to "required" and userVerification set to "preferred".
If true, values in the public_key_credential_creation_options will be base64 URL encoded. Set this option to true when using built-in browser methods like navigator.credentials.create and navigator.credentials.get.
Successful response
Globally unique UUID that is returned with every API call. This value is important to log for debugging purposes; we may ask for this value to help identify a specific API call when helping you debug an issue.
The unique ID of the affected User.
Options used for Passkey or WebAuthn registration.
The HTTP status code of the response. Stytch follows standard HTTP response status code patterns, e.g. 2XX values equate to success, 3XX values are redirects, 4XX are client errors, and 5XX are server errors.