Thanks to visit codestin.com
Credit goes to docs.nhost.io

Skip to content

Auth

This is the main module to interact with Nhost’s Auth service. Typically you would use this module via the main Nhost client but you can also use it directly if you have a specific use case.

You can import and use this package with:

import { createClient } from '@nhost/nhost-js/auth'
import { createClient } from '@nhost/nhost-js'
const nhost = createClient({
subdomain,
region
})
await nhost.auth.signUpEmailPassword({
email,
password
})

The SDK will throw errors in most operations if the request returns a status >=300 or if the request fails entirely (i.e., due to network errors). The type of the error will be a FetchError<ErrorResponse>:

import { createClient } from '@nhost/nhost-js'
import { FetchError } from '@nhost/nhost-js/fetch'
const nhost = createClient({
subdomain,
region
})
try {
await nhost.auth.signInEmailPassword({
email,
password
})
} catch (err) {
if (!(err instanceof FetchError)) {
throw err // Re-throw if it's not a FetchError
}
console.log('Error:', err)
// Error: {
// body: {
// error: 'invalid-email-password',
// message: 'Incorrect email or password',
// status: 401
// },
// status: 401,
// headers: {
// 'content-length': '88',
// 'content-type': 'application/json',
// date: 'Mon, 12 May 2025 08:08:28 GMT'
// }
// }
// error handling...
}

This type extends the standard Error type so if you want to just log the error you can do so like this:

import { createClient } from '@nhost/nhost-js'
import { FetchError } from '@nhost/nhost-js/fetch'
const nhost = createClient({
subdomain,
region
})
try {
await nhost.auth.signInEmailPassword({
email,
password
})
} catch (err) {
if (!(err instanceof Error)) {
throw err // Re-throw if it's not an Error
}
console.log('Error:', err.message)
// Error: Incorrect email or password
}

Map of extension outputs from the client

optional appid: boolean;

Application identifier extension output

optional credProps: CredentialPropertiesOutput;

Credential properties extension output

optional hmacCreateSecret: boolean;

HMAC secret extension output


authenticatorData: string

(string) - Base64url encoded authenticator data

clientDataJSON: string

(string) - Base64url encoded client data JSON

signature: string

(string) - Base64url encoded assertion signature

optional userHandle: string;

Base64url encoded user handle


attestationObject: string

(string) - Base64url-encoded binary data

  • Format - byte
optional authenticatorData: string;

Base64url-encoded binary data Format - byte

clientDataJSON: string

(string) - Base64url-encoded binary data

  • Format - byte
optional publicKey: string;

Base64url-encoded binary data Format - byte

optional publicKeyAlgorithm: number;

The public key algorithm identifier Format - int64

optional transports: string[];

The authenticator transports


optional authenticatorAttachment: AuthenticatorAttachment;

The authenticator attachment modality

optional requireResidentKey: boolean;

Whether the authenticator must create a client-side-resident public key credential source

optional residentKey: ResidentKeyRequirement;

The resident key requirement

optional userVerification: UserVerificationRequirement;

A requirement for user verification for the operation


baseURL: string
addSecurityKey(options?: RequestInit): Promise<FetchResponse<PublicKeyCredentialCreationOptions>>;

Summary: Initialize adding of a new webauthn security key Start the process of adding a new WebAuthn security key to the user’s account. Returns a challenge that must be completed by the user’s authenticator device. Requires elevated permissions.

This method may return different T based on the response code:

  • 200: PublicKeyCredentialCreationOptions
ParameterType
options?RequestInit

Promise<FetchResponse<PublicKeyCredentialCreationOptions>>

changeUserEmail(body: UserEmailChangeRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Change user email Request to change the authenticated user’s email address. A verification email will be sent to the new address to confirm the change. Requires elevated permissions.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodyUserEmailChangeRequest
options?RequestInit

Promise<FetchResponse<"OK">>

changeUserMfa(options?: RequestInit): Promise<FetchResponse<TotpGenerateResponse>>;

Summary: Generate TOTP secret Generate a Time-based One-Time Password (TOTP) secret for setting up multi-factor authentication

This method may return different T based on the response code:

  • 200: TotpGenerateResponse
ParameterType
options?RequestInit

Promise<FetchResponse<TotpGenerateResponse>>

changeUserPassword(body: UserPasswordRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Change user password Change the user’s password. The user must be authenticated with elevated permissions or provide a valid password reset ticket.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodyUserPasswordRequest
options?RequestInit

Promise<FetchResponse<"OK">>

createPAT(body: CreatePATRequest, options?: RequestInit): Promise<FetchResponse<CreatePATResponse>>;

Summary: Create a Personal Access Token (PAT) Generate a new Personal Access Token for programmatic API access. PATs are long-lived tokens that can be used instead of regular authentication for automated systems. Requires elevated permissions.

This method may return different T based on the response code:

  • 200: CreatePATResponse
ParameterType
bodyCreatePATRequest
options?RequestInit

Promise<FetchResponse<CreatePATResponse>>

deanonymizeUser(body: UserDeanonymizeRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Deanonymize an anonymous user Convert an anonymous user to a regular user by adding email and optionally password credentials. A confirmation email will be sent if the server is configured to do so.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodyUserDeanonymizeRequest
options?RequestInit

Promise<FetchResponse<"OK">>

elevateWebauthn(options?: RequestInit): Promise<FetchResponse<PublicKeyCredentialRequestOptions>>;

Summary: Elevate access for an already signed in user using FIDO2 Webauthn Generate a Webauthn challenge for elevating user permissions

This method may return different T based on the response code:

  • 200: PublicKeyCredentialRequestOptions
ParameterType
options?RequestInit

Promise<FetchResponse<PublicKeyCredentialRequestOptions>>

getJWKs(options?: RequestInit): Promise<FetchResponse<JWKSet>>;

Summary: Get public keys for JWT verification in JWK Set format Retrieve the JSON Web Key Set (JWKS) containing public keys used to verify JWT signatures. This endpoint is used by clients to validate access tokens.

This method may return different T based on the response code:

  • 200: JWKSet
ParameterType
options?RequestInit

Promise<FetchResponse<JWKSet>>

getProviderTokens(provider: SignInProvider, options?: RequestInit): Promise<FetchResponse<ProviderSession>>;

Summary: Retrieve OAuth2 provider tokens from callback After successful OAuth2 authentication, retrieve the provider session containing access token, refresh token, and expiration information for the specified provider. To ensure the data isn’t stale this endpoint must be called immediately after the OAuth callback to obtain the tokens. The session is cleared from the database during this call, so subsequent calls will fail without going through the sign-in flow again. It is the user’s responsibility to store the session safely (e.g., in browser local storage).

This method may return different T based on the response code:

  • 200: ProviderSession
ParameterType
providerSignInProvider
options?RequestInit

Promise<FetchResponse<ProviderSession>>

getUser(options?: RequestInit): Promise<FetchResponse<User>>;

Summary: Get user information Retrieve the authenticated user’s profile information including roles, metadata, and account status.

This method may return different T based on the response code:

  • 200: User
ParameterType
options?RequestInit

Promise<FetchResponse<User>>

getVersion(options?: RequestInit): Promise<FetchResponse<GetVersionResponse200>>;

Summary: Get service version Retrieve version information about the authentication service

This method may return different T based on the response code:

  • 200: GetVersionResponse200
ParameterType
options?RequestInit

Promise<FetchResponse<GetVersionResponse200>>

healthCheckGet(options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Health check (GET) Verify if the authentication service is operational using GET method

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
options?RequestInit

Promise<FetchResponse<"OK">>

healthCheckHead(options?: RequestInit): Promise<FetchResponse<void>>;

Summary: Health check (HEAD) Verify if the authentication service is operational using HEAD method

This method may return different T based on the response code:

  • 200: void
ParameterType
options?RequestInit

Promise<FetchResponse<void>>

linkIdToken(body: LinkIdTokenRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Link a user account with the provider’s account using an id token Link the authenticated user’s account with an external OAuth provider account using an ID token. Requires elevated permissions.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodyLinkIdTokenRequest
options?RequestInit

Promise<FetchResponse<"OK">>

pushChainFunction(chainFunction: ChainFunction): void;

Add a middleware function to the fetch chain

ParameterTypeDescription
chainFunctionChainFunctionThe middleware function to add

void

refreshProviderToken(
provider: SignInProvider,
body: RefreshProviderTokenRequest,
options?: RequestInit): Promise<FetchResponse<ProviderSession>>;

Summary: Refresh OAuth2 provider tokens Refresh the OAuth2 provider access token using a valid refresh token. Returns a new provider session with updated access token, refresh token (if rotated by provider), and expiration information. This endpoint allows maintaining long-lived access to provider APIs without requiring the user to re-authenticate.

This method may return different T based on the response code:

  • 200: ProviderSession
ParameterType
providerSignInProvider
bodyRefreshProviderTokenRequest
options?RequestInit

Promise<FetchResponse<ProviderSession>>

refreshToken(body: RefreshTokenRequest, options?: RequestInit): Promise<FetchResponse<Session>>;

Summary: Refresh access token Generate a new JWT access token using a valid refresh token. The refresh token used will be revoked and a new one will be issued.

This method may return different T based on the response code:

  • 200: Session
ParameterType
bodyRefreshTokenRequest
options?RequestInit

Promise<FetchResponse<Session>>

sendPasswordResetEmail(body: UserPasswordResetRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Request password reset Request a password reset for a user account. An email with a verification link will be sent to the user’s email address to complete the password reset process.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodyUserPasswordResetRequest
options?RequestInit

Promise<FetchResponse<"OK">>

sendVerificationEmail(body: UserEmailSendVerificationEmailRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Send verification email Send an email verification link to the specified email address. Used to verify email addresses for new accounts or email changes.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodyUserEmailSendVerificationEmailRequest
options?RequestInit

Promise<FetchResponse<"OK">>

signInAnonymous(body?: SignInAnonymousRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Sign in anonymously Create an anonymous user session without providing credentials. Anonymous users can be converted to regular users later via the deanonymize endpoint.

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
body?SignInAnonymousRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

signInEmailPassword(body: SignInEmailPasswordRequest, options?: RequestInit): Promise<FetchResponse<SignInEmailPasswordResponse>>;

Summary: Sign in with email and password Authenticate a user with their email and password. Returns a session object or MFA challenge if two-factor authentication is enabled.

This method may return different T based on the response code:

  • 200: SignInEmailPasswordResponse
ParameterType
bodySignInEmailPasswordRequest
options?RequestInit

Promise<FetchResponse<SignInEmailPasswordResponse>>

signInIdToken(body: SignInIdTokenRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Sign in with an ID token Authenticate using an ID token from a supported OAuth provider (Apple or Google). Creates a new user account if one doesn’t exist.

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
bodySignInIdTokenRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

signInOTPEmail(body: SignInOTPEmailRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Sign in with email OTP Initiate email-based one-time password authentication. Sends an OTP to the specified email address. If the user doesn’t exist, a new account will be created with the provided options.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodySignInOTPEmailRequest
options?RequestInit

Promise<FetchResponse<"OK">>

signInPasswordlessEmail(body: SignInPasswordlessEmailRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Sign in with magic link email Initiate passwordless authentication by sending a magic link to the user’s email. If the user doesn’t exist, a new account will be created with the provided options.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodySignInPasswordlessEmailRequest
options?RequestInit

Promise<FetchResponse<"OK">>

signInPasswordlessSms(body: SignInPasswordlessSmsRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Sign in with SMS OTP Initiate passwordless authentication by sending a one-time password to the user’s phone number. If the user doesn’t exist, a new account will be created with the provided options.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodySignInPasswordlessSmsRequest
options?RequestInit

Promise<FetchResponse<"OK">>

signInPAT(body: SignInPATRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Sign in with Personal Access Token (PAT) Authenticate using a Personal Access Token. PATs are long-lived tokens that can be used for programmatic access to the API.

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
bodySignInPATRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

signInProviderURL(
provider: SignInProvider,
params?: SignInProviderParams,
options?: RequestInit): string;

Summary: Sign in with an OAuth2 provider Initiate OAuth2 authentication flow with a social provider. Redirects the user to the provider’s authorization page.

As this method is a redirect, it returns a URL string instead of a Promise

ParameterType
providerSignInProvider
params?SignInProviderParams
options?RequestInit

string

signInWebauthn(body?: SignInWebauthnRequest, options?: RequestInit): Promise<FetchResponse<PublicKeyCredentialRequestOptions>>;

Summary: Sign in with Webauthn Initiate a Webauthn sign-in process by sending a challenge to the user’s device. The user must have previously registered a Webauthn credential.

This method may return different T based on the response code:

  • 200: PublicKeyCredentialRequestOptions
ParameterType
body?SignInWebauthnRequest
options?RequestInit

Promise<FetchResponse<PublicKeyCredentialRequestOptions>>

signOut(body: SignOutRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Sign out End the current user session by invalidating refresh tokens. Optionally sign out from all devices.

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodySignOutRequest
options?RequestInit

Promise<FetchResponse<"OK">>

signUpEmailPassword(body: SignUpEmailPasswordRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Sign up with email and password Register a new user account with email and password. Returns a session if email verification is not required, otherwise returns null session.

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
bodySignUpEmailPasswordRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

signUpWebauthn(body: SignUpWebauthnRequest, options?: RequestInit): Promise<FetchResponse<PublicKeyCredentialCreationOptions>>;

Summary: Sign up with Webauthn Initiate a Webauthn sign-up process by sending a challenge to the user’s device. The user must not have an existing account.

This method may return different T based on the response code:

  • 200: PublicKeyCredentialCreationOptions
ParameterType
bodySignUpWebauthnRequest
options?RequestInit

Promise<FetchResponse<PublicKeyCredentialCreationOptions>>

verifyAddSecurityKey(body: VerifyAddSecurityKeyRequest, options?: RequestInit): Promise<FetchResponse<VerifyAddSecurityKeyResponse>>;

Summary: Verify adding of a new webauthn security key Complete the process of adding a new WebAuthn security key by verifying the authenticator response. Requires elevated permissions.

This method may return different T based on the response code:

  • 200: VerifyAddSecurityKeyResponse
ParameterType
bodyVerifyAddSecurityKeyRequest
options?RequestInit

Promise<FetchResponse<VerifyAddSecurityKeyResponse>>

verifyChangeUserMfa(body: UserMfaRequest, options?: RequestInit): Promise<FetchResponse<"OK">>;

Summary: Manage multi-factor authentication Activate or deactivate multi-factor authentication for the authenticated user

This method may return different T based on the response code:

  • 200: OKResponse
ParameterType
bodyUserMfaRequest
options?RequestInit

Promise<FetchResponse<"OK">>

verifyElevateWebauthn(body: SignInWebauthnVerifyRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Verify FIDO2 Webauthn authentication using public-key cryptography for elevation Complete Webauthn elevation by verifying the authentication response

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
bodySignInWebauthnVerifyRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

verifySignInMfaTotp(body: SignInMfaTotpRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Verify TOTP for MFA Complete the multi-factor authentication by verifying a Time-based One-Time Password (TOTP). Returns a session if validation is successful.

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
bodySignInMfaTotpRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

verifySignInOTPEmail(body: SignInOTPEmailVerifyRequest, options?: RequestInit): Promise<FetchResponse<SignInOTPEmailVerifyResponse>>;

Summary: Verify email OTP Complete email OTP authentication by verifying the one-time password. Returns a session if validation is successful.

This method may return different T based on the response code:

  • 200: SignInOTPEmailVerifyResponse
ParameterType
bodySignInOTPEmailVerifyRequest
options?RequestInit

Promise<FetchResponse<SignInOTPEmailVerifyResponse>>

verifySignInPasswordlessSms(body: SignInPasswordlessSmsOtpRequest, options?: RequestInit): Promise<FetchResponse<SignInPasswordlessSmsOtpResponse>>;

Summary: Verify SMS OTP Complete passwordless SMS authentication by verifying the one-time password. Returns a session if validation is successful.

This method may return different T based on the response code:

  • 200: SignInPasswordlessSmsOtpResponse
ParameterType
bodySignInPasswordlessSmsOtpRequest
options?RequestInit

Promise<FetchResponse<SignInPasswordlessSmsOtpResponse>>

verifySignInWebauthn(body: SignInWebauthnVerifyRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Verify Webauthn sign-in Complete the Webauthn sign-in process by verifying the response from the user’s device. Returns a session if validation is successful.

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
bodySignInWebauthnVerifyRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

verifySignUpWebauthn(body: SignUpWebauthnVerifyRequest, options?: RequestInit): Promise<FetchResponse<SessionPayload>>;

Summary: Verify Webauthn sign-up Complete the Webauthn sign-up process by verifying the response from the user’s device. Returns a session if validation is successful.

This method may return different T based on the response code:

  • 200: SessionPayload
ParameterType
bodySignUpWebauthnVerifyRequest
options?RequestInit

Promise<FetchResponse<SessionPayload>>

verifyTicketURL(params?: VerifyTicketParams, options?: RequestInit): string;

Summary: Verify email and authentication tickets Verify tickets created by email verification, magic link authentication, or password reset processes. Redirects the user to the appropriate destination upon successful verification.

As this method is a redirect, it returns a URL string instead of a Promise

ParameterType
params?VerifyTicketParams
options?RequestInit

string

verifyToken(body?: VerifyTokenRequest, options?: RequestInit): Promise<FetchResponse<string>>;

Summary: Verify JWT token Verify the validity of a JWT access token. If no request body is provided, the Authorization header will be used for verification.

This method may return different T based on the response code:

  • 200: string
ParameterType
body?VerifyTokenRequest
options?RequestInit

Promise<FetchResponse<string>>


expiresAt: string

(string) - Expiration date of the PAT

  • Format - date-time
optional metadata: Record<string, unknown>;

Example - {"name":"my-pat","used-by":"my-app-cli"}


id: string

(string) - ID of the PAT

  • Example - "2c35b6f3-c4b9-48e3-978a-d4d0f1d42e24"
  • Pattern - \b[0-9a-f]{8}\b-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-\b[0-9a-f]{12}\b
personalAccessToken: string

(string) - PAT

  • Example - "2c35b6f3-c4b9-48e3-978a-d4d0f1d42e24"
  • Pattern - \b[0-9a-f]{8}\b-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-\b[0-9a-f]{12}\b

optional authenticatorAttachment: string;

The authenticator attachment

optional clientExtensionResults: AuthenticationExtensionsClientOutputs;

Map of extension outputs from the client

id: string

(string) - The credential’s identifier

rawId: string

(string) - Base64url-encoded binary data

  • Format - byte
response: AuthenticatorAssertionResponse

(AuthenticatorAssertionResponse) -

type: string

(string) - The credential type represented by this object


optional authenticatorAttachment: string;

The authenticator attachment

optional clientExtensionResults: AuthenticationExtensionsClientOutputs;

Map of extension outputs from the client

id: string

(string) - The credential’s identifier

rawId: string

(string) - Base64url-encoded binary data

  • Format - byte
response: AuthenticatorAttestationResponse

(AuthenticatorAttestationResponse) -

type: string

(string) - The credential type represented by this object


alg: number

(number) - The cryptographic algorithm identifier

type: 'public-key'

(CredentialType) - The valid credential types


Credential properties extension output

optional rk: boolean;

Indicates if the credential is a resident key


Standardized error response

error: ErrorResponseError

(ErrorResponseError) - Error code identifying the specific application error

message: string

(string) - Human-friendly error message

  • Example - "Invalid email format"
status: number

(number) - HTTP status error code

  • Example - 400

version: string

(string) - The version of the authentication service

  • Example - "1.2.3"

JSON Web Key for JWT verification

alg: string

(string) - Algorithm used with this key

  • Example - "RS256"
e: string

(string) - RSA public exponent

  • Example - "AQAB"
kid: string

(string) - Key ID

  • Example - "key-id-1"
kty: string

(string) - Key type

  • Example - "RSA"
n: string

(string) - RSA modulus

  • Example - "abcd1234..."
use: string

(string) - Key usage

  • Example - "sig"

JSON Web Key Set for verifying JWT signatures

keys: JWK[];

(JWK[]) - Array of public keys


idToken: string

(string) - Apple ID token

optional nonce: string;

Nonce used during sign in process

provider: IdTokenProvider

(IdTokenProvider) -


Challenge payload for multi-factor authentication

ticket: string

(string) - Ticket to use when completing the MFA challenge

  • Example - "mfaTotp:abc123def456"

optional redirectTo: string;

Example - "https://my-app.com/catch-redirection" Format - uri


OAuth2 provider session containing access and refresh tokens

accessToken: string

(string) - OAuth2 provider access token for API calls

  • Example - "ya29.a0AfH6SMBx..."
expiresAt: string

(string) - Timestamp when the access token expires

  • Example - "2024-12-31T23:59:59Z"
  • Format - date-time
expiresIn: number

(number) - Number of seconds until the access token expires

  • Example - 3599
optional refreshToken: string;

OAuth2 provider refresh token for obtaining new access tokens (if provided by the provider) Example - "1//0gK8..."


optional connection: string;

(workos) Specifies the connection to use for authentication

optional organization: string;

(workos) Specifies the organization to use for authentication


optional attestation: ConveyancePreference;

The attestation conveyance preference

optional attestationFormats: AttestationFormat[];

The preferred attestation statement formats

optional authenticatorSelection: AuthenticatorSelection;
challenge: string

(string) - Base64url-encoded binary data

  • Format - byte
optional excludeCredentials: PublicKeyCredentialDescriptor[];

A list of PublicKeyCredentialDescriptor objects representing public key credentials that are not acceptable to the caller

optional extensions: Record<string, unknown>;

Additional parameters requesting additional processing by the client and authenticator

optional hints: PublicKeyCredentialHints[];

Hints to help guide the user through the experience

pubKeyCredParams: CredentialParameter[];

(CredentialParameter[]) - The desired credential types and their respective cryptographic parameters

rp: RelyingPartyEntity

(RelyingPartyEntity) -

optional timeout: number;

A time, in milliseconds, that the caller is willing to wait for the call to complete

user: UserEntity

(UserEntity) -


id: string

(string) - Base64url-encoded binary data

  • Format - byte
optional transports: AuthenticatorTransport[];

The authenticator transports that can be used

type: 'public-key'

(CredentialType) - The valid credential types


optional allowCredentials: PublicKeyCredentialDescriptor[];

A list of CredentialDescriptor objects representing public key credentials acceptable to the caller

challenge: string

(string) - Base64url-encoded binary data

  • Format - byte
optional extensions: Record<string, unknown>;

Additional parameters requesting additional processing by the client and authenticator

optional hints: PublicKeyCredentialHints[];

Hints to help guide the user through the experience

optional rpId: string;

The RP ID the credential should be scoped to

optional timeout: number;

A time, in milliseconds, that the caller is willing to wait for the call to complete

optional userVerification: UserVerificationRequirement;

A requirement for user verification for the operation


Request to refresh OAuth2 provider tokens

refreshToken: string

(string) - OAuth2 provider refresh token obtained from previous authentication

  • Example - "1//0gK8..."

Request to refresh an access token

refreshToken: string

(string) - Refresh token used to generate a new access token

  • Example - "2c35b6f3-c4b9-48e3-978a-d4d0f1d42e24"
  • Pattern - \b[0-9a-f]{8}\b-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-\b[0-9a-f]{12}\b

id: string

(string) - A unique identifier for the Relying Party entity, which sets the RP ID

name: string

(string) - A human-palatable name for the entity


User authentication session containing tokens and user information

accessToken: string

(string) - JWT token for authenticating API requests

  • Example - "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
accessTokenExpiresIn: number

(number) - Expiration time of the access token in seconds

  • Example - 900
  • Format - int64
refreshToken: string

(string) - Token used to refresh the access token

  • Example - "2c35b6f3-c4b9-48e3-978a-d4d0f1d42e24"
  • Pattern - \b[0-9a-f]{8}\b-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-\b[0-9a-f]{12}\b
refreshTokenId: string

(string) - Identifier for the refresh token

  • Example - "2c35b6f3-c4b9-48e3-978a-d4d0f1d42e24"
  • Pattern - \b[0-9a-f]{8}\b-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-\b[0-9a-f]{12}\b
optional user: User;

User profile and account information


Container for session information

optional session: Session;

User authentication session containing tokens and user information


optional displayName: string;

Example - "John Smith"

optional locale: string;

A two or three characters locale Example - "en" MinLength - 2 MaxLength - 3

optional metadata: Record<string, unknown>;

Example - {"firstName":"John","lastName":"Smith"}


Request to authenticate using email and password

email: string

(string) - User’s email address

password: string

(string) - User’s password

  • Example - "Str0ngPassw#ord-94|%"
  • MinLength - 3
  • MaxLength - 50

Response for email-password authentication that may include a session or MFA challenge

optional mfa: MFAChallengePayload;

Challenge payload for multi-factor authentication

optional session: Session;

User authentication session containing tokens and user information


idToken: string

(string) - Apple ID token

optional nonce: string;

Nonce used during sign in process

optional options: SignUpOptions;
provider: IdTokenProvider

(IdTokenProvider) -


otp: string

(string) - One time password

ticket: string

(string) - Ticket

  • Pattern - ^mfaTotp:.*$

email: string

(string) - A valid email

optional options: SignUpOptions;

email: string

(string) - A valid email

otp: string

(string) - One time password


optional session: Session;

User authentication session containing tokens and user information


email: string

(string) - A valid email

optional options: SignUpOptions;

otp: string

(string) - One-time password received by SMS

phoneNumber: string

(string) - Phone number of the user

  • Example - "+123456789"

optional mfa: MFAChallengePayload;

Challenge payload for multi-factor authentication

optional session: Session;

User authentication session containing tokens and user information


optional options: SignUpOptions;
phoneNumber: string

(string) - Phone number of the user

  • Example - "+123456789"

personalAccessToken: string

(string) - PAT

  • Example - "2c35b6f3-c4b9-48e3-978a-d4d0f1d42e24"
  • Pattern - \b[0-9a-f]{8}\b-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-\b[0-9a-f]{12}\b

Parameters for the signInProvider method.

optional allowedRoles: string[];

Array of allowed roles for the user

optional connect: string;

If set, this means that the user is already authenticated and wants to link their account. This needs to be a valid JWT access token.

optional defaultRole: string;

Default role for the user

optional displayName: string;

Display name for the user

optional locale: string;

A two or three characters locale

optional metadata: Record<string, unknown>;

Additional metadata for the user (JSON encoded string)

optional providerSpecificParams: ProviderSpecificParams;

Additional provider-specific parameters

optional redirectTo: string;

URI to redirect to

optional state: string;

Opaque state value to be returned by the provider


optional email: string;

A valid email Example - "[email protected]" Format - email


credential: CredentialAssertionResponse

(CredentialAssertionResponse) -

optional email: string;

A valid email. Deprecated, no longer used Example - "[email protected]" Format - email


optional all: boolean;

Sign out from all connected devices

optional refreshToken: string;

Refresh token for the current session


Request to register a new user with email and password

email: string

(string) - Email address for the new user account

optional options: SignUpOptions;
password: string

(string) - Password for the new user account

  • Example - "Str0ngPassw#ord-94|%"
  • MinLength - 3
  • MaxLength - 50

optional allowedRoles: string[];

Example - ["me","user"]

optional defaultRole: string;

Example - "user"

optional displayName: string;

Example - "John Smith" Pattern - ^[\p{L}\p{N}\p{S} ,.’-]+$ MaxLength - 32

optional locale: string;

A two or three characters locale Example - "en" MinLength - 2 MaxLength - 3

optional metadata: Record<string, unknown>;

Example - {"firstName":"John","lastName":"Smith"}

optional redirectTo: string;

Example - "https://my-app.com/catch-redirection" Format - uri


email: string

(string) - A valid email

optional options: SignUpOptions;

credential: CredentialCreationResponse

(CredentialCreationResponse) -

optional nickname: string;

Nickname for the security key

optional options: SignUpOptions;

Response containing TOTP setup information for MFA

imageUrl: string

(string) - URL to QR code image for scanning with an authenticator app

  • Example - "..."
totpSecret: string

(string) - TOTP secret key for manual setup with an authenticator app

  • Example - "ABCDEFGHIJK23456"

User profile and account information

optional activeMfaType: string;

Active MFA type for the user

avatarUrl: string

(string) - URL to the user’s profile picture

  • Example - "https://myapp.com/avatars/user123.jpg"
createdAt: string

(string) - Timestamp when the user account was created

  • Example - "2023-01-15T12:34:56Z"
  • Format - date-time
defaultRole: string

(string) - Default authorization role for the user

  • Example - "user"
displayName: string

(string) - User’s display name

  • Example - "John Smith"
optional email: string;

User’s email address Example - "[email protected]" Format - email

emailVerified: boolean

(boolean) - Whether the user’s email has been verified

  • Example - true
id: string

(string) - Unique identifier for the user

  • Example - "2c35b6f3-c4b9-48e3-978a-d4d0f1d42e24"
  • Pattern - \b[0-9a-f]{8}\b-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-\b[0-9a-f]{12}\b
isAnonymous: boolean

(boolean) - Whether this is an anonymous user account

  • Example - false
locale: string

(string) - User’s preferred locale (language code)

  • Example - "en"
  • MinLength - 2
  • MaxLength - 3
metadata: Record<string, unknown>

(Record<string, unknown>) - Custom metadata associated with the user

  • Example - {"firstName":"John","lastName":"Smith"}
optional phoneNumber: string;

User’s phone number Example - "+12025550123"

phoneNumberVerified: boolean

(boolean) - Whether the user’s phone number has been verified

  • Example - false
roles: string[];

(string[]) - List of roles assigned to the user

  • Example - ["user","customer"]

optional connection: string;

Deprecated, will be ignored

email: string

(string) - A valid email

optional options: SignUpOptions;
optional password: string;

A password of minimum 3 characters Example - "Str0ngPassw#ord-94|%" MinLength - 3 MaxLength - 50

signInMethod: UserDeanonymizeRequestSignInMethod

(UserDeanonymizeRequestSignInMethod) - Which sign-in method to use


newEmail: string

(string) - A valid email

optional options: OptionsRedirectTo;

email: string

(string) - A valid email

optional options: OptionsRedirectTo;

displayName: string

(string) - A human-palatable name for the user account, intended only for display

id: string

(string) - The user handle of the user account entity

name: string

(string) - A human-palatable name for the entity


Request to activate or deactivate multi-factor authentication

optional activeMfaType: UserMfaRequestActiveMfaType;

Type of MFA to activate. Use empty string to disable MFA. Example - "totp"

code: string

(string) - Verification code from the authenticator app when activating MFA

  • Example - "123456"

newPassword: string

(string) - A password of minimum 3 characters

  • Example - "Str0ngPassw#ord-94|%"
  • MinLength - 3
  • MaxLength - 50
optional ticket: string;

Ticket to reset the password, required if the user is not authenticated Pattern - ^passwordReset:.*$


email: string

(string) - A valid email

optional options: OptionsRedirectTo;

credential: CredentialCreationResponse

(CredentialCreationResponse) -

optional nickname: string;

Optional nickname for the security key


id: string

(string) - The ID of the newly added security key

  • Example - "123e4567-e89b-12d3-a456-426614174000"
optional nickname: string;

The nickname of the security key if provided


Parameters for the verifyTicket method.

redirectTo: string

(RedirectToQuery) - Target URL for the redirect

  • Target URL for the redirect
ticket: string

(TicketQuery) - Ticket

  • Ticket
optional type: TicketTypeQuery;

Type of the ticket. Deprecated, no longer used

  • Type of the ticket

optional token: string;

JWT token to verify

type AttestationFormat =
| 'packed'
| 'tpm'
| 'android-key'
| 'android-safetynet'
| 'fido-u2f'
| 'apple'
| 'none'

The attestation statement format


type AuthenticatorAttachment = 'platform' | 'cross-platform'

The authenticator attachment modality


type AuthenticatorTransport = 'usb' | 'nfc' | 'ble' | 'smart-card' | 'hybrid' | 'internal'

The authenticator transports that can be used


type ConveyancePreference = 'none' | 'indirect' | 'direct' | 'enterprise'

The attestation conveyance preference


type CredentialType = 'public-key'

The valid credential types


type ErrorResponseError =
| 'default-role-must-be-in-allowed-roles'
| 'disabled-endpoint'
| 'disabled-user'
| 'email-already-in-use'
| 'email-already-verified'
| 'forbidden-anonymous'
| 'internal-server-error'
| 'invalid-email-password'
| 'invalid-request'
| 'locale-not-allowed'
| 'password-too-short'
| 'password-in-hibp-database'
| 'redirectTo-not-allowed'
| 'role-not-allowed'
| 'signup-disabled'
| 'unverified-user'
| 'user-not-anonymous'
| 'invalid-pat'
| 'invalid-refresh-token'
| 'invalid-ticket'
| 'disabled-mfa-totp'
| 'no-totp-secret'
| 'invalid-totp'
| 'mfa-type-not-found'
| 'totp-already-active'
| 'invalid-state'
| 'oauth-token-echange-failed'
| 'oauth-profile-fetch-failed'
| 'oauth-provider-error'
| 'invalid-otp'
| 'cannot-send-sms'
| 'provider-account-already-linked'

Error code identifying the specific application error


type IdTokenProvider = 'apple' | 'google'

type OKResponse = 'OK'

type PublicKeyCredentialHints = 'security-key' | 'client-device' | 'hybrid'

Hints to help guide the user through the experience


type RedirectToQuery = string

Target URL for the redirect


type ResidentKeyRequirement = 'discouraged' | 'preferred' | 'required'

The resident key requirement


type SignInProvider =
| 'apple'
| 'github'
| 'google'
| 'linkedin'
| 'discord'
| 'spotify'
| 'twitch'
| 'gitlab'
| 'bitbucket'
| 'workos'
| 'azuread'
| 'entraid'
| 'strava'
| 'facebook'
| 'windowslive'
| 'twitter'

type TicketQuery = string

Ticket


type TicketTypeQuery = 'emailVerify' | 'emailConfirmChange' | 'signinPasswordless' | 'passwordReset'

Type of the ticket


type URLEncodedBase64 = string

Base64url-encoded binary data


type UserDeanonymizeRequestSignInMethod = 'email-password' | 'passwordless'

Which sign-in method to use


type UserMfaRequestActiveMfaType = 'totp' | ''

Type of MFA to activate. Use empty string to disable MFA.


type UserVerificationRequirement = 'required' | 'preferred' | 'discouraged'

A requirement for user verification for the operation

function createAPIClient(baseURL: string, chainFunctions: ChainFunction[]): Client
ParameterTypeDefault value
baseURLstringundefined
chainFunctionsChainFunction[][]

Client