@douvery/auth 0.3.0 → 0.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/types.ts","../../src/pkce.ts","../../src/storage.ts","../../src/client.ts","../../src/react/index.tsx"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * @douvery/auth - Core Types\n * OAuth 2.0/OIDC type definitions\n */\n\n// ============================================\n// Configuration Types\n// ============================================\n\nexport interface DouveryAuthConfig {\n /** OAuth Client ID */\n clientId: string;\n /** Authorization server base URL @default \"https://auth.douvery.com\" */\n issuer?: string;\n /** Redirect URI after authentication */\n redirectUri: string;\n /** Post-logout redirect URI */\n postLogoutRedirectUri?: string;\n /** OAuth scopes to request @default [\"openid\", \"profile\", \"email\"] */\n scopes?: string[];\n /** Token storage strategy @default \"localStorage\" */\n storage?: \"localStorage\" | \"sessionStorage\" | \"memory\" | \"cookie\";\n /** Custom storage implementation */\n customStorage?: TokenStorage;\n /** Auto-refresh tokens before expiry @default true */\n autoRefresh?: boolean;\n /** Seconds before expiry to trigger refresh @default 60 */\n refreshThreshold?: number;\n /** Enable debug logging @default false */\n debug?: boolean;\n}\n\n// ============================================\n// Token Types\n// ============================================\n\nexport interface TokenSet {\n access_token: string;\n token_type: string;\n expires_in: number;\n refresh_token?: string;\n id_token?: string;\n scope?: string;\n}\n\nexport interface TokenInfo {\n accessToken: string;\n refreshToken?: string;\n idToken?: string;\n expiresAt: number;\n tokenType: string;\n scope: string[];\n}\n\nexport interface DecodedIdToken {\n iss: string;\n sub: string;\n aud: string;\n exp: number;\n iat: number;\n auth_time?: number;\n nonce?: string;\n acr?: string;\n amr?: string[];\n azp?: string;\n at_hash?: string;\n c_hash?: string;\n name?: string;\n given_name?: string;\n family_name?: string;\n middle_name?: string;\n nickname?: string;\n preferred_username?: string;\n profile?: string;\n picture?: string;\n website?: string;\n email?: string;\n email_verified?: boolean;\n gender?: string;\n birthdate?: string;\n zoneinfo?: string;\n locale?: string;\n phone_number?: string;\n phone_number_verified?: boolean;\n address?: {\n formatted?: string;\n street_address?: string;\n locality?: string;\n region?: string;\n postal_code?: string;\n country?: string;\n };\n updated_at?: number;\n [key: string]: unknown;\n}\n\n// ============================================\n// User Types\n// ============================================\n\nexport interface User {\n id: string;\n email?: string;\n emailVerified?: boolean;\n name?: string;\n firstName?: string;\n lastName?: string;\n picture?: string;\n phoneNumber?: string;\n phoneNumberVerified?: boolean;\n locale?: string;\n [key: string]: unknown;\n}\n\n// ============================================\n// Auth State Types\n// ============================================\n\nexport type AuthStatus = \"loading\" | \"authenticated\" | \"unauthenticated\";\n\nexport interface AuthState {\n status: AuthStatus;\n user: User | null;\n tokens: TokenInfo | null;\n error: AuthError | null;\n}\n\n// ============================================\n// PKCE Types\n// ============================================\n\nexport interface PKCEPair {\n codeVerifier: string;\n codeChallenge: string;\n codeChallengeMethod: \"S256\";\n}\n\nexport interface AuthorizationParams {\n state: string;\n nonce: string;\n codeVerifier: string;\n codeChallenge: string;\n redirectUri: string;\n}\n\n// ============================================\n// Storage Types\n// ============================================\n\nexport interface TokenStorage {\n get(key: string): string | null | Promise<string | null>;\n set(key: string, value: string): void | Promise<void>;\n remove(key: string): void | Promise<void>;\n clear(): void | Promise<void>;\n}\n\nexport interface StorageKeys {\n accessToken: string;\n refreshToken: string;\n idToken: string;\n expiresAt: string;\n state: string;\n nonce: string;\n codeVerifier: string;\n returnTo: string;\n}\n\n// ============================================\n// Event Types\n// ============================================\n\nexport type AuthEvent =\n | { type: \"INITIALIZED\" }\n | { type: \"LOGIN_STARTED\" }\n | { type: \"LOGIN_SUCCESS\"; user: User; tokens: TokenInfo }\n | { type: \"LOGIN_ERROR\"; error: AuthError }\n | { type: \"LOGOUT_STARTED\" }\n | { type: \"LOGOUT_SUCCESS\" }\n | { type: \"LOGOUT_ERROR\"; error: AuthError }\n | { type: \"TOKEN_REFRESHED\"; tokens: TokenInfo }\n | { type: \"TOKEN_REFRESH_ERROR\"; error: AuthError }\n | { type: \"SESSION_EXPIRED\" };\n\nexport type AuthEventHandler = (event: AuthEvent) => void;\n\n// ============================================\n// Error Types\n// ============================================\n\nexport class AuthError extends Error {\n constructor(\n public code: AuthErrorCode,\n message: string,\n public cause?: Error,\n ) {\n super(message);\n this.name = \"AuthError\";\n }\n}\n\nexport type AuthErrorCode =\n | \"invalid_request\"\n | \"invalid_client\"\n | \"invalid_grant\"\n | \"unauthorized_client\"\n | \"unsupported_grant_type\"\n | \"invalid_scope\"\n | \"access_denied\"\n | \"server_error\"\n | \"temporarily_unavailable\"\n | \"login_required\"\n | \"consent_required\"\n | \"interaction_required\"\n | \"invalid_token\"\n | \"insufficient_scope\"\n | \"token_expired\"\n | \"token_refresh_failed\"\n | \"pkce_error\"\n | \"state_mismatch\"\n | \"nonce_mismatch\"\n | \"network_error\"\n | \"configuration_error\"\n | \"unknown_error\";\n\n// ============================================\n// Discovery Types\n// ============================================\n\nexport interface OIDCDiscovery {\n issuer: string;\n authorization_endpoint: string;\n token_endpoint: string;\n userinfo_endpoint: string;\n jwks_uri: string;\n revocation_endpoint?: string;\n introspection_endpoint?: string;\n end_session_endpoint?: string;\n registration_endpoint?: string;\n scopes_supported: string[];\n response_types_supported: string[];\n response_modes_supported?: string[];\n grant_types_supported: string[];\n token_endpoint_auth_methods_supported?: string[];\n subject_types_supported: string[];\n id_token_signing_alg_values_supported: string[];\n claims_supported?: string[];\n code_challenge_methods_supported?: string[];\n}\n\n// ============================================\n// Callback Types\n// ============================================\n\nexport interface CallbackParams {\n code?: string;\n state?: string;\n error?: string;\n error_description?: string;\n}\n\nexport interface CallbackResult {\n success: boolean;\n user?: User;\n tokens?: TokenInfo;\n error?: AuthError;\n returnTo?: string;\n}\n\n// ============================================\n// Login Options\n// ============================================\n\nexport interface LoginOptions {\n /** URL to return to after login */\n returnTo?: string;\n /** Additional authorization parameters */\n authorizationParams?: Record<string, string>;\n /** Prompt parameter (none, login, consent, select_account) */\n prompt?: \"none\" | \"login\" | \"consent\" | \"select_account\";\n /** Login hint (email or identifier) */\n loginHint?: string;\n /** UI locales preference */\n uiLocales?: string;\n /** Maximum authentication age in seconds */\n maxAge?: number;\n /** ACR values requested */\n acrValues?: string;\n}\n\nexport interface LogoutOptions {\n /** URL to return to after logout */\n returnTo?: string;\n /** Whether to federate logout (end session at IdP) @default true */\n federated?: boolean;\n /** Only clear local session, don't redirect @default false */\n localOnly?: boolean;\n}\n\n// ============================================\n// Navigation Options\n// ============================================\n\n/** Base options for all auth navigation redirects */\nexport interface AuthNavigationOptions {\n /** URL to return to after the action completes */\n returnTo?: string;\n /** OAuth client_id for branded experiences */\n clientId?: string;\n /** Open in a new tab/window instead of redirecting */\n openInNewTab?: boolean;\n}\n\nexport interface SelectAccountOptions extends AuthNavigationOptions {\n /** Pre-select a specific email/account */\n loginHint?: string;\n}\n\nexport interface RegisterOptions extends AuthNavigationOptions {\n /** Pre-fill email on register form */\n email?: string;\n /** Pre-fill first name */\n firstName?: string;\n /** Pre-fill last name */\n lastName?: string;\n /** UI locale preference */\n uiLocales?: string;\n}\n\nexport interface RecoverAccountOptions extends AuthNavigationOptions {\n /** Pre-fill email for recovery */\n email?: string;\n}\n\nexport interface VerifyAccountOptions extends AuthNavigationOptions {\n /** Email to verify */\n email?: string;\n}\n\nexport interface UpgradeAccountOptions extends AuthNavigationOptions {\n /** Scopes to request on upgrade */\n scopes?: string[];\n}\n\nexport interface SetupPasskeyOptions extends AuthNavigationOptions {}\n\nexport interface SetupAddressOptions extends AuthNavigationOptions {}\n\nexport interface AddAccountOptions extends AuthNavigationOptions {\n /** Pre-fill email hint for the new account */\n loginHint?: string;\n}\n\nexport interface RevokeTokenOptions {\n /** Specific token to revoke. If not provided, revokes current access token */\n token?: string;\n /** Token type hint: \"access_token\" or \"refresh_token\" */\n tokenTypeHint?: \"access_token\" | \"refresh_token\";\n}\n\n/** Result of URL builder methods (non-redirecting) */\nexport interface AuthUrl {\n /** The full URL */\n url: string;\n /** Open the URL via redirect */\n redirect: () => void;\n /** Open the URL in a new tab */\n open: () => Window | null;\n}\n","/**\n * @douvery/auth - PKCE Utilities\n * RFC 7636 - Proof Key for Code Exchange\n */\n\nimport type { PKCEPair } from \"./types\";\n\n/** Generate a cryptographically random string for use as code_verifier */\nexport function generateCodeVerifier(length: number = 64): string {\n const charset =\n \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~\";\n const randomValues = crypto.getRandomValues(new Uint8Array(length));\n return Array.from(randomValues)\n .map((v) => charset[v % charset.length])\n .join(\"\");\n}\n\n/** Generate a random state parameter for CSRF protection */\nexport function generateState(): string {\n return generateCodeVerifier(32);\n}\n\n/** Generate a random nonce for replay attack protection */\nexport function generateNonce(): string {\n return generateCodeVerifier(32);\n}\n\n/** Create SHA-256 hash and encode as base64url */\nexport async function generateCodeChallenge(verifier: string): Promise<string> {\n const encoder = new TextEncoder();\n const data = encoder.encode(verifier);\n const hashBuffer = await crypto.subtle.digest(\"SHA-256\", data);\n return base64UrlEncode(hashBuffer);\n}\n\n/** Encode ArrayBuffer as base64url (RFC 4648 Section 5) */\nexport function base64UrlEncode(buffer: ArrayBuffer): string {\n const bytes = new Uint8Array(buffer);\n let binary = \"\";\n for (let i = 0; i < bytes.length; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n const base64 = btoa(binary);\n return base64.replace(/\\+/g, \"-\").replace(/\\//g, \"_\").replace(/=+$/, \"\");\n}\n\n/** Decode base64url string to ArrayBuffer */\nexport function base64UrlDecode(input: string): ArrayBuffer {\n let base64 = input.replace(/-/g, \"+\").replace(/_/g, \"/\");\n const padding = base64.length % 4;\n if (padding) {\n base64 += \"=\".repeat(4 - padding);\n }\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/** Generate a complete PKCE pair (verifier + challenge) */\nexport async function generatePKCEPair(): Promise<PKCEPair> {\n const codeVerifier = generateCodeVerifier();\n const codeChallenge = await generateCodeChallenge(codeVerifier);\n return {\n codeVerifier,\n codeChallenge,\n codeChallengeMethod: \"S256\",\n };\n}\n\n/** Verify a code_verifier against a code_challenge */\nexport async function verifyCodeChallenge(\n verifier: string,\n challenge: string,\n method: \"S256\" | \"plain\" = \"S256\",\n): Promise<boolean> {\n if (method === \"plain\") {\n return verifier === challenge;\n }\n const computedChallenge = await generateCodeChallenge(verifier);\n return computedChallenge === challenge;\n}\n\n/** Parse and decode a JWT token (without verification) */\nexport function decodeJWT<T = Record<string, unknown>>(token: string): T {\n const parts = token.split(\".\");\n if (parts.length !== 3) {\n throw new Error(\"Invalid JWT format\");\n }\n const payload = parts[1];\n const decoded = base64UrlDecode(payload);\n const text = new TextDecoder().decode(decoded);\n return JSON.parse(text) as T;\n}\n\n/** Check if a JWT token is expired */\nexport function isTokenExpired(token: string, clockSkew: number = 60): boolean {\n try {\n const payload = decodeJWT<{ exp?: number }>(token);\n if (!payload.exp) {\n return false;\n }\n const now = Math.floor(Date.now() / 1000);\n return payload.exp < now - clockSkew;\n } catch {\n return true;\n }\n}\n\n/** Get token expiration timestamp */\nexport function getTokenExpiration(token: string): number | null {\n try {\n const payload = decodeJWT<{ exp?: number }>(token);\n return payload.exp ? payload.exp * 1000 : null;\n } catch {\n return null;\n }\n}\n","/**\n * @douvery/auth - Token Storage\n * Abstraction for token persistence\n */\n\nimport type { TokenStorage, StorageKeys, TokenInfo } from \"./types\";\n\nconst DEFAULT_PREFIX = \"douvery_auth\";\n\nexport const STORAGE_KEYS: StorageKeys = {\n accessToken: `${DEFAULT_PREFIX}_access_token`,\n refreshToken: `${DEFAULT_PREFIX}_refresh_token`,\n idToken: `${DEFAULT_PREFIX}_id_token`,\n expiresAt: `${DEFAULT_PREFIX}_expires_at`,\n state: `${DEFAULT_PREFIX}_state`,\n nonce: `${DEFAULT_PREFIX}_nonce`,\n codeVerifier: `${DEFAULT_PREFIX}_code_verifier`,\n returnTo: `${DEFAULT_PREFIX}_return_to`,\n};\n\n/** In-memory storage implementation */\nexport class MemoryStorage implements TokenStorage {\n private store = new Map<string, string>();\n\n get(key: string): string | null {\n return this.store.get(key) ?? null;\n }\n\n set(key: string, value: string): void {\n this.store.set(key, value);\n }\n\n remove(key: string): void {\n this.store.delete(key);\n }\n\n clear(): void {\n this.store.clear();\n }\n}\n\n/** LocalStorage implementation */\nexport class LocalStorage implements TokenStorage {\n get(key: string): string | null {\n if (typeof window === \"undefined\") return null;\n return localStorage.getItem(key);\n }\n\n set(key: string, value: string): void {\n if (typeof window === \"undefined\") return;\n localStorage.setItem(key, value);\n }\n\n remove(key: string): void {\n if (typeof window === \"undefined\") return;\n localStorage.removeItem(key);\n }\n\n clear(): void {\n if (typeof window === \"undefined\") return;\n Object.values(STORAGE_KEYS).forEach((key) => {\n localStorage.removeItem(key);\n });\n }\n}\n\n/** SessionStorage implementation */\nexport class SessionStorage implements TokenStorage {\n get(key: string): string | null {\n if (typeof window === \"undefined\") return null;\n return sessionStorage.getItem(key);\n }\n\n set(key: string, value: string): void {\n if (typeof window === \"undefined\") return;\n sessionStorage.setItem(key, value);\n }\n\n remove(key: string): void {\n if (typeof window === \"undefined\") return;\n sessionStorage.removeItem(key);\n }\n\n clear(): void {\n if (typeof window === \"undefined\") return;\n Object.values(STORAGE_KEYS).forEach((key) => {\n sessionStorage.removeItem(key);\n });\n }\n}\n\n/** Cookie storage implementation (for SSR compatibility) */\nexport class CookieStorage implements TokenStorage {\n constructor(\n private options: {\n path?: string;\n domain?: string;\n secure?: boolean;\n sameSite?: \"Strict\" | \"Lax\" | \"None\";\n maxAge?: number;\n } = {},\n ) {\n this.options = { path: \"/\", secure: true, sameSite: \"Lax\", ...options };\n }\n\n get(key: string): string | null {\n if (typeof document === \"undefined\") return null;\n const cookies = document.cookie.split(\";\");\n for (const cookie of cookies) {\n const [name, value] = cookie.trim().split(\"=\");\n if (name === key) {\n return decodeURIComponent(value);\n }\n }\n return null;\n }\n\n set(key: string, value: string): void {\n if (typeof document === \"undefined\") return;\n const parts = [\n `${key}=${encodeURIComponent(value)}`,\n `path=${this.options.path}`,\n ];\n if (this.options.domain) parts.push(`domain=${this.options.domain}`);\n if (this.options.secure) parts.push(\"secure\");\n if (this.options.sameSite) parts.push(`samesite=${this.options.sameSite}`);\n if (this.options.maxAge) parts.push(`max-age=${this.options.maxAge}`);\n document.cookie = parts.join(\"; \");\n }\n\n remove(key: string): void {\n if (typeof document === \"undefined\") return;\n document.cookie = `${key}=; path=${this.options.path}; expires=Thu, 01 Jan 1970 00:00:00 GMT`;\n }\n\n clear(): void {\n Object.values(STORAGE_KEYS).forEach((key) => this.remove(key));\n }\n}\n\n/** Create storage instance based on type */\nexport function createStorage(\n type: \"localStorage\" | \"sessionStorage\" | \"memory\" | \"cookie\",\n): TokenStorage {\n switch (type) {\n case \"localStorage\":\n return new LocalStorage();\n case \"sessionStorage\":\n return new SessionStorage();\n case \"cookie\":\n return new CookieStorage();\n case \"memory\":\n default:\n return new MemoryStorage();\n }\n}\n\n/** Token manager for handling token persistence */\nexport class TokenManager {\n constructor(private storage: TokenStorage) {}\n\n async getTokens(): Promise<TokenInfo | null> {\n const accessToken = await this.storage.get(STORAGE_KEYS.accessToken);\n if (!accessToken) return null;\n\n const refreshToken = await this.storage.get(STORAGE_KEYS.refreshToken);\n const idToken = await this.storage.get(STORAGE_KEYS.idToken);\n const expiresAt = await this.storage.get(STORAGE_KEYS.expiresAt);\n\n return {\n accessToken,\n refreshToken: refreshToken ?? undefined,\n idToken: idToken ?? undefined,\n expiresAt: expiresAt ? parseInt(expiresAt, 10) : 0,\n tokenType: \"Bearer\",\n scope: [],\n };\n }\n\n async setTokens(tokens: TokenInfo): Promise<void> {\n await this.storage.set(STORAGE_KEYS.accessToken, tokens.accessToken);\n await this.storage.set(STORAGE_KEYS.expiresAt, tokens.expiresAt.toString());\n if (tokens.refreshToken) {\n await this.storage.set(STORAGE_KEYS.refreshToken, tokens.refreshToken);\n }\n if (tokens.idToken) {\n await this.storage.set(STORAGE_KEYS.idToken, tokens.idToken);\n }\n }\n\n async clearTokens(): Promise<void> {\n await this.storage.remove(STORAGE_KEYS.accessToken);\n await this.storage.remove(STORAGE_KEYS.refreshToken);\n await this.storage.remove(STORAGE_KEYS.idToken);\n await this.storage.remove(STORAGE_KEYS.expiresAt);\n }\n\n async saveState(state: string): Promise<void> {\n await this.storage.set(STORAGE_KEYS.state, state);\n }\n\n async getState(): Promise<string | null> {\n return this.storage.get(STORAGE_KEYS.state);\n }\n\n async clearState(): Promise<void> {\n await this.storage.remove(STORAGE_KEYS.state);\n }\n\n async saveNonce(nonce: string): Promise<void> {\n await this.storage.set(STORAGE_KEYS.nonce, nonce);\n }\n\n async getNonce(): Promise<string | null> {\n return this.storage.get(STORAGE_KEYS.nonce);\n }\n\n async clearNonce(): Promise<void> {\n await this.storage.remove(STORAGE_KEYS.nonce);\n }\n\n async saveCodeVerifier(verifier: string): Promise<void> {\n await this.storage.set(STORAGE_KEYS.codeVerifier, verifier);\n }\n\n async getCodeVerifier(): Promise<string | null> {\n return this.storage.get(STORAGE_KEYS.codeVerifier);\n }\n\n async clearCodeVerifier(): Promise<void> {\n await this.storage.remove(STORAGE_KEYS.codeVerifier);\n }\n\n async saveReturnTo(url: string): Promise<void> {\n await this.storage.set(STORAGE_KEYS.returnTo, url);\n }\n\n async getReturnTo(): Promise<string | null> {\n return this.storage.get(STORAGE_KEYS.returnTo);\n }\n\n async clearReturnTo(): Promise<void> {\n await this.storage.remove(STORAGE_KEYS.returnTo);\n }\n\n async clearAll(): Promise<void> {\n await this.storage.clear();\n }\n}\n","/**\n * @douvery/auth - Auth Client\n * Main OAuth 2.0/OIDC client implementation\n */\n\nimport type {\n DouveryAuthConfig,\n TokenSet,\n TokenInfo,\n User,\n AuthState,\n AuthEvent,\n AuthEventHandler,\n OIDCDiscovery,\n CallbackResult,\n LoginOptions,\n LogoutOptions,\n DecodedIdToken,\n SelectAccountOptions,\n RegisterOptions,\n RecoverAccountOptions,\n VerifyAccountOptions,\n UpgradeAccountOptions,\n SetupPasskeyOptions,\n SetupAddressOptions,\n AddAccountOptions,\n RevokeTokenOptions,\n AuthNavigationOptions,\n AuthUrl,\n} from \"./types\";\nimport { AuthError } from \"./types\";\nimport {\n generatePKCEPair,\n generateState,\n generateNonce,\n decodeJWT,\n isTokenExpired,\n} from \"./pkce\";\nimport { createStorage, TokenManager } from \"./storage\";\n\nconst DEFAULT_ISSUER = \"https://auth.douvery.com\";\nconst DEFAULT_SCOPES = [\"openid\", \"profile\", \"email\"];\n\nexport class DouveryAuthClient {\n private config: Required<\n Pick<DouveryAuthConfig, \"clientId\" | \"issuer\" | \"redirectUri\" | \"scopes\">\n > &\n DouveryAuthConfig;\n private tokenManager: TokenManager;\n private discovery: OIDCDiscovery | null = null;\n private eventHandlers: Set<AuthEventHandler> = new Set();\n private refreshTimer: ReturnType<typeof setTimeout> | null = null;\n private state: AuthState = {\n status: \"loading\",\n user: null,\n tokens: null,\n error: null,\n };\n\n constructor(config: DouveryAuthConfig) {\n this.config = {\n issuer: DEFAULT_ISSUER,\n scopes: DEFAULT_SCOPES,\n storage: \"localStorage\",\n autoRefresh: true,\n refreshThreshold: 60,\n debug: false,\n ...config,\n };\n\n const storage =\n config.customStorage ??\n createStorage(this.config.storage ?? \"localStorage\");\n this.tokenManager = new TokenManager(storage);\n }\n\n /** Initialize the auth client */\n async initialize(): Promise<AuthState> {\n this.log(\"Initializing auth client...\");\n\n try {\n if (this.isCallback()) {\n this.log(\"Handling OAuth callback...\");\n const result = await this.handleCallback();\n if (result.success && result.user && result.tokens) {\n this.updateState({\n status: \"authenticated\",\n user: result.user,\n tokens: result.tokens,\n error: null,\n });\n this.setupAutoRefresh();\n } else {\n this.updateState({\n status: \"unauthenticated\",\n user: null,\n tokens: null,\n error: result.error ?? null,\n });\n }\n } else {\n const tokens = await this.tokenManager.getTokens();\n if (tokens && tokens.accessToken) {\n if (!isTokenExpired(tokens.accessToken)) {\n this.log(\"Found valid existing session\");\n const user = await this.fetchUser(tokens.accessToken);\n this.updateState({\n status: \"authenticated\",\n user,\n tokens,\n error: null,\n });\n this.setupAutoRefresh();\n } else if (tokens.refreshToken) {\n this.log(\"Access token expired, attempting refresh...\");\n await this.refreshTokens();\n } else {\n this.log(\"Session expired, no refresh token\");\n await this.tokenManager.clearTokens();\n this.updateState({\n status: \"unauthenticated\",\n user: null,\n tokens: null,\n error: null,\n });\n }\n } else {\n this.log(\"No existing session found\");\n this.updateState({\n status: \"unauthenticated\",\n user: null,\n tokens: null,\n error: null,\n });\n }\n }\n\n this.emit({ type: \"INITIALIZED\" });\n } catch (error) {\n this.log(\"Initialization error:\", error);\n this.updateState({\n status: \"unauthenticated\",\n user: null,\n tokens: null,\n error:\n error instanceof AuthError\n ? error\n : new AuthError(\n \"unknown_error\",\n \"Initialization failed\",\n error as Error,\n ),\n });\n }\n\n return this.state;\n }\n\n /** Start the login flow */\n async login(options: LoginOptions = {}): Promise<void> {\n this.log(\"Starting login flow...\");\n this.emit({ type: \"LOGIN_STARTED\" });\n\n try {\n const discovery = await this.getDiscovery();\n const pkce = await generatePKCEPair();\n const state = generateState();\n const nonce = generateNonce();\n\n await this.tokenManager.saveState(state);\n await this.tokenManager.saveNonce(nonce);\n await this.tokenManager.saveCodeVerifier(pkce.codeVerifier);\n\n if (options.returnTo) {\n await this.tokenManager.saveReturnTo(options.returnTo);\n }\n\n const params = new URLSearchParams({\n response_type: \"code\",\n client_id: this.config.clientId,\n redirect_uri: this.config.redirectUri,\n scope: this.config.scopes!.join(\" \"),\n state,\n nonce,\n code_challenge: pkce.codeChallenge,\n code_challenge_method: pkce.codeChallengeMethod,\n ...options.authorizationParams,\n });\n\n if (options.prompt) params.set(\"prompt\", options.prompt);\n if (options.loginHint) params.set(\"login_hint\", options.loginHint);\n if (options.uiLocales) params.set(\"ui_locales\", options.uiLocales);\n if (options.maxAge !== undefined)\n params.set(\"max_age\", options.maxAge.toString());\n if (options.acrValues) params.set(\"acr_values\", options.acrValues);\n\n const authUrl = `${discovery.authorization_endpoint}?${params}`;\n this.log(\"Redirecting to:\", authUrl);\n\n window.location.href = authUrl;\n } catch (error) {\n const authError =\n error instanceof AuthError\n ? error\n : new AuthError(\n \"configuration_error\",\n \"Login failed\",\n error as Error,\n );\n this.emit({ type: \"LOGIN_ERROR\", error: authError });\n throw authError;\n }\n }\n\n /** Logout the user */\n async logout(options: LogoutOptions = {}): Promise<void> {\n this.log(\"Starting logout...\");\n this.emit({ type: \"LOGOUT_STARTED\" });\n\n try {\n await this.tokenManager.clearAll();\n this.clearAutoRefresh();\n\n this.updateState({\n status: \"unauthenticated\",\n user: null,\n tokens: null,\n error: null,\n });\n\n if (options.localOnly) {\n this.emit({ type: \"LOGOUT_SUCCESS\" });\n return;\n }\n\n if (options.federated !== false) {\n const discovery = await this.getDiscovery();\n if (discovery.end_session_endpoint) {\n const params = new URLSearchParams();\n if (this.state.tokens?.idToken) {\n params.set(\"id_token_hint\", this.state.tokens.idToken);\n }\n if (options.returnTo || this.config.postLogoutRedirectUri) {\n params.set(\n \"post_logout_redirect_uri\",\n options.returnTo || this.config.postLogoutRedirectUri!,\n );\n }\n params.set(\"client_id\", this.config.clientId);\n\n const logoutUrl = `${discovery.end_session_endpoint}?${params}`;\n this.log(\"Redirecting to logout:\", logoutUrl);\n window.location.href = logoutUrl;\n return;\n }\n }\n\n this.emit({ type: \"LOGOUT_SUCCESS\" });\n\n if (options.returnTo) {\n window.location.href = options.returnTo;\n }\n } catch (error) {\n const authError =\n error instanceof AuthError\n ? error\n : new AuthError(\"unknown_error\", \"Logout failed\", error as Error);\n this.emit({ type: \"LOGOUT_ERROR\", error: authError });\n throw authError;\n }\n }\n\n /** Check if current URL is an OAuth callback */\n isCallback(): boolean {\n if (typeof window === \"undefined\") return false;\n const params = new URLSearchParams(window.location.search);\n return params.has(\"code\") || params.has(\"error\");\n }\n\n /** Handle the OAuth callback */\n async handleCallback(): Promise<CallbackResult> {\n this.log(\"Processing callback...\");\n\n if (typeof window === \"undefined\") {\n return {\n success: false,\n error: new AuthError(\n \"configuration_error\",\n \"Cannot handle callback on server\",\n ),\n };\n }\n\n const params = new URLSearchParams(window.location.search);\n const code = params.get(\"code\");\n const stateParam = params.get(\"state\");\n const errorParam = params.get(\"error\");\n const errorDescription = params.get(\"error_description\");\n\n if (errorParam) {\n const error = new AuthError(\n errorParam as any,\n errorDescription ?? \"Authorization failed\",\n );\n return { success: false, error };\n }\n\n const savedState = await this.tokenManager.getState();\n if (!stateParam || stateParam !== savedState) {\n return {\n success: false,\n error: new AuthError(\"state_mismatch\", \"State parameter mismatch\"),\n };\n }\n\n if (!code) {\n return {\n success: false,\n error: new AuthError(\n \"invalid_request\",\n \"No authorization code received\",\n ),\n };\n }\n\n const codeVerifier = await this.tokenManager.getCodeVerifier();\n if (!codeVerifier) {\n return {\n success: false,\n error: new AuthError(\"pkce_error\", \"No code verifier found\"),\n };\n }\n\n try {\n const tokens = await this.exchangeCode(code, codeVerifier);\n await this.tokenManager.setTokens(tokens);\n const user = await this.fetchUser(tokens.accessToken);\n const returnTo = await this.tokenManager.getReturnTo();\n\n await this.tokenManager.clearState();\n await this.tokenManager.clearNonce();\n await this.tokenManager.clearCodeVerifier();\n await this.tokenManager.clearReturnTo();\n\n window.history.replaceState({}, \"\", window.location.pathname);\n\n this.emit({ type: \"LOGIN_SUCCESS\", user, tokens });\n\n return { success: true, user, tokens, returnTo: returnTo ?? undefined };\n } catch (error) {\n const authError =\n error instanceof AuthError\n ? error\n : new AuthError(\n \"invalid_grant\",\n \"Token exchange failed\",\n error as Error,\n );\n this.emit({ type: \"LOGIN_ERROR\", error: authError });\n return { success: false, error: authError };\n }\n }\n\n private async exchangeCode(\n code: string,\n codeVerifier: string,\n ): Promise<TokenInfo> {\n const discovery = await this.getDiscovery();\n\n const response = await fetch(discovery.token_endpoint, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/x-www-form-urlencoded\" },\n body: new URLSearchParams({\n grant_type: \"authorization_code\",\n code,\n redirect_uri: this.config.redirectUri,\n client_id: this.config.clientId,\n code_verifier: codeVerifier,\n }),\n });\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({}));\n throw new AuthError(\n error.error ?? \"invalid_grant\",\n error.error_description ?? \"Token exchange failed\",\n );\n }\n\n const tokenSet: TokenSet = await response.json();\n return this.tokenSetToInfo(tokenSet);\n }\n\n /** Refresh the access token */\n async refreshTokens(): Promise<TokenInfo> {\n this.log(\"Refreshing tokens...\");\n\n const tokens = await this.tokenManager.getTokens();\n if (!tokens?.refreshToken) {\n throw new AuthError(\"token_refresh_failed\", \"No refresh token available\");\n }\n\n const discovery = await this.getDiscovery();\n\n const response = await fetch(discovery.token_endpoint, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/x-www-form-urlencoded\" },\n body: new URLSearchParams({\n grant_type: \"refresh_token\",\n refresh_token: tokens.refreshToken,\n client_id: this.config.clientId,\n }),\n });\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({}));\n const authError = new AuthError(\n error.error ?? \"token_refresh_failed\",\n error.error_description ?? \"Token refresh failed\",\n );\n this.emit({ type: \"TOKEN_REFRESH_ERROR\", error: authError });\n await this.tokenManager.clearTokens();\n this.updateState({\n status: \"unauthenticated\",\n user: null,\n tokens: null,\n error: authError,\n });\n this.emit({ type: \"SESSION_EXPIRED\" });\n throw authError;\n }\n\n const tokenSet: TokenSet = await response.json();\n const newTokens = this.tokenSetToInfo(tokenSet);\n await this.tokenManager.setTokens(newTokens);\n\n const user = newTokens.idToken\n ? this.extractUserFromIdToken(newTokens.idToken)\n : this.state.user;\n\n this.updateState({ ...this.state, tokens: newTokens, user });\n this.emit({ type: \"TOKEN_REFRESHED\", tokens: newTokens });\n this.setupAutoRefresh();\n\n return newTokens;\n }\n\n /** Get current access token (auto-refreshes if needed) */\n async getAccessToken(): Promise<string | null> {\n const tokens = await this.tokenManager.getTokens();\n if (!tokens) return null;\n\n if (isTokenExpired(tokens.accessToken)) {\n if (tokens.refreshToken) {\n const newTokens = await this.refreshTokens();\n return newTokens.accessToken;\n }\n return null;\n }\n\n return tokens.accessToken;\n }\n\n // ============================================\n // Navigation Methods\n // ============================================\n\n /** Redirect to select/switch account */\n selectAccount(options: SelectAccountOptions = {}): void {\n const url = this.buildSelectAccountUrl(options);\n this.navigate(url, options);\n }\n\n /** Build select-account URL without redirecting */\n buildSelectAccountUrl(options: SelectAccountOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n if (options.loginHint) params.set(\"login_hint\", options.loginHint);\n return this.createAuthUrl(\"/select-account\", params);\n }\n\n /** Redirect to add another account (multi-session) */\n addAccount(options: AddAccountOptions = {}): void {\n const url = this.buildAddAccountUrl(options);\n this.navigate(url, options);\n }\n\n /** Build add-account URL without redirecting */\n buildAddAccountUrl(options: AddAccountOptions = {}): AuthUrl {\n const params = new URLSearchParams({ add_account: \"true\" });\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n if (options.loginHint) params.set(\"login_hint\", options.loginHint);\n return this.createAuthUrl(\"/login\", params);\n }\n\n /** Redirect to register a new account */\n register(options: RegisterOptions = {}): void {\n const url = this.buildRegisterUrl(options);\n this.navigate(url, options);\n }\n\n /** Build register URL without redirecting */\n buildRegisterUrl(options: RegisterOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n if (options.email) params.set(\"email\", options.email);\n if (options.firstName) params.set(\"first_name\", options.firstName);\n if (options.lastName) params.set(\"last_name\", options.lastName);\n if (options.uiLocales) params.set(\"ui_locales\", options.uiLocales);\n return this.createAuthUrl(\"/register\", params);\n }\n\n /** Redirect to recover account (forgot password) */\n recoverAccount(options: RecoverAccountOptions = {}): void {\n const url = this.buildRecoverAccountUrl(options);\n this.navigate(url, options);\n }\n\n /** Build recover-account URL without redirecting */\n buildRecoverAccountUrl(options: RecoverAccountOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n if (options.email) params.set(\"email\", options.email);\n return this.createAuthUrl(\"/recover-account\", params);\n }\n\n /** Redirect to verify account (email verification) */\n verifyAccount(options: VerifyAccountOptions = {}): void {\n const url = this.buildVerifyAccountUrl(options);\n this.navigate(url, options);\n }\n\n /** Build verify-account URL without redirecting */\n buildVerifyAccountUrl(options: VerifyAccountOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n if (options.email) params.set(\"email\", options.email);\n return this.createAuthUrl(\"/verify-account\", params);\n }\n\n /** Redirect to upgrade account (guest → full account) */\n upgradeAccount(options: UpgradeAccountOptions = {}): void {\n const url = this.buildUpgradeAccountUrl(options);\n this.navigate(url, options);\n }\n\n /** Build upgrade-account URL without redirecting */\n buildUpgradeAccountUrl(options: UpgradeAccountOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n if (options.scopes?.length) params.set(\"scope\", options.scopes.join(\" \"));\n return this.createAuthUrl(\"/upgrade-account\", params);\n }\n\n /** Redirect to passkey setup */\n setupPasskey(options: SetupPasskeyOptions = {}): void {\n const url = this.buildSetupPasskeyUrl(options);\n this.navigate(url, options);\n }\n\n /** Build setup-passkey URL without redirecting */\n buildSetupPasskeyUrl(options: SetupPasskeyOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n return this.createAuthUrl(\"/setup-passkey\", params);\n }\n\n /** Redirect to address setup */\n setupAddress(options: SetupAddressOptions = {}): void {\n const url = this.buildSetupAddressUrl(options);\n this.navigate(url, options);\n }\n\n /** Build setup-address URL without redirecting */\n buildSetupAddressUrl(options: SetupAddressOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.clientId) params.set(\"client_id\", options.clientId);\n return this.createAuthUrl(\"/setup-address\", params);\n }\n\n /** Build a login URL without redirecting (useful for links/buttons) */\n buildLoginUrl(options: LoginOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n if (options.loginHint) params.set(\"email\", options.loginHint);\n if (options.prompt) params.set(\"prompt\", options.prompt);\n if (options.uiLocales) params.set(\"ui_locales\", options.uiLocales);\n return this.createAuthUrl(\"/login\", params);\n }\n\n /** Build a logout URL without redirecting */\n buildLogoutUrl(options: LogoutOptions = {}): AuthUrl {\n const params = new URLSearchParams();\n if (options.returnTo) params.set(\"continue\", options.returnTo);\n return this.createAuthUrl(\"/logout\", params);\n }\n\n /** Revoke a token (access or refresh) */\n async revokeToken(options: RevokeTokenOptions = {}): Promise<void> {\n this.log(\"Revoking token...\");\n\n const token =\n options.token ?? (await this.tokenManager.getTokens())?.accessToken;\n if (!token) {\n throw new AuthError(\"invalid_token\", \"No token to revoke\");\n }\n\n const revokeUrl = `${this.config.issuer}/oauth/revoke`;\n\n const body = new URLSearchParams({\n token,\n client_id: this.config.clientId,\n });\n if (options.tokenTypeHint) {\n body.set(\"token_type_hint\", options.tokenTypeHint);\n }\n\n const response = await fetch(revokeUrl, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/x-www-form-urlencoded\" },\n body,\n });\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({}));\n throw new AuthError(\n error.error ?? \"server_error\",\n error.error_description ?? \"Token revocation failed\",\n );\n }\n\n this.log(\"Token revoked successfully\");\n }\n\n /** Check if the user's session is expired */\n isSessionExpired(): boolean {\n if (!this.state.tokens) return true;\n return isTokenExpired(this.state.tokens.accessToken);\n }\n\n /** Check if user needs email verification */\n needsEmailVerification(): boolean {\n return this.state.user?.emailVerified === false;\n }\n\n /** Check if user is a guest account */\n isGuestAccount(): boolean {\n return (\n (this.state.user as Record<string, unknown>)?.accountType === \"guest\"\n );\n }\n\n private tokenSetToInfo(tokenSet: TokenSet): TokenInfo {\n return {\n accessToken: tokenSet.access_token,\n refreshToken: tokenSet.refresh_token,\n idToken: tokenSet.id_token,\n expiresAt: Date.now() + tokenSet.expires_in * 1000,\n tokenType: tokenSet.token_type,\n scope: tokenSet.scope?.split(\" \") ?? [],\n };\n }\n\n /** Build an AuthUrl object for a given path and params */\n private createAuthUrl(path: string, params: URLSearchParams): AuthUrl {\n const query = params.toString();\n const url = `${this.config.issuer}${path}${query ? `?${query}` : \"\"}`;\n return {\n url,\n redirect: () => {\n window.location.href = url;\n },\n open: () => {\n return window.open(url, \"_blank\");\n },\n };\n }\n\n /** Navigate to an auth URL, respecting openInNewTab option */\n private navigate(authUrl: AuthUrl, options: AuthNavigationOptions): void {\n if (options.openInNewTab) {\n authUrl.open();\n } else {\n authUrl.redirect();\n }\n }\n\n private async fetchUser(accessToken: string): Promise<User> {\n const discovery = await this.getDiscovery();\n\n const response = await fetch(discovery.userinfo_endpoint, {\n headers: { Authorization: `Bearer ${accessToken}` },\n });\n\n if (!response.ok) {\n throw new AuthError(\"invalid_token\", \"Failed to fetch user info\");\n }\n\n const userInfo = await response.json();\n return this.normalizeUser(userInfo);\n }\n\n private extractUserFromIdToken(idToken: string): User {\n const claims = decodeJWT<DecodedIdToken>(idToken);\n return this.normalizeUser(claims);\n }\n\n private normalizeUser(claims: Record<string, unknown>): User {\n return {\n id: claims.sub as string,\n email: claims.email as string | undefined,\n emailVerified: claims.email_verified as boolean | undefined,\n name: claims.name as string | undefined,\n firstName: claims.given_name as string | undefined,\n lastName: claims.family_name as string | undefined,\n picture: claims.picture as string | undefined,\n phoneNumber: claims.phone_number as string | undefined,\n phoneNumberVerified: claims.phone_number_verified as boolean | undefined,\n locale: claims.locale as string | undefined,\n ...claims,\n };\n }\n\n private async getDiscovery(): Promise<OIDCDiscovery> {\n if (this.discovery) return this.discovery;\n const discoveryUrl = `${this.config.issuer}/.well-known/openid-configuration`;\n const response = await fetch(discoveryUrl);\n if (!response.ok) {\n throw new AuthError(\n \"configuration_error\",\n \"Failed to fetch discovery document\",\n );\n }\n this.discovery = await response.json();\n return this.discovery!;\n }\n\n private setupAutoRefresh(): void {\n if (!this.config.autoRefresh || !this.state.tokens) return;\n this.clearAutoRefresh();\n const expiresIn = this.state.tokens.expiresAt - Date.now();\n const refreshIn = expiresIn - this.config.refreshThreshold! * 1000;\n if (refreshIn > 0) {\n this.log(`Scheduling token refresh in ${Math.round(refreshIn / 1000)}s`);\n this.refreshTimer = setTimeout(() => {\n this.refreshTokens().catch((error) =>\n this.log(\"Auto-refresh failed:\", error),\n );\n }, refreshIn);\n }\n }\n\n private clearAutoRefresh(): void {\n if (this.refreshTimer) {\n clearTimeout(this.refreshTimer);\n this.refreshTimer = null;\n }\n }\n\n getState(): AuthState {\n return { ...this.state };\n }\n\n isAuthenticated(): boolean {\n return this.state.status === \"authenticated\";\n }\n\n getUser(): User | null {\n return this.state.user;\n }\n\n subscribe(handler: AuthEventHandler): () => void {\n this.eventHandlers.add(handler);\n return () => this.eventHandlers.delete(handler);\n }\n\n private updateState(newState: AuthState): void {\n this.state = newState;\n }\n\n private emit(event: AuthEvent): void {\n this.eventHandlers.forEach((handler) => {\n try {\n handler(event);\n } catch (error) {\n console.error(\"Event handler error:\", error);\n }\n });\n }\n\n private log(...args: unknown[]): void {\n if (this.config.debug) {\n console.log(\"[DouveryAuth]\", ...args);\n }\n }\n}\n\n/** Create a new DouveryAuthClient instance */\nexport function createDouveryAuth(\n config: DouveryAuthConfig,\n): DouveryAuthClient {\n return new DouveryAuthClient(config);\n}\n","/**\n * @douvery/auth/react - React adapter\n */\n\nimport {\n createContext,\n useContext,\n useState,\n useEffect,\n useCallback,\n useMemo,\n type ReactNode,\n} from \"react\";\nimport {\n DouveryAuthClient,\n createDouveryAuth,\n type DouveryAuthConfig,\n type AuthState,\n type User,\n type LoginOptions,\n type LogoutOptions,\n type SelectAccountOptions,\n type RegisterOptions,\n type RecoverAccountOptions,\n type VerifyAccountOptions,\n type UpgradeAccountOptions,\n type SetupPasskeyOptions,\n type SetupAddressOptions,\n type AddAccountOptions,\n type RevokeTokenOptions,\n type AuthUrl,\n} from \"../index\";\n\ninterface DouveryAuthContextValue {\n state: AuthState;\n isInitialized: boolean;\n isLoading: boolean;\n user: User | null;\n isAuthenticated: boolean;\n accessToken: string | null;\n error: Error | null;\n login: (options?: LoginOptions) => Promise<void>;\n logout: (options?: LogoutOptions) => Promise<void>;\n selectAccount: (options?: SelectAccountOptions) => void;\n addAccount: (options?: AddAccountOptions) => void;\n register: (options?: RegisterOptions) => void;\n recoverAccount: (options?: RecoverAccountOptions) => void;\n verifyAccount: (options?: VerifyAccountOptions) => void;\n upgradeAccount: (options?: UpgradeAccountOptions) => void;\n setupPasskey: (options?: SetupPasskeyOptions) => void;\n setupAddress: (options?: SetupAddressOptions) => void;\n revokeToken: (options?: RevokeTokenOptions) => Promise<void>;\n getAccessToken: () => Promise<string | null>;\n refreshTokens: () => Promise<void>;\n client: DouveryAuthClient;\n}\n\nconst DouveryAuthContext = createContext<DouveryAuthContextValue | null>(null);\n\nexport interface DouveryAuthProviderProps {\n config: DouveryAuthConfig;\n children: ReactNode;\n client?: DouveryAuthClient;\n onAuthenticated?: (user: User) => void;\n onLogout?: () => void;\n onError?: (error: Error) => void;\n}\n\nexport function DouveryAuthProvider({\n config,\n children,\n client: externalClient,\n onAuthenticated,\n onLogout,\n onError,\n}: DouveryAuthProviderProps) {\n const [client] = useState(() => externalClient || createDouveryAuth(config));\n const [state, setState] = useState<AuthState>(client.getState());\n const [isInitialized, setIsInitialized] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n const [error, setError] = useState<Error | null>(null);\n\n useEffect(() => {\n let mounted = true;\n const initialize = async () => {\n try {\n await client.initialize();\n if (mounted) {\n setIsInitialized(true);\n setState(client.getState());\n }\n } catch (err) {\n if (mounted) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n }\n }\n };\n initialize();\n return () => {\n mounted = false;\n };\n }, [client, onError]);\n\n useEffect(() => {\n const unsubscribe = client.subscribe((event) => {\n setState(client.getState());\n\n if (event.type === \"LOGIN_SUCCESS\") {\n onAuthenticated?.(event.user);\n } else if (event.type === \"LOGOUT_SUCCESS\") {\n onLogout?.();\n } else if (\n event.type === \"LOGIN_ERROR\" ||\n event.type === \"LOGOUT_ERROR\" ||\n event.type === \"TOKEN_REFRESH_ERROR\"\n ) {\n setError(event.error);\n onError?.(event.error);\n }\n });\n return unsubscribe;\n }, [client, onAuthenticated, onLogout, onError]);\n\n const login = useCallback(\n async (options?: LoginOptions) => {\n setIsLoading(true);\n setError(null);\n try {\n await client.login(options);\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n },\n [client, onError],\n );\n\n const logout = useCallback(\n async (options?: LogoutOptions) => {\n setIsLoading(true);\n setError(null);\n try {\n await client.logout(options);\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n },\n [client, onError],\n );\n\n const getAccessToken = useCallback(() => client.getAccessToken(), [client]);\n\n const refreshTokens = useCallback(async () => {\n setIsLoading(true);\n try {\n await client.refreshTokens();\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n }, [client, onError]);\n\n const selectAccount = useCallback(\n (options?: SelectAccountOptions) => client.selectAccount(options),\n [client],\n );\n\n const addAccount = useCallback(\n (options?: AddAccountOptions) => client.addAccount(options),\n [client],\n );\n\n const register = useCallback(\n (options?: RegisterOptions) => client.register(options),\n [client],\n );\n\n const recoverAccount = useCallback(\n (options?: RecoverAccountOptions) => client.recoverAccount(options),\n [client],\n );\n\n const verifyAccount = useCallback(\n (options?: VerifyAccountOptions) => client.verifyAccount(options),\n [client],\n );\n\n const upgradeAccount = useCallback(\n (options?: UpgradeAccountOptions) => client.upgradeAccount(options),\n [client],\n );\n\n const setupPasskey = useCallback(\n (options?: SetupPasskeyOptions) => client.setupPasskey(options),\n [client],\n );\n\n const setupAddress = useCallback(\n (options?: SetupAddressOptions) => client.setupAddress(options),\n [client],\n );\n\n const revokeToken = useCallback(\n async (options?: RevokeTokenOptions) => {\n setIsLoading(true);\n setError(null);\n try {\n await client.revokeToken(options);\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n },\n [client, onError],\n );\n\n const value = useMemo<DouveryAuthContextValue>(\n () => ({\n state,\n isInitialized,\n isLoading,\n user: state.user,\n isAuthenticated: state.status === \"authenticated\",\n accessToken: state.tokens?.accessToken ?? null,\n error,\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n getAccessToken,\n refreshTokens,\n client,\n }),\n [\n state,\n isInitialized,\n isLoading,\n error,\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n getAccessToken,\n refreshTokens,\n client,\n ],\n );\n\n return (\n <DouveryAuthContext.Provider value={value}>\n {children}\n </DouveryAuthContext.Provider>\n );\n}\n\nexport function useDouveryAuth(): DouveryAuthContextValue {\n const context = useContext(DouveryAuthContext);\n if (context === null) {\n throw new Error(\"useDouveryAuth must be used within DouveryAuthProvider\");\n }\n return context;\n}\n\nexport function useUser(): User | null {\n return useDouveryAuth().user;\n}\n\nexport function useIsAuthenticated(): boolean {\n return useDouveryAuth().isAuthenticated;\n}\n\nexport function useAccessToken() {\n const { accessToken, getAccessToken } = useDouveryAuth();\n return { accessToken, getAccessToken };\n}\n\nexport function useAuthActions() {\n const {\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n isLoading,\n } = useDouveryAuth();\n return {\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n isLoading,\n };\n}\n\n/** Get URL builders for auth pages (non-redirecting, useful for <a> tags) */\nexport function useAuthUrls() {\n const { client } = useDouveryAuth();\n return useMemo(\n () => ({\n loginUrl: (options?: LoginOptions): AuthUrl =>\n client.buildLoginUrl(options),\n logoutUrl: (options?: LogoutOptions): AuthUrl =>\n client.buildLogoutUrl(options),\n selectAccountUrl: (options?: SelectAccountOptions): AuthUrl =>\n client.buildSelectAccountUrl(options),\n addAccountUrl: (options?: AddAccountOptions): AuthUrl =>\n client.buildAddAccountUrl(options),\n registerUrl: (options?: RegisterOptions): AuthUrl =>\n client.buildRegisterUrl(options),\n recoverAccountUrl: (options?: RecoverAccountOptions): AuthUrl =>\n client.buildRecoverAccountUrl(options),\n verifyAccountUrl: (options?: VerifyAccountOptions): AuthUrl =>\n client.buildVerifyAccountUrl(options),\n upgradeAccountUrl: (options?: UpgradeAccountOptions): AuthUrl =>\n client.buildUpgradeAccountUrl(options),\n setupPasskeyUrl: (options?: SetupPasskeyOptions): AuthUrl =>\n client.buildSetupPasskeyUrl(options),\n setupAddressUrl: (options?: SetupAddressOptions): AuthUrl =>\n client.buildSetupAddressUrl(options),\n }),\n [client],\n );\n}\n\n/** Get session status helpers */\nexport function useSessionStatus() {\n const { client, state } = useDouveryAuth();\n return useMemo(\n () => ({\n isExpired: client.isSessionExpired(),\n needsVerification: client.needsEmailVerification(),\n isGuest: client.isGuestAccount(),\n }),\n [client, state],\n );\n}\n\nexport { DouveryAuthClient, createDouveryAuth } from \"../index\";\nexport type {\n DouveryAuthConfig,\n AuthState,\n User,\n LoginOptions,\n LogoutOptions,\n SelectAccountOptions,\n RegisterOptions,\n RecoverAccountOptions,\n VerifyAccountOptions,\n UpgradeAccountOptions,\n SetupPasskeyOptions,\n SetupAddressOptions,\n AddAccountOptions,\n RevokeTokenOptions,\n AuthUrl,\n} from \"../index\";\n"]}
1
+ {"version":3,"sources":["../../src/react/index.tsx"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * @douvery/auth/react - React adapter\n */\n\nimport {\n createContext,\n useContext,\n useState,\n useEffect,\n useCallback,\n useMemo,\n type ReactNode,\n} from \"react\";\nimport {\n DouveryAuthClient,\n createDouveryAuth,\n type DouveryAuthConfig,\n type AuthState,\n type User,\n type LoginOptions,\n type LogoutOptions,\n type SelectAccountOptions,\n type RegisterOptions,\n type RecoverAccountOptions,\n type VerifyAccountOptions,\n type UpgradeAccountOptions,\n type SetupPasskeyOptions,\n type SetupAddressOptions,\n type AddAccountOptions,\n type RevokeTokenOptions,\n type AuthUrl,\n} from \"@douvery/auth\";\n\ninterface DouveryAuthContextValue {\n state: AuthState;\n isInitialized: boolean;\n isLoading: boolean;\n user: User | null;\n isAuthenticated: boolean;\n accessToken: string | null;\n error: Error | null;\n login: (options?: LoginOptions) => Promise<void>;\n logout: (options?: LogoutOptions) => Promise<void>;\n selectAccount: (options?: SelectAccountOptions) => void;\n addAccount: (options?: AddAccountOptions) => void;\n register: (options?: RegisterOptions) => void;\n recoverAccount: (options?: RecoverAccountOptions) => void;\n verifyAccount: (options?: VerifyAccountOptions) => void;\n upgradeAccount: (options?: UpgradeAccountOptions) => void;\n setupPasskey: (options?: SetupPasskeyOptions) => void;\n setupAddress: (options?: SetupAddressOptions) => void;\n revokeToken: (options?: RevokeTokenOptions) => Promise<void>;\n getAccessToken: () => Promise<string | null>;\n refreshTokens: () => Promise<void>;\n client: DouveryAuthClient;\n}\n\nconst DouveryAuthContext = createContext<DouveryAuthContextValue | null>(null);\n\nexport interface DouveryAuthProviderProps {\n config: DouveryAuthConfig;\n children: ReactNode;\n client?: DouveryAuthClient;\n onAuthenticated?: (user: User) => void;\n onLogout?: () => void;\n onError?: (error: Error) => void;\n}\n\nexport function DouveryAuthProvider({\n config,\n children,\n client: externalClient,\n onAuthenticated,\n onLogout,\n onError,\n}: DouveryAuthProviderProps) {\n const [client] = useState(() => externalClient || createDouveryAuth(config));\n const [state, setState] = useState<AuthState>(client.getState());\n const [isInitialized, setIsInitialized] = useState(false);\n const [isLoading, setIsLoading] = useState(false);\n const [error, setError] = useState<Error | null>(null);\n\n useEffect(() => {\n let mounted = true;\n const initialize = async () => {\n try {\n await client.initialize();\n if (mounted) {\n setIsInitialized(true);\n setState(client.getState());\n }\n } catch (err) {\n if (mounted) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n }\n }\n };\n initialize();\n return () => {\n mounted = false;\n };\n }, [client, onError]);\n\n useEffect(() => {\n const unsubscribe = client.subscribe((event) => {\n setState(client.getState());\n\n if (event.type === \"LOGIN_SUCCESS\") {\n onAuthenticated?.(event.user);\n } else if (event.type === \"LOGOUT_SUCCESS\") {\n onLogout?.();\n } else if (\n event.type === \"LOGIN_ERROR\" ||\n event.type === \"LOGOUT_ERROR\" ||\n event.type === \"TOKEN_REFRESH_ERROR\"\n ) {\n setError(event.error);\n onError?.(event.error);\n }\n });\n return unsubscribe;\n }, [client, onAuthenticated, onLogout, onError]);\n\n const login = useCallback(\n async (options?: LoginOptions) => {\n setIsLoading(true);\n setError(null);\n try {\n await client.login(options);\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n },\n [client, onError],\n );\n\n const logout = useCallback(\n async (options?: LogoutOptions) => {\n setIsLoading(true);\n setError(null);\n try {\n await client.logout(options);\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n },\n [client, onError],\n );\n\n const getAccessToken = useCallback(() => client.getAccessToken(), [client]);\n\n const refreshTokens = useCallback(async () => {\n setIsLoading(true);\n try {\n await client.refreshTokens();\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n }, [client, onError]);\n\n const selectAccount = useCallback(\n (options?: SelectAccountOptions) => client.selectAccount(options),\n [client],\n );\n\n const addAccount = useCallback(\n (options?: AddAccountOptions) => client.addAccount(options),\n [client],\n );\n\n const register = useCallback(\n (options?: RegisterOptions) => client.register(options),\n [client],\n );\n\n const recoverAccount = useCallback(\n (options?: RecoverAccountOptions) => client.recoverAccount(options),\n [client],\n );\n\n const verifyAccount = useCallback(\n (options?: VerifyAccountOptions) => client.verifyAccount(options),\n [client],\n );\n\n const upgradeAccount = useCallback(\n (options?: UpgradeAccountOptions) => client.upgradeAccount(options),\n [client],\n );\n\n const setupPasskey = useCallback(\n (options?: SetupPasskeyOptions) => client.setupPasskey(options),\n [client],\n );\n\n const setupAddress = useCallback(\n (options?: SetupAddressOptions) => client.setupAddress(options),\n [client],\n );\n\n const revokeToken = useCallback(\n async (options?: RevokeTokenOptions) => {\n setIsLoading(true);\n setError(null);\n try {\n await client.revokeToken(options);\n } catch (err) {\n const e = err instanceof Error ? err : new Error(String(err));\n setError(e);\n onError?.(e);\n throw e;\n } finally {\n setIsLoading(false);\n }\n },\n [client, onError],\n );\n\n const value = useMemo<DouveryAuthContextValue>(\n () => ({\n state,\n isInitialized,\n isLoading,\n user: state.user,\n isAuthenticated: state.status === \"authenticated\",\n accessToken: state.tokens?.accessToken ?? null,\n error,\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n getAccessToken,\n refreshTokens,\n client,\n }),\n [\n state,\n isInitialized,\n isLoading,\n error,\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n getAccessToken,\n refreshTokens,\n client,\n ],\n );\n\n return (\n <DouveryAuthContext.Provider value={value}>\n {children}\n </DouveryAuthContext.Provider>\n );\n}\n\nexport function useDouveryAuth(): DouveryAuthContextValue {\n const context = useContext(DouveryAuthContext);\n if (context === null) {\n throw new Error(\"useDouveryAuth must be used within DouveryAuthProvider\");\n }\n return context;\n}\n\nexport function useUser(): User | null {\n return useDouveryAuth().user;\n}\n\nexport function useIsAuthenticated(): boolean {\n return useDouveryAuth().isAuthenticated;\n}\n\nexport function useAccessToken() {\n const { accessToken, getAccessToken } = useDouveryAuth();\n return { accessToken, getAccessToken };\n}\n\nexport function useAuthActions() {\n const {\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n isLoading,\n } = useDouveryAuth();\n return {\n login,\n logout,\n selectAccount,\n addAccount,\n register,\n recoverAccount,\n verifyAccount,\n upgradeAccount,\n setupPasskey,\n setupAddress,\n revokeToken,\n isLoading,\n };\n}\n\n/** Get URL builders for auth pages (non-redirecting, useful for <a> tags) */\nexport function useAuthUrls() {\n const { client } = useDouveryAuth();\n return useMemo(\n () => ({\n loginUrl: (options?: LoginOptions): AuthUrl =>\n client.buildLoginUrl(options),\n logoutUrl: (options?: LogoutOptions): AuthUrl =>\n client.buildLogoutUrl(options),\n selectAccountUrl: (options?: SelectAccountOptions): AuthUrl =>\n client.buildSelectAccountUrl(options),\n addAccountUrl: (options?: AddAccountOptions): AuthUrl =>\n client.buildAddAccountUrl(options),\n registerUrl: (options?: RegisterOptions): AuthUrl =>\n client.buildRegisterUrl(options),\n recoverAccountUrl: (options?: RecoverAccountOptions): AuthUrl =>\n client.buildRecoverAccountUrl(options),\n verifyAccountUrl: (options?: VerifyAccountOptions): AuthUrl =>\n client.buildVerifyAccountUrl(options),\n upgradeAccountUrl: (options?: UpgradeAccountOptions): AuthUrl =>\n client.buildUpgradeAccountUrl(options),\n setupPasskeyUrl: (options?: SetupPasskeyOptions): AuthUrl =>\n client.buildSetupPasskeyUrl(options),\n setupAddressUrl: (options?: SetupAddressOptions): AuthUrl =>\n client.buildSetupAddressUrl(options),\n }),\n [client],\n );\n}\n\n/** Get session status helpers */\nexport function useSessionStatus() {\n const { client, state } = useDouveryAuth();\n return useMemo(\n () => ({\n isExpired: client.isSessionExpired(),\n needsVerification: client.needsEmailVerification(),\n isGuest: client.isGuestAccount(),\n }),\n [client, state],\n );\n}\n\nexport { DouveryAuthClient, createDouveryAuth } from \"@douvery/auth\";\nexport type {\n DouveryAuthConfig,\n AuthState,\n User,\n LoginOptions,\n LogoutOptions,\n SelectAccountOptions,\n RegisterOptions,\n RecoverAccountOptions,\n VerifyAccountOptions,\n UpgradeAccountOptions,\n SetupPasskeyOptions,\n SetupAddressOptions,\n AddAccountOptions,\n RevokeTokenOptions,\n AuthUrl,\n} from \"@douvery/auth\";\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@douvery/auth",
3
- "version": "0.3.0",
3
+ "version": "0.3.2",
4
4
  "description": "OAuth 2.0/OIDC client for Douvery authentication",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -16,18 +16,16 @@
16
16
  "types": "./dist/react/index.d.ts"
17
17
  },
18
18
  "./qwik": {
19
- "import": "./dist/qwik/index.js",
19
+ "import": "./src/qwik/index.tsx",
20
20
  "types": "./dist/qwik/index.d.ts"
21
21
  }
22
22
  },
23
23
  "files": [
24
- "dist"
24
+ "dist",
25
+ "src/qwik"
25
26
  ],
26
27
  "scripts": {
27
- "build": "npm run clean && npm run build:core && npm run build:react && npm run build:qwik",
28
- "build:core": "tsup src/index.ts --format esm --dts --out-dir dist",
29
- "build:react": "tsup src/react/index.tsx --format esm --dts --out-dir dist/react --external react --external @douvery/auth --tsconfig tsconfig.react.json",
30
- "build:qwik": "tsup src/qwik/index.tsx --format esm --dts --out-dir dist/qwik --external @builder.io/qwik --external @douvery/auth --tsconfig tsconfig.qwik.json",
28
+ "build": "npm run clean && tsup",
31
29
  "dev": "tsup --watch",
32
30
  "clean": "rm -rf dist"
33
31
  },
@@ -0,0 +1,271 @@
1
+ /**
2
+ * @douvery/auth/qwik - Qwik adapter
3
+ */
4
+
5
+ import {
6
+ createContextId,
7
+ useContextProvider,
8
+ useContext,
9
+ useSignal,
10
+ useTask$,
11
+ useVisibleTask$,
12
+ component$,
13
+ Slot,
14
+ type Signal,
15
+ } from "@builder.io/qwik";
16
+ import {
17
+ DouveryAuthClient,
18
+ createDouveryAuth,
19
+ type DouveryAuthConfig,
20
+ type AuthState,
21
+ type User,
22
+ type LoginOptions,
23
+ type LogoutOptions,
24
+ type SelectAccountOptions,
25
+ type RegisterOptions,
26
+ type RecoverAccountOptions,
27
+ type VerifyAccountOptions,
28
+ type UpgradeAccountOptions,
29
+ type SetupPasskeyOptions,
30
+ type SetupAddressOptions,
31
+ type AddAccountOptions,
32
+ type RevokeTokenOptions,
33
+ type AuthUrl,
34
+ } from "@douvery/auth";
35
+
36
+ interface DouveryAuthContextValue {
37
+ state: Signal<AuthState>;
38
+ isInitialized: Signal<boolean>;
39
+ isLoading: Signal<boolean>;
40
+ error: Signal<Error | null>;
41
+ client: DouveryAuthClient;
42
+ }
43
+
44
+ export const DouveryAuthContext =
45
+ createContextId<DouveryAuthContextValue>("douvery-auth");
46
+
47
+ export interface DouveryAuthProviderProps {
48
+ config: DouveryAuthConfig;
49
+ }
50
+
51
+ export const DouveryAuthProvider = component$<DouveryAuthProviderProps>(
52
+ ({ config }) => {
53
+ const client = createDouveryAuth(config);
54
+ const state = useSignal<AuthState>(client.getState());
55
+ const isInitialized = useSignal(false);
56
+ const isLoading = useSignal(false);
57
+ const error = useSignal<Error | null>(null);
58
+
59
+ useContextProvider(DouveryAuthContext, {
60
+ state,
61
+ isInitialized,
62
+ isLoading,
63
+ error,
64
+ client,
65
+ });
66
+
67
+ useVisibleTask$(() => {
68
+ client
69
+ .initialize()
70
+ .then(() => {
71
+ isInitialized.value = true;
72
+ state.value = client.getState();
73
+ })
74
+ .catch((err) => {
75
+ error.value = err instanceof Error ? err : new Error(String(err));
76
+ });
77
+
78
+ const unsubscribe = client.subscribe((event) => {
79
+ state.value = client.getState();
80
+ if (
81
+ event.type === "LOGIN_ERROR" ||
82
+ event.type === "LOGOUT_ERROR" ||
83
+ event.type === "TOKEN_REFRESH_ERROR"
84
+ ) {
85
+ error.value = event.error;
86
+ }
87
+ });
88
+
89
+ return () => unsubscribe();
90
+ });
91
+
92
+ return <Slot />;
93
+ },
94
+ );
95
+
96
+ export function useDouveryAuth() {
97
+ return useContext(DouveryAuthContext);
98
+ }
99
+
100
+ export function useUser(): Signal<User | null> {
101
+ const { state } = useDouveryAuth();
102
+ const user = useSignal<User | null>(state.value.user);
103
+ useTask$(({ track }) => {
104
+ track(() => state.value);
105
+ user.value = state.value.user;
106
+ });
107
+ return user;
108
+ }
109
+
110
+ export function useIsAuthenticated(): Signal<boolean> {
111
+ const { state } = useDouveryAuth();
112
+ const isAuth = useSignal(state.value.status === "authenticated");
113
+ useTask$(({ track }) => {
114
+ track(() => state.value);
115
+ isAuth.value = state.value.status === "authenticated";
116
+ });
117
+ return isAuth;
118
+ }
119
+
120
+ export function useAuthActions() {
121
+ const { client, isLoading, error } = useDouveryAuth();
122
+
123
+ const login = async (options?: LoginOptions) => {
124
+ isLoading.value = true;
125
+ error.value = null;
126
+ try {
127
+ await client.login(options);
128
+ } catch (err) {
129
+ error.value = err instanceof Error ? err : new Error(String(err));
130
+ throw err;
131
+ } finally {
132
+ isLoading.value = false;
133
+ }
134
+ };
135
+
136
+ const logout = async (options?: LogoutOptions) => {
137
+ isLoading.value = true;
138
+ error.value = null;
139
+ try {
140
+ await client.logout(options);
141
+ } catch (err) {
142
+ error.value = err instanceof Error ? err : new Error(String(err));
143
+ throw err;
144
+ } finally {
145
+ isLoading.value = false;
146
+ }
147
+ };
148
+
149
+ const selectAccount = (options?: SelectAccountOptions) => {
150
+ client.selectAccount(options);
151
+ };
152
+
153
+ const addAccount = (options?: AddAccountOptions) => {
154
+ client.addAccount(options);
155
+ };
156
+
157
+ const register = (options?: RegisterOptions) => {
158
+ client.register(options);
159
+ };
160
+
161
+ const recoverAccount = (options?: RecoverAccountOptions) => {
162
+ client.recoverAccount(options);
163
+ };
164
+
165
+ const verifyAccount = (options?: VerifyAccountOptions) => {
166
+ client.verifyAccount(options);
167
+ };
168
+
169
+ const upgradeAccount = (options?: UpgradeAccountOptions) => {
170
+ client.upgradeAccount(options);
171
+ };
172
+
173
+ const setupPasskey = (options?: SetupPasskeyOptions) => {
174
+ client.setupPasskey(options);
175
+ };
176
+
177
+ const setupAddress = (options?: SetupAddressOptions) => {
178
+ client.setupAddress(options);
179
+ };
180
+
181
+ const revokeToken = async (options?: RevokeTokenOptions) => {
182
+ isLoading.value = true;
183
+ error.value = null;
184
+ try {
185
+ await client.revokeToken(options);
186
+ } catch (err) {
187
+ error.value = err instanceof Error ? err : new Error(String(err));
188
+ throw err;
189
+ } finally {
190
+ isLoading.value = false;
191
+ }
192
+ };
193
+
194
+ return {
195
+ login,
196
+ logout,
197
+ selectAccount,
198
+ addAccount,
199
+ register,
200
+ recoverAccount,
201
+ verifyAccount,
202
+ upgradeAccount,
203
+ setupPasskey,
204
+ setupAddress,
205
+ revokeToken,
206
+ isLoading,
207
+ };
208
+ }
209
+
210
+ /** Get URL builders for auth pages (non-redirecting, useful for <a> tags) */
211
+ export function useAuthUrls() {
212
+ const { client } = useDouveryAuth();
213
+ return {
214
+ loginUrl: (options?: LoginOptions): AuthUrl =>
215
+ client.buildLoginUrl(options),
216
+ logoutUrl: (options?: LogoutOptions): AuthUrl =>
217
+ client.buildLogoutUrl(options),
218
+ selectAccountUrl: (options?: SelectAccountOptions): AuthUrl =>
219
+ client.buildSelectAccountUrl(options),
220
+ addAccountUrl: (options?: AddAccountOptions): AuthUrl =>
221
+ client.buildAddAccountUrl(options),
222
+ registerUrl: (options?: RegisterOptions): AuthUrl =>
223
+ client.buildRegisterUrl(options),
224
+ recoverAccountUrl: (options?: RecoverAccountOptions): AuthUrl =>
225
+ client.buildRecoverAccountUrl(options),
226
+ verifyAccountUrl: (options?: VerifyAccountOptions): AuthUrl =>
227
+ client.buildVerifyAccountUrl(options),
228
+ upgradeAccountUrl: (options?: UpgradeAccountOptions): AuthUrl =>
229
+ client.buildUpgradeAccountUrl(options),
230
+ setupPasskeyUrl: (options?: SetupPasskeyOptions): AuthUrl =>
231
+ client.buildSetupPasskeyUrl(options),
232
+ setupAddressUrl: (options?: SetupAddressOptions): AuthUrl =>
233
+ client.buildSetupAddressUrl(options),
234
+ };
235
+ }
236
+
237
+ /** Get session status helpers */
238
+ export function useSessionStatus() {
239
+ const { client, state } = useDouveryAuth();
240
+ const isExpired = useSignal(client.isSessionExpired());
241
+ const needsVerification = useSignal(client.needsEmailVerification());
242
+ const isGuest = useSignal(client.isGuestAccount());
243
+
244
+ useTask$(({ track }) => {
245
+ track(() => state.value);
246
+ isExpired.value = client.isSessionExpired();
247
+ needsVerification.value = client.needsEmailVerification();
248
+ isGuest.value = client.isGuestAccount();
249
+ });
250
+
251
+ return { isExpired, needsVerification, isGuest };
252
+ }
253
+
254
+ export { DouveryAuthClient, createDouveryAuth } from "@douvery/auth";
255
+ export type {
256
+ DouveryAuthConfig,
257
+ AuthState,
258
+ User,
259
+ LoginOptions,
260
+ LogoutOptions,
261
+ SelectAccountOptions,
262
+ RegisterOptions,
263
+ RecoverAccountOptions,
264
+ VerifyAccountOptions,
265
+ UpgradeAccountOptions,
266
+ SetupPasskeyOptions,
267
+ SetupAddressOptions,
268
+ AddAccountOptions,
269
+ RevokeTokenOptions,
270
+ AuthUrl,
271
+ } from "@douvery/auth";