@relaycore/sdk 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../index.ts","../relay-agent.ts","../relay-service.ts","../provider-sdk.ts","../consumer-sdk.ts","../../../node_modules/tslib/tslib.es6.mjs","../../../node_modules/@supabase/functions-js/src/helper.ts","../../../node_modules/@supabase/functions-js/src/types.ts","../../../node_modules/@supabase/functions-js/src/FunctionsClient.ts","../../../node_modules/@supabase/postgrest-js/src/PostgrestError.ts","../../../node_modules/@supabase/postgrest-js/src/PostgrestBuilder.ts","../../../node_modules/@supabase/postgrest-js/src/PostgrestTransformBuilder.ts","../../../node_modules/@supabase/postgrest-js/src/PostgrestFilterBuilder.ts","../../../node_modules/@supabase/postgrest-js/src/PostgrestQueryBuilder.ts","../../../node_modules/@supabase/postgrest-js/src/PostgrestClient.ts","../../../node_modules/@supabase/postgrest-js/src/index.ts","../../../node_modules/@supabase/realtime-js/src/lib/websocket-factory.ts","../../../node_modules/@supabase/realtime-js/src/lib/version.ts","../../../node_modules/@supabase/realtime-js/src/lib/constants.ts","../../../node_modules/@supabase/realtime-js/src/lib/serializer.ts","../../../node_modules/@supabase/realtime-js/src/lib/timer.ts","../../../node_modules/@supabase/realtime-js/src/lib/transformers.ts","../../../node_modules/@supabase/realtime-js/src/lib/push.ts","../../../node_modules/@supabase/realtime-js/src/RealtimePresence.ts","../../../node_modules/@supabase/realtime-js/src/RealtimeChannel.ts","../../../node_modules/@supabase/realtime-js/src/RealtimeClient.ts","../../../node_modules/iceberg-js/src/errors/IcebergError.ts","../../../node_modules/iceberg-js/src/utils/url.ts","../../../node_modules/iceberg-js/src/http/createFetchClient.ts","../../../node_modules/iceberg-js/src/catalog/namespaces.ts","../../../node_modules/iceberg-js/src/catalog/tables.ts","../../../node_modules/iceberg-js/src/catalog/IcebergRestCatalog.ts","../../../node_modules/iceberg-js/src/catalog/types.ts","../../../node_modules/@supabase/storage-js/src/lib/errors.ts","../../../node_modules/@supabase/storage-js/src/lib/helpers.ts","../../../node_modules/@supabase/storage-js/src/lib/fetch.ts","../../../node_modules/@supabase/storage-js/src/packages/StreamDownloadBuilder.ts","../../../node_modules/@supabase/storage-js/src/packages/BlobDownloadBuilder.ts","../../../node_modules/@supabase/storage-js/src/packages/StorageFileApi.ts","../../../node_modules/@supabase/storage-js/src/lib/version.ts","../../../node_modules/@supabase/storage-js/src/lib/constants.ts","../../../node_modules/@supabase/storage-js/src/packages/StorageBucketApi.ts","../../../node_modules/@supabase/storage-js/src/packages/StorageAnalyticsClient.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/constants.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/errors.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/helpers.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/fetch.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/VectorIndexApi.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/VectorDataApi.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/VectorBucketApi.ts","../../../node_modules/@supabase/storage-js/src/lib/vectors/StorageVectorsClient.ts","../../../node_modules/@supabase/storage-js/src/StorageClient.ts","../../../node_modules/@supabase/auth-js/src/lib/version.ts","../../../node_modules/@supabase/auth-js/src/lib/constants.ts","../../../node_modules/@supabase/auth-js/src/lib/errors.ts","../../../node_modules/@supabase/auth-js/src/lib/base64url.ts","../../../node_modules/@supabase/auth-js/src/lib/helpers.ts","../../../node_modules/@supabase/auth-js/src/lib/fetch.ts","../../../node_modules/@supabase/auth-js/src/lib/types.ts","../../../node_modules/@supabase/auth-js/src/GoTrueAdminApi.ts","../../../node_modules/@supabase/auth-js/src/lib/local-storage.ts","../../../node_modules/@supabase/auth-js/src/lib/locks.ts","../../../node_modules/@supabase/auth-js/src/lib/polyfills.ts","../../../node_modules/@supabase/auth-js/src/lib/web3/ethereum.ts","../../../node_modules/@supabase/auth-js/src/lib/webauthn.errors.ts","../../../node_modules/@supabase/auth-js/src/lib/webauthn.ts","../../../node_modules/@supabase/auth-js/src/GoTrueClient.ts","../../../node_modules/@supabase/auth-js/src/AuthClient.ts","../../../node_modules/@supabase/supabase-js/src/lib/version.ts","../../../node_modules/@supabase/supabase-js/src/lib/constants.ts","../../../node_modules/@supabase/supabase-js/src/lib/fetch.ts","../../../node_modules/@supabase/supabase-js/src/lib/helpers.ts","../../../node_modules/@supabase/supabase-js/src/lib/SupabaseAuthClient.ts","../../../node_modules/@supabase/supabase-js/src/SupabaseClient.ts","../../../node_modules/@supabase/supabase-js/src/index.ts","../lib/supabase.ts","../lib/facilitator.ts","../lib/ipfs.ts","../lib/erc8004.ts","../agent-sdk.ts","../lib/x402.ts","../types/chat.types.ts","../relay-rwa.ts"],"sourcesContent":["/**\n * Relay Core SDK\n * \n * Complete SDK for interacting with the Relay Core platform.\n * \n * NEW (Recommended):\n * - RelayAgent - For AI agents to discover, decide, and execute\n * - RelayService - For service providers to expose, deliver, and earn\n * \n * LEGACY (Still supported):\n * - ServiceProviderSDK\n * - ServiceConsumerSDK\n * - AgentSDK\n */\n\n// =============================================================================\n// NEW IMPROVED SDKs (Recommended)\n// =============================================================================\n\n// RelayAgent - For AI agents\nexport {\n RelayAgent,\n createAgent,\n type AgentConfig,\n type TrustPolicy,\n type ServiceCriteria,\n type SelectedService,\n type ExecutionResult,\n type ExecutionError,\n type ErrorCode,\n type WorkflowStep as AgentWorkflowStep,\n type WorkflowResult,\n type OutcomeRecord as AgentOutcome,\n type AgentMemory,\n type AgentCard,\n type AgentCardResource,\n type TaskArtifact,\n type TaskState,\n type TaskStats,\n} from './relay-agent';\n\n// RelayService - For service providers\nexport {\n RelayService,\n createService,\n defineService,\n hashProof,\n createPaymentMiddleware,\n type ServiceConfig,\n type ServiceDefinition,\n type RegisteredService as ServiceRegistered,\n type PaymentContext,\n type DeliveryProof,\n type PaymentStatus,\n type PaymentEvent,\n type OutcomeType,\n type OutcomeRecord as ServiceOutcome,\n type ServiceMetrics as ServiceMetricsData,\n type ProviderReputation as ServiceReputation,\n type PaymentRequirements as ServicePaymentRequirements,\n type ServiceLogger,\n type JsonSchema,\n} from './relay-service';\n\n// =============================================================================\n// LEGACY SDKs (Backwards compatible)\n// =============================================================================\n\n// Provider SDK - For registering and managing services\nexport {\n ServiceProviderSDK,\n createProviderSDK,\n type ProviderSDKConfig,\n type ServiceRegistration,\n type RegisteredService,\n type ProviderReputation,\n type PaymentReceived,\n type ServiceMetrics,\n} from './provider-sdk';\n\n// Consumer SDK - For discovering and calling services\nexport {\n ServiceConsumerSDK,\n createConsumerSDK,\n type ConsumerSDKConfig,\n type ServiceQuery,\n type DiscoveredService,\n type PaymentResult,\n type ServiceCallResult,\n type WorkflowStep,\n} from './consumer-sdk';\n\n// Legacy Agent SDK (for backwards compatibility)\nexport {\n AgentSDK,\n createAgentSDK,\n type AgentService,\n type AgentProfile,\n} from './agent-sdk';\n\n// Re-export types for convenience\nexport type { PaymentRequirements } from '@crypto.com/facilitator-client';\n\n// =============================================================================\n// X402 PROTOCOL (Cronos Standard)\n// =============================================================================\n\nexport {\n requireX402,\n handleX402Settlement,\n generatePaymentId,\n isEntitled,\n getEntitlement,\n recordEntitlement,\n createPaymentRequirements,\n} from './lib/x402';\n\nexport type {\n X402Accepts,\n X402Response,\n X402PaidRecord,\n X402PayResult,\n X402ProtectionOptions,\n X402PayParams,\n} from './types/x402.types';\n\n// =============================================================================\n// CHAT TYPES (Control Plane Architecture)\n// =============================================================================\n\nexport type {\n ChatMode,\n ChatResponseType,\n ChatRequest,\n ChatResponse,\n ChatAction,\n SimulationResult,\n} from './types/chat.types';\n\nexport { CHAT_CAPABILITIES, PROHIBITED_OPERATIONS } from './types/chat.types';\n\n// =============================================================================\n// RWA SDK (State Machine & Asset Management)\n// =============================================================================\n\nexport {\n RelayRWASDK,\n createRWASDK,\n type RWAConfig,\n type RWAStateMachine,\n type TransitionParams,\n type TransitionResult\n} from './relay-rwa';\n","/**\n * Relay Core - Agent SDK\n * \n * For AI agents to discover services, make decisions, and execute workflows.\n * \n * Design Principles:\n * - Decision abstraction, not CRUD\n * - Workflow primitives first\n * - Failure is first-class\n * - 10-minute quickstart\n * \n * @example Quickstart\n * ```ts\n * const agent = new RelayAgent({ wallet, network: \"cronos-testnet\" });\n * \n * // Select best service by policy\n * const service = await agent.selectService({\n * category: \"data.prices\",\n * constraints: { minReputation: 90 }\n * });\n * \n * // Execute with automatic payment\n * const result = await agent.execute(service, { pair: \"BTC/USD\" });\n * ```\n */\n\nimport { ethers } from 'ethers';\n\n// ============================================================================\n// TYPES - Clear, descriptive names\n// ============================================================================\n\n/** Network configuration */\nexport type Network = 'cronos-mainnet' | 'cronos-testnet' | 'cronos-zkevm';\n\n/** Agent configuration - minimal required, progressive optional */\nexport interface AgentConfig {\n /** Connected wallet (ethers.Signer or address for read-only) */\n wallet: ethers.Signer | string;\n /** Relay Core API Key (starts with rc_...) */\n apiKey: string;\n /** Target network */\n network?: Network;\n /** API endpoint (defaults to production) */\n apiUrl?: string;\n}\n\n/** Trust policy for service selection */\nexport interface TrustPolicy {\n /** Minimum reputation score (0-100) */\n minReputation?: number;\n /** Maximum acceptable latency in ms */\n maxLatency?: number;\n /** Maximum price per call in USDC */\n maxPrice?: number;\n /** Require verified/reliable services only */\n verifiedOnly?: boolean;\n /** Preferred service providers (addresses) */\n preferredProviders?: string[];\n /** Blacklisted providers (addresses) */\n blacklistedProviders?: string[];\n}\n\n/** Service selection criteria */\nexport interface ServiceCriteria {\n /** Service category (e.g., \"data.prices\", \"trading.execution\") */\n category?: string;\n /** Required input type */\n inputType?: string;\n /** Required output type */\n outputType?: string;\n /** Required tags */\n tags?: string[];\n /** Required capabilities */\n capabilities?: string[];\n /** Trust constraints */\n constraints?: TrustPolicy;\n}\n\n/** Selected service with selection explanation */\nexport interface SelectedService {\n id: string;\n name: string;\n endpoint: string;\n price: string;\n provider: string;\n reputation: number;\n latency: number;\n /** Why this service was selected */\n selectionReason: string;\n /** Score breakdown */\n scoreBreakdown: {\n reputation: number;\n latency: number;\n price: number;\n total: number;\n };\n}\n\n/** Execution result with full context */\nexport interface ExecutionResult<T = unknown> {\n success: boolean;\n data?: T;\n error?: ExecutionError;\n /** Payment details if payment was made */\n payment?: {\n id: string;\n txHash: string;\n amount: string;\n };\n /** Performance metrics */\n metrics: {\n totalMs: number;\n paymentMs?: number;\n serviceMs?: number;\n };\n}\n\n/** Structured error with actionable information */\nexport interface ExecutionError {\n code: ErrorCode;\n message: string;\n /** Can this operation be retried? */\n retryable: boolean;\n /** If retryable, suggested wait time in ms */\n retryAfterMs?: number;\n /** Original error details */\n details?: unknown;\n}\n\n/** Error codes for programmatic handling */\nexport type ErrorCode =\n | 'SERVICE_NOT_FOUND'\n | 'SERVICE_UNAVAILABLE'\n | 'PAYMENT_FAILED'\n | 'PAYMENT_TIMEOUT'\n | 'EXECUTION_FAILED'\n | 'EXECUTION_TIMEOUT'\n | 'INSUFFICIENT_BALANCE'\n | 'UNAUTHORIZED'\n | 'RATE_LIMITED'\n | 'INVALID_INPUT'\n | 'PARTIAL_SUCCESS'\n | 'UNKNOWN';\n\n/** Workflow step definition */\nexport interface WorkflowStep<TInput = unknown, TOutput = unknown> {\n name: string;\n service?: SelectedService;\n serviceId?: string;\n criteria?: ServiceCriteria;\n transform?: (input: TInput) => TOutput | Promise<TOutput>;\n timeout?: number;\n retries?: number;\n fallback?: WorkflowStep<TInput, TOutput>;\n onSuccess?: (result: TOutput) => void | Promise<void>;\n onFailure?: (error: ExecutionError) => void | Promise<void>;\n}\n\n/** Workflow execution result */\nexport interface WorkflowResult<T = unknown> {\n success: boolean;\n data?: T;\n /** Results from each step */\n stepResults: Array<{\n stepName: string;\n success: boolean;\n data?: unknown;\n error?: ExecutionError;\n durationMs: number;\n }>;\n /** Total workflow duration */\n totalMs: number;\n /** Number of steps completed */\n completedSteps: number;\n /** Number of steps that failed */\n failedSteps: number;\n}\n\n/** Outcome record for memory */\nexport interface OutcomeRecord {\n timestamp: Date;\n serviceId: string;\n success: boolean;\n latencyMs: number;\n paymentAmount?: string;\n error?: ExecutionError;\n}\n\n/** Memory hooks for agent learning */\nexport interface AgentMemory {\n record(outcome: OutcomeRecord): void;\n getHistory(serviceId?: string): OutcomeRecord[];\n getStats(): { totalCalls: number; successRate: number; avgLatency: number };\n clear(): void;\n}\n\n/** A2A Agent Card Resource */\nexport interface AgentCardResource {\n id: string;\n title: string;\n url: string;\n price?: string;\n paywall: {\n protocol: 'x402';\n settlement: string;\n };\n}\n\n/** A2A Agent Card for discovery */\nexport interface AgentCard {\n name: string;\n description: string;\n url: string;\n version?: string;\n network: string;\n capabilities?: string[];\n resources: AgentCardResource[];\n contracts?: {\n escrowSession?: string;\n identityRegistry?: string;\n reputationRegistry?: string;\n usdcToken?: string;\n };\n x402?: {\n facilitator?: string;\n token?: string;\n chainId?: number;\n };\n}\n\n/** Task state enum */\nexport type TaskState = 'idle' | 'pending' | 'settled' | 'failed';\n\n/** Task Artifact for tracking agent actions */\nexport interface TaskArtifact {\n task_id: string;\n agent_id: string;\n service_id?: string;\n session_id?: string;\n state: TaskState;\n payment_id?: string;\n facilitator_tx?: string;\n retries: number;\n timestamps: {\n created: string;\n updated: string;\n completed?: string;\n };\n inputs: Record<string, unknown>;\n outputs: Record<string, unknown>;\n error?: {\n code: string;\n message: string;\n retryable: boolean;\n };\n metrics?: {\n total_ms: number;\n payment_ms?: number;\n service_ms?: number;\n };\n}\n\n/** Task statistics summary */\nexport interface TaskStats {\n total: number;\n pending: number;\n settled: number;\n failed: number;\n success_rate: number;\n avg_duration_ms: number;\n}\n\n// ============================================================================\n// IMPLEMENTATION\n// ============================================================================\n\nconst NETWORK_CONFIG: Record<Network, { apiUrl: string; chainId: number }> = {\n 'cronos-mainnet': { apiUrl: 'https://api.relaycore.xyz', chainId: 25 },\n 'cronos-testnet': { apiUrl: 'https://testnet-api.relaycore.xyz', chainId: 338 },\n 'cronos-zkevm': { apiUrl: 'https://zkevm-api.relaycore.xyz', chainId: 388 },\n};\n\nconst FACILITATOR_URL = 'https://facilitator.cronoslabs.org/v2/x402';\n\n/**\n * Relay Agent SDK\n * \n * The main entry point for AI agents to interact with Relay Core services.\n */\n/** Internal discovered service type with all fields */\ninterface DiscoveredServiceInternal {\n id: string;\n name: string;\n endpoint: string;\n price: string;\n provider: string;\n reputation: number;\n latency: number;\n category: string;\n inputType?: string;\n outputType?: string;\n tags: string[];\n capabilities: string[];\n verified: boolean;\n}\n\nexport class RelayAgent {\n private signer: ethers.Signer | null = null;\n private _address: string = '';\n private network: Network;\n private apiUrl: string;\n private apiKey: string;\n private trustPolicy: TrustPolicy = {};\n private memoryStore: OutcomeRecord[] = [];\n\n constructor(config: AgentConfig) {\n this.network = config.network || 'cronos-mainnet';\n this.apiUrl = config.apiUrl || NETWORK_CONFIG[this.network].apiUrl;\n this.apiKey = config.apiKey;\n\n if (typeof config.wallet === 'string') {\n this._address = config.wallet.toLowerCase();\n } else {\n this.signer = config.wallet;\n // Get address async\n config.wallet.getAddress().then(addr => {\n this._address = addr.toLowerCase();\n });\n }\n }\n\n /**\n * Get authenticated headers for API requests\n */\n private getHeaders(): HeadersInit {\n return {\n 'Content-Type': 'application/json',\n 'x-api-key': this.apiKey\n };\n }\n\n // ==========================================================================\n // CONFIGURATION - Progressive, not overwhelming\n // ==========================================================================\n\n /**\n * Get agent's wallet address\n */\n async getAddress(): Promise<string> {\n if (this.signer && !this._address) {\n this._address = (await this.signer.getAddress()).toLowerCase();\n }\n return this._address;\n }\n\n /**\n * Set trust policy for service selection\n * \n * @example\n * agent.setTrustPolicy({\n * minReputation: 90,\n * maxLatency: 500,\n * verifiedOnly: true\n * });\n */\n setTrustPolicy(policy: TrustPolicy): void {\n this.trustPolicy = { ...this.trustPolicy, ...policy };\n }\n\n /**\n * Get current trust policy\n */\n getTrustPolicy(): TrustPolicy {\n return { ...this.trustPolicy };\n }\n\n // ==========================================================================\n // SERVICE SELECTION - Decision abstraction, not CRUD\n // ==========================================================================\n\n /**\n * Select the best service matching criteria\n * \n * This is the main decision interface. The SDK handles:\n * - Filtering by criteria\n * - Scoring by trust policy\n * - Explaining why a service was selected\n * \n * @example\n * const service = await agent.selectService({\n * category: \"data.prices\",\n * constraints: { minReputation: 90, maxLatency: 200 }\n * });\n * \n * console.log(service.selectionReason);\n * // \"Highest score (92.5) based on: reputation=95, latency=150ms, price=$0.01\"\n */\n async selectService(criteria: ServiceCriteria): Promise<SelectedService | null> {\n const services = await this.discoverServices(criteria);\n\n if (services.length === 0) return null;\n\n // Apply trust policy + criteria constraints\n const constraints = { ...this.trustPolicy, ...criteria.constraints };\n\n const scored = services\n .filter(s => this.passesConstraints(s, constraints))\n .map(s => this.scoreService(s, constraints))\n .sort((a, b) => b.score - a.score);\n\n if (scored.length === 0) return null;\n\n const best = scored[0];\n return {\n id: best.service.id,\n name: best.service.name,\n endpoint: best.service.endpoint,\n price: best.service.price,\n provider: best.service.provider,\n reputation: best.service.reputation,\n latency: best.service.latency,\n selectionReason: this.explainSelection(best),\n scoreBreakdown: {\n reputation: best.repScore,\n latency: best.latScore,\n price: best.priceScore,\n total: best.score,\n },\n };\n }\n\n /**\n * Discover all services matching criteria (raw, unfiltered)\n */\n async discoverServices(criteria: ServiceCriteria): Promise<Array<{\n id: string;\n name: string;\n endpoint: string;\n price: string;\n provider: string;\n reputation: number;\n latency: number;\n category: string;\n inputType?: string;\n outputType?: string;\n tags: string[];\n capabilities: string[];\n verified: boolean;\n }>> {\n const params = new URLSearchParams();\n if (criteria.category) params.set('category', criteria.category);\n if (criteria.inputType) params.set('inputType', criteria.inputType);\n if (criteria.outputType) params.set('outputType', criteria.outputType);\n if (criteria.tags) params.set('tags', criteria.tags.join(','));\n if (criteria.capabilities) params.set('capabilities', criteria.capabilities.join(','));\n params.set('limit', '100');\n\n const response = await fetch(`${this.apiUrl}/api/services?${params}`, {\n headers: this.getHeaders()\n });\n if (!response.ok) {\n throw this.createError('SERVICE_UNAVAILABLE', 'Failed to discover services', true);\n }\n\n const data = await response.json();\n return (data.services || []).map((s: Record<string, unknown>) => ({\n id: s.id as string,\n name: s.name as string,\n endpoint: s.endpointUrl as string || s.endpoint_url as string || '',\n price: s.pricePerCall as string || s.price_per_call as string || '0',\n provider: s.ownerAddress as string || s.owner_address as string || '',\n reputation: (s.reputationScore as number) || (s.reputation_score as number) || 0,\n latency: (s.avgLatencyMs as number) || (s.avg_latency_ms as number) || 0,\n category: s.category as string || '',\n inputType: (s.schema as Record<string, unknown>)?.inputType as string,\n outputType: (s.schema as Record<string, unknown>)?.outputType as string,\n tags: ((s.schema as Record<string, unknown>)?.tags as string[]) || [],\n capabilities: ((s.schema as Record<string, unknown>)?.capabilities as string[]) || [],\n verified: (s.health as Record<string, unknown>)?.reliable as boolean || false,\n }));\n }\n\n // ==========================================================================\n // EXECUTION - Payment-first, failure-aware\n // ==========================================================================\n\n /**\n * Execute a service with automatic payment handling\n * \n * @example\n * const result = await agent.execute(service, { pair: \"BTC/USD\" });\n * \n * if (result.success) {\n * console.log(\"Price:\", result.data.price);\n * } else if (result.error?.retryable) {\n * // Wait and retry\n * await sleep(result.error.retryAfterMs);\n * const retry = await agent.execute(service, input);\n * }\n */\n async execute<TInput = unknown, TOutput = unknown>(\n service: SelectedService | string,\n input?: TInput,\n options: { timeout?: number } = {}\n ): Promise<ExecutionResult<TOutput>> {\n const startTime = performance.now();\n const timeout = options.timeout || 30000;\n\n // Resolve service\n const resolvedService = typeof service === 'string'\n ? await this.getServiceById(service)\n : service;\n\n if (!resolvedService) {\n return {\n success: false,\n error: this.createError('SERVICE_NOT_FOUND', 'Service not found', false),\n metrics: { totalMs: Math.round(performance.now() - startTime) },\n };\n }\n\n // Make initial request\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), timeout);\n\n try {\n let response = await fetch(resolvedService.endpoint, {\n method: input ? 'POST' : 'GET',\n headers: this.getHeaders(),\n body: input ? JSON.stringify(input) : undefined,\n signal: controller.signal,\n });\n\n let paymentInfo: ExecutionResult<TOutput>['payment'];\n let paymentMs: number | undefined;\n\n // Handle 402 Payment Required\n if (response.status === 402) {\n if (!this.signer) {\n clearTimeout(timeoutId);\n return {\n success: false,\n error: this.createError('UNAUTHORIZED', 'Signer required for paid services', false),\n metrics: { totalMs: Math.round(performance.now() - startTime) },\n };\n }\n\n const paymentRequired = await response.json();\n const requirements = paymentRequired.paymentRequirements;\n\n const paymentStart = performance.now();\n const payment = await this.makePayment(requirements);\n paymentMs = Math.round(performance.now() - paymentStart);\n\n paymentInfo = {\n id: payment.paymentId,\n txHash: payment.txHash,\n amount: requirements.maxAmountRequired,\n };\n\n // Retry with payment\n response = await fetch(resolvedService.endpoint, {\n method: input ? 'POST' : 'GET',\n headers: {\n ...this.getHeaders(),\n 'X-Payment': payment.txHash,\n 'X-Payment-Id': payment.paymentId,\n },\n body: input ? JSON.stringify(input) : undefined,\n signal: controller.signal,\n });\n }\n\n clearTimeout(timeoutId);\n const totalMs = Math.round(performance.now() - startTime);\n const serviceMs = paymentMs ? totalMs - paymentMs : totalMs;\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({}));\n return {\n success: false,\n error: this.createError(\n response.status === 429 ? 'RATE_LIMITED' : 'EXECUTION_FAILED',\n error.message || `Service returned ${response.status}`,\n response.status === 429 || response.status >= 500\n ),\n payment: paymentInfo,\n metrics: { totalMs, paymentMs, serviceMs },\n };\n }\n\n const data = await response.json();\n\n // Record outcome for memory\n this.recordOutcome({\n timestamp: new Date(),\n serviceId: resolvedService.id,\n success: true,\n latencyMs: serviceMs,\n paymentAmount: paymentInfo?.amount,\n });\n\n return {\n success: true,\n data,\n payment: paymentInfo,\n metrics: { totalMs, paymentMs, serviceMs },\n };\n\n } catch (err) {\n clearTimeout(timeoutId);\n const totalMs = Math.round(performance.now() - startTime);\n\n const isTimeout = err instanceof Error && err.name === 'AbortError';\n return {\n success: false,\n error: this.createError(\n isTimeout ? 'EXECUTION_TIMEOUT' : 'EXECUTION_FAILED',\n isTimeout ? 'Request timed out' : (err instanceof Error ? err.message : 'Unknown error'),\n true,\n isTimeout ? 5000 : 1000\n ),\n metrics: { totalMs },\n };\n }\n }\n\n // ==========================================================================\n // WORKFLOWS - Multi-step execution with retries and fallbacks\n // ==========================================================================\n\n /**\n * Execute a multi-step workflow\n * \n * @example\n * const result = await agent.executeWorkflow([\n * { name: 'getPrice', criteria: { category: 'data.prices' } },\n * { name: 'validate', transform: (price) => price.value > 0 ? price : null },\n * { name: 'trade', criteria: { category: 'trading.execution' } },\n * ], { pair: 'BTC/USD' });\n */\n async executeWorkflow<TInput = unknown, TOutput = unknown>(\n steps: WorkflowStep[],\n initialInput: TInput\n ): Promise<WorkflowResult<TOutput>> {\n const startTime = performance.now();\n const stepResults: WorkflowResult['stepResults'] = [];\n let currentInput: unknown = initialInput;\n let failedSteps = 0;\n\n for (const step of steps) {\n const stepStart = performance.now();\n const maxRetries = step.retries || 0;\n let lastError: ExecutionError | undefined;\n\n for (let attempt = 0; attempt <= maxRetries; attempt++) {\n try {\n let result: unknown;\n\n if (step.transform) {\n // Pure transformation step\n result = await step.transform(currentInput as never);\n } else {\n // Service execution step\n let service = step.service;\n if (!service && step.criteria) {\n service = await this.selectService(step.criteria) || undefined;\n }\n if (!service && step.serviceId) {\n service = await this.getServiceById(step.serviceId) || undefined;\n }\n\n if (!service) {\n throw this.createError('SERVICE_NOT_FOUND', `No service found for step: ${step.name}`, false);\n }\n\n const execResult = await this.execute(service, currentInput, { timeout: step.timeout });\n if (!execResult.success) {\n throw execResult.error;\n }\n result = execResult.data;\n }\n\n // Success\n if (step.onSuccess) await step.onSuccess(result as never);\n\n stepResults.push({\n stepName: step.name,\n success: true,\n data: result,\n durationMs: Math.round(performance.now() - stepStart),\n });\n\n currentInput = result;\n lastError = undefined;\n break;\n\n } catch (err) {\n // Check if it's already an ExecutionError\n if (err && typeof err === 'object' && 'code' in err && 'retryable' in err) {\n lastError = err as ExecutionError;\n } else {\n lastError = this.createError('EXECUTION_FAILED', err instanceof Error ? err.message : 'Unknown', false);\n }\n\n // Try fallback if available and no retries left\n if (attempt === maxRetries && step.fallback) {\n try {\n const fallbackResult = await this.executeWorkflow([step.fallback], currentInput);\n if (fallbackResult.success) {\n currentInput = fallbackResult.data;\n lastError = undefined;\n stepResults.push({\n stepName: `${step.name} (fallback)`,\n success: true,\n data: fallbackResult.data,\n durationMs: Math.round(performance.now() - stepStart),\n });\n break;\n }\n } catch {\n // Fallback failed, continue with error\n }\n }\n }\n }\n\n if (lastError) {\n if (step.onFailure) await step.onFailure(lastError);\n\n stepResults.push({\n stepName: step.name,\n success: false,\n error: lastError,\n durationMs: Math.round(performance.now() - stepStart),\n });\n\n failedSteps++;\n\n // Stop workflow on non-retryable error\n if (!lastError.retryable) break;\n }\n }\n\n const completedSteps = stepResults.filter(r => r.success).length;\n const totalMs = Math.round(performance.now() - startTime);\n\n return {\n success: failedSteps === 0,\n data: currentInput as TOutput,\n stepResults,\n totalMs,\n completedSteps,\n failedSteps,\n };\n }\n\n // ==========================================================================\n // MEMORY - Built-in hooks for agent learning\n // ==========================================================================\n\n /**\n * Get agent memory interface\n */\n get memory(): AgentMemory {\n return {\n record: (outcome) => this.recordOutcome(outcome),\n getHistory: (serviceId) => serviceId\n ? this.memoryStore.filter(o => o.serviceId === serviceId)\n : [...this.memoryStore],\n getStats: () => {\n const total = this.memoryStore.length;\n const successful = this.memoryStore.filter(o => o.success).length;\n const avgLatency = total > 0\n ? this.memoryStore.reduce((sum, o) => sum + o.latencyMs, 0) / total\n : 0;\n return {\n totalCalls: total,\n successRate: total > 0 ? successful / total : 0,\n avgLatency: Math.round(avgLatency),\n };\n },\n clear: () => { this.memoryStore = []; },\n };\n }\n\n /**\n * Register callback for outcomes (for external memory systems)\n */\n onOutcome(callback: (outcome: OutcomeRecord) => void): () => void {\n this.outcomeCallbacks.push(callback);\n return () => {\n const idx = this.outcomeCallbacks.indexOf(callback);\n if (idx > -1) this.outcomeCallbacks.splice(idx, 1);\n };\n }\n\n private outcomeCallbacks: Array<(outcome: OutcomeRecord) => void> = [];\n\n private recordOutcome(outcome: OutcomeRecord): void {\n this.memoryStore.push(outcome);\n // Keep last 1000 outcomes\n if (this.memoryStore.length > 1000) {\n this.memoryStore = this.memoryStore.slice(-1000);\n }\n this.outcomeCallbacks.forEach(cb => cb(outcome));\n }\n\n // ==========================================================================\n // HELPERS\n // ==========================================================================\n\n private async getServiceById(serviceId: string): Promise<SelectedService | null> {\n const response = await fetch(`${this.apiUrl}/api/services/${serviceId}`, {\n headers: this.getHeaders()\n });\n if (!response.ok) return null;\n\n const s = await response.json();\n return {\n id: s.id,\n name: s.name,\n endpoint: s.endpointUrl || s.endpoint_url,\n price: s.pricePerCall || '0',\n provider: s.ownerAddress || '',\n reputation: s.reputationScore || 0,\n latency: s.avgLatencyMs || 0,\n selectionReason: 'Direct lookup',\n scoreBreakdown: { reputation: 0, latency: 0, price: 0, total: 0 },\n };\n }\n\n private passesConstraints(\n service: { reputation: number; latency: number; price: string; provider: string; verified: boolean },\n constraints: TrustPolicy\n ): boolean {\n if (constraints.minReputation && service.reputation < constraints.minReputation) return false;\n if (constraints.maxLatency && service.latency > constraints.maxLatency) return false;\n if (constraints.maxPrice && parseFloat(service.price) > constraints.maxPrice) return false;\n if (constraints.verifiedOnly && !service.verified) return false;\n if (constraints.blacklistedProviders?.includes(service.provider)) return false;\n return true;\n }\n\n private scoreService(\n service: DiscoveredServiceInternal,\n constraints: TrustPolicy\n ): {\n service: DiscoveredServiceInternal;\n score: number;\n repScore: number;\n latScore: number;\n priceScore: number;\n } {\n // Normalize scores to 0-100\n const repScore = service.reputation; // Already 0-100\n const latScore = Math.max(0, 100 - (service.latency / 10)); // Lower is better\n const priceScore = Math.max(0, 100 - (parseFloat(service.price) * 100)); // Lower is better\n\n // Boost for preferred providers\n const preferredBoost = constraints.preferredProviders?.includes(service.provider) ? 10 : 0;\n\n // Weighted score\n const score = (repScore * 0.5 + latScore * 0.3 + priceScore * 0.2) + preferredBoost;\n\n return { service, score, repScore, latScore, priceScore };\n }\n\n private explainSelection(scored: { service: { reputation: number; latency: number; price: string }; score: number }): string {\n return `Highest score (${scored.score.toFixed(1)}) based on: reputation=${scored.service.reputation}, ` +\n `latency=${scored.service.latency}ms, price=$${scored.service.price}`;\n }\n\n private async makePayment(requirements: {\n payTo: string;\n maxAmountRequired: string;\n asset?: string;\n }): Promise<{ paymentId: string; txHash: string }> {\n if (!this.signer) throw this.createError('UNAUTHORIZED', 'Signer required', false);\n\n const signerAddress = await this.signer.getAddress();\n const chainId = NETWORK_CONFIG[this.network].chainId;\n\n // EIP-3009 authorization\n const domain = {\n name: 'USD Coin',\n version: '2',\n chainId,\n verifyingContract: requirements.asset || '0xf951eC28187D9E5Ca673Da8FE6757E6f0Be5F77C',\n };\n\n const types = {\n TransferWithAuthorization: [\n { name: 'from', type: 'address' },\n { name: 'to', type: 'address' },\n { name: 'value', type: 'uint256' },\n { name: 'validAfter', type: 'uint256' },\n { name: 'validBefore', type: 'uint256' },\n { name: 'nonce', type: 'bytes32' },\n ],\n };\n\n const nonce = ethers.hexlify(ethers.randomBytes(32));\n const validAfter = 0;\n const validBefore = Math.floor(Date.now() / 1000) + 3600;\n\n const value = {\n from: signerAddress,\n to: requirements.payTo,\n value: ethers.parseUnits(requirements.maxAmountRequired, 6),\n validAfter,\n validBefore,\n nonce,\n };\n\n const signature = await (this.signer as ethers.Signer & {\n signTypedData: (d: typeof domain, t: typeof types, v: typeof value) => Promise<string>;\n }).signTypedData(domain, types, value);\n\n const response = await fetch(`${FACILITATOR_URL}/settle`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n from: signerAddress,\n to: requirements.payTo,\n value: requirements.maxAmountRequired,\n validAfter,\n validBefore,\n nonce,\n signature,\n network: this.network === 'cronos-mainnet' ? 'cronos-mainnet' : 'cronos-testnet',\n }),\n });\n\n if (!response.ok) {\n throw this.createError('PAYMENT_FAILED', 'Payment settlement failed', true, 5000);\n }\n\n const result = await response.json();\n return {\n paymentId: `pay_${result.txHash?.slice(2, 18) || Date.now()}`,\n txHash: result.txHash || '',\n };\n }\n\n // ==========================================================================\n // A2A DISCOVERY - Agent-to-Agent Protocol Support\n // ==========================================================================\n\n /**\n * Discover an agent's capabilities via their agent card\n * \n * @example\n * const card = await agent.discoverAgentCard(\"https://api.service.com\");\n * console.log(card.resources); // Available x402-gated resources\n */\n async discoverAgentCard(baseUrl: string): Promise<AgentCard | null> {\n const paths = ['/.well-known/agent-card.json', '/.well-known/agent.json'];\n\n for (const path of paths) {\n try {\n const response = await fetch(`${baseUrl.replace(/\\/$/, '')}${path}`, {\n headers: { 'Accept': 'application/json' },\n });\n\n if (response.ok) {\n return await response.json();\n }\n } catch {\n continue;\n }\n }\n\n return null;\n }\n\n /**\n * Discover multiple remote agents in parallel\n * \n * @example\n * const agents = await agent.discoverRemoteAgents([\n * \"https://perpai.relaycore.xyz\",\n * \"https://rwa.relaycore.xyz\"\n * ]);\n */\n async discoverRemoteAgents(urls: string[]): Promise<Array<{\n url: string;\n card: AgentCard | null;\n online: boolean;\n }>> {\n return Promise.all(\n urls.map(async (url) => {\n const card = await this.discoverAgentCard(url);\n return {\n url,\n card,\n online: card !== null,\n };\n })\n );\n }\n\n /**\n * Get local Relay Core agent card\n */\n async getLocalAgentCard(): Promise<AgentCard> {\n const response = await fetch(`${this.apiUrl}/.well-known/agent-card.json`);\n if (!response.ok) {\n throw this.createError('SERVICE_UNAVAILABLE', 'Failed to fetch agent card', true);\n }\n return response.json();\n }\n\n // ==========================================================================\n // TASK ARTIFACTS - Track and audit all agent actions\n // ==========================================================================\n\n /**\n * Create a new task artifact\n * \n * @example\n * const task = await agent.createTask({\n * service_id: \"perpai-quote\",\n * inputs: { pair: \"BTC/USD\" }\n * });\n */\n async createTask(params: {\n service_id?: string;\n session_id?: string;\n inputs: Record<string, unknown>;\n }): Promise<TaskArtifact> {\n const agentId = await this.getAddress();\n\n const response = await fetch(`${this.apiUrl}/api/tasks`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n agent_id: agentId,\n service_id: params.service_id,\n session_id: params.session_id,\n inputs: params.inputs,\n }),\n });\n\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to create task', true);\n }\n\n return response.json();\n }\n\n /**\n * Get a task artifact by ID\n */\n async getTask(taskId: string): Promise<TaskArtifact | null> {\n const response = await fetch(`${this.apiUrl}/api/tasks/${taskId}`, {\n headers: this.getHeaders()\n });\n if (response.status === 404) return null;\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to get task', true);\n }\n return response.json();\n }\n\n /**\n * Query task artifacts\n * \n * @example\n * const tasks = await agent.getTasks({ state: 'settled', limit: 10 });\n */\n async getTasks(params?: {\n service_id?: string;\n session_id?: string;\n state?: TaskState;\n from?: Date;\n to?: Date;\n limit?: number;\n }): Promise<TaskArtifact[]> {\n const agentId = await this.getAddress();\n const queryParams = new URLSearchParams();\n queryParams.set('agent_id', agentId);\n\n if (params?.service_id) queryParams.set('service_id', params.service_id);\n if (params?.session_id) queryParams.set('session_id', params.session_id.toString());\n if (params?.state) queryParams.set('state', params.state);\n if (params?.from) queryParams.set('from', params.from.toISOString());\n if (params?.to) queryParams.set('to', params.to.toISOString());\n if (params?.limit) queryParams.set('limit', params.limit.toString());\n\n const response = await fetch(`${this.apiUrl}/api/tasks?${queryParams}`, {\n headers: this.getHeaders()\n });\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to query tasks', true);\n }\n\n const data = await response.json();\n return data.tasks || [];\n }\n\n /**\n * Get task statistics\n */\n async getTaskStats(): Promise<TaskStats> {\n const agentId = await this.getAddress();\n const response = await fetch(`${this.apiUrl}/api/tasks/stats?agent_id=${agentId}`, {\n headers: this.getHeaders()\n });\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to get task stats', true);\n }\n return response.json();\n }\n\n /**\n * Mark a task as settled (success)\n */\n async settleTask(taskId: string, outputs: Record<string, unknown>, metrics?: TaskArtifact['metrics']): Promise<TaskArtifact> {\n const response = await fetch(`${this.apiUrl}/api/tasks/${taskId}/settle`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({ outputs, metrics }),\n });\n\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to settle task', true);\n }\n\n return response.json();\n }\n\n /**\n * Mark a task as failed\n */\n async failTask(taskId: string, error: { code: string; message: string; retryable: boolean }, metrics?: TaskArtifact['metrics']): Promise<TaskArtifact> {\n const response = await fetch(`${this.apiUrl}/api/tasks/${taskId}/fail`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({ error, metrics }),\n });\n\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to fail task', true);\n }\n\n return response.json();\n }\n\n // ========================================================================\n // META-AGENT METHODS (Agent Discovery & Hiring)\n // ========================================================================\n\n /**\n * Discover agents based on criteria\n */\n async discoverAgents(query: {\n capability?: string;\n category?: string;\n minReputation?: number;\n maxPricePerCall?: string;\n limit?: number;\n }): Promise<Array<{\n agentId: string;\n agentName: string;\n agentUrl: string;\n reputationScore: number;\n pricePerCall: string;\n successRate: number;\n compositeScore: number;\n }>> {\n const response = await fetch(`${this.apiUrl}/api/meta-agent/discover`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify(query)\n });\n\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Agent discovery failed', true);\n }\n\n const data = await response.json();\n return data.agents || [];\n }\n\n /**\n * Hire an agent to perform a task\n */\n async hireAgent(request: {\n agentId: string;\n resourceId: string;\n budget: string;\n task: Record<string, unknown>;\n }): Promise<{\n success: boolean;\n taskId: string;\n agentId: string;\n cost: string;\n }> {\n const agentId = await this.getAddress();\n\n const response = await fetch(`${this.apiUrl}/api/meta-agent/hire`, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'X-Agent-Id': agentId\n },\n body: JSON.stringify(request)\n });\n\n if (!response.ok) {\n const error = await response.json();\n throw this.createError('EXECUTION_FAILED', error.error || 'Agent hiring failed', true);\n }\n\n return response.json();\n }\n\n /**\n * Execute a delegated task\n */\n async executeDelegation(taskId: string): Promise<{\n success: boolean;\n outcome: {\n taskId: string;\n agentId: string;\n state: string;\n outputs?: Record<string, unknown>;\n error?: { code: string; message: string };\n };\n }> {\n const response = await fetch(`${this.apiUrl}/api/meta-agent/execute/${taskId}`, {\n method: 'POST',\n headers: this.getHeaders()\n });\n\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Delegation execution failed', true);\n }\n\n return response.json();\n }\n\n /**\n * Get delegation status\n */\n async getDelegationStatus(taskId: string): Promise<{\n taskId: string;\n agentId: string;\n state: string;\n cost: string;\n outputs?: Record<string, unknown>;\n }> {\n const response = await fetch(`${this.apiUrl}/api/meta-agent/status/${taskId}`, {\n headers: this.getHeaders()\n });\n\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to get delegation status', true);\n }\n\n const data = await response.json();\n return data.outcome;\n }\n\n /**\n * Fetch agent card for a specific agent\n */\n async getAgentCard(agentId: string): Promise<{\n name: string;\n description: string;\n url: string;\n network: string;\n resources: Array<{\n id: string;\n title: string;\n url: string;\n }>;\n } | null> {\n const response = await fetch(`${this.apiUrl}/api/meta-agent/agent-card/${agentId}`, {\n headers: this.getHeaders()\n });\n\n if (!response.ok) {\n return null;\n }\n\n const data = await response.json();\n return data.card || null;\n }\n\n // ========================================================================\n // SESSION MANAGEMENT (x402)\n // ========================================================================\n\n /**\n * Create a new x402 session\n * \n * @returns Session ID and payment request to activate it\n */\n async createSession(params: {\n maxSpend: number;\n durationHours: number;\n authorizedAgents?: string[];\n }): Promise<{\n sessionId: string;\n paymentRequest: {\n amount: string;\n payTo: string;\n asset: string;\n };\n }> {\n const ownerAddress = await this.getAddress();\n\n const response = await fetch(`${this.apiUrl}/api/sessions/create`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({\n ownerAddress,\n maxSpend: params.maxSpend,\n durationHours: params.durationHours,\n authorizedAgents: params.authorizedAgents || []\n })\n });\n\n if (!response.ok) {\n const error = await response.json();\n throw this.createError('EXECUTION_FAILED', error.message || 'Failed to create session', false);\n }\n\n const result = await response.json();\n return {\n sessionId: result.session.session_id,\n paymentRequest: result.paymentRequest\n };\n }\n\n /**\n * Activate a session after paying USDC\n */\n async activateSession(sessionId: string, txHash: string, amount: string): Promise<{ success: boolean }> {\n const response = await fetch(`${this.apiUrl}/api/sessions/${sessionId}/activate`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: JSON.stringify({ txHash, amount })\n });\n\n if (!response.ok) {\n const error = await response.json();\n throw this.createError('EXECUTION_FAILED', error.message || 'Failed to activate session', true);\n }\n\n return { success: true };\n }\n\n /**\n * Get session details\n */\n async getSession(sessionId: string): Promise<{\n id: string;\n owner: string;\n maxSpend: string;\n spent: string;\n isActive: boolean;\n expiresAt: string;\n } | null> {\n const response = await fetch(`${this.apiUrl}/api/sessions/${sessionId}`, {\n headers: this.getHeaders()\n });\n\n if (response.status === 404) return null;\n if (!response.ok) {\n throw this.createError('EXECUTION_FAILED', 'Failed to get session', true);\n }\n\n const data = await response.json();\n const session = data.session;\n return {\n id: session.session_id,\n owner: session.owner_address,\n maxSpend: session.max_spend,\n spent: session.spent,\n isActive: session.is_active,\n expiresAt: session.expires_at\n };\n }\n\n\n private createError(\n code: ErrorCode,\n message: string,\n retryable: boolean,\n retryAfterMs?: number\n ): ExecutionError {\n return { code, message, retryable, retryAfterMs };\n }\n}\n\n// ============================================================================\n// FACTORY & EXPORTS\n// ============================================================================\n\n/**\n * Create a Relay Agent instance\n * \n * @example\n * const agent = createAgent({ wallet, network: \"cronos-testnet\" });\n */\nexport function createAgent(config: AgentConfig): RelayAgent {\n return new RelayAgent(config);\n}\n\nexport default RelayAgent;\n","/**\n * Relay Core - Service SDK\n * \n * For service providers to expose services, handle payments, prove delivery,\n * and track reputation on the Relay Core platform.\n * \n * Design Principles:\n * - Explicit service definition (first-class metadata)\n * - Payment-first thinking (not hidden magic)\n * - Delivery proof is sacred\n * - Built-in observability\n * - Runtime-agnostic\n * \n * @example Quickstart (10 minutes)\n * ```ts\n * const service = defineService({\n * name: \"price-feed\",\n * category: \"data.prices\",\n * price: \"0.01\",\n * inputSchema: { type: \"object\", properties: { pair: { type: \"string\" } } },\n * outputSchema: { type: \"object\", properties: { price: { type: \"number\" } } },\n * });\n * \n * const provider = new RelayService({ wallet, network: \"cronos-testnet\" });\n * await provider.register(service);\n * \n * // In your request handler:\n * provider.onPaymentReceived(async (ctx) => {\n * const result = await getPrice(ctx.input);\n * ctx.deliver({ result, proof: hash(result) });\n * });\n * ```\n */\n\nimport { ethers } from 'ethers';\n\n// ============================================================================\n// TYPES - Clear, descriptive names\n// ============================================================================\n\n/** Network configuration */\nexport type Network = 'cronos-mainnet' | 'cronos-testnet' | 'cronos-zkevm';\n\n/** Service provider configuration */\nexport interface ServiceConfig {\n /** Connected wallet for signing */\n wallet: ethers.Signer;\n /** Target network */\n network?: Network;\n /** API endpoint (defaults to production) */\n apiUrl?: string;\n}\n\n/** Service definition - first-class metadata */\nexport interface ServiceDefinition {\n /** Unique service name */\n name: string;\n /** Human-readable description */\n description?: string;\n /** Service category (e.g., \"data.prices\", \"trading.execution\", \"ai.inference\") */\n category: string;\n /** Price per call in USDC (e.g., \"0.01\") */\n price: string;\n /** Service endpoint URL */\n endpoint?: string;\n /** Input JSON schema */\n inputSchema?: JsonSchema;\n /** Output JSON schema */\n outputSchema?: JsonSchema;\n /** Input type name for discovery (e.g., \"PriceQuery\") */\n inputType?: string;\n /** Output type name for discovery (e.g., \"PriceData\") */\n outputType?: string;\n /** Searchable tags */\n tags?: string[];\n /** Declared capabilities */\n capabilities?: string[];\n /** Version string */\n version?: string;\n}\n\n/** JSON Schema type */\nexport interface JsonSchema {\n type: string;\n properties?: Record<string, JsonSchema>;\n required?: string[];\n items?: JsonSchema;\n description?: string;\n [key: string]: unknown;\n}\n\n/** Registered service (after registration) */\nexport interface RegisteredService extends ServiceDefinition {\n id: string;\n ownerAddress: string;\n registeredAt: Date;\n isActive: boolean;\n}\n\n/** Payment context passed to handlers */\nexport interface PaymentContext<TInput = unknown> {\n /** Unique payment ID */\n paymentId: string;\n /** Transaction hash */\n txHash: string;\n /** Amount paid in USDC */\n amount: string;\n /** Payer's wallet address */\n payerAddress: string;\n /** Parsed input from request */\n input: TInput;\n /** Timestamp of payment */\n timestamp: Date;\n /** Deliver result with proof */\n deliver: <TOutput>(output: DeliveryProof<TOutput>) => Promise<void>;\n /** Report failure with reason */\n fail: (reason: string, retryable?: boolean) => Promise<void>;\n}\n\n/** Delivery proof - the heart of the system */\nexport interface DeliveryProof<T = unknown> {\n /** The actual result data */\n result: T;\n /** Hash of the result for verification */\n proof?: string;\n /** Additional evidence (receipts, signatures, etc.) */\n evidence?: Record<string, unknown>;\n /** Execution latency in ms */\n latencyMs?: number;\n}\n\n/** Payment status */\nexport type PaymentStatus = 'pending' | 'received' | 'settled' | 'failed' | 'timeout';\n\n/** Payment event */\nexport interface PaymentEvent {\n paymentId: string;\n status: PaymentStatus;\n txHash?: string;\n amount?: string;\n payerAddress?: string;\n timestamp: Date;\n error?: string;\n}\n\n/** Outcome types for reputation tracking */\nexport type OutcomeType = 'delivered' | 'failed' | 'partial' | 'timeout';\n\n/** Outcome record */\nexport interface OutcomeRecord {\n paymentId: string;\n outcomeType: OutcomeType;\n latencyMs: number;\n proofHash?: string;\n evidence?: Record<string, unknown>;\n timestamp: Date;\n}\n\n/** Service metrics */\nexport interface ServiceMetrics {\n timestamp: Date;\n reputationScore: number;\n successRate: number;\n avgLatencyMs: number;\n totalCalls: number;\n totalPayments: number;\n totalRevenue: string;\n}\n\n/** Provider reputation */\nexport interface ProviderReputation {\n reputationScore: number;\n successRate: number;\n totalDeliveries: number;\n avgLatencyMs: number;\n trend: 'improving' | 'stable' | 'declining';\n rank?: number;\n percentile?: number;\n}\n\n/** x402 payment requirements (for 402 responses) */\nexport interface PaymentRequirements {\n x402Version: number;\n paymentRequirements: {\n scheme: 'exact';\n network: string;\n payTo: string;\n asset: string;\n maxAmountRequired: string;\n maxTimeoutSeconds: number;\n resource?: string;\n description?: string;\n };\n}\n\n/** Observability/logging interface */\nexport interface ServiceLogger {\n info(message: string, data?: Record<string, unknown>): void;\n warn(message: string, data?: Record<string, unknown>): void;\n error(message: string, error?: Error, data?: Record<string, unknown>): void;\n metric(name: string, value: number, tags?: Record<string, string>): void;\n}\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Define a service with typed schema\n * \n * @example\n * const myService = defineService({\n * name: \"price-feed\",\n * category: \"data.prices\",\n * price: \"0.01\",\n * inputSchema: { type: \"object\", properties: { pair: { type: \"string\" } } },\n * outputSchema: { type: \"object\", properties: { price: { type: \"number\" } } },\n * });\n */\nexport function defineService(definition: ServiceDefinition): ServiceDefinition {\n // Validate required fields\n if (!definition.name) throw new Error('Service name is required');\n if (!definition.category) throw new Error('Service category is required');\n if (!definition.price) throw new Error('Service price is required');\n\n // Normalize price format\n const normalizedPrice = definition.price.replace('$', '').replace(' USDC', '');\n\n return {\n ...definition,\n price: normalizedPrice,\n tags: definition.tags || [],\n capabilities: definition.capabilities || [],\n version: definition.version || '1.0.0',\n };\n}\n\n/**\n * Create a hash of data for delivery proof\n * \n * @example\n * const proof = hashProof(result);\n * ctx.deliver({ result, proof });\n */\nexport function hashProof(data: unknown): string {\n const json = JSON.stringify(data);\n // Simple hash for demo - in production use crypto.subtle or ethers.keccak256\n let hash = 0;\n for (let i = 0; i < json.length; i++) {\n const char = json.charCodeAt(i);\n hash = ((hash << 5) - hash) + char;\n hash = hash & hash;\n }\n return `0x${Math.abs(hash).toString(16).padStart(16, '0')}`;\n}\n\n// ============================================================================\n// IMPLEMENTATION\n// ============================================================================\n\nconst NETWORK_CONFIG: Record<Network, { apiUrl: string; chainId: number; asset: string }> = {\n 'cronos-mainnet': {\n apiUrl: 'https://api.relaycore.xyz',\n chainId: 25,\n asset: '0xf951eC28187D9E5Ca673Da8FE6757E6f0Be5F77C', // USDC.e\n },\n 'cronos-testnet': {\n apiUrl: 'https://testnet-api.relaycore.xyz',\n chainId: 338,\n asset: '0xf951eC28187D9E5Ca673Da8FE6757E6f0Be5F77C',\n },\n 'cronos-zkevm': {\n apiUrl: 'https://zkevm-api.relaycore.xyz',\n chainId: 388,\n asset: '0xf951eC28187D9E5Ca673Da8FE6757E6f0Be5F77C',\n },\n};\n\n/**\n * Relay Service SDK\n * \n * The main entry point for service providers on Relay Core.\n */\nexport class RelayService {\n private signer: ethers.Signer;\n private address: string = '';\n private network: Network;\n private apiUrl: string;\n private registeredServices: Map<string, RegisteredService> = new Map();\n private outcomes: OutcomeRecord[] = [];\n private logger: ServiceLogger;\n\n // Event handlers\n private paymentReceivedHandlers: Array<(ctx: PaymentContext) => Promise<void>> = [];\n private paymentTimeoutHandlers: Array<(event: PaymentEvent) => Promise<void>> = [];\n private paymentFailedHandlers: Array<(event: PaymentEvent) => Promise<void>> = [];\n\n constructor(config: ServiceConfig) {\n this.signer = config.wallet;\n this.network = config.network || 'cronos-mainnet';\n this.apiUrl = config.apiUrl || NETWORK_CONFIG[this.network].apiUrl;\n\n // Get address\n config.wallet.getAddress().then(addr => {\n this.address = addr.toLowerCase();\n });\n\n // Default console logger\n this.logger = {\n info: (msg, data) => console.log(`[RelayService] ${msg}`, data || ''),\n warn: (msg, data) => console.warn(`[RelayService] ${msg}`, data || ''),\n error: (msg, err, data) => console.error(`[RelayService] ${msg}`, err, data || ''),\n metric: (name, value, tags) => console.log(`[Metric] ${name}=${value}`, tags || ''),\n };\n }\n\n // ==========================================================================\n // CONFIGURATION\n // ==========================================================================\n\n /**\n * Set custom logger for observability\n */\n setLogger(logger: ServiceLogger): void {\n this.logger = logger;\n }\n\n /**\n * Get provider wallet address\n */\n async getAddress(): Promise<string> {\n if (!this.address) {\n this.address = (await this.signer.getAddress()).toLowerCase();\n }\n return this.address;\n }\n\n // ==========================================================================\n // SERVICE REGISTRATION - Explicit, first-class\n // ==========================================================================\n\n /**\n * Register a service on Relay Core\n * \n * @example\n * const registered = await provider.register(defineService({\n * name: \"price-feed\",\n * category: \"data.prices\",\n * price: \"0.01\",\n * }));\n * \n * console.log(`Service ID: ${registered.id}`);\n */\n async register(service: ServiceDefinition): Promise<RegisteredService> {\n const ownerAddress = await this.getAddress();\n\n this.logger.info('Registering service', { name: service.name, category: service.category });\n\n const response = await fetch(`${this.apiUrl}/api/services`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n name: service.name,\n description: service.description || `${service.name} service`,\n category: service.category,\n endpointUrl: service.endpoint,\n pricePerCall: service.price,\n ownerAddress,\n inputSchema: service.inputSchema,\n outputSchema: service.outputSchema,\n inputType: service.inputType,\n outputType: service.outputType,\n tags: service.tags,\n capabilities: service.capabilities,\n }),\n });\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({ error: 'Unknown error' }));\n this.logger.error('Registration failed', new Error(error.error || 'Unknown'));\n throw new Error(`Failed to register service: ${error.error || response.statusText}`);\n }\n\n const data = await response.json();\n\n const registered: RegisteredService = {\n ...service,\n id: data.id,\n ownerAddress,\n registeredAt: new Date(),\n isActive: true,\n };\n\n this.registeredServices.set(data.id, registered);\n this.logger.info('Service registered', { id: data.id, name: service.name });\n\n return registered;\n }\n\n /**\n * Update an existing service\n */\n async update(serviceId: string, updates: Partial<ServiceDefinition>): Promise<void> {\n this.logger.info('Updating service', { id: serviceId, updates });\n\n const response = await fetch(`${this.apiUrl}/api/services/${serviceId}`, {\n method: 'PUT',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n name: updates.name,\n description: updates.description,\n category: updates.category,\n endpointUrl: updates.endpoint,\n pricePerCall: updates.price,\n inputSchema: updates.inputSchema,\n outputSchema: updates.outputSchema,\n inputType: updates.inputType,\n outputType: updates.outputType,\n tags: updates.tags,\n capabilities: updates.capabilities,\n }),\n });\n\n if (!response.ok) {\n throw new Error(`Failed to update service: ${response.statusText}`);\n }\n\n // Update local cache\n const existing = this.registeredServices.get(serviceId);\n if (existing) {\n this.registeredServices.set(serviceId, { ...existing, ...updates });\n }\n\n this.logger.info('Service updated', { id: serviceId });\n }\n\n /**\n * Deactivate a service\n */\n async deactivate(serviceId: string): Promise<void> {\n await this.update(serviceId, { endpoint: undefined } as never);\n\n const existing = this.registeredServices.get(serviceId);\n if (existing) {\n existing.isActive = false;\n }\n\n this.logger.info('Service deactivated', { id: serviceId });\n }\n\n /**\n * Get all registered services for this provider\n */\n async getMyServices(): Promise<RegisteredService[]> {\n const ownerAddress = await this.getAddress();\n\n const response = await fetch(\n `${this.apiUrl}/api/services?ownerAddress=${ownerAddress}`\n );\n\n if (!response.ok) {\n throw new Error('Failed to fetch services');\n }\n\n const data = await response.json();\n return (data.services || []).map((s: Record<string, unknown>) => ({\n id: s.id as string,\n name: s.name as string,\n description: s.description as string,\n category: s.category as string,\n price: s.pricePerCall as string,\n endpoint: s.endpointUrl as string,\n ownerAddress: s.ownerAddress as string,\n registeredAt: new Date(s.createdAt as string),\n isActive: s.isActive as boolean ?? true,\n }));\n }\n\n // ==========================================================================\n // PAYMENT HANDLING - Explicit, not magic\n // ==========================================================================\n\n /**\n * Generate x402 payment requirements for a 402 response\n * \n * Use this when building your service's payment-required response.\n * \n * @example Express.js middleware\n * ```ts\n * app.use('/api/price', (req, res, next) => {\n * const paymentId = req.headers['x-payment-id'];\n * \n * if (!paymentId) {\n * const requirements = provider.createPaymentRequired({\n * amount: \"0.01\",\n * resource: \"/api/price\",\n * description: \"Price feed access\",\n * });\n * return res.status(402).json(requirements);\n * }\n * \n * next();\n * });\n * ```\n */\n async createPaymentRequired(params: {\n amount: string;\n resource?: string;\n description?: string;\n timeoutSeconds?: number;\n }): Promise<PaymentRequirements> {\n const payTo = await this.getAddress();\n const config = NETWORK_CONFIG[this.network];\n\n return {\n x402Version: 1,\n paymentRequirements: {\n scheme: 'exact',\n network: this.network === 'cronos-mainnet' ? 'cronos-mainnet' : 'cronos-testnet',\n payTo,\n asset: config.asset,\n maxAmountRequired: params.amount,\n maxTimeoutSeconds: params.timeoutSeconds || 60,\n resource: params.resource,\n description: params.description,\n },\n };\n }\n\n /**\n * Verify a payment was made\n * \n * @example\n * const { verified, amount, payerAddress } = await provider.verifyPayment(paymentId);\n * if (!verified) {\n * return res.status(402).json({ error: 'Payment not verified' });\n * }\n */\n async verifyPayment(paymentId: string): Promise<{\n verified: boolean;\n status: PaymentStatus;\n amount?: string;\n payerAddress?: string;\n txHash?: string;\n }> {\n const response = await fetch(`${this.apiUrl}/api/payments/${paymentId}`);\n\n if (!response.ok) {\n return { verified: false, status: 'failed' };\n }\n\n const data = await response.json();\n const payment = data.payment;\n\n return {\n verified: payment?.status === 'settled',\n status: payment?.status || 'pending',\n amount: payment?.amount,\n payerAddress: payment?.payerAddress,\n txHash: payment?.txHash,\n };\n }\n\n /**\n * Register handler for payment received events\n * \n * @example\n * provider.onPaymentReceived(async (ctx) => {\n * const result = await processRequest(ctx.input);\n * ctx.deliver({\n * result,\n * proof: hashProof(result),\n * latencyMs: Date.now() - ctx.timestamp.getTime(),\n * });\n * });\n */\n onPaymentReceived(handler: (ctx: PaymentContext) => Promise<void>): () => void {\n this.paymentReceivedHandlers.push(handler);\n return () => {\n const idx = this.paymentReceivedHandlers.indexOf(handler);\n if (idx > -1) this.paymentReceivedHandlers.splice(idx, 1);\n };\n }\n\n /**\n * Register handler for payment timeout events\n */\n onPaymentTimeout(handler: (event: PaymentEvent) => Promise<void>): () => void {\n this.paymentTimeoutHandlers.push(handler);\n return () => {\n const idx = this.paymentTimeoutHandlers.indexOf(handler);\n if (idx > -1) this.paymentTimeoutHandlers.splice(idx, 1);\n };\n }\n\n /**\n * Register handler for payment failed events\n */\n onPaymentFailed(handler: (event: PaymentEvent) => Promise<void>): () => void {\n this.paymentFailedHandlers.push(handler);\n return () => {\n const idx = this.paymentFailedHandlers.indexOf(handler);\n if (idx > -1) this.paymentFailedHandlers.splice(idx, 1);\n };\n }\n\n /**\n * Process a verified payment and trigger handlers\n * \n * Call this from your request handler after verifying payment.\n */\n async processPayment<TInput = unknown>(params: {\n paymentId: string;\n txHash: string;\n amount: string;\n payerAddress: string;\n input: TInput;\n }): Promise<void> {\n const ctx: PaymentContext<TInput> = {\n paymentId: params.paymentId,\n txHash: params.txHash,\n amount: params.amount,\n payerAddress: params.payerAddress,\n input: params.input,\n timestamp: new Date(),\n deliver: async (output) => this.recordDelivery(params.paymentId, output),\n fail: async (reason, retryable) => this.recordFailure(params.paymentId, reason, retryable),\n };\n\n this.logger.info('Processing payment', { paymentId: params.paymentId, amount: params.amount });\n\n for (const handler of this.paymentReceivedHandlers) {\n try {\n await handler(ctx as PaymentContext);\n } catch (error) {\n this.logger.error('Payment handler error', error instanceof Error ? error : new Error(String(error)));\n await ctx.fail(error instanceof Error ? error.message : 'Handler error', true);\n }\n }\n }\n\n // ==========================================================================\n // DELIVERY PROOF - Sacred\n // ==========================================================================\n\n /**\n * Record a successful delivery\n * \n * Called automatically by ctx.deliver() or can be called directly.\n */\n async recordDelivery<T>(paymentId: string, output: DeliveryProof<T>): Promise<void> {\n const outcome: OutcomeRecord = {\n paymentId,\n outcomeType: 'delivered',\n latencyMs: output.latencyMs || 0,\n proofHash: output.proof,\n evidence: output.evidence,\n timestamp: new Date(),\n };\n\n this.outcomes.push(outcome);\n this.logger.info('Delivery recorded', { paymentId, proof: output.proof });\n this.logger.metric('delivery.success', 1, { paymentId });\n this.logger.metric('delivery.latency', output.latencyMs || 0, { paymentId });\n\n // Report to API\n await this.reportOutcome(outcome);\n }\n\n /**\n * Record a failure\n * \n * Called automatically by ctx.fail() or can be called directly.\n */\n async recordFailure(paymentId: string, reason: string, retryable?: boolean): Promise<void> {\n const outcome: OutcomeRecord = {\n paymentId,\n outcomeType: retryable ? 'partial' : 'failed',\n latencyMs: 0,\n evidence: { reason, retryable },\n timestamp: new Date(),\n };\n\n this.outcomes.push(outcome);\n this.logger.warn('Failure recorded', { paymentId, reason, retryable });\n this.logger.metric('delivery.failure', 1, { paymentId, reason });\n\n await this.reportOutcome(outcome);\n }\n\n private async reportOutcome(outcome: OutcomeRecord): Promise<void> {\n try {\n await fetch(`${this.apiUrl}/api/outcomes`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({\n paymentId: outcome.paymentId,\n outcomeType: outcome.outcomeType,\n latencyMs: outcome.latencyMs,\n proofHash: outcome.proofHash,\n evidence: outcome.evidence,\n }),\n });\n } catch (error) {\n this.logger.error('Failed to report outcome', error instanceof Error ? error : new Error(String(error)));\n }\n }\n\n // ==========================================================================\n // OBSERVABILITY - Built-in, not afterthought\n // ==========================================================================\n\n /**\n * Get current reputation\n */\n async getReputation(): Promise<ProviderReputation> {\n const ownerAddress = await this.getAddress();\n\n const response = await fetch(\n `${this.apiUrl}/api/services?ownerAddress=${ownerAddress}&limit=1`\n );\n\n if (!response.ok) {\n throw new Error('Failed to fetch reputation');\n }\n\n const data = await response.json();\n const service = data.services?.[0];\n\n if (!service) {\n return {\n reputationScore: 0,\n successRate: 0,\n totalDeliveries: 0,\n avgLatencyMs: 0,\n trend: 'stable',\n };\n }\n\n return {\n reputationScore: service.reputationScore || 0,\n successRate: service.successRate || 0,\n totalDeliveries: service.totalPayments || 0,\n avgLatencyMs: service.avgLatencyMs || 0,\n trend: service.trend || 'stable',\n rank: service.rank,\n percentile: service.percentile,\n };\n }\n\n /**\n * Get service metrics history\n */\n async getMetrics(serviceId: string, options: {\n from?: Date;\n to?: Date;\n interval?: '1h' | '1d' | '7d';\n } = {}): Promise<ServiceMetrics[]> {\n const params = new URLSearchParams();\n if (options.from) params.set('from', options.from.toISOString());\n if (options.to) params.set('to', options.to.toISOString());\n if (options.interval) params.set('interval', options.interval);\n\n const response = await fetch(\n `${this.apiUrl}/api/services/${serviceId}/metrics?${params}`\n );\n\n if (!response.ok) {\n throw new Error('Failed to fetch metrics');\n }\n\n const data = await response.json();\n return (data.data || []).map((m: Record<string, unknown>) => ({\n timestamp: new Date(m.timestamp as string),\n reputationScore: m.reputationScore as number || 0,\n successRate: m.successRate as number || 0,\n avgLatencyMs: m.avgLatencyMs as number || 0,\n totalCalls: m.totalCalls as number || 0,\n totalPayments: m.totalPayments as number || 0,\n totalRevenue: m.totalRevenue as string || '0',\n }));\n }\n\n /**\n * Get local outcome stats (in-memory)\n */\n getLocalStats(): {\n totalOutcomes: number;\n deliveries: number;\n failures: number;\n successRate: number;\n avgLatencyMs: number;\n } {\n const deliveries = this.outcomes.filter(o => o.outcomeType === 'delivered').length;\n const failures = this.outcomes.filter(o => o.outcomeType === 'failed').length;\n const total = this.outcomes.length;\n const avgLatency = total > 0\n ? this.outcomes.reduce((sum, o) => sum + o.latencyMs, 0) / total\n : 0;\n\n return {\n totalOutcomes: total,\n deliveries,\n failures,\n successRate: total > 0 ? deliveries / total : 0,\n avgLatencyMs: Math.round(avgLatency),\n };\n }\n\n /**\n * Get recent outcomes\n */\n getRecentOutcomes(limit: number = 10): OutcomeRecord[] {\n return this.outcomes.slice(-limit);\n }\n}\n\n// ============================================================================\n// EXPRESS MIDDLEWARE\n// ============================================================================\n\n/**\n * Create Express middleware for x402 payment handling\n * \n * @example\n * const paymentMiddleware = createPaymentMiddleware(provider, {\n * amount: \"0.01\",\n * description: \"API access\",\n * });\n * \n * app.use('/api/protected', paymentMiddleware, (req, res) => {\n * res.json({ data: 'protected data' });\n * });\n */\nexport function createPaymentMiddleware(\n provider: RelayService,\n options: {\n amount: string;\n description?: string;\n timeoutSeconds?: number;\n }\n) {\n return async (req: { headers: Record<string, string | undefined> }, res: {\n status: (code: number) => { json: (data: unknown) => void };\n }, next: () => void) => {\n const paymentId = req.headers['x-payment-id'];\n const paymentTx = req.headers['x-payment'];\n\n if (!paymentId || !paymentTx) {\n const requirements = await provider.createPaymentRequired({\n amount: options.amount,\n description: options.description,\n timeoutSeconds: options.timeoutSeconds,\n });\n return res.status(402).json(requirements);\n }\n\n // Verify payment\n const verification = await provider.verifyPayment(paymentId);\n\n if (!verification.verified) {\n return res.status(402).json({\n error: 'Payment not verified',\n status: verification.status,\n });\n }\n\n next();\n };\n}\n\n// ============================================================================\n// FACTORY & EXPORTS\n// ============================================================================\n\n/**\n * Create a Relay Service instance\n * \n * @example\n * const provider = createService({ wallet, network: \"cronos-testnet\" });\n */\nexport function createService(config: ServiceConfig): RelayService {\n return new RelayService(config);\n}\n\nexport default RelayService;\n","\n/**\n * Service Provider SDK\n * \n * For service providers to register services, handle payments,\n * and track their reputation on the Relay Core platform.\n */\n\n// Configuration for the SDK\nexport interface ProviderSDKConfig {\n apiUrl?: string;\n supabaseUrl?: string;\n supabaseKey?: string;\n}\n\n// Service registration parameters\nexport interface ServiceRegistration {\n name: string;\n description: string;\n category: string;\n endpointUrl: string;\n pricePerCall: string;\n inputSchema?: Record<string, unknown>;\n outputSchema?: Record<string, unknown>;\n inputType?: string;\n outputType?: string;\n tags?: string[];\n capabilities?: string[];\n}\n\n// Registered service response\nexport interface RegisteredService {\n id: string;\n name: string;\n endpointUrl: string;\n ownerAddress: string;\n createdAt: string;\n}\n\n// Reputation data\nexport interface ProviderReputation {\n reputationScore: number;\n successRate: number;\n totalPayments: number;\n avgLatencyMs: number;\n trend: 'improving' | 'stable' | 'declining';\n}\n\n// Payment received event\nexport interface PaymentReceived {\n paymentId: string;\n txHash: string;\n amount: string;\n payerAddress: string;\n timestamp: string;\n}\n\n// Metrics snapshot\nexport interface ServiceMetrics {\n timestamp: string;\n successRate: number;\n avgLatencyMs: number;\n callVolume: number;\n reputationScore: number;\n}\n\nconst DEFAULT_API_URL = 'https://api.relaycore.xyz';\n\nexport class ServiceProviderSDK {\n private apiUrl: string;\n private walletAddress: string;\n\n constructor(walletAddress: string, config: ProviderSDKConfig = {}) {\n this.walletAddress = walletAddress.toLowerCase();\n this.apiUrl = config.apiUrl || DEFAULT_API_URL;\n }\n\n /**\n * Register a new service\n */\n async registerService(service: ServiceRegistration): Promise<RegisteredService> {\n const response = await fetch(`${this.apiUrl}/api/services`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n ...service,\n ownerAddress: this.walletAddress,\n }),\n });\n\n if (!response.ok) {\n const error = await response.json();\n throw new Error(`Failed to register service: ${error.error || response.statusText}`);\n }\n\n const data = await response.json();\n return {\n id: data.id,\n name: data.name,\n endpointUrl: data.endpointUrl,\n ownerAddress: this.walletAddress,\n createdAt: new Date().toISOString(),\n };\n }\n\n /**\n * Update an existing service\n */\n async updateService(\n serviceId: string,\n updates: Partial<ServiceRegistration>\n ): Promise<void> {\n const response = await fetch(`${this.apiUrl}/api/services/${serviceId}`, {\n method: 'PUT',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(updates),\n });\n\n if (!response.ok) {\n const error = await response.json();\n throw new Error(`Failed to update service: ${error.error || response.statusText}`);\n }\n }\n\n /**\n * Deactivate a service\n */\n async deactivateService(serviceId: string): Promise<void> {\n await this.updateService(serviceId, { isActive: false } as any);\n }\n\n /**\n * Get current reputation\n */\n async getReputation(): Promise<ProviderReputation> {\n const response = await fetch(\n `${this.apiUrl}/api/services?ownerAddress=${this.walletAddress}&limit=1`\n );\n\n if (!response.ok) {\n throw new Error('Failed to fetch reputation');\n }\n\n const data = await response.json();\n const service = data.services?.[0];\n\n if (!service) {\n return {\n reputationScore: 0,\n successRate: 0,\n totalPayments: 0,\n avgLatencyMs: 0,\n trend: 'stable',\n };\n }\n\n return {\n reputationScore: service.reputationScore || 0,\n successRate: service.successRate || 0,\n totalPayments: service.totalPayments || 0,\n avgLatencyMs: service.avgLatencyMs || 0,\n trend: service.trend || 'stable',\n };\n }\n\n /**\n * Get service metrics history\n */\n async getMetricsHistory(\n serviceId: string,\n options: { from?: Date; to?: Date } = {}\n ): Promise<ServiceMetrics[]> {\n const params = new URLSearchParams();\n if (options.from) params.set('from', options.from.toISOString());\n if (options.to) params.set('to', options.to.toISOString());\n\n const response = await fetch(\n `${this.apiUrl}/api/services/${serviceId}/metrics?${params}`\n );\n\n if (!response.ok) {\n throw new Error('Failed to fetch metrics');\n }\n\n const data = await response.json();\n return data.data || [];\n }\n\n /**\n * Get all registered services for this provider\n */\n async getMyServices(): Promise<RegisteredService[]> {\n const response = await fetch(\n `${this.apiUrl}/api/services?ownerAddress=${this.walletAddress}`\n );\n\n if (!response.ok) {\n throw new Error('Failed to fetch services');\n }\n\n const data = await response.json();\n return (data.services || []).map((s: Record<string, unknown>) => ({\n id: s.id,\n name: s.name,\n endpointUrl: s.endpointUrl,\n ownerAddress: s.ownerAddress,\n createdAt: s.createdAt,\n }));\n }\n\n /**\n * Generate x402 payment requirements for an endpoint\n * Use this when building your service's 402 response\n */\n generatePaymentRequirements(params: {\n amount: string;\n resourceUrl: string;\n description?: string;\n timeoutSeconds?: number;\n }): {\n x402Version: number;\n paymentRequirements: {\n scheme: 'exact';\n network: string;\n payTo: string;\n asset: string;\n maxAmountRequired: string;\n maxTimeoutSeconds: number;\n description?: string;\n };\n } {\n return {\n x402Version: 1,\n paymentRequirements: {\n scheme: 'exact',\n network: 'cronos-mainnet',\n payTo: this.walletAddress,\n asset: '0xf951eC28187D9E5Ca673Da8FE6757E6f0Be5F77C', // USDC.e on Cronos\n maxAmountRequired: params.amount,\n maxTimeoutSeconds: params.timeoutSeconds || 60,\n description: params.description,\n },\n };\n }\n\n /**\n * Verify a payment was made (for use in your service)\n */\n async verifyPayment(paymentId: string): Promise<{\n verified: boolean;\n amount?: string;\n payerAddress?: string;\n }> {\n const response = await fetch(`${this.apiUrl}/api/payments/${paymentId}`);\n\n if (!response.ok) {\n return { verified: false };\n }\n\n const data = await response.json();\n return {\n verified: data.payment?.status === 'settled',\n amount: data.payment?.amount,\n payerAddress: data.payment?.payerAddress,\n };\n }\n\n /**\n * Record a service outcome (success or failure)\n * Call after each service invocation\n */\n async recordOutcome(params: {\n paymentId: string;\n outcomeType: 'delivered' | 'failed' | 'partial';\n latencyMs: number;\n evidence?: Record<string, unknown>;\n }): Promise<void> {\n const response = await fetch(`${this.apiUrl}/api/outcomes`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n paymentId: params.paymentId,\n outcomeType: params.outcomeType,\n latencyMs: params.latencyMs,\n evidence: params.evidence,\n }),\n });\n\n if (!response.ok) {\n console.error('Failed to record outcome');\n }\n }\n}\n\n/**\n * Create a Service Provider SDK instance\n */\nexport function createProviderSDK(\n walletAddress: string,\n config?: ProviderSDKConfig\n): ServiceProviderSDK {\n return new ServiceProviderSDK(walletAddress, config);\n}\n\nexport default ServiceProviderSDK;\n","import { ethers } from 'ethers';\n\n/**\n * Service Consumer SDK\n * \n * For agents and applications to discover services, make payments,\n * and consume services on the Relay Core platform.\n */\n\n// Configuration for the SDK\nexport interface ConsumerSDKConfig {\n apiUrl?: string;\n network?: 'testnet' | 'mainnet';\n}\n\n// Service query parameters\nexport interface ServiceQuery {\n category?: string;\n minReputation?: number;\n maxLatency?: number;\n maxPrice?: number;\n inputType?: string;\n outputType?: string;\n tags?: string[];\n capabilities?: string[];\n sortBy?: 'reputation' | 'latency' | 'price' | 'volume';\n limit?: number;\n}\n\n// Discovered service\nexport interface DiscoveredService {\n id: string;\n name: string;\n description: string;\n category: string;\n endpointUrl: string;\n pricePerCall: string;\n ownerAddress: string;\n reputationScore: number;\n successRate: number;\n avgLatencyMs: number;\n schema?: {\n inputType?: string;\n outputType?: string;\n tags?: string[];\n capabilities?: string[];\n };\n}\n\n// Payment result\nexport interface PaymentResult {\n paymentId: string;\n txHash: string;\n settled: boolean;\n}\n\n// Service call result\nexport interface ServiceCallResult<T = unknown> {\n success: boolean;\n data?: T;\n error?: string;\n paymentId?: string;\n latencyMs: number;\n}\n\n// Workflow step\nexport interface WorkflowStep {\n serviceId: string;\n serviceName: string;\n inputType: string;\n outputType: string;\n}\n\nconst DEFAULT_API_URL = 'https://api.relaycore.xyz';\nconst FACILITATOR_URL = 'https://facilitator.cronoslabs.org/v2/x402';\n\nexport class ServiceConsumerSDK {\n private apiUrl: string;\n private network: 'testnet' | 'mainnet';\n private signer: ethers.Signer | null = null;\n\n constructor(config: ConsumerSDKConfig = {}) {\n this.apiUrl = config.apiUrl || DEFAULT_API_URL;\n this.network = config.network || 'mainnet';\n }\n\n /**\n * Connect a signer for payment operations\n */\n connectSigner(signer: ethers.Signer): void {\n this.signer = signer;\n }\n\n /**\n * Discover services matching criteria\n */\n async discoverServices(query: ServiceQuery = {}): Promise<DiscoveredService[]> {\n const params = new URLSearchParams();\n\n if (query.category) params.set('category', query.category);\n if (query.minReputation) params.set('minReputation', query.minReputation.toString());\n if (query.maxLatency) params.set('maxLatency', query.maxLatency.toString());\n if (query.inputType) params.set('inputType', query.inputType);\n if (query.outputType) params.set('outputType', query.outputType);\n if (query.tags) params.set('tags', query.tags.join(','));\n if (query.capabilities) params.set('capabilities', query.capabilities.join(','));\n if (query.sortBy) params.set('sortBy', query.sortBy);\n if (query.limit) params.set('limit', query.limit.toString());\n\n const response = await fetch(`${this.apiUrl}/api/services?${params}`);\n\n if (!response.ok) {\n throw new Error('Failed to discover services');\n }\n\n const data = await response.json();\n return (data.services || []).map(this.formatService);\n }\n\n /**\n * Get service details\n */\n async getService(serviceId: string): Promise<DiscoveredService | null> {\n const response = await fetch(`${this.apiUrl}/api/services/${serviceId}`);\n\n if (!response.ok) {\n if (response.status === 404) return null;\n throw new Error('Failed to get service');\n }\n\n const data = await response.json();\n return this.formatService(data);\n }\n\n /**\n * Find services compatible with given input/output types\n */\n async findCompatibleServices(params: {\n inputType?: string;\n outputType?: string;\n tags?: string[];\n capabilities?: string[];\n }): Promise<DiscoveredService[]> {\n const query = new URLSearchParams();\n if (params.inputType) query.set('inputType', params.inputType);\n if (params.outputType) query.set('outputType', params.outputType);\n if (params.tags) query.set('tags', params.tags.join(','));\n if (params.capabilities) query.set('capabilities', params.capabilities.join(','));\n\n const response = await fetch(`${this.apiUrl}/api/schemas/compatible?${query}`);\n\n if (!response.ok) {\n throw new Error('Failed to find compatible services');\n }\n\n const data = await response.json();\n return (data.services || []).map(this.formatService);\n }\n\n /**\n * Suggest a workflow to transform input type to output type\n */\n async suggestWorkflow(params: {\n startInputType: string;\n endOutputType: string;\n maxSteps?: number;\n }): Promise<WorkflowStep[][]> {\n const query = new URLSearchParams({\n startInputType: params.startInputType,\n endOutputType: params.endOutputType,\n });\n if (params.maxSteps) query.set('maxSteps', params.maxSteps.toString());\n\n const response = await fetch(`${this.apiUrl}/api/schemas/workflow?${query}`);\n\n if (!response.ok) {\n throw new Error('Failed to suggest workflow');\n }\n\n const data = await response.json();\n return data.workflows || [];\n }\n\n /**\n * Call a service with automatic payment handling\n */\n async callService<T = unknown>(params: {\n serviceId: string;\n endpoint?: string;\n method?: 'GET' | 'POST';\n body?: unknown;\n headers?: Record<string, string>;\n }): Promise<ServiceCallResult<T>> {\n const startTime = performance.now();\n\n if (!this.signer) {\n throw new Error('Signer not connected. Call connectSigner first.');\n }\n\n // Get service details if needed\n let endpoint = params.endpoint;\n if (!endpoint) {\n const service = await this.getService(params.serviceId);\n if (!service) {\n return {\n success: false,\n error: 'Service not found',\n latencyMs: Math.round(performance.now() - startTime),\n };\n }\n endpoint = service.endpointUrl;\n }\n\n // Initial request\n let response = await fetch(endpoint, {\n method: params.method || 'GET',\n headers: {\n 'Content-Type': 'application/json',\n ...params.headers,\n },\n body: params.body ? JSON.stringify(params.body) : undefined,\n });\n\n let paymentId: string | undefined;\n\n // Handle 402 Payment Required\n if (response.status === 402) {\n const paymentRequired = await response.json();\n const requirements = paymentRequired.paymentRequirements;\n\n if (!requirements) {\n return {\n success: false,\n error: 'Invalid payment requirements',\n latencyMs: Math.round(performance.now() - startTime),\n };\n }\n\n // Make payment via facilitator\n const paymentResult = await this.makePayment({\n to: requirements.payTo,\n amount: requirements.maxAmountRequired,\n asset: requirements.asset,\n });\n\n paymentId = paymentResult.paymentId;\n\n // Retry with payment header\n response = await fetch(endpoint, {\n method: params.method || 'GET',\n headers: {\n 'Content-Type': 'application/json',\n 'X-Payment': paymentResult.txHash,\n 'X-Payment-Id': paymentId,\n ...params.headers,\n },\n body: params.body ? JSON.stringify(params.body) : undefined,\n });\n }\n\n const latencyMs = Math.round(performance.now() - startTime);\n\n if (!response.ok) {\n return {\n success: false,\n error: `Service returned ${response.status}: ${response.statusText}`,\n paymentId,\n latencyMs,\n };\n }\n\n const data = await response.json();\n return {\n success: true,\n data,\n paymentId,\n latencyMs,\n };\n }\n\n /**\n * Make a direct payment to a service provider\n */\n async makePayment(params: {\n to: string;\n amount: string;\n asset?: string;\n }): Promise<PaymentResult> {\n if (!this.signer) {\n throw new Error('Signer not connected');\n }\n\n const signerAddress = await this.signer.getAddress();\n\n // EIP-3009 authorization for USDC transfer\n const domain = {\n name: 'USD Coin',\n version: '2',\n chainId: this.network === 'mainnet' ? 25 : 338,\n verifyingContract: params.asset || '0xf951eC28187D9E5Ca673Da8FE6757E6f0Be5F77C',\n };\n\n const types = {\n TransferWithAuthorization: [\n { name: 'from', type: 'address' },\n { name: 'to', type: 'address' },\n { name: 'value', type: 'uint256' },\n { name: 'validAfter', type: 'uint256' },\n { name: 'validBefore', type: 'uint256' },\n { name: 'nonce', type: 'bytes32' },\n ],\n };\n\n const nonce = ethers.hexlify(ethers.randomBytes(32));\n const validAfter = 0;\n const validBefore = Math.floor(Date.now() / 1000) + 3600;\n\n const value = {\n from: signerAddress,\n to: params.to,\n value: ethers.parseUnits(params.amount, 6),\n validAfter,\n validBefore,\n nonce,\n };\n\n // Sign authorization\n const signature = await (this.signer as ethers.Signer & {\n signTypedData: (\n domain: typeof domain,\n types: typeof types,\n value: typeof value\n ) => Promise<string>;\n }).signTypedData(domain, types, value);\n\n // Submit to facilitator\n const response = await fetch(`${FACILITATOR_URL}/settle`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n from: signerAddress,\n to: params.to,\n value: params.amount,\n validAfter,\n validBefore,\n nonce,\n signature,\n network: this.network === 'mainnet' ? 'cronos-mainnet' : 'cronos-testnet',\n }),\n });\n\n if (!response.ok) {\n throw new Error('Payment failed');\n }\n\n const result = await response.json();\n return {\n paymentId: `pay_${result.txHash?.slice(2, 18) || Date.now()}`,\n txHash: result.txHash || '',\n settled: result.success || false,\n };\n }\n\n /**\n * Get service dependencies graph\n */\n async getServiceGraph(serviceId: string): Promise<{\n dependencies: Array<{ serviceId: string; callCount: number }>;\n dependents: Array<{ serviceId: string; callCount: number }>;\n }> {\n const [depsResponse, deptsResponse] = await Promise.all([\n fetch(`${this.apiUrl}/api/services/${serviceId}/dependencies`),\n fetch(`${this.apiUrl}/api/services/${serviceId}/dependents`),\n ]);\n\n const dependencies = depsResponse.ok\n ? (await depsResponse.json()).dependencies\n : [];\n const dependents = deptsResponse.ok\n ? (await deptsResponse.json()).dependents\n : [];\n\n return { dependencies, dependents };\n }\n\n /**\n * Find path between two services\n */\n async findServicePath(\n fromServiceId: string,\n toServiceId: string\n ): Promise<{\n path: string[];\n totalLatency: number;\n } | null> {\n const response = await fetch(\n `${this.apiUrl}/api/graph/path?from=${fromServiceId}&to=${toServiceId}`\n );\n\n if (!response.ok) {\n return null;\n }\n\n const data = await response.json();\n return data.shortestPath || null;\n }\n\n private formatService(s: Record<string, unknown>): DiscoveredService {\n return {\n id: s.id as string,\n name: s.name as string,\n description: s.description as string,\n category: s.category as string,\n endpointUrl: s.endpointUrl as string,\n pricePerCall: s.pricePerCall as string,\n ownerAddress: s.ownerAddress as string,\n reputationScore: (s.reputationScore as number) || 0,\n successRate: (s.successRate as number) || 0,\n avgLatencyMs: (s.avgLatencyMs as number) || 0,\n schema: s.schema as DiscoveredService['schema'],\n };\n }\n}\n\n/**\n * Create a Service Consumer SDK instance\n */\nexport function createConsumerSDK(config?: ConsumerSDKConfig): ServiceConsumerSDK {\n return new ServiceConsumerSDK(config);\n}\n\nexport default ServiceConsumerSDK;\n","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nvar ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose, inner;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n if (async) inner = dispose;\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n var r, s = 0;\n function next() {\n while (r = env.stack.pop()) {\n try {\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\n if (r.dispose) {\n var result = r.dispose.call(r.value);\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n else s |= 1;\n }\n catch (e) {\n fail(e);\n }\n }\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\n });\n }\n return path;\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __esDecorate,\n __runInitializers,\n __propKey,\n __setFunctionName,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n __rewriteRelativeImportExtension,\n};\n","import { Fetch } from './types'\n\nexport const resolveFetch = (customFetch?: Fetch): Fetch => {\n if (customFetch) {\n return (...args) => customFetch(...args)\n }\n return (...args) => fetch(...args)\n}\n","export type Fetch = typeof fetch\n\n/**\n * Response format\n */\nexport interface FunctionsResponseSuccess<T> {\n data: T\n error: null\n response?: Response\n}\nexport interface FunctionsResponseFailure {\n data: null\n error: any\n response?: Response\n}\nexport type FunctionsResponse<T> = FunctionsResponseSuccess<T> | FunctionsResponseFailure\n\n/**\n * Base error for Supabase Edge Function invocations.\n *\n * @example\n * ```ts\n * import { FunctionsError } from '@supabase/functions-js'\n *\n * throw new FunctionsError('Unexpected error invoking function', 'FunctionsError', {\n * requestId: 'abc123',\n * })\n * ```\n */\nexport class FunctionsError extends Error {\n context: any\n constructor(message: string, name = 'FunctionsError', context?: any) {\n super(message)\n this.name = name\n this.context = context\n }\n}\n\n/**\n * Error thrown when the network request to an Edge Function fails.\n *\n * @example\n * ```ts\n * import { FunctionsFetchError } from '@supabase/functions-js'\n *\n * throw new FunctionsFetchError({ requestId: 'abc123' })\n * ```\n */\nexport class FunctionsFetchError extends FunctionsError {\n constructor(context: any) {\n super('Failed to send a request to the Edge Function', 'FunctionsFetchError', context)\n }\n}\n\n/**\n * Error thrown when the Supabase relay cannot reach the Edge Function.\n *\n * @example\n * ```ts\n * import { FunctionsRelayError } from '@supabase/functions-js'\n *\n * throw new FunctionsRelayError({ region: 'us-east-1' })\n * ```\n */\nexport class FunctionsRelayError extends FunctionsError {\n constructor(context: any) {\n super('Relay Error invoking the Edge Function', 'FunctionsRelayError', context)\n }\n}\n\n/**\n * Error thrown when the Edge Function returns a non-2xx status code.\n *\n * @example\n * ```ts\n * import { FunctionsHttpError } from '@supabase/functions-js'\n *\n * throw new FunctionsHttpError({ status: 500 })\n * ```\n */\nexport class FunctionsHttpError extends FunctionsError {\n constructor(context: any) {\n super('Edge Function returned a non-2xx status code', 'FunctionsHttpError', context)\n }\n}\n// Define the enum for the 'region' property\nexport enum FunctionRegion {\n Any = 'any',\n ApNortheast1 = 'ap-northeast-1',\n ApNortheast2 = 'ap-northeast-2',\n ApSouth1 = 'ap-south-1',\n ApSoutheast1 = 'ap-southeast-1',\n ApSoutheast2 = 'ap-southeast-2',\n CaCentral1 = 'ca-central-1',\n EuCentral1 = 'eu-central-1',\n EuWest1 = 'eu-west-1',\n EuWest2 = 'eu-west-2',\n EuWest3 = 'eu-west-3',\n SaEast1 = 'sa-east-1',\n UsEast1 = 'us-east-1',\n UsWest1 = 'us-west-1',\n UsWest2 = 'us-west-2',\n}\n\nexport type FunctionInvokeOptions = {\n /**\n * Object representing the headers to send with the request.\n */\n headers?: { [key: string]: string }\n /**\n * The HTTP verb of the request\n */\n method?: 'POST' | 'GET' | 'PUT' | 'PATCH' | 'DELETE'\n /**\n * The Region to invoke the function in.\n */\n region?: FunctionRegion\n /**\n * The body of the request.\n */\n body?:\n | File\n | Blob\n | ArrayBuffer\n | FormData\n | ReadableStream<Uint8Array>\n | Record<string, any>\n | string\n /**\n * The AbortSignal to use for the request.\n * */\n signal?: AbortSignal\n /**\n * The timeout for the request in milliseconds.\n * If the function takes longer than this, the request will be aborted.\n * */\n timeout?: number\n}\n","import { resolveFetch } from './helper'\nimport {\n Fetch,\n FunctionInvokeOptions,\n FunctionRegion,\n FunctionsFetchError,\n FunctionsHttpError,\n FunctionsRelayError,\n FunctionsResponse,\n} from './types'\n\n/**\n * Client for invoking Supabase Edge Functions.\n */\nexport class FunctionsClient {\n protected url: string\n protected headers: Record<string, string>\n protected region: FunctionRegion\n protected fetch: Fetch\n\n /**\n * Creates a new Functions client bound to an Edge Functions URL.\n *\n * @example\n * ```ts\n * import { FunctionsClient, FunctionRegion } from '@supabase/functions-js'\n *\n * const functions = new FunctionsClient('https://xyzcompany.supabase.co/functions/v1', {\n * headers: { apikey: 'public-anon-key' },\n * region: FunctionRegion.UsEast1,\n * })\n * ```\n */\n constructor(\n url: string,\n {\n headers = {},\n customFetch,\n region = FunctionRegion.Any,\n }: {\n headers?: Record<string, string>\n customFetch?: Fetch\n region?: FunctionRegion\n } = {}\n ) {\n this.url = url\n this.headers = headers\n this.region = region\n this.fetch = resolveFetch(customFetch)\n }\n\n /**\n * Updates the authorization header\n * @param token - the new jwt token sent in the authorisation header\n * @example\n * ```ts\n * functions.setAuth(session.access_token)\n * ```\n */\n setAuth(token: string) {\n this.headers.Authorization = `Bearer ${token}`\n }\n\n /**\n * Invokes a function\n * @param functionName - The name of the Function to invoke.\n * @param options - Options for invoking the Function.\n * @example\n * ```ts\n * const { data, error } = await functions.invoke('hello-world', {\n * body: { name: 'Ada' },\n * })\n * ```\n */\n async invoke<T = any>(\n functionName: string,\n options: FunctionInvokeOptions = {}\n ): Promise<FunctionsResponse<T>> {\n let timeoutId: ReturnType<typeof setTimeout> | undefined\n let timeoutController: AbortController | undefined\n\n try {\n const { headers, method, body: functionArgs, signal, timeout } = options\n let _headers: Record<string, string> = {}\n let { region } = options\n if (!region) {\n region = this.region\n }\n // Add region as query parameter using URL API\n const url = new URL(`${this.url}/${functionName}`)\n if (region && region !== 'any') {\n _headers['x-region'] = region\n url.searchParams.set('forceFunctionRegion', region)\n }\n let body: any\n if (\n functionArgs &&\n ((headers && !Object.prototype.hasOwnProperty.call(headers, 'Content-Type')) || !headers)\n ) {\n if (\n (typeof Blob !== 'undefined' && functionArgs instanceof Blob) ||\n functionArgs instanceof ArrayBuffer\n ) {\n // will work for File as File inherits Blob\n // also works for ArrayBuffer as it is the same underlying structure as a Blob\n _headers['Content-Type'] = 'application/octet-stream'\n body = functionArgs\n } else if (typeof functionArgs === 'string') {\n // plain string\n _headers['Content-Type'] = 'text/plain'\n body = functionArgs\n } else if (typeof FormData !== 'undefined' && functionArgs instanceof FormData) {\n // don't set content-type headers\n // Request will automatically add the right boundary value\n body = functionArgs\n } else {\n // default, assume this is JSON\n _headers['Content-Type'] = 'application/json'\n body = JSON.stringify(functionArgs)\n }\n } else {\n if (\n functionArgs &&\n typeof functionArgs !== 'string' &&\n !(typeof Blob !== 'undefined' && functionArgs instanceof Blob) &&\n !(functionArgs instanceof ArrayBuffer) &&\n !(typeof FormData !== 'undefined' && functionArgs instanceof FormData)\n ) {\n body = JSON.stringify(functionArgs)\n } else {\n body = functionArgs\n }\n }\n\n // Handle timeout by creating an AbortController\n let effectiveSignal = signal\n if (timeout) {\n timeoutController = new AbortController()\n timeoutId = setTimeout(() => timeoutController!.abort(), timeout)\n\n // If user provided their own signal, we need to respect both\n if (signal) {\n effectiveSignal = timeoutController.signal\n // If the user's signal is aborted, abort our timeout controller too\n signal.addEventListener('abort', () => timeoutController!.abort())\n } else {\n effectiveSignal = timeoutController.signal\n }\n }\n\n const response = await this.fetch(url.toString(), {\n method: method || 'POST',\n // headers priority is (high to low):\n // 1. invoke-level headers\n // 2. client-level headers\n // 3. default Content-Type header\n headers: { ..._headers, ...this.headers, ...headers },\n body,\n signal: effectiveSignal,\n }).catch((fetchError) => {\n throw new FunctionsFetchError(fetchError)\n })\n\n const isRelayError = response.headers.get('x-relay-error')\n if (isRelayError && isRelayError === 'true') {\n throw new FunctionsRelayError(response)\n }\n\n if (!response.ok) {\n throw new FunctionsHttpError(response)\n }\n\n let responseType = (response.headers.get('Content-Type') ?? 'text/plain').split(';')[0].trim()\n let data: any\n if (responseType === 'application/json') {\n data = await response.json()\n } else if (\n responseType === 'application/octet-stream' ||\n responseType === 'application/pdf'\n ) {\n data = await response.blob()\n } else if (responseType === 'text/event-stream') {\n data = response\n } else if (responseType === 'multipart/form-data') {\n data = await response.formData()\n } else {\n // default to text\n data = await response.text()\n }\n\n return { data, error: null, response }\n } catch (error) {\n return {\n data: null,\n error,\n response:\n error instanceof FunctionsHttpError || error instanceof FunctionsRelayError\n ? error.context\n : undefined,\n }\n } finally {\n // Clear the timeout if it was set\n if (timeoutId) {\n clearTimeout(timeoutId)\n }\n }\n }\n}\n","/**\n * Error format\n *\n * {@link https://postgrest.org/en/stable/api.html?highlight=options#errors-and-http-status-codes}\n */\nexport default class PostgrestError extends Error {\n details: string\n hint: string\n code: string\n\n /**\n * @example\n * ```ts\n * import PostgrestError from '@supabase/postgrest-js'\n *\n * throw new PostgrestError({\n * message: 'Row level security prevented the request',\n * details: 'RLS denied the insert',\n * hint: 'Check your policies',\n * code: 'PGRST301',\n * })\n * ```\n */\n constructor(context: { message: string; details: string; hint: string; code: string }) {\n super(context.message)\n this.name = 'PostgrestError'\n this.details = context.details\n this.hint = context.hint\n this.code = context.code\n }\n}\n","import type {\n PostgrestSingleResponse,\n PostgrestResponseSuccess,\n CheckMatchingArrayTypes,\n MergePartialResult,\n IsValidResultOverride,\n} from './types/types'\nimport { ClientServerOptions, Fetch } from './types/common/common'\nimport PostgrestError from './PostgrestError'\nimport { ContainsNull } from './select-query-parser/types'\n\nexport default abstract class PostgrestBuilder<\n ClientOptions extends ClientServerOptions,\n Result,\n ThrowOnError extends boolean = false,\n> implements\n PromiseLike<\n ThrowOnError extends true ? PostgrestResponseSuccess<Result> : PostgrestSingleResponse<Result>\n >\n{\n protected method: 'GET' | 'HEAD' | 'POST' | 'PATCH' | 'DELETE'\n protected url: URL\n protected headers: Headers\n protected schema?: string\n protected body?: unknown\n protected shouldThrowOnError = false\n protected signal?: AbortSignal\n protected fetch: Fetch\n protected isMaybeSingle: boolean\n\n /**\n * Creates a builder configured for a specific PostgREST request.\n *\n * @example\n * ```ts\n * import PostgrestQueryBuilder from '@supabase/postgrest-js'\n *\n * const builder = new PostgrestQueryBuilder(\n * new URL('https://xyzcompany.supabase.co/rest/v1/users'),\n * { headers: new Headers({ apikey: 'public-anon-key' }) }\n * )\n * ```\n */\n constructor(builder: {\n method: 'GET' | 'HEAD' | 'POST' | 'PATCH' | 'DELETE'\n url: URL\n headers: HeadersInit\n schema?: string\n body?: unknown\n shouldThrowOnError?: boolean\n signal?: AbortSignal\n fetch?: Fetch\n isMaybeSingle?: boolean\n }) {\n this.method = builder.method\n this.url = builder.url\n this.headers = new Headers(builder.headers)\n this.schema = builder.schema\n this.body = builder.body\n this.shouldThrowOnError = builder.shouldThrowOnError ?? false\n this.signal = builder.signal\n this.isMaybeSingle = builder.isMaybeSingle ?? false\n\n if (builder.fetch) {\n this.fetch = builder.fetch\n } else {\n this.fetch = fetch\n }\n }\n\n /**\n * If there's an error with the query, throwOnError will reject the promise by\n * throwing the error instead of returning it as part of a successful response.\n *\n * {@link https://github.com/supabase/supabase-js/issues/92}\n */\n throwOnError(): this & PostgrestBuilder<ClientOptions, Result, true> {\n this.shouldThrowOnError = true\n return this as this & PostgrestBuilder<ClientOptions, Result, true>\n }\n\n /**\n * Set an HTTP header for the request.\n */\n setHeader(name: string, value: string): this {\n this.headers = new Headers(this.headers)\n this.headers.set(name, value)\n return this\n }\n\n then<\n TResult1 = ThrowOnError extends true\n ? PostgrestResponseSuccess<Result>\n : PostgrestSingleResponse<Result>,\n TResult2 = never,\n >(\n onfulfilled?:\n | ((\n value: ThrowOnError extends true\n ? PostgrestResponseSuccess<Result>\n : PostgrestSingleResponse<Result>\n ) => TResult1 | PromiseLike<TResult1>)\n | undefined\n | null,\n onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null\n ): PromiseLike<TResult1 | TResult2> {\n // https://postgrest.org/en/stable/api.html#switching-schemas\n if (this.schema === undefined) {\n // skip\n } else if (['GET', 'HEAD'].includes(this.method)) {\n this.headers.set('Accept-Profile', this.schema)\n } else {\n this.headers.set('Content-Profile', this.schema)\n }\n if (this.method !== 'GET' && this.method !== 'HEAD') {\n this.headers.set('Content-Type', 'application/json')\n }\n\n // NOTE: Invoke w/o `this` to avoid illegal invocation error.\n // https://github.com/supabase/postgrest-js/pull/247\n const _fetch = this.fetch\n let res = _fetch(this.url.toString(), {\n method: this.method,\n headers: this.headers,\n body: JSON.stringify(this.body),\n signal: this.signal,\n }).then(async (res) => {\n let error = null\n let data = null\n let count: number | null = null\n let status = res.status\n let statusText = res.statusText\n\n if (res.ok) {\n if (this.method !== 'HEAD') {\n const body = await res.text()\n if (body === '') {\n // Prefer: return=minimal\n } else if (this.headers.get('Accept') === 'text/csv') {\n data = body\n } else if (\n this.headers.get('Accept') &&\n this.headers.get('Accept')?.includes('application/vnd.pgrst.plan+text')\n ) {\n data = body\n } else {\n data = JSON.parse(body)\n }\n }\n\n const countHeader = this.headers.get('Prefer')?.match(/count=(exact|planned|estimated)/)\n const contentRange = res.headers.get('content-range')?.split('/')\n if (countHeader && contentRange && contentRange.length > 1) {\n count = parseInt(contentRange[1])\n }\n\n // Temporary partial fix for https://github.com/supabase/postgrest-js/issues/361\n // Issue persists e.g. for `.insert([...]).select().maybeSingle()`\n if (this.isMaybeSingle && this.method === 'GET' && Array.isArray(data)) {\n if (data.length > 1) {\n error = {\n // https://github.com/PostgREST/postgrest/blob/a867d79c42419af16c18c3fb019eba8df992626f/src/PostgREST/Error.hs#L553\n code: 'PGRST116',\n details: `Results contain ${data.length} rows, application/vnd.pgrst.object+json requires 1 row`,\n hint: null,\n message: 'JSON object requested, multiple (or no) rows returned',\n }\n data = null\n count = null\n status = 406\n statusText = 'Not Acceptable'\n } else if (data.length === 1) {\n data = data[0]\n } else {\n data = null\n }\n }\n } else {\n const body = await res.text()\n\n try {\n error = JSON.parse(body)\n\n // Workaround for https://github.com/supabase/postgrest-js/issues/295\n if (Array.isArray(error) && res.status === 404) {\n data = []\n error = null\n status = 200\n statusText = 'OK'\n }\n } catch {\n // Workaround for https://github.com/supabase/postgrest-js/issues/295\n if (res.status === 404 && body === '') {\n status = 204\n statusText = 'No Content'\n } else {\n error = {\n message: body,\n }\n }\n }\n\n if (error && this.isMaybeSingle && error?.details?.includes('0 rows')) {\n error = null\n status = 200\n statusText = 'OK'\n }\n\n if (error && this.shouldThrowOnError) {\n throw new PostgrestError(error)\n }\n }\n\n const postgrestResponse = {\n error,\n data,\n count,\n status,\n statusText,\n }\n\n return postgrestResponse\n })\n if (!this.shouldThrowOnError) {\n res = res.catch((fetchError) => {\n // Build detailed error information including cause if available\n // Note: We don't populate code/hint for client-side network errors since those\n // fields are meant for upstream service errors (PostgREST/PostgreSQL)\n let errorDetails = ''\n\n // Add cause information if available (e.g., DNS errors, network failures)\n const cause = fetchError?.cause\n if (cause) {\n const causeMessage = cause?.message ?? ''\n const causeCode = cause?.code ?? ''\n\n errorDetails = `${fetchError?.name ?? 'FetchError'}: ${fetchError?.message}`\n errorDetails += `\\n\\nCaused by: ${cause?.name ?? 'Error'}: ${causeMessage}`\n if (causeCode) {\n errorDetails += ` (${causeCode})`\n }\n if (cause?.stack) {\n errorDetails += `\\n${cause.stack}`\n }\n } else {\n // No cause available, just include the error stack\n errorDetails = fetchError?.stack ?? ''\n }\n\n return {\n error: {\n message: `${fetchError?.name ?? 'FetchError'}: ${fetchError?.message}`,\n details: errorDetails,\n hint: '',\n code: '',\n },\n data: null,\n count: null,\n status: 0,\n statusText: '',\n }\n })\n }\n\n return res.then(onfulfilled, onrejected)\n }\n\n /**\n * Override the type of the returned `data`.\n *\n * @typeParam NewResult - The new result type to override with\n * @deprecated Use overrideTypes<yourType, { merge: false }>() method at the end of your call chain instead\n */\n returns<NewResult>(): PostgrestBuilder<\n ClientOptions,\n CheckMatchingArrayTypes<Result, NewResult>,\n ThrowOnError\n > {\n /* istanbul ignore next */\n return this as unknown as PostgrestBuilder<\n ClientOptions,\n CheckMatchingArrayTypes<Result, NewResult>,\n ThrowOnError\n >\n }\n\n /**\n * Override the type of the returned `data` field in the response.\n *\n * @typeParam NewResult - The new type to cast the response data to\n * @typeParam Options - Optional type configuration (defaults to { merge: true })\n * @typeParam Options.merge - When true, merges the new type with existing return type. When false, replaces the existing types entirely (defaults to true)\n * @example\n * ```typescript\n * // Merge with existing types (default behavior)\n * const query = supabase\n * .from('users')\n * .select()\n * .overrideTypes<{ custom_field: string }>()\n *\n * // Replace existing types completely\n * const replaceQuery = supabase\n * .from('users')\n * .select()\n * .overrideTypes<{ id: number; name: string }, { merge: false }>()\n * ```\n * @returns A PostgrestBuilder instance with the new type\n */\n overrideTypes<\n NewResult,\n Options extends { merge?: boolean } = { merge: true },\n >(): PostgrestBuilder<\n ClientOptions,\n IsValidResultOverride<Result, NewResult, false, false> extends true\n ? // Preserve the optionality of the result if the overriden type is an object (case of chaining with `maybeSingle`)\n ContainsNull<Result> extends true\n ? MergePartialResult<NewResult, NonNullable<Result>, Options> | null\n : MergePartialResult<NewResult, Result, Options>\n : CheckMatchingArrayTypes<Result, NewResult>,\n ThrowOnError\n > {\n return this as unknown as PostgrestBuilder<\n ClientOptions,\n IsValidResultOverride<Result, NewResult, false, false> extends true\n ? // Preserve the optionality of the result if the overriden type is an object (case of chaining with `maybeSingle`)\n ContainsNull<Result> extends true\n ? MergePartialResult<NewResult, NonNullable<Result>, Options> | null\n : MergePartialResult<NewResult, Result, Options>\n : CheckMatchingArrayTypes<Result, NewResult>,\n ThrowOnError\n >\n }\n}\n","import PostgrestBuilder from './PostgrestBuilder'\nimport PostgrestFilterBuilder, { InvalidMethodError } from './PostgrestFilterBuilder'\nimport { GetResult } from './select-query-parser/result'\nimport { CheckMatchingArrayTypes } from './types/types'\nimport { ClientServerOptions, GenericSchema } from './types/common/common'\nimport type { MaxAffectedEnabled } from './types/feature-flags'\n\nexport default class PostgrestTransformBuilder<\n ClientOptions extends ClientServerOptions,\n Schema extends GenericSchema,\n Row extends Record<string, unknown>,\n Result,\n RelationName = unknown,\n Relationships = unknown,\n Method = unknown,\n> extends PostgrestBuilder<ClientOptions, Result> {\n /**\n * Perform a SELECT on the query result.\n *\n * By default, `.insert()`, `.update()`, `.upsert()`, and `.delete()` do not\n * return modified rows. By calling this method, modified rows are returned in\n * `data`.\n *\n * @param columns - The columns to retrieve, separated by commas\n */\n select<\n Query extends string = '*',\n NewResultOne = GetResult<Schema, Row, RelationName, Relationships, Query, ClientOptions>,\n >(\n columns?: Query\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Row,\n Method extends 'RPC'\n ? Result extends unknown[]\n ? NewResultOne[]\n : NewResultOne\n : NewResultOne[],\n RelationName,\n Relationships,\n Method\n > {\n // Remove whitespaces except when quoted\n let quoted = false\n const cleanedColumns = (columns ?? '*')\n .split('')\n .map((c) => {\n if (/\\s/.test(c) && !quoted) {\n return ''\n }\n if (c === '\"') {\n quoted = !quoted\n }\n return c\n })\n .join('')\n this.url.searchParams.set('select', cleanedColumns)\n this.headers.append('Prefer', 'return=representation')\n return this as unknown as PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Row,\n Method extends 'RPC'\n ? Result extends unknown[]\n ? NewResultOne[]\n : NewResultOne\n : NewResultOne[],\n RelationName,\n Relationships,\n Method\n >\n }\n\n order<ColumnName extends string & keyof Row>(\n column: ColumnName,\n options?: { ascending?: boolean; nullsFirst?: boolean; referencedTable?: undefined }\n ): this\n order(\n column: string,\n options?: { ascending?: boolean; nullsFirst?: boolean; referencedTable?: string }\n ): this\n /**\n * @deprecated Use `options.referencedTable` instead of `options.foreignTable`\n */\n order<ColumnName extends string & keyof Row>(\n column: ColumnName,\n options?: { ascending?: boolean; nullsFirst?: boolean; foreignTable?: undefined }\n ): this\n /**\n * @deprecated Use `options.referencedTable` instead of `options.foreignTable`\n */\n order(\n column: string,\n options?: { ascending?: boolean; nullsFirst?: boolean; foreignTable?: string }\n ): this\n /**\n * Order the query result by `column`.\n *\n * You can call this method multiple times to order by multiple columns.\n *\n * You can order referenced tables, but it only affects the ordering of the\n * parent table if you use `!inner` in the query.\n *\n * @param column - The column to order by\n * @param options - Named parameters\n * @param options.ascending - If `true`, the result will be in ascending order\n * @param options.nullsFirst - If `true`, `null`s appear first. If `false`,\n * `null`s appear last.\n * @param options.referencedTable - Set this to order a referenced table by\n * its columns\n * @param options.foreignTable - Deprecated, use `options.referencedTable`\n * instead\n */\n order(\n column: string,\n {\n ascending = true,\n nullsFirst,\n foreignTable,\n referencedTable = foreignTable,\n }: {\n ascending?: boolean\n nullsFirst?: boolean\n foreignTable?: string\n referencedTable?: string\n } = {}\n ): this {\n const key = referencedTable ? `${referencedTable}.order` : 'order'\n const existingOrder = this.url.searchParams.get(key)\n\n this.url.searchParams.set(\n key,\n `${existingOrder ? `${existingOrder},` : ''}${column}.${ascending ? 'asc' : 'desc'}${\n nullsFirst === undefined ? '' : nullsFirst ? '.nullsfirst' : '.nullslast'\n }`\n )\n return this\n }\n\n /**\n * Limit the query result by `count`.\n *\n * @param count - The maximum number of rows to return\n * @param options - Named parameters\n * @param options.referencedTable - Set this to limit rows of referenced\n * tables instead of the parent table\n * @param options.foreignTable - Deprecated, use `options.referencedTable`\n * instead\n */\n limit(\n count: number,\n {\n foreignTable,\n referencedTable = foreignTable,\n }: { foreignTable?: string; referencedTable?: string } = {}\n ): this {\n const key = typeof referencedTable === 'undefined' ? 'limit' : `${referencedTable}.limit`\n this.url.searchParams.set(key, `${count}`)\n return this\n }\n\n /**\n * Limit the query result by starting at an offset `from` and ending at the offset `to`.\n * Only records within this range are returned.\n * This respects the query order and if there is no order clause the range could behave unexpectedly.\n * The `from` and `to` values are 0-based and inclusive: `range(1, 3)` will include the second, third\n * and fourth rows of the query.\n *\n * @param from - The starting index from which to limit the result\n * @param to - The last index to which to limit the result\n * @param options - Named parameters\n * @param options.referencedTable - Set this to limit rows of referenced\n * tables instead of the parent table\n * @param options.foreignTable - Deprecated, use `options.referencedTable`\n * instead\n */\n range(\n from: number,\n to: number,\n {\n foreignTable,\n referencedTable = foreignTable,\n }: { foreignTable?: string; referencedTable?: string } = {}\n ): this {\n const keyOffset =\n typeof referencedTable === 'undefined' ? 'offset' : `${referencedTable}.offset`\n const keyLimit = typeof referencedTable === 'undefined' ? 'limit' : `${referencedTable}.limit`\n this.url.searchParams.set(keyOffset, `${from}`)\n // Range is inclusive, so add 1\n this.url.searchParams.set(keyLimit, `${to - from + 1}`)\n return this\n }\n\n /**\n * Set the AbortSignal for the fetch request.\n *\n * @param signal - The AbortSignal to use for the fetch request\n */\n abortSignal(signal: AbortSignal): this {\n this.signal = signal\n return this\n }\n\n /**\n * Return `data` as a single object instead of an array of objects.\n *\n * Query result must be one row (e.g. using `.limit(1)`), otherwise this\n * returns an error.\n */\n single<ResultOne = Result extends (infer ResultOne)[] ? ResultOne : never>(): PostgrestBuilder<\n ClientOptions,\n ResultOne\n > {\n this.headers.set('Accept', 'application/vnd.pgrst.object+json')\n return this as unknown as PostgrestBuilder<ClientOptions, ResultOne>\n }\n\n /**\n * Return `data` as a single object instead of an array of objects.\n *\n * Query result must be zero or one row (e.g. using `.limit(1)`), otherwise\n * this returns an error.\n */\n maybeSingle<\n ResultOne = Result extends (infer ResultOne)[] ? ResultOne : never,\n >(): PostgrestBuilder<ClientOptions, ResultOne | null> {\n // Temporary partial fix for https://github.com/supabase/postgrest-js/issues/361\n // Issue persists e.g. for `.insert([...]).select().maybeSingle()`\n if (this.method === 'GET') {\n this.headers.set('Accept', 'application/json')\n } else {\n this.headers.set('Accept', 'application/vnd.pgrst.object+json')\n }\n this.isMaybeSingle = true\n return this as unknown as PostgrestBuilder<ClientOptions, ResultOne | null>\n }\n\n /**\n * Return `data` as a string in CSV format.\n */\n csv(): PostgrestBuilder<ClientOptions, string> {\n this.headers.set('Accept', 'text/csv')\n return this as unknown as PostgrestBuilder<ClientOptions, string>\n }\n\n /**\n * Return `data` as an object in [GeoJSON](https://geojson.org) format.\n */\n geojson(): PostgrestBuilder<ClientOptions, Record<string, unknown>> {\n this.headers.set('Accept', 'application/geo+json')\n return this as unknown as PostgrestBuilder<ClientOptions, Record<string, unknown>>\n }\n\n /**\n * Return `data` as the EXPLAIN plan for the query.\n *\n * You need to enable the\n * [db_plan_enabled](https://supabase.com/docs/guides/database/debugging-performance#enabling-explain)\n * setting before using this method.\n *\n * @param options - Named parameters\n *\n * @param options.analyze - If `true`, the query will be executed and the\n * actual run time will be returned\n *\n * @param options.verbose - If `true`, the query identifier will be returned\n * and `data` will include the output columns of the query\n *\n * @param options.settings - If `true`, include information on configuration\n * parameters that affect query planning\n *\n * @param options.buffers - If `true`, include information on buffer usage\n *\n * @param options.wal - If `true`, include information on WAL record generation\n *\n * @param options.format - The format of the output, can be `\"text\"` (default)\n * or `\"json\"`\n */\n explain({\n analyze = false,\n verbose = false,\n settings = false,\n buffers = false,\n wal = false,\n format = 'text',\n }: {\n analyze?: boolean\n verbose?: boolean\n settings?: boolean\n buffers?: boolean\n wal?: boolean\n format?: 'json' | 'text'\n } = {}) {\n const options = [\n analyze ? 'analyze' : null,\n verbose ? 'verbose' : null,\n settings ? 'settings' : null,\n buffers ? 'buffers' : null,\n wal ? 'wal' : null,\n ]\n .filter(Boolean)\n .join('|')\n // An Accept header can carry multiple media types but postgrest-js always sends one\n const forMediatype = this.headers.get('Accept') ?? 'application/json'\n this.headers.set(\n 'Accept',\n `application/vnd.pgrst.plan+${format}; for=\"${forMediatype}\"; options=${options};`\n )\n if (format === 'json') {\n return this as unknown as PostgrestBuilder<ClientOptions, Record<string, unknown>[]>\n } else {\n return this as unknown as PostgrestBuilder<ClientOptions, string>\n }\n }\n\n /**\n * Rollback the query.\n *\n * `data` will still be returned, but the query is not committed.\n */\n rollback(): this {\n this.headers.append('Prefer', 'tx=rollback')\n return this\n }\n\n /**\n * Override the type of the returned `data`.\n *\n * @typeParam NewResult - The new result type to override with\n * @deprecated Use overrideTypes<yourType, { merge: false }>() method at the end of your call chain instead\n */\n returns<NewResult>(): PostgrestTransformBuilder<\n ClientOptions,\n Schema,\n Row,\n CheckMatchingArrayTypes<Result, NewResult>,\n RelationName,\n Relationships,\n Method\n > {\n return this as unknown as PostgrestTransformBuilder<\n ClientOptions,\n Schema,\n Row,\n CheckMatchingArrayTypes<Result, NewResult>,\n RelationName,\n Relationships,\n Method\n >\n }\n\n /**\n * Set the maximum number of rows that can be affected by the query.\n * Only available in PostgREST v13+ and only works with PATCH and DELETE methods.\n *\n * @param value - The maximum number of rows that can be affected\n */\n maxAffected(value: number): MaxAffectedEnabled<ClientOptions['PostgrestVersion']> extends true\n ? // TODO: update the RPC case to only work on RPC that returns SETOF rows\n Method extends 'PATCH' | 'DELETE' | 'RPC'\n ? this\n : InvalidMethodError<'maxAffected method only available on update or delete'>\n : InvalidMethodError<'maxAffected method only available on postgrest 13+'> {\n this.headers.append('Prefer', 'handling=strict')\n this.headers.append('Prefer', `max-affected=${value}`)\n return this as unknown as MaxAffectedEnabled<ClientOptions['PostgrestVersion']> extends true\n ? Method extends 'PATCH' | 'DELETE' | 'RPC'\n ? this\n : InvalidMethodError<'maxAffected method only available on update or delete'>\n : InvalidMethodError<'maxAffected method only available on postgrest 13+'>\n }\n}\n","import PostgrestTransformBuilder from './PostgrestTransformBuilder'\nimport { JsonPathToAccessor, JsonPathToType } from './select-query-parser/utils'\nimport { ClientServerOptions, GenericSchema } from './types/common/common'\n\ntype FilterOperator =\n | 'eq'\n | 'neq'\n | 'gt'\n | 'gte'\n | 'lt'\n | 'lte'\n | 'like'\n | 'ilike'\n | 'is'\n | 'isdistinct'\n | 'in'\n | 'cs'\n | 'cd'\n | 'sl'\n | 'sr'\n | 'nxl'\n | 'nxr'\n | 'adj'\n | 'ov'\n | 'fts'\n | 'plfts'\n | 'phfts'\n | 'wfts'\n | 'match'\n | 'imatch'\n\nexport type IsStringOperator<Path extends string> = Path extends `${string}->>${string}`\n ? true\n : false\n\nconst PostgrestReservedCharsRegexp = new RegExp('[,()]')\n\n// Match relationship filters with `table.column` syntax and resolve underlying\n// column value. If not matched, fallback to generic type.\n// TODO: Validate the relationship itself ala select-query-parser. Currently we\n// assume that all tables have valid relationships to each other, despite\n// nonexistent foreign keys.\ntype ResolveFilterValue<\n Schema extends GenericSchema,\n Row extends Record<string, unknown>,\n ColumnName extends string,\n> = ColumnName extends `${infer RelationshipTable}.${infer Remainder}`\n ? Remainder extends `${infer _}.${infer _}`\n ? ResolveFilterValue<Schema, Row, Remainder>\n : ResolveFilterRelationshipValue<Schema, RelationshipTable, Remainder>\n : ColumnName extends keyof Row\n ? Row[ColumnName]\n : // If the column selection is a jsonpath like `data->value` or `data->>value` we attempt to match\n // the expected type with the parsed custom json type\n IsStringOperator<ColumnName> extends true\n ? string\n : JsonPathToType<Row, JsonPathToAccessor<ColumnName>> extends infer JsonPathValue\n ? JsonPathValue extends never\n ? never\n : JsonPathValue\n : never\n\ntype ResolveFilterRelationshipValue<\n Schema extends GenericSchema,\n RelationshipTable extends string,\n RelationshipColumn extends string,\n> = Schema['Tables'] & Schema['Views'] extends infer TablesAndViews\n ? RelationshipTable extends keyof TablesAndViews\n ? 'Row' extends keyof TablesAndViews[RelationshipTable]\n ? RelationshipColumn extends keyof TablesAndViews[RelationshipTable]['Row']\n ? TablesAndViews[RelationshipTable]['Row'][RelationshipColumn]\n : unknown\n : unknown\n : unknown\n : never\n\nexport type InvalidMethodError<S extends string> = { Error: S }\n\nexport default class PostgrestFilterBuilder<\n ClientOptions extends ClientServerOptions,\n Schema extends GenericSchema,\n Row extends Record<string, unknown>,\n Result,\n RelationName = unknown,\n Relationships = unknown,\n Method = unknown,\n> extends PostgrestTransformBuilder<\n ClientOptions,\n Schema,\n Row,\n Result,\n RelationName,\n Relationships,\n Method\n> {\n /**\n * Match only rows where `column` is equal to `value`.\n *\n * To check if the value of `column` is NULL, you should use `.is()` instead.\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n eq<ColumnName extends string>(\n column: ColumnName,\n value: ResolveFilterValue<Schema, Row, ColumnName> extends never\n ? NonNullable<unknown>\n : // We want to infer the type before wrapping it into a `NonNullable` to avoid too deep\n // type resolution error\n ResolveFilterValue<Schema, Row, ColumnName> extends infer ResolvedFilterValue\n ? NonNullable<ResolvedFilterValue>\n : // We should never enter this case as all the branches are covered above\n never\n ): this {\n this.url.searchParams.append(column, `eq.${value}`)\n return this\n }\n\n /**\n * Match only rows where `column` is not equal to `value`.\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n neq<ColumnName extends string>(\n column: ColumnName,\n value: ResolveFilterValue<Schema, Row, ColumnName> extends never\n ? unknown\n : ResolveFilterValue<Schema, Row, ColumnName> extends infer ResolvedFilterValue\n ? ResolvedFilterValue\n : never\n ): this {\n this.url.searchParams.append(column, `neq.${value}`)\n return this\n }\n\n gt<ColumnName extends string & keyof Row>(column: ColumnName, value: Row[ColumnName]): this\n gt(column: string, value: unknown): this\n /**\n * Match only rows where `column` is greater than `value`.\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n gt(column: string, value: unknown): this {\n this.url.searchParams.append(column, `gt.${value}`)\n return this\n }\n\n gte<ColumnName extends string & keyof Row>(column: ColumnName, value: Row[ColumnName]): this\n gte(column: string, value: unknown): this\n /**\n * Match only rows where `column` is greater than or equal to `value`.\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n gte(column: string, value: unknown): this {\n this.url.searchParams.append(column, `gte.${value}`)\n return this\n }\n\n lt<ColumnName extends string & keyof Row>(column: ColumnName, value: Row[ColumnName]): this\n lt(column: string, value: unknown): this\n /**\n * Match only rows where `column` is less than `value`.\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n lt(column: string, value: unknown): this {\n this.url.searchParams.append(column, `lt.${value}`)\n return this\n }\n\n lte<ColumnName extends string & keyof Row>(column: ColumnName, value: Row[ColumnName]): this\n lte(column: string, value: unknown): this\n /**\n * Match only rows where `column` is less than or equal to `value`.\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n lte(column: string, value: unknown): this {\n this.url.searchParams.append(column, `lte.${value}`)\n return this\n }\n\n like<ColumnName extends string & keyof Row>(column: ColumnName, pattern: string): this\n like(column: string, pattern: string): this\n /**\n * Match only rows where `column` matches `pattern` case-sensitively.\n *\n * @param column - The column to filter on\n * @param pattern - The pattern to match with\n */\n like(column: string, pattern: string): this {\n this.url.searchParams.append(column, `like.${pattern}`)\n return this\n }\n\n likeAllOf<ColumnName extends string & keyof Row>(\n column: ColumnName,\n patterns: readonly string[]\n ): this\n likeAllOf(column: string, patterns: readonly string[]): this\n /**\n * Match only rows where `column` matches all of `patterns` case-sensitively.\n *\n * @param column - The column to filter on\n * @param patterns - The patterns to match with\n */\n likeAllOf(column: string, patterns: readonly string[]): this {\n this.url.searchParams.append(column, `like(all).{${patterns.join(',')}}`)\n return this\n }\n\n likeAnyOf<ColumnName extends string & keyof Row>(\n column: ColumnName,\n patterns: readonly string[]\n ): this\n likeAnyOf(column: string, patterns: readonly string[]): this\n /**\n * Match only rows where `column` matches any of `patterns` case-sensitively.\n *\n * @param column - The column to filter on\n * @param patterns - The patterns to match with\n */\n likeAnyOf(column: string, patterns: readonly string[]): this {\n this.url.searchParams.append(column, `like(any).{${patterns.join(',')}}`)\n return this\n }\n\n ilike<ColumnName extends string & keyof Row>(column: ColumnName, pattern: string): this\n ilike(column: string, pattern: string): this\n /**\n * Match only rows where `column` matches `pattern` case-insensitively.\n *\n * @param column - The column to filter on\n * @param pattern - The pattern to match with\n */\n ilike(column: string, pattern: string): this {\n this.url.searchParams.append(column, `ilike.${pattern}`)\n return this\n }\n\n ilikeAllOf<ColumnName extends string & keyof Row>(\n column: ColumnName,\n patterns: readonly string[]\n ): this\n ilikeAllOf(column: string, patterns: readonly string[]): this\n /**\n * Match only rows where `column` matches all of `patterns` case-insensitively.\n *\n * @param column - The column to filter on\n * @param patterns - The patterns to match with\n */\n ilikeAllOf(column: string, patterns: readonly string[]): this {\n this.url.searchParams.append(column, `ilike(all).{${patterns.join(',')}}`)\n return this\n }\n\n ilikeAnyOf<ColumnName extends string & keyof Row>(\n column: ColumnName,\n patterns: readonly string[]\n ): this\n ilikeAnyOf(column: string, patterns: readonly string[]): this\n /**\n * Match only rows where `column` matches any of `patterns` case-insensitively.\n *\n * @param column - The column to filter on\n * @param patterns - The patterns to match with\n */\n ilikeAnyOf(column: string, patterns: readonly string[]): this {\n this.url.searchParams.append(column, `ilike(any).{${patterns.join(',')}}`)\n return this\n }\n\n regexMatch<ColumnName extends string & keyof Row>(column: ColumnName, pattern: string): this\n regexMatch(column: string, pattern: string): this\n /**\n * Match only rows where `column` matches the PostgreSQL regex `pattern`\n * case-sensitively (using the `~` operator).\n *\n * @param column - The column to filter on\n * @param pattern - The PostgreSQL regular expression pattern to match with\n */\n regexMatch(column: string, pattern: string): this {\n this.url.searchParams.append(column, `match.${pattern}`)\n return this\n }\n\n regexIMatch<ColumnName extends string & keyof Row>(column: ColumnName, pattern: string): this\n regexIMatch(column: string, pattern: string): this\n /**\n * Match only rows where `column` matches the PostgreSQL regex `pattern`\n * case-insensitively (using the `~*` operator).\n *\n * @param column - The column to filter on\n * @param pattern - The PostgreSQL regular expression pattern to match with\n */\n regexIMatch(column: string, pattern: string): this {\n this.url.searchParams.append(column, `imatch.${pattern}`)\n return this\n }\n\n is<ColumnName extends string & keyof Row>(\n column: ColumnName,\n value: Row[ColumnName] & (boolean | null)\n ): this\n is(column: string, value: boolean | null): this\n /**\n * Match only rows where `column` IS `value`.\n *\n * For non-boolean columns, this is only relevant for checking if the value of\n * `column` is NULL by setting `value` to `null`.\n *\n * For boolean columns, you can also set `value` to `true` or `false` and it\n * will behave the same way as `.eq()`.\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n is(column: string, value: boolean | null): this {\n this.url.searchParams.append(column, `is.${value}`)\n return this\n }\n\n /**\n * Match only rows where `column` IS DISTINCT FROM `value`.\n *\n * Unlike `.neq()`, this treats `NULL` as a comparable value. Two `NULL` values\n * are considered equal (not distinct), and comparing `NULL` with any non-NULL\n * value returns true (distinct).\n *\n * @param column - The column to filter on\n * @param value - The value to filter with\n */\n isDistinct<ColumnName extends string>(\n column: ColumnName,\n value: ResolveFilterValue<Schema, Row, ColumnName> extends never\n ? unknown\n : ResolveFilterValue<Schema, Row, ColumnName> extends infer ResolvedFilterValue\n ? ResolvedFilterValue\n : never\n ): this {\n this.url.searchParams.append(column, `isdistinct.${value}`)\n return this\n }\n\n /**\n * Match only rows where `column` is included in the `values` array.\n *\n * @param column - The column to filter on\n * @param values - The values array to filter with\n */\n in<ColumnName extends string>(\n column: ColumnName,\n values: ReadonlyArray<\n ResolveFilterValue<Schema, Row, ColumnName> extends never\n ? unknown\n : // We want to infer the type before wrapping it into a `NonNullable` to avoid too deep\n // type resolution error\n ResolveFilterValue<Schema, Row, ColumnName> extends infer ResolvedFilterValue\n ? ResolvedFilterValue\n : // We should never enter this case as all the branches are covered above\n never\n >\n ): this {\n const cleanedValues = Array.from(new Set(values))\n .map((s) => {\n // handle postgrest reserved characters\n // https://postgrest.org/en/v7.0.0/api.html#reserved-characters\n if (typeof s === 'string' && PostgrestReservedCharsRegexp.test(s)) return `\"${s}\"`\n else return `${s}`\n })\n .join(',')\n this.url.searchParams.append(column, `in.(${cleanedValues})`)\n return this\n }\n\n /**\n * Match only rows where `column` is NOT included in the `values` array.\n *\n * @param column - The column to filter on\n * @param values - The values array to filter with\n */\n notIn<ColumnName extends string>(\n column: ColumnName,\n values: ReadonlyArray<\n ResolveFilterValue<Schema, Row, ColumnName> extends never\n ? unknown\n : ResolveFilterValue<Schema, Row, ColumnName> extends infer ResolvedFilterValue\n ? ResolvedFilterValue\n : never\n >\n ): this {\n const cleanedValues = Array.from(new Set(values))\n .map((s) => {\n // handle postgrest reserved characters\n // https://postgrest.org/en/v7.0.0/api.html#reserved-characters\n if (typeof s === 'string' && PostgrestReservedCharsRegexp.test(s)) return `\"${s}\"`\n else return `${s}`\n })\n .join(',')\n this.url.searchParams.append(column, `not.in.(${cleanedValues})`)\n return this\n }\n\n contains<ColumnName extends string & keyof Row>(\n column: ColumnName,\n value: string | ReadonlyArray<Row[ColumnName]> | Record<string, unknown>\n ): this\n contains(column: string, value: string | readonly unknown[] | Record<string, unknown>): this\n /**\n * Only relevant for jsonb, array, and range columns. Match only rows where\n * `column` contains every element appearing in `value`.\n *\n * @param column - The jsonb, array, or range column to filter on\n * @param value - The jsonb, array, or range value to filter with\n */\n contains(column: string, value: string | readonly unknown[] | Record<string, unknown>): this {\n if (typeof value === 'string') {\n // range types can be inclusive '[', ']' or exclusive '(', ')' so just\n // keep it simple and accept a string\n this.url.searchParams.append(column, `cs.${value}`)\n } else if (Array.isArray(value)) {\n // array\n this.url.searchParams.append(column, `cs.{${value.join(',')}}`)\n } else {\n // json\n this.url.searchParams.append(column, `cs.${JSON.stringify(value)}`)\n }\n return this\n }\n\n containedBy<ColumnName extends string & keyof Row>(\n column: ColumnName,\n value: string | ReadonlyArray<Row[ColumnName]> | Record<string, unknown>\n ): this\n containedBy(column: string, value: string | readonly unknown[] | Record<string, unknown>): this\n /**\n * Only relevant for jsonb, array, and range columns. Match only rows where\n * every element appearing in `column` is contained by `value`.\n *\n * @param column - The jsonb, array, or range column to filter on\n * @param value - The jsonb, array, or range value to filter with\n */\n containedBy(column: string, value: string | readonly unknown[] | Record<string, unknown>): this {\n if (typeof value === 'string') {\n // range\n this.url.searchParams.append(column, `cd.${value}`)\n } else if (Array.isArray(value)) {\n // array\n this.url.searchParams.append(column, `cd.{${value.join(',')}}`)\n } else {\n // json\n this.url.searchParams.append(column, `cd.${JSON.stringify(value)}`)\n }\n return this\n }\n\n rangeGt<ColumnName extends string & keyof Row>(column: ColumnName, range: string): this\n rangeGt(column: string, range: string): this\n /**\n * Only relevant for range columns. Match only rows where every element in\n * `column` is greater than any element in `range`.\n *\n * @param column - The range column to filter on\n * @param range - The range to filter with\n */\n rangeGt(column: string, range: string): this {\n this.url.searchParams.append(column, `sr.${range}`)\n return this\n }\n\n rangeGte<ColumnName extends string & keyof Row>(column: ColumnName, range: string): this\n rangeGte(column: string, range: string): this\n /**\n * Only relevant for range columns. Match only rows where every element in\n * `column` is either contained in `range` or greater than any element in\n * `range`.\n *\n * @param column - The range column to filter on\n * @param range - The range to filter with\n */\n rangeGte(column: string, range: string): this {\n this.url.searchParams.append(column, `nxl.${range}`)\n return this\n }\n\n rangeLt<ColumnName extends string & keyof Row>(column: ColumnName, range: string): this\n rangeLt(column: string, range: string): this\n /**\n * Only relevant for range columns. Match only rows where every element in\n * `column` is less than any element in `range`.\n *\n * @param column - The range column to filter on\n * @param range - The range to filter with\n */\n rangeLt(column: string, range: string): this {\n this.url.searchParams.append(column, `sl.${range}`)\n return this\n }\n\n rangeLte<ColumnName extends string & keyof Row>(column: ColumnName, range: string): this\n rangeLte(column: string, range: string): this\n /**\n * Only relevant for range columns. Match only rows where every element in\n * `column` is either contained in `range` or less than any element in\n * `range`.\n *\n * @param column - The range column to filter on\n * @param range - The range to filter with\n */\n rangeLte(column: string, range: string): this {\n this.url.searchParams.append(column, `nxr.${range}`)\n return this\n }\n\n rangeAdjacent<ColumnName extends string & keyof Row>(column: ColumnName, range: string): this\n rangeAdjacent(column: string, range: string): this\n /**\n * Only relevant for range columns. Match only rows where `column` is\n * mutually exclusive to `range` and there can be no element between the two\n * ranges.\n *\n * @param column - The range column to filter on\n * @param range - The range to filter with\n */\n rangeAdjacent(column: string, range: string): this {\n this.url.searchParams.append(column, `adj.${range}`)\n return this\n }\n\n overlaps<ColumnName extends string & keyof Row>(\n column: ColumnName,\n value: string | ReadonlyArray<Row[ColumnName]>\n ): this\n overlaps(column: string, value: string | readonly unknown[]): this\n /**\n * Only relevant for array and range columns. Match only rows where\n * `column` and `value` have an element in common.\n *\n * @param column - The array or range column to filter on\n * @param value - The array or range value to filter with\n */\n overlaps(column: string, value: string | readonly unknown[]): this {\n if (typeof value === 'string') {\n // range\n this.url.searchParams.append(column, `ov.${value}`)\n } else {\n // array\n this.url.searchParams.append(column, `ov.{${value.join(',')}}`)\n }\n return this\n }\n\n textSearch<ColumnName extends string & keyof Row>(\n column: ColumnName,\n query: string,\n options?: { config?: string; type?: 'plain' | 'phrase' | 'websearch' }\n ): this\n textSearch(\n column: string,\n query: string,\n options?: { config?: string; type?: 'plain' | 'phrase' | 'websearch' }\n ): this\n /**\n * Only relevant for text and tsvector columns. Match only rows where\n * `column` matches the query string in `query`.\n *\n * @param column - The text or tsvector column to filter on\n * @param query - The query text to match with\n * @param options - Named parameters\n * @param options.config - The text search configuration to use\n * @param options.type - Change how the `query` text is interpreted\n */\n textSearch(\n column: string,\n query: string,\n { config, type }: { config?: string; type?: 'plain' | 'phrase' | 'websearch' } = {}\n ): this {\n let typePart = ''\n if (type === 'plain') {\n typePart = 'pl'\n } else if (type === 'phrase') {\n typePart = 'ph'\n } else if (type === 'websearch') {\n typePart = 'w'\n }\n const configPart = config === undefined ? '' : `(${config})`\n this.url.searchParams.append(column, `${typePart}fts${configPart}.${query}`)\n return this\n }\n\n match<ColumnName extends string & keyof Row>(query: Record<ColumnName, Row[ColumnName]>): this\n match(query: Record<string, unknown>): this\n /**\n * Match only rows where each column in `query` keys is equal to its\n * associated value. Shorthand for multiple `.eq()`s.\n *\n * @param query - The object to filter with, with column names as keys mapped\n * to their filter values\n */\n match(query: Record<string, unknown>): this {\n Object.entries(query).forEach(([column, value]) => {\n this.url.searchParams.append(column, `eq.${value}`)\n })\n return this\n }\n\n not<ColumnName extends string & keyof Row>(\n column: ColumnName,\n operator: FilterOperator,\n value: Row[ColumnName]\n ): this\n not(column: string, operator: string, value: unknown): this\n /**\n * Match only rows which doesn't satisfy the filter.\n *\n * Unlike most filters, `opearator` and `value` are used as-is and need to\n * follow [PostgREST\n * syntax](https://postgrest.org/en/stable/api.html#operators). You also need\n * to make sure they are properly sanitized.\n *\n * @param column - The column to filter on\n * @param operator - The operator to be negated to filter with, following\n * PostgREST syntax\n * @param value - The value to filter with, following PostgREST syntax\n */\n not(column: string, operator: string, value: unknown): this {\n this.url.searchParams.append(column, `not.${operator}.${value}`)\n return this\n }\n\n /**\n * Match only rows which satisfy at least one of the filters.\n *\n * Unlike most filters, `filters` is used as-is and needs to follow [PostgREST\n * syntax](https://postgrest.org/en/stable/api.html#operators). You also need\n * to make sure it's properly sanitized.\n *\n * It's currently not possible to do an `.or()` filter across multiple tables.\n *\n * @param filters - The filters to use, following PostgREST syntax\n * @param options - Named parameters\n * @param options.referencedTable - Set this to filter on referenced tables\n * instead of the parent table\n * @param options.foreignTable - Deprecated, use `referencedTable` instead\n */\n or(\n filters: string,\n {\n foreignTable,\n referencedTable = foreignTable,\n }: { foreignTable?: string; referencedTable?: string } = {}\n ): this {\n const key = referencedTable ? `${referencedTable}.or` : 'or'\n this.url.searchParams.append(key, `(${filters})`)\n return this\n }\n\n filter<ColumnName extends string & keyof Row>(\n column: ColumnName,\n operator: `${'' | 'not.'}${FilterOperator}`,\n value: unknown\n ): this\n filter(column: string, operator: string, value: unknown): this\n /**\n * Match only rows which satisfy the filter. This is an escape hatch - you\n * should use the specific filter methods wherever possible.\n *\n * Unlike most filters, `opearator` and `value` are used as-is and need to\n * follow [PostgREST\n * syntax](https://postgrest.org/en/stable/api.html#operators). You also need\n * to make sure they are properly sanitized.\n *\n * @param column - The column to filter on\n * @param operator - The operator to filter with, following PostgREST syntax\n * @param value - The value to filter with, following PostgREST syntax\n */\n filter(column: string, operator: string, value: unknown): this {\n this.url.searchParams.append(column, `${operator}.${value}`)\n return this\n }\n}\n","import PostgrestFilterBuilder from './PostgrestFilterBuilder'\nimport { GetResult } from './select-query-parser/result'\nimport {\n ClientServerOptions,\n Fetch,\n GenericSchema,\n GenericTable,\n GenericView,\n} from './types/common/common'\n\nexport default class PostgrestQueryBuilder<\n ClientOptions extends ClientServerOptions,\n Schema extends GenericSchema,\n Relation extends GenericTable | GenericView,\n RelationName = unknown,\n Relationships = Relation extends { Relationships: infer R } ? R : unknown,\n> {\n url: URL\n headers: Headers\n schema?: string\n signal?: AbortSignal\n fetch?: Fetch\n\n /**\n * Creates a query builder scoped to a Postgres table or view.\n *\n * @example\n * ```ts\n * import PostgrestQueryBuilder from '@supabase/postgrest-js'\n *\n * const query = new PostgrestQueryBuilder(\n * new URL('https://xyzcompany.supabase.co/rest/v1/users'),\n * { headers: { apikey: 'public-anon-key' } }\n * )\n * ```\n */\n constructor(\n url: URL,\n {\n headers = {},\n schema,\n fetch,\n }: {\n headers?: HeadersInit\n schema?: string\n fetch?: Fetch\n }\n ) {\n this.url = url\n this.headers = new Headers(headers)\n this.schema = schema\n this.fetch = fetch\n }\n\n /**\n * Clone URL and headers to prevent shared state between operations.\n */\n private cloneRequestState(): { url: URL; headers: Headers } {\n return {\n url: new URL(this.url.toString()),\n headers: new Headers(this.headers),\n }\n }\n\n /**\n * Perform a SELECT query on the table or view.\n *\n * @param columns - The columns to retrieve, separated by commas. Columns can be renamed when returned with `customName:columnName`\n *\n * @param options - Named parameters\n *\n * @param options.head - When set to `true`, `data` will not be returned.\n * Useful if you only need the count.\n *\n * @param options.count - Count algorithm to use to count rows in the table or view.\n *\n * `\"exact\"`: Exact but slow count algorithm. Performs a `COUNT(*)` under the\n * hood.\n *\n * `\"planned\"`: Approximated but fast count algorithm. Uses the Postgres\n * statistics under the hood.\n *\n * `\"estimated\"`: Uses exact count for low numbers and planned count for high\n * numbers.\n */\n select<\n Query extends string = '*',\n ResultOne = GetResult<\n Schema,\n Relation['Row'],\n RelationName,\n Relationships,\n Query,\n ClientOptions\n >,\n >(\n columns?: Query,\n options?: {\n head?: boolean\n count?: 'exact' | 'planned' | 'estimated'\n }\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n ResultOne[],\n RelationName,\n Relationships,\n 'GET'\n > {\n const { head = false, count } = options ?? {}\n\n const method = head ? 'HEAD' : 'GET'\n // Remove whitespaces except when quoted\n let quoted = false\n const cleanedColumns = (columns ?? '*')\n .split('')\n .map((c) => {\n if (/\\s/.test(c) && !quoted) {\n return ''\n }\n if (c === '\"') {\n quoted = !quoted\n }\n return c\n })\n .join('')\n\n const { url, headers } = this.cloneRequestState()\n url.searchParams.set('select', cleanedColumns)\n\n if (count) {\n headers.append('Prefer', `count=${count}`)\n }\n\n return new PostgrestFilterBuilder({\n method,\n url,\n headers,\n schema: this.schema,\n fetch: this.fetch,\n })\n }\n\n // TODO(v3): Make `defaultToNull` consistent for both single & bulk inserts.\n insert<Row extends Relation extends { Insert: unknown } ? Relation['Insert'] : never>(\n values: Row,\n options?: {\n count?: 'exact' | 'planned' | 'estimated'\n }\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'POST'\n >\n insert<Row extends Relation extends { Insert: unknown } ? Relation['Insert'] : never>(\n values: Row[],\n options?: {\n count?: 'exact' | 'planned' | 'estimated'\n defaultToNull?: boolean\n }\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'POST'\n >\n /**\n * Perform an INSERT into the table or view.\n *\n * By default, inserted rows are not returned. To return it, chain the call\n * with `.select()`.\n *\n * @param values - The values to insert. Pass an object to insert a single row\n * or an array to insert multiple rows.\n *\n * @param options - Named parameters\n *\n * @param options.count - Count algorithm to use to count inserted rows.\n *\n * `\"exact\"`: Exact but slow count algorithm. Performs a `COUNT(*)` under the\n * hood.\n *\n * `\"planned\"`: Approximated but fast count algorithm. Uses the Postgres\n * statistics under the hood.\n *\n * `\"estimated\"`: Uses exact count for low numbers and planned count for high\n * numbers.\n *\n * @param options.defaultToNull - Make missing fields default to `null`.\n * Otherwise, use the default value for the column. Only applies for bulk\n * inserts.\n */\n insert<Row extends Relation extends { Insert: unknown } ? Relation['Insert'] : never>(\n values: Row | Row[],\n {\n count,\n defaultToNull = true,\n }: {\n count?: 'exact' | 'planned' | 'estimated'\n defaultToNull?: boolean\n } = {}\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'POST'\n > {\n const method = 'POST'\n const { url, headers } = this.cloneRequestState()\n\n if (count) {\n headers.append('Prefer', `count=${count}`)\n }\n if (!defaultToNull) {\n headers.append('Prefer', `missing=default`)\n }\n\n if (Array.isArray(values)) {\n const columns = values.reduce((acc, x) => acc.concat(Object.keys(x)), [] as string[])\n if (columns.length > 0) {\n const uniqueColumns = [...new Set(columns)].map((column) => `\"${column}\"`)\n url.searchParams.set('columns', uniqueColumns.join(','))\n }\n }\n\n return new PostgrestFilterBuilder({\n method,\n url,\n headers,\n schema: this.schema,\n body: values,\n fetch: this.fetch ?? fetch,\n })\n }\n\n // TODO(v3): Make `defaultToNull` consistent for both single & bulk upserts.\n upsert<Row extends Relation extends { Insert: unknown } ? Relation['Insert'] : never>(\n values: Row,\n options?: {\n onConflict?: string\n ignoreDuplicates?: boolean\n count?: 'exact' | 'planned' | 'estimated'\n }\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'POST'\n >\n upsert<Row extends Relation extends { Insert: unknown } ? Relation['Insert'] : never>(\n values: Row[],\n options?: {\n onConflict?: string\n ignoreDuplicates?: boolean\n count?: 'exact' | 'planned' | 'estimated'\n defaultToNull?: boolean\n }\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'POST'\n >\n /**\n * Perform an UPSERT on the table or view. Depending on the column(s) passed\n * to `onConflict`, `.upsert()` allows you to perform the equivalent of\n * `.insert()` if a row with the corresponding `onConflict` columns doesn't\n * exist, or if it does exist, perform an alternative action depending on\n * `ignoreDuplicates`.\n *\n * By default, upserted rows are not returned. To return it, chain the call\n * with `.select()`.\n *\n * @param values - The values to upsert with. Pass an object to upsert a\n * single row or an array to upsert multiple rows.\n *\n * @param options - Named parameters\n *\n * @param options.onConflict - Comma-separated UNIQUE column(s) to specify how\n * duplicate rows are determined. Two rows are duplicates if all the\n * `onConflict` columns are equal.\n *\n * @param options.ignoreDuplicates - If `true`, duplicate rows are ignored. If\n * `false`, duplicate rows are merged with existing rows.\n *\n * @param options.count - Count algorithm to use to count upserted rows.\n *\n * `\"exact\"`: Exact but slow count algorithm. Performs a `COUNT(*)` under the\n * hood.\n *\n * `\"planned\"`: Approximated but fast count algorithm. Uses the Postgres\n * statistics under the hood.\n *\n * `\"estimated\"`: Uses exact count for low numbers and planned count for high\n * numbers.\n *\n * @param options.defaultToNull - Make missing fields default to `null`.\n * Otherwise, use the default value for the column. This only applies when\n * inserting new rows, not when merging with existing rows under\n * `ignoreDuplicates: false`. This also only applies when doing bulk upserts.\n *\n * @example Upsert a single row using a unique key\n * ```ts\n * // Upserting a single row, overwriting based on the 'username' unique column\n * const { data, error } = await supabase\n * .from('users')\n * .upsert({ username: 'supabot' }, { onConflict: 'username' })\n *\n * // Example response:\n * // {\n * // data: [\n * // { id: 4, message: 'bar', username: 'supabot' }\n * // ],\n * // error: null\n * // }\n * ```\n *\n * @example Upsert with conflict resolution and exact row counting\n * ```ts\n * // Upserting and returning exact count\n * const { data, error, count } = await supabase\n * .from('users')\n * .upsert(\n * {\n * id: 3,\n * message: 'foo',\n * username: 'supabot'\n * },\n * {\n * onConflict: 'username',\n * count: 'exact'\n * }\n * )\n *\n * // Example response:\n * // {\n * // data: [\n * // {\n * // id: 42,\n * // handle: \"saoirse\",\n * // display_name: \"Saoirse\"\n * // }\n * // ],\n * // count: 1,\n * // error: null\n * // }\n * ```\n */\n\n upsert<Row extends Relation extends { Insert: unknown } ? Relation['Insert'] : never>(\n values: Row | Row[],\n {\n onConflict,\n ignoreDuplicates = false,\n count,\n defaultToNull = true,\n }: {\n onConflict?: string\n ignoreDuplicates?: boolean\n count?: 'exact' | 'planned' | 'estimated'\n defaultToNull?: boolean\n } = {}\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'POST'\n > {\n const method = 'POST'\n const { url, headers } = this.cloneRequestState()\n\n headers.append('Prefer', `resolution=${ignoreDuplicates ? 'ignore' : 'merge'}-duplicates`)\n\n if (onConflict !== undefined) url.searchParams.set('on_conflict', onConflict)\n if (count) {\n headers.append('Prefer', `count=${count}`)\n }\n if (!defaultToNull) {\n headers.append('Prefer', 'missing=default')\n }\n\n if (Array.isArray(values)) {\n const columns = values.reduce((acc, x) => acc.concat(Object.keys(x)), [] as string[])\n if (columns.length > 0) {\n const uniqueColumns = [...new Set(columns)].map((column) => `\"${column}\"`)\n url.searchParams.set('columns', uniqueColumns.join(','))\n }\n }\n\n return new PostgrestFilterBuilder({\n method,\n url,\n headers,\n schema: this.schema,\n body: values,\n fetch: this.fetch ?? fetch,\n })\n }\n\n /**\n * Perform an UPDATE on the table or view.\n *\n * By default, updated rows are not returned. To return it, chain the call\n * with `.select()` after filters.\n *\n * @param values - The values to update with\n *\n * @param options - Named parameters\n *\n * @param options.count - Count algorithm to use to count updated rows.\n *\n * `\"exact\"`: Exact but slow count algorithm. Performs a `COUNT(*)` under the\n * hood.\n *\n * `\"planned\"`: Approximated but fast count algorithm. Uses the Postgres\n * statistics under the hood.\n *\n * `\"estimated\"`: Uses exact count for low numbers and planned count for high\n * numbers.\n */\n update<Row extends Relation extends { Update: unknown } ? Relation['Update'] : never>(\n values: Row,\n {\n count,\n }: {\n count?: 'exact' | 'planned' | 'estimated'\n } = {}\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'PATCH'\n > {\n const method = 'PATCH'\n const { url, headers } = this.cloneRequestState()\n\n if (count) {\n headers.append('Prefer', `count=${count}`)\n }\n\n return new PostgrestFilterBuilder({\n method,\n url,\n headers,\n schema: this.schema,\n body: values,\n fetch: this.fetch ?? fetch,\n })\n }\n\n /**\n * Perform a DELETE on the table or view.\n *\n * By default, deleted rows are not returned. To return it, chain the call\n * with `.select()` after filters.\n *\n * @param options - Named parameters\n *\n * @param options.count - Count algorithm to use to count deleted rows.\n *\n * `\"exact\"`: Exact but slow count algorithm. Performs a `COUNT(*)` under the\n * hood.\n *\n * `\"planned\"`: Approximated but fast count algorithm. Uses the Postgres\n * statistics under the hood.\n *\n * `\"estimated\"`: Uses exact count for low numbers and planned count for high\n * numbers.\n */\n delete({\n count,\n }: {\n count?: 'exact' | 'planned' | 'estimated'\n } = {}): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n Relation['Row'],\n null,\n RelationName,\n Relationships,\n 'DELETE'\n > {\n const method = 'DELETE'\n const { url, headers } = this.cloneRequestState()\n\n if (count) {\n headers.append('Prefer', `count=${count}`)\n }\n\n return new PostgrestFilterBuilder({\n method,\n url,\n headers,\n schema: this.schema,\n fetch: this.fetch ?? fetch,\n })\n }\n}\n","import PostgrestQueryBuilder from './PostgrestQueryBuilder'\nimport PostgrestFilterBuilder from './PostgrestFilterBuilder'\nimport { Fetch, GenericSchema, ClientServerOptions } from './types/common/common'\nimport { GetRpcFunctionFilterBuilderByArgs } from './types/common/rpc'\n\n/**\n * PostgREST client.\n *\n * @typeParam Database - Types for the schema from the [type\n * generator](https://supabase.com/docs/reference/javascript/next/typescript-support)\n *\n * @typeParam SchemaName - Postgres schema to switch to. Must be a string\n * literal, the same one passed to the constructor. If the schema is not\n * `\"public\"`, this must be supplied manually.\n */\nexport default class PostgrestClient<\n Database = any,\n ClientOptions extends ClientServerOptions = Database extends {\n __InternalSupabase: infer I extends ClientServerOptions\n }\n ? I\n : {},\n SchemaName extends string &\n keyof Omit<Database, '__InternalSupabase'> = 'public' extends keyof Omit<\n Database,\n '__InternalSupabase'\n >\n ? 'public'\n : string & keyof Omit<Database, '__InternalSupabase'>,\n Schema extends GenericSchema = Omit<\n Database,\n '__InternalSupabase'\n >[SchemaName] extends GenericSchema\n ? Omit<Database, '__InternalSupabase'>[SchemaName]\n : any,\n> {\n url: string\n headers: Headers\n schemaName?: SchemaName\n fetch?: Fetch\n\n // TODO: Add back shouldThrowOnError once we figure out the typings\n /**\n * Creates a PostgREST client.\n *\n * @param url - URL of the PostgREST endpoint\n * @param options - Named parameters\n * @param options.headers - Custom headers\n * @param options.schema - Postgres schema to switch to\n * @param options.fetch - Custom fetch\n * @example\n * ```ts\n * import PostgrestClient from '@supabase/postgrest-js'\n *\n * const postgrest = new PostgrestClient('https://xyzcompany.supabase.co/rest/v1', {\n * headers: { apikey: 'public-anon-key' },\n * schema: 'public',\n * })\n * ```\n */\n constructor(\n url: string,\n {\n headers = {},\n schema,\n fetch,\n }: {\n headers?: HeadersInit\n schema?: SchemaName\n fetch?: Fetch\n } = {}\n ) {\n this.url = url\n this.headers = new Headers(headers)\n this.schemaName = schema\n this.fetch = fetch\n }\n from<\n TableName extends string & keyof Schema['Tables'],\n Table extends Schema['Tables'][TableName],\n >(relation: TableName): PostgrestQueryBuilder<ClientOptions, Schema, Table, TableName>\n from<ViewName extends string & keyof Schema['Views'], View extends Schema['Views'][ViewName]>(\n relation: ViewName\n ): PostgrestQueryBuilder<ClientOptions, Schema, View, ViewName>\n /**\n * Perform a query on a table or a view.\n *\n * @param relation - The table or view name to query\n */\n from(relation: string): PostgrestQueryBuilder<ClientOptions, Schema, any, any> {\n if (!relation || typeof relation !== 'string' || relation.trim() === '') {\n throw new Error('Invalid relation name: relation must be a non-empty string.')\n }\n\n const url = new URL(`${this.url}/${relation}`)\n return new PostgrestQueryBuilder(url, {\n headers: new Headers(this.headers),\n schema: this.schemaName,\n fetch: this.fetch,\n })\n }\n\n /**\n * Select a schema to query or perform an function (rpc) call.\n *\n * The schema needs to be on the list of exposed schemas inside Supabase.\n *\n * @param schema - The schema to query\n */\n schema<DynamicSchema extends string & keyof Omit<Database, '__InternalSupabase'>>(\n schema: DynamicSchema\n ): PostgrestClient<\n Database,\n ClientOptions,\n DynamicSchema,\n Database[DynamicSchema] extends GenericSchema ? Database[DynamicSchema] : any\n > {\n return new PostgrestClient(this.url, {\n headers: this.headers,\n schema,\n fetch: this.fetch,\n })\n }\n\n /**\n * Perform a function call.\n *\n * @param fn - The function name to call\n * @param args - The arguments to pass to the function call\n * @param options - Named parameters\n * @param options.head - When set to `true`, `data` will not be returned.\n * Useful if you only need the count.\n * @param options.get - When set to `true`, the function will be called with\n * read-only access mode.\n * @param options.count - Count algorithm to use to count rows returned by the\n * function. Only applicable for [set-returning\n * functions](https://www.postgresql.org/docs/current/functions-srf.html).\n *\n * `\"exact\"`: Exact but slow count algorithm. Performs a `COUNT(*)` under the\n * hood.\n *\n * `\"planned\"`: Approximated but fast count algorithm. Uses the Postgres\n * statistics under the hood.\n *\n * `\"estimated\"`: Uses exact count for low numbers and planned count for high\n * numbers.\n *\n * @example\n * ```ts\n * // For cross-schema functions where type inference fails, use overrideTypes:\n * const { data } = await supabase\n * .schema('schema_b')\n * .rpc('function_a', {})\n * .overrideTypes<{ id: string; user_id: string }[]>()\n * ```\n */\n rpc<\n FnName extends string & keyof Schema['Functions'],\n Args extends Schema['Functions'][FnName]['Args'] = never,\n FilterBuilder extends GetRpcFunctionFilterBuilderByArgs<\n Schema,\n FnName,\n Args\n > = GetRpcFunctionFilterBuilderByArgs<Schema, FnName, Args>,\n >(\n fn: FnName,\n args: Args = {} as Args,\n {\n head = false,\n get = false,\n count,\n }: {\n head?: boolean\n get?: boolean\n count?: 'exact' | 'planned' | 'estimated'\n } = {}\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n FilterBuilder['Row'],\n FilterBuilder['Result'],\n FilterBuilder['RelationName'],\n FilterBuilder['Relationships'],\n 'RPC'\n > {\n let method: 'HEAD' | 'GET' | 'POST'\n const url = new URL(`${this.url}/rpc/${fn}`)\n let body: unknown | undefined\n // objects/arrays-of-objects can't be serialized to URL params, use POST + return=minimal instead\n const _isObject = (v: unknown): boolean =>\n v !== null && typeof v === 'object' && (!Array.isArray(v) || v.some(_isObject))\n const _hasObjectArg = head && Object.values(args as object).some(_isObject)\n if (_hasObjectArg) {\n method = 'POST'\n body = args\n } else if (head || get) {\n method = head ? 'HEAD' : 'GET'\n Object.entries(args)\n // params with undefined value needs to be filtered out, otherwise it'll\n // show up as `?param=undefined`\n .filter(([_, value]) => value !== undefined)\n // array values need special syntax\n .map(([name, value]) => [name, Array.isArray(value) ? `{${value.join(',')}}` : `${value}`])\n .forEach(([name, value]) => {\n url.searchParams.append(name, value)\n })\n } else {\n method = 'POST'\n body = args\n }\n\n const headers = new Headers(this.headers)\n if (_hasObjectArg) {\n headers.set('Prefer', count ? `count=${count},return=minimal` : 'return=minimal')\n } else if (count) {\n headers.set('Prefer', `count=${count}`)\n }\n\n return new PostgrestFilterBuilder({\n method,\n url,\n headers,\n schema: this.schemaName,\n body,\n fetch: this.fetch ?? fetch,\n })\n }\n}\n","import PostgrestClient from './PostgrestClient'\nimport PostgrestQueryBuilder from './PostgrestQueryBuilder'\nimport PostgrestFilterBuilder from './PostgrestFilterBuilder'\nimport PostgrestTransformBuilder from './PostgrestTransformBuilder'\nimport PostgrestBuilder from './PostgrestBuilder'\nimport PostgrestError from './PostgrestError'\n\nexport {\n PostgrestClient,\n PostgrestQueryBuilder,\n PostgrestFilterBuilder,\n PostgrestTransformBuilder,\n PostgrestBuilder,\n PostgrestError,\n}\nexport default {\n PostgrestClient,\n PostgrestQueryBuilder,\n PostgrestFilterBuilder,\n PostgrestTransformBuilder,\n PostgrestBuilder,\n PostgrestError,\n}\nexport type {\n PostgrestResponse,\n PostgrestResponseFailure,\n PostgrestResponseSuccess,\n PostgrestSingleResponse,\n PostgrestMaybeSingleResponse,\n} from './types/types'\nexport type { ClientServerOptions as PostgrestClientOptions } from './types/common/common'\n// https://github.com/supabase/postgrest-js/issues/551\n// To be replaced with a helper type that only uses public types\nexport type { GetResult as UnstableGetResult } from './select-query-parser/result'\n","export interface WebSocketLike {\n readonly CONNECTING: number\n readonly OPEN: number\n readonly CLOSING: number\n readonly CLOSED: number\n readonly readyState: number\n readonly url: string\n readonly protocol: string\n\n /**\n * Closes the socket, optionally providing a close code and reason.\n */\n close(code?: number, reason?: string): void\n /**\n * Sends data through the socket using the underlying implementation.\n */\n send(data: string | ArrayBufferLike | Blob | ArrayBufferView): void\n\n onopen: ((this: any, ev: Event) => any) | null\n onmessage: ((this: any, ev: MessageEvent) => any) | null\n onclose: ((this: any, ev: CloseEvent) => any) | null\n onerror: ((this: any, ev: Event) => any) | null\n\n /**\n * Registers an event listener on the socket (compatible with browser WebSocket API).\n */\n addEventListener(type: string, listener: EventListener): void\n /**\n * Removes a previously registered event listener.\n */\n removeEventListener(type: string, listener: EventListener): void\n\n // Add additional properties that may exist on WebSocket implementations\n binaryType?: string\n bufferedAmount?: number\n extensions?: string\n dispatchEvent?: (event: Event) => boolean\n}\n\nexport interface WebSocketEnvironment {\n type: 'native' | 'ws' | 'cloudflare' | 'unsupported'\n constructor?: any\n error?: string\n workaround?: string\n}\n\n/**\n * Utilities for creating WebSocket instances across runtimes.\n */\nexport class WebSocketFactory {\n /**\n * Static-only utility – prevent instantiation.\n */\n private constructor() {}\n private static detectEnvironment(): WebSocketEnvironment {\n if (typeof WebSocket !== 'undefined') {\n return { type: 'native', constructor: WebSocket }\n }\n\n if (typeof globalThis !== 'undefined' && typeof (globalThis as any).WebSocket !== 'undefined') {\n return { type: 'native', constructor: (globalThis as any).WebSocket }\n }\n\n if (typeof global !== 'undefined' && typeof (global as any).WebSocket !== 'undefined') {\n return { type: 'native', constructor: (global as any).WebSocket }\n }\n\n if (\n typeof globalThis !== 'undefined' &&\n typeof (globalThis as any).WebSocketPair !== 'undefined' &&\n typeof globalThis.WebSocket === 'undefined'\n ) {\n return {\n type: 'cloudflare',\n error:\n 'Cloudflare Workers detected. WebSocket clients are not supported in Cloudflare Workers.',\n workaround:\n 'Use Cloudflare Workers WebSocket API for server-side WebSocket handling, or deploy to a different runtime.',\n }\n }\n\n if (\n (typeof globalThis !== 'undefined' && (globalThis as any).EdgeRuntime) ||\n (typeof navigator !== 'undefined' && navigator.userAgent?.includes('Vercel-Edge'))\n ) {\n return {\n type: 'unsupported',\n error:\n 'Edge runtime detected (Vercel Edge/Netlify Edge). WebSockets are not supported in edge functions.',\n workaround:\n 'Use serverless functions or a different deployment target for WebSocket functionality.',\n }\n }\n\n // Use dynamic property access to avoid Next.js Edge Runtime static analysis warnings\n const _process = (globalThis as any)['process']\n if (_process) {\n const processVersions = _process['versions']\n if (processVersions && processVersions['node']) {\n // Remove 'v' prefix if present and parse the major version\n const versionString = processVersions['node']\n const nodeVersion = parseInt(versionString.replace(/^v/, '').split('.')[0])\n\n // Node.js 22+ should have native WebSocket\n if (nodeVersion >= 22) {\n // Check if native WebSocket is available (should be in Node.js 22+)\n if (typeof globalThis.WebSocket !== 'undefined') {\n return { type: 'native', constructor: globalThis.WebSocket }\n }\n // If not available, user needs to provide it\n return {\n type: 'unsupported',\n error: `Node.js ${nodeVersion} detected but native WebSocket not found.`,\n workaround: 'Provide a WebSocket implementation via the transport option.',\n }\n }\n\n // Node.js < 22 doesn't have native WebSocket\n return {\n type: 'unsupported',\n error: `Node.js ${nodeVersion} detected without native WebSocket support.`,\n workaround:\n 'For Node.js < 22, install \"ws\" package and provide it via the transport option:\\n' +\n 'import ws from \"ws\"\\n' +\n 'new RealtimeClient(url, { transport: ws })',\n }\n }\n }\n\n return {\n type: 'unsupported',\n error: 'Unknown JavaScript runtime without WebSocket support.',\n workaround:\n \"Ensure you're running in a supported environment (browser, Node.js, Deno) or provide a custom WebSocket implementation.\",\n }\n }\n\n /**\n * Returns the best available WebSocket constructor for the current runtime.\n *\n * @example\n * ```ts\n * const WS = WebSocketFactory.getWebSocketConstructor()\n * const socket = new WS('wss://realtime.supabase.co/socket')\n * ```\n */\n public static getWebSocketConstructor(): typeof WebSocket {\n const env = this.detectEnvironment()\n if (env.constructor) {\n return env.constructor\n }\n let errorMessage = env.error || 'WebSocket not supported in this environment.'\n if (env.workaround) {\n errorMessage += `\\n\\nSuggested solution: ${env.workaround}`\n }\n throw new Error(errorMessage)\n }\n\n /**\n * Creates a WebSocket using the detected constructor.\n *\n * @example\n * ```ts\n * const socket = WebSocketFactory.createWebSocket('wss://realtime.supabase.co/socket')\n * ```\n */\n public static createWebSocket(url: string | URL, protocols?: string | string[]): WebSocketLike {\n const WS = this.getWebSocketConstructor()\n return new WS(url, protocols)\n }\n\n /**\n * Detects whether the runtime can establish WebSocket connections.\n *\n * @example\n * ```ts\n * if (!WebSocketFactory.isWebSocketSupported()) {\n * console.warn('Falling back to long polling')\n * }\n * ```\n */\n public static isWebSocketSupported(): boolean {\n try {\n const env = this.detectEnvironment()\n return env.type === 'native' || env.type === 'ws'\n } catch {\n return false\n }\n }\n}\n\nexport default WebSocketFactory\n","// Generated automatically during releases by scripts/update-version-files.ts\n// This file provides runtime access to the package version for:\n// - HTTP request headers (e.g., X-Client-Info header for API requests)\n// - Debugging and support (identifying which version is running)\n// - Telemetry and logging (version reporting in errors/analytics)\n// - Ensuring build artifacts match the published package version\nexport const version = '2.90.1'\n","import { version } from './version'\n\nexport const DEFAULT_VERSION = `realtime-js/${version}`\n\nexport const VSN_1_0_0: string = '1.0.0'\nexport const VSN_2_0_0: string = '2.0.0'\nexport const DEFAULT_VSN: string = VSN_1_0_0\n\nexport const VERSION = version\n\nexport const DEFAULT_TIMEOUT = 10000\n\nexport const WS_CLOSE_NORMAL = 1000\nexport const MAX_PUSH_BUFFER_SIZE = 100\n\nexport enum SOCKET_STATES {\n connecting = 0,\n open = 1,\n closing = 2,\n closed = 3,\n}\n\nexport enum CHANNEL_STATES {\n closed = 'closed',\n errored = 'errored',\n joined = 'joined',\n joining = 'joining',\n leaving = 'leaving',\n}\n\nexport enum CHANNEL_EVENTS {\n close = 'phx_close',\n error = 'phx_error',\n join = 'phx_join',\n reply = 'phx_reply',\n leave = 'phx_leave',\n access_token = 'access_token',\n}\n\nexport enum TRANSPORTS {\n websocket = 'websocket',\n}\n\nexport enum CONNECTION_STATE {\n Connecting = 'connecting',\n Open = 'open',\n Closing = 'closing',\n Closed = 'closed',\n}\n","// This file draws heavily from https://github.com/phoenixframework/phoenix/commit/cf098e9cf7a44ee6479d31d911a97d3c7430c6fe\n// License: https://github.com/phoenixframework/phoenix/blob/master/LICENSE.md\nexport type Msg<T> = {\n join_ref?: string | null\n ref?: string | null\n topic: string\n event: string\n payload: T\n}\n\nexport default class Serializer {\n HEADER_LENGTH = 1\n USER_BROADCAST_PUSH_META_LENGTH = 6\n KINDS = { userBroadcastPush: 3, userBroadcast: 4 }\n BINARY_ENCODING = 0\n JSON_ENCODING = 1\n BROADCAST_EVENT = 'broadcast'\n\n allowedMetadataKeys: string[] = []\n\n constructor(allowedMetadataKeys?: string[] | null) {\n this.allowedMetadataKeys = allowedMetadataKeys ?? []\n }\n\n encode(msg: Msg<{ [key: string]: any }>, callback: (result: ArrayBuffer | string) => any) {\n if (\n msg.event === this.BROADCAST_EVENT &&\n !(msg.payload instanceof ArrayBuffer) &&\n typeof msg.payload.event === 'string'\n ) {\n return callback(\n this._binaryEncodeUserBroadcastPush(msg as Msg<{ event: string } & { [key: string]: any }>)\n )\n }\n\n let payload = [msg.join_ref, msg.ref, msg.topic, msg.event, msg.payload]\n return callback(JSON.stringify(payload))\n }\n\n private _binaryEncodeUserBroadcastPush(message: Msg<{ event: string } & { [key: string]: any }>) {\n if (this._isArrayBuffer(message.payload?.payload)) {\n return this._encodeBinaryUserBroadcastPush(message)\n } else {\n return this._encodeJsonUserBroadcastPush(message)\n }\n }\n\n private _encodeBinaryUserBroadcastPush(message: Msg<{ event: string } & { [key: string]: any }>) {\n const userPayload = message.payload?.payload ?? new ArrayBuffer(0)\n return this._encodeUserBroadcastPush(message, this.BINARY_ENCODING, userPayload)\n }\n\n private _encodeJsonUserBroadcastPush(message: Msg<{ event: string } & { [key: string]: any }>) {\n const userPayload = message.payload?.payload ?? {}\n const encoder = new TextEncoder()\n const encodedUserPayload = encoder.encode(JSON.stringify(userPayload)).buffer\n return this._encodeUserBroadcastPush(message, this.JSON_ENCODING, encodedUserPayload)\n }\n\n private _encodeUserBroadcastPush(\n message: Msg<{ event: string } & { [key: string]: any }>,\n encodingType: number,\n encodedPayload: ArrayBuffer\n ) {\n const topic = message.topic\n const ref = message.ref ?? ''\n const joinRef = message.join_ref ?? ''\n const userEvent = message.payload.event\n\n // Filter metadata based on allowed keys\n const rest = this.allowedMetadataKeys\n ? this._pick(message.payload, this.allowedMetadataKeys)\n : {}\n\n const metadata = Object.keys(rest).length === 0 ? '' : JSON.stringify(rest)\n\n // Validate lengths don't exceed uint8 max value (255)\n if (joinRef.length > 255) {\n throw new Error(`joinRef length ${joinRef.length} exceeds maximum of 255`)\n }\n if (ref.length > 255) {\n throw new Error(`ref length ${ref.length} exceeds maximum of 255`)\n }\n if (topic.length > 255) {\n throw new Error(`topic length ${topic.length} exceeds maximum of 255`)\n }\n if (userEvent.length > 255) {\n throw new Error(`userEvent length ${userEvent.length} exceeds maximum of 255`)\n }\n if (metadata.length > 255) {\n throw new Error(`metadata length ${metadata.length} exceeds maximum of 255`)\n }\n\n const metaLength =\n this.USER_BROADCAST_PUSH_META_LENGTH +\n joinRef.length +\n ref.length +\n topic.length +\n userEvent.length +\n metadata.length\n\n const header = new ArrayBuffer(this.HEADER_LENGTH + metaLength)\n let view = new DataView(header)\n let offset = 0\n\n view.setUint8(offset++, this.KINDS.userBroadcastPush) // kind\n view.setUint8(offset++, joinRef.length)\n view.setUint8(offset++, ref.length)\n view.setUint8(offset++, topic.length)\n view.setUint8(offset++, userEvent.length)\n view.setUint8(offset++, metadata.length)\n view.setUint8(offset++, encodingType)\n Array.from(joinRef, (char) => view.setUint8(offset++, char.charCodeAt(0)))\n Array.from(ref, (char) => view.setUint8(offset++, char.charCodeAt(0)))\n Array.from(topic, (char) => view.setUint8(offset++, char.charCodeAt(0)))\n Array.from(userEvent, (char) => view.setUint8(offset++, char.charCodeAt(0)))\n Array.from(metadata, (char) => view.setUint8(offset++, char.charCodeAt(0)))\n\n var combined = new Uint8Array(header.byteLength + encodedPayload.byteLength)\n combined.set(new Uint8Array(header), 0)\n combined.set(new Uint8Array(encodedPayload), header.byteLength)\n\n return combined.buffer\n }\n\n decode(rawPayload: ArrayBuffer | string, callback: Function) {\n if (this._isArrayBuffer(rawPayload)) {\n let result = this._binaryDecode(rawPayload as ArrayBuffer)\n return callback(result)\n }\n\n if (typeof rawPayload === 'string') {\n const jsonPayload = JSON.parse(rawPayload)\n const [join_ref, ref, topic, event, payload] = jsonPayload\n return callback({ join_ref, ref, topic, event, payload })\n }\n\n return callback({})\n }\n\n private _binaryDecode(buffer: ArrayBuffer) {\n const view = new DataView(buffer)\n const kind = view.getUint8(0)\n const decoder = new TextDecoder()\n switch (kind) {\n case this.KINDS.userBroadcast:\n return this._decodeUserBroadcast(buffer, view, decoder)\n }\n }\n\n private _decodeUserBroadcast(\n buffer: ArrayBuffer,\n view: DataView,\n decoder: TextDecoder\n ): {\n join_ref: null\n ref: null\n topic: string\n event: string\n payload: { [key: string]: any }\n } {\n const topicSize = view.getUint8(1)\n const userEventSize = view.getUint8(2)\n const metadataSize = view.getUint8(3)\n const payloadEncoding = view.getUint8(4)\n\n let offset = this.HEADER_LENGTH + 4\n const topic = decoder.decode(buffer.slice(offset, offset + topicSize))\n offset = offset + topicSize\n const userEvent = decoder.decode(buffer.slice(offset, offset + userEventSize))\n offset = offset + userEventSize\n const metadata = decoder.decode(buffer.slice(offset, offset + metadataSize))\n offset = offset + metadataSize\n\n const payload = buffer.slice(offset, buffer.byteLength)\n const parsedPayload =\n payloadEncoding === this.JSON_ENCODING ? JSON.parse(decoder.decode(payload)) : payload\n\n const data: { [key: string]: any } = {\n type: this.BROADCAST_EVENT,\n event: userEvent,\n payload: parsedPayload,\n }\n\n // Metadata is optional and always JSON encoded\n if (metadataSize > 0) {\n data['meta'] = JSON.parse(metadata)\n }\n\n return { join_ref: null, ref: null, topic: topic, event: this.BROADCAST_EVENT, payload: data }\n }\n\n private _isArrayBuffer(buffer: any): boolean {\n return buffer instanceof ArrayBuffer || buffer?.constructor?.name === 'ArrayBuffer'\n }\n\n private _pick(obj: Record<string, any> | null | undefined, keys: string[]): Record<string, any> {\n if (!obj || typeof obj !== 'object') {\n return {}\n }\n return Object.fromEntries(Object.entries(obj).filter(([key]) => keys.includes(key)))\n }\n}\n","/**\n * Creates a timer that accepts a `timerCalc` function to perform calculated timeout retries, such as exponential backoff.\n *\n * @example\n * let reconnectTimer = new Timer(() => this.connect(), function(tries){\n * return [1000, 5000, 10000][tries - 1] || 10000\n * })\n * reconnectTimer.scheduleTimeout() // fires after 1000\n * reconnectTimer.scheduleTimeout() // fires after 5000\n * reconnectTimer.reset()\n * reconnectTimer.scheduleTimeout() // fires after 1000\n */\nexport default class Timer {\n timer: number | undefined = undefined\n tries: number = 0\n\n constructor(\n public callback: Function,\n public timerCalc: Function\n ) {\n this.callback = callback\n this.timerCalc = timerCalc\n }\n\n reset() {\n this.tries = 0\n clearTimeout(this.timer)\n this.timer = undefined\n }\n\n // Cancels any previous scheduleTimeout and schedules callback\n scheduleTimeout() {\n clearTimeout(this.timer)\n\n this.timer = <any>setTimeout(\n () => {\n this.tries = this.tries + 1\n this.callback()\n },\n this.timerCalc(this.tries + 1)\n )\n }\n}\n","/**\n * Helpers to convert the change Payload into native JS types.\n */\n\n// Adapted from epgsql (src/epgsql_binary.erl), this module licensed under\n// 3-clause BSD found here: https://raw.githubusercontent.com/epgsql/epgsql/devel/LICENSE\n\nexport enum PostgresTypes {\n abstime = 'abstime',\n bool = 'bool',\n date = 'date',\n daterange = 'daterange',\n float4 = 'float4',\n float8 = 'float8',\n int2 = 'int2',\n int4 = 'int4',\n int4range = 'int4range',\n int8 = 'int8',\n int8range = 'int8range',\n json = 'json',\n jsonb = 'jsonb',\n money = 'money',\n numeric = 'numeric',\n oid = 'oid',\n reltime = 'reltime',\n text = 'text',\n time = 'time',\n timestamp = 'timestamp',\n timestamptz = 'timestamptz',\n timetz = 'timetz',\n tsrange = 'tsrange',\n tstzrange = 'tstzrange',\n}\n\ntype Columns = {\n name: string // the column name. eg: \"user_id\"\n type: string // the column type. eg: \"uuid\"\n flags?: string[] // any special flags for the column. eg: [\"key\"]\n type_modifier?: number // the type modifier. eg: 4294967295\n}[]\n\ntype BaseValue = null | string | number | boolean\ntype RecordValue = BaseValue | BaseValue[]\n\ntype Record = {\n [key: string]: RecordValue\n}\n\n/**\n * Takes an array of columns and an object of string values then converts each string value\n * to its mapped type.\n *\n * @param {{name: String, type: String}[]} columns\n * @param {Object} record\n * @param {Object} options The map of various options that can be applied to the mapper\n * @param {Array} options.skipTypes The array of types that should not be converted\n *\n * @example convertChangeData([{name: 'first_name', type: 'text'}, {name: 'age', type: 'int4'}], {first_name: 'Paul', age:'33'}, {})\n * //=>{ first_name: 'Paul', age: 33 }\n */\nexport const convertChangeData = (\n columns: Columns,\n record: Record | null,\n options: { skipTypes?: string[] } = {}\n): Record => {\n const skipTypes = options.skipTypes ?? []\n\n if (!record) {\n return {}\n }\n\n return Object.keys(record).reduce((acc, rec_key) => {\n acc[rec_key] = convertColumn(rec_key, columns, record, skipTypes)\n return acc\n }, {} as Record)\n}\n\n/**\n * Converts the value of an individual column.\n *\n * @param {String} columnName The column that you want to convert\n * @param {{name: String, type: String}[]} columns All of the columns\n * @param {Object} record The map of string values\n * @param {Array} skipTypes An array of types that should not be converted\n * @return {object} Useless information\n *\n * @example convertColumn('age', [{name: 'first_name', type: 'text'}, {name: 'age', type: 'int4'}], {first_name: 'Paul', age: '33'}, [])\n * //=> 33\n * @example convertColumn('age', [{name: 'first_name', type: 'text'}, {name: 'age', type: 'int4'}], {first_name: 'Paul', age: '33'}, ['int4'])\n * //=> \"33\"\n */\nexport const convertColumn = (\n columnName: string,\n columns: Columns,\n record: Record,\n skipTypes: string[]\n): RecordValue => {\n const column = columns.find((x) => x.name === columnName)\n const colType = column?.type\n const value = record[columnName]\n\n if (colType && !skipTypes.includes(colType)) {\n return convertCell(colType, value)\n }\n\n return noop(value)\n}\n\n/**\n * If the value of the cell is `null`, returns null.\n * Otherwise converts the string value to the correct type.\n * @param {String} type A postgres column type\n * @param {String} value The cell value\n *\n * @example convertCell('bool', 't')\n * //=> true\n * @example convertCell('int8', '10')\n * //=> 10\n * @example convertCell('_int4', '{1,2,3,4}')\n * //=> [1,2,3,4]\n */\nexport const convertCell = (type: string, value: RecordValue): RecordValue => {\n // if data type is an array\n if (type.charAt(0) === '_') {\n const dataType = type.slice(1, type.length)\n return toArray(value, dataType)\n }\n\n // If not null, convert to correct type.\n switch (type) {\n case PostgresTypes.bool:\n return toBoolean(value)\n case PostgresTypes.float4:\n case PostgresTypes.float8:\n case PostgresTypes.int2:\n case PostgresTypes.int4:\n case PostgresTypes.int8:\n case PostgresTypes.numeric:\n case PostgresTypes.oid:\n return toNumber(value)\n case PostgresTypes.json:\n case PostgresTypes.jsonb:\n return toJson(value)\n case PostgresTypes.timestamp:\n return toTimestampString(value) // Format to be consistent with PostgREST\n case PostgresTypes.abstime: // To allow users to cast it based on Timezone\n case PostgresTypes.date: // To allow users to cast it based on Timezone\n case PostgresTypes.daterange:\n case PostgresTypes.int4range:\n case PostgresTypes.int8range:\n case PostgresTypes.money:\n case PostgresTypes.reltime: // To allow users to cast it based on Timezone\n case PostgresTypes.text:\n case PostgresTypes.time: // To allow users to cast it based on Timezone\n case PostgresTypes.timestamptz: // To allow users to cast it based on Timezone\n case PostgresTypes.timetz: // To allow users to cast it based on Timezone\n case PostgresTypes.tsrange:\n case PostgresTypes.tstzrange:\n return noop(value)\n default:\n // Return the value for remaining types\n return noop(value)\n }\n}\n\nconst noop = (value: RecordValue): RecordValue => {\n return value\n}\nexport const toBoolean = (value: RecordValue): RecordValue => {\n switch (value) {\n case 't':\n return true\n case 'f':\n return false\n default:\n return value\n }\n}\nexport const toNumber = (value: RecordValue): RecordValue => {\n if (typeof value === 'string') {\n const parsedValue = parseFloat(value)\n if (!Number.isNaN(parsedValue)) {\n return parsedValue\n }\n }\n return value\n}\nexport const toJson = (value: RecordValue): RecordValue => {\n if (typeof value === 'string') {\n try {\n return JSON.parse(value)\n } catch {\n return value\n }\n }\n return value\n}\n\n/**\n * Converts a Postgres Array into a native JS array\n *\n * @example toArray('{}', 'int4')\n * //=> []\n * @example toArray('{\"[2021-01-01,2021-12-31)\",\"(2021-01-01,2021-12-32]\"}', 'daterange')\n * //=> ['[2021-01-01,2021-12-31)', '(2021-01-01,2021-12-32]']\n * @example toArray([1,2,3,4], 'int4')\n * //=> [1,2,3,4]\n */\nexport const toArray = (value: RecordValue, type: string): RecordValue => {\n if (typeof value !== 'string') {\n return value\n }\n\n const lastIdx = value.length - 1\n const closeBrace = value[lastIdx]\n const openBrace = value[0]\n\n // Confirm value is a Postgres array by checking curly brackets\n if (openBrace === '{' && closeBrace === '}') {\n let arr\n const valTrim = value.slice(1, lastIdx)\n\n // TODO: find a better solution to separate Postgres array data\n try {\n arr = JSON.parse('[' + valTrim + ']')\n } catch (_) {\n // WARNING: splitting on comma does not cover all edge cases\n arr = valTrim ? valTrim.split(',') : []\n }\n\n return arr.map((val: BaseValue) => convertCell(type, val))\n }\n\n return value\n}\n\n/**\n * Fixes timestamp to be ISO-8601. Swaps the space between the date and time for a 'T'\n * See https://github.com/supabase/supabase/issues/18\n *\n * @example toTimestampString('2019-09-10 00:00:00')\n * //=> '2019-09-10T00:00:00'\n */\nexport const toTimestampString = (value: RecordValue): RecordValue => {\n if (typeof value === 'string') {\n return value.replace(' ', 'T')\n }\n\n return value\n}\n\nexport const httpEndpointURL = (socketUrl: string): string => {\n const wsUrl = new URL(socketUrl)\n\n wsUrl.protocol = wsUrl.protocol.replace(/^ws/i, 'http')\n\n wsUrl.pathname = wsUrl.pathname\n .replace(/\\/+$/, '') // remove all trailing slashes\n .replace(/\\/socket\\/websocket$/i, '') // remove the socket/websocket path\n .replace(/\\/socket$/i, '') // remove the socket path\n .replace(/\\/websocket$/i, '') // remove the websocket path\n\n if (wsUrl.pathname === '' || wsUrl.pathname === '/') {\n wsUrl.pathname = '/api/broadcast'\n } else {\n wsUrl.pathname = wsUrl.pathname + '/api/broadcast'\n }\n\n return wsUrl.href\n}\n","import { DEFAULT_TIMEOUT } from '../lib/constants'\nimport type RealtimeChannel from '../RealtimeChannel'\n\nexport default class Push {\n sent: boolean = false\n timeoutTimer: number | undefined = undefined\n ref: string = ''\n receivedResp: {\n status: string\n response: { [key: string]: any }\n } | null = null\n recHooks: {\n status: string\n callback: Function\n }[] = []\n refEvent: string | null = null\n\n /**\n * Initializes the Push\n *\n * @param channel The Channel\n * @param event The event, for example `\"phx_join\"`\n * @param payload The payload, for example `{user_id: 123}`\n * @param timeout The push timeout in milliseconds\n */\n constructor(\n public channel: RealtimeChannel,\n public event: string,\n public payload: { [key: string]: any } = {},\n public timeout: number = DEFAULT_TIMEOUT\n ) {}\n\n resend(timeout: number) {\n this.timeout = timeout\n this._cancelRefEvent()\n this.ref = ''\n this.refEvent = null\n this.receivedResp = null\n this.sent = false\n this.send()\n }\n\n send() {\n if (this._hasReceived('timeout')) {\n return\n }\n this.startTimeout()\n this.sent = true\n this.channel.socket.push({\n topic: this.channel.topic,\n event: this.event,\n payload: this.payload,\n ref: this.ref,\n join_ref: this.channel._joinRef(),\n })\n }\n\n updatePayload(payload: { [key: string]: any }): void {\n this.payload = { ...this.payload, ...payload }\n }\n\n receive(status: string, callback: Function) {\n if (this._hasReceived(status)) {\n callback(this.receivedResp?.response)\n }\n\n this.recHooks.push({ status, callback })\n return this\n }\n\n startTimeout() {\n if (this.timeoutTimer) {\n return\n }\n this.ref = this.channel.socket._makeRef()\n this.refEvent = this.channel._replyEventName(this.ref)\n\n const callback = (payload: any) => {\n this._cancelRefEvent()\n this._cancelTimeout()\n this.receivedResp = payload\n this._matchReceive(payload)\n }\n\n this.channel._on(this.refEvent, {}, callback)\n\n this.timeoutTimer = <any>setTimeout(() => {\n this.trigger('timeout', {})\n }, this.timeout)\n }\n\n trigger(status: string, response: any) {\n if (this.refEvent) this.channel._trigger(this.refEvent, { status, response })\n }\n\n destroy() {\n this._cancelRefEvent()\n this._cancelTimeout()\n }\n\n private _cancelRefEvent() {\n if (!this.refEvent) {\n return\n }\n\n this.channel._off(this.refEvent, {})\n }\n\n private _cancelTimeout() {\n clearTimeout(this.timeoutTimer)\n this.timeoutTimer = undefined\n }\n\n private _matchReceive({ status, response }: { status: string; response: Function }) {\n this.recHooks.filter((h) => h.status === status).forEach((h) => h.callback(response))\n }\n\n private _hasReceived(status: string) {\n return this.receivedResp && this.receivedResp.status === status\n }\n}\n","/*\n This file draws heavily from https://github.com/phoenixframework/phoenix/blob/d344ec0a732ab4ee204215b31de69cf4be72e3bf/assets/js/phoenix/presence.js\n License: https://github.com/phoenixframework/phoenix/blob/d344ec0a732ab4ee204215b31de69cf4be72e3bf/LICENSE.md\n*/\n\nimport type { PresenceOpts, PresenceOnJoinCallback, PresenceOnLeaveCallback } from 'phoenix'\nimport type RealtimeChannel from './RealtimeChannel'\n\ntype Presence<T extends { [key: string]: any } = {}> = {\n presence_ref: string\n} & T\n\nexport type RealtimePresenceState<T extends { [key: string]: any } = {}> = {\n [key: string]: Presence<T>[]\n}\n\nexport type RealtimePresenceJoinPayload<T extends { [key: string]: any }> = {\n event: `${REALTIME_PRESENCE_LISTEN_EVENTS.JOIN}`\n key: string\n currentPresences: Presence<T>[]\n newPresences: Presence<T>[]\n}\n\nexport type RealtimePresenceLeavePayload<T extends { [key: string]: any }> = {\n event: `${REALTIME_PRESENCE_LISTEN_EVENTS.LEAVE}`\n key: string\n currentPresences: Presence<T>[]\n leftPresences: Presence<T>[]\n}\n\nexport enum REALTIME_PRESENCE_LISTEN_EVENTS {\n SYNC = 'sync',\n JOIN = 'join',\n LEAVE = 'leave',\n}\n\ntype PresenceDiff = {\n joins: RealtimePresenceState\n leaves: RealtimePresenceState\n}\n\ntype RawPresenceState = {\n [key: string]: {\n metas: {\n phx_ref?: string\n phx_ref_prev?: string\n [key: string]: any\n }[]\n }\n}\n\ntype RawPresenceDiff = {\n joins: RawPresenceState\n leaves: RawPresenceState\n}\n\ntype PresenceChooser<T> = (key: string, presences: Presence[]) => T\n\nexport default class RealtimePresence {\n state: RealtimePresenceState = {}\n pendingDiffs: RawPresenceDiff[] = []\n joinRef: string | null = null\n enabled: boolean = false\n caller: {\n onJoin: PresenceOnJoinCallback\n onLeave: PresenceOnLeaveCallback\n onSync: () => void\n } = {\n onJoin: () => {},\n onLeave: () => {},\n onSync: () => {},\n }\n\n /**\n * Creates a Presence helper that keeps the local presence state in sync with the server.\n *\n * @param channel - The realtime channel to bind to.\n * @param opts - Optional custom event names, e.g. `{ events: { state: 'state', diff: 'diff' } }`.\n *\n * @example\n * ```ts\n * const presence = new RealtimePresence(channel)\n *\n * channel.on('presence', ({ event, key }) => {\n * console.log(`Presence ${event} on ${key}`)\n * })\n * ```\n */\n constructor(\n public channel: RealtimeChannel,\n opts?: PresenceOpts\n ) {\n const events = opts?.events || {\n state: 'presence_state',\n diff: 'presence_diff',\n }\n\n this.channel._on(events.state, {}, (newState: RawPresenceState) => {\n const { onJoin, onLeave, onSync } = this.caller\n\n this.joinRef = this.channel._joinRef()\n\n this.state = RealtimePresence.syncState(this.state, newState, onJoin, onLeave)\n\n this.pendingDiffs.forEach((diff) => {\n this.state = RealtimePresence.syncDiff(this.state, diff, onJoin, onLeave)\n })\n\n this.pendingDiffs = []\n\n onSync()\n })\n\n this.channel._on(events.diff, {}, (diff: RawPresenceDiff) => {\n const { onJoin, onLeave, onSync } = this.caller\n\n if (this.inPendingSyncState()) {\n this.pendingDiffs.push(diff)\n } else {\n this.state = RealtimePresence.syncDiff(this.state, diff, onJoin, onLeave)\n\n onSync()\n }\n })\n\n this.onJoin((key, currentPresences, newPresences) => {\n this.channel._trigger('presence', {\n event: 'join',\n key,\n currentPresences,\n newPresences,\n })\n })\n\n this.onLeave((key, currentPresences, leftPresences) => {\n this.channel._trigger('presence', {\n event: 'leave',\n key,\n currentPresences,\n leftPresences,\n })\n })\n\n this.onSync(() => {\n this.channel._trigger('presence', { event: 'sync' })\n })\n }\n\n /**\n * Used to sync the list of presences on the server with the\n * client's state.\n *\n * An optional `onJoin` and `onLeave` callback can be provided to\n * react to changes in the client's local presences across\n * disconnects and reconnects with the server.\n *\n * @internal\n */\n private static syncState(\n currentState: RealtimePresenceState,\n newState: RawPresenceState | RealtimePresenceState,\n onJoin: PresenceOnJoinCallback,\n onLeave: PresenceOnLeaveCallback\n ): RealtimePresenceState {\n const state = this.cloneDeep(currentState)\n const transformedState = this.transformState(newState)\n const joins: RealtimePresenceState = {}\n const leaves: RealtimePresenceState = {}\n\n this.map(state, (key: string, presences: Presence[]) => {\n if (!transformedState[key]) {\n leaves[key] = presences\n }\n })\n\n this.map(transformedState, (key, newPresences: Presence[]) => {\n const currentPresences: Presence[] = state[key]\n\n if (currentPresences) {\n const newPresenceRefs = newPresences.map((m: Presence) => m.presence_ref)\n const curPresenceRefs = currentPresences.map((m: Presence) => m.presence_ref)\n const joinedPresences: Presence[] = newPresences.filter(\n (m: Presence) => curPresenceRefs.indexOf(m.presence_ref) < 0\n )\n const leftPresences: Presence[] = currentPresences.filter(\n (m: Presence) => newPresenceRefs.indexOf(m.presence_ref) < 0\n )\n\n if (joinedPresences.length > 0) {\n joins[key] = joinedPresences\n }\n\n if (leftPresences.length > 0) {\n leaves[key] = leftPresences\n }\n } else {\n joins[key] = newPresences\n }\n })\n\n return this.syncDiff(state, { joins, leaves }, onJoin, onLeave)\n }\n\n /**\n * Used to sync a diff of presence join and leave events from the\n * server, as they happen.\n *\n * Like `syncState`, `syncDiff` accepts optional `onJoin` and\n * `onLeave` callbacks to react to a user joining or leaving from a\n * device.\n *\n * @internal\n */\n private static syncDiff(\n state: RealtimePresenceState,\n diff: RawPresenceDiff | PresenceDiff,\n onJoin: PresenceOnJoinCallback,\n onLeave: PresenceOnLeaveCallback\n ): RealtimePresenceState {\n const { joins, leaves } = {\n joins: this.transformState(diff.joins),\n leaves: this.transformState(diff.leaves),\n }\n\n if (!onJoin) {\n onJoin = () => {}\n }\n\n if (!onLeave) {\n onLeave = () => {}\n }\n\n this.map(joins, (key, newPresences: Presence[]) => {\n const currentPresences: Presence[] = state[key] ?? []\n state[key] = this.cloneDeep(newPresences)\n\n if (currentPresences.length > 0) {\n const joinedPresenceRefs = state[key].map((m: Presence) => m.presence_ref)\n const curPresences: Presence[] = currentPresences.filter(\n (m: Presence) => joinedPresenceRefs.indexOf(m.presence_ref) < 0\n )\n\n state[key].unshift(...curPresences)\n }\n\n onJoin(key, currentPresences, newPresences)\n })\n\n this.map(leaves, (key, leftPresences: Presence[]) => {\n let currentPresences: Presence[] = state[key]\n\n if (!currentPresences) return\n\n const presenceRefsToRemove = leftPresences.map((m: Presence) => m.presence_ref)\n currentPresences = currentPresences.filter(\n (m: Presence) => presenceRefsToRemove.indexOf(m.presence_ref) < 0\n )\n\n state[key] = currentPresences\n\n onLeave(key, currentPresences, leftPresences)\n\n if (currentPresences.length === 0) delete state[key]\n })\n\n return state\n }\n\n /** @internal */\n private static map<T = any>(obj: RealtimePresenceState, func: PresenceChooser<T>): T[] {\n return Object.getOwnPropertyNames(obj).map((key) => func(key, obj[key]))\n }\n\n /**\n * Remove 'metas' key\n * Change 'phx_ref' to 'presence_ref'\n * Remove 'phx_ref' and 'phx_ref_prev'\n *\n * @example\n * // returns {\n * abc123: [\n * { presence_ref: '2', user_id: 1 },\n * { presence_ref: '3', user_id: 2 }\n * ]\n * }\n * RealtimePresence.transformState({\n * abc123: {\n * metas: [\n * { phx_ref: '2', phx_ref_prev: '1' user_id: 1 },\n * { phx_ref: '3', user_id: 2 }\n * ]\n * }\n * })\n *\n * @internal\n */\n private static transformState(\n state: RawPresenceState | RealtimePresenceState\n ): RealtimePresenceState {\n state = this.cloneDeep(state)\n\n return Object.getOwnPropertyNames(state).reduce((newState, key) => {\n const presences = state[key]\n\n if ('metas' in presences) {\n newState[key] = presences.metas.map((presence) => {\n presence['presence_ref'] = presence['phx_ref']\n\n delete presence['phx_ref']\n delete presence['phx_ref_prev']\n\n return presence\n }) as Presence[]\n } else {\n newState[key] = presences\n }\n\n return newState\n }, {} as RealtimePresenceState)\n }\n\n /** @internal */\n private static cloneDeep(obj: { [key: string]: any }) {\n return JSON.parse(JSON.stringify(obj))\n }\n\n /** @internal */\n private onJoin(callback: PresenceOnJoinCallback): void {\n this.caller.onJoin = callback\n }\n\n /** @internal */\n private onLeave(callback: PresenceOnLeaveCallback): void {\n this.caller.onLeave = callback\n }\n\n /** @internal */\n private onSync(callback: () => void): void {\n this.caller.onSync = callback\n }\n\n /** @internal */\n private inPendingSyncState(): boolean {\n return !this.joinRef || this.joinRef !== this.channel._joinRef()\n }\n}\n","import { CHANNEL_EVENTS, CHANNEL_STATES, MAX_PUSH_BUFFER_SIZE } from './lib/constants'\nimport Push from './lib/push'\nimport type RealtimeClient from './RealtimeClient'\nimport Timer from './lib/timer'\nimport RealtimePresence, { REALTIME_PRESENCE_LISTEN_EVENTS } from './RealtimePresence'\nimport type {\n RealtimePresenceJoinPayload,\n RealtimePresenceLeavePayload,\n RealtimePresenceState,\n} from './RealtimePresence'\nimport * as Transformers from './lib/transformers'\nimport { httpEndpointURL } from './lib/transformers'\n\ntype ReplayOption = {\n since: number\n limit?: number\n}\n\nexport type RealtimeChannelOptions = {\n config: {\n /**\n * self option enables client to receive message it broadcast\n * ack option instructs server to acknowledge that broadcast message was received\n * replay option instructs server to replay broadcast messages\n */\n broadcast?: { self?: boolean; ack?: boolean; replay?: ReplayOption }\n /**\n * key option is used to track presence payload across clients\n */\n presence?: { key?: string; enabled?: boolean }\n /**\n * defines if the channel is private or not and if RLS policies will be used to check data\n */\n private?: boolean\n }\n}\n\ntype RealtimeChangesPayloadBase = {\n schema: string\n table: string\n}\n\ntype RealtimeBroadcastChangesPayloadBase = RealtimeChangesPayloadBase & {\n id: string\n}\n\nexport type RealtimeBroadcastInsertPayload<T extends { [key: string]: any }> =\n RealtimeBroadcastChangesPayloadBase & {\n operation: `${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.INSERT}`\n record: T\n old_record: null\n }\n\nexport type RealtimeBroadcastUpdatePayload<T extends { [key: string]: any }> =\n RealtimeBroadcastChangesPayloadBase & {\n operation: `${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.UPDATE}`\n record: T\n old_record: T\n }\n\nexport type RealtimeBroadcastDeletePayload<T extends { [key: string]: any }> =\n RealtimeBroadcastChangesPayloadBase & {\n operation: `${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.DELETE}`\n record: null\n old_record: T\n }\n\nexport type RealtimeBroadcastPayload<T extends { [key: string]: any }> =\n | RealtimeBroadcastInsertPayload<T>\n | RealtimeBroadcastUpdatePayload<T>\n | RealtimeBroadcastDeletePayload<T>\n\ntype RealtimePostgresChangesPayloadBase = {\n schema: string\n table: string\n commit_timestamp: string\n errors: string[]\n}\n\nexport type RealtimePostgresInsertPayload<T extends { [key: string]: any }> =\n RealtimePostgresChangesPayloadBase & {\n eventType: `${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.INSERT}`\n new: T\n old: {}\n }\n\nexport type RealtimePostgresUpdatePayload<T extends { [key: string]: any }> =\n RealtimePostgresChangesPayloadBase & {\n eventType: `${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.UPDATE}`\n new: T\n old: Partial<T>\n }\n\nexport type RealtimePostgresDeletePayload<T extends { [key: string]: any }> =\n RealtimePostgresChangesPayloadBase & {\n eventType: `${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.DELETE}`\n new: {}\n old: Partial<T>\n }\n\nexport type RealtimePostgresChangesPayload<T extends { [key: string]: any }> =\n | RealtimePostgresInsertPayload<T>\n | RealtimePostgresUpdatePayload<T>\n | RealtimePostgresDeletePayload<T>\n\nexport type RealtimePostgresChangesFilter<T extends `${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT}`> = {\n /**\n * The type of database change to listen to.\n */\n event: T\n /**\n * The database schema to listen to.\n */\n schema: string\n /**\n * The database table to listen to.\n */\n table?: string\n /**\n * Receive database changes when filter is matched.\n */\n filter?: string\n}\n\nexport type RealtimeChannelSendResponse = 'ok' | 'timed out' | 'error'\n\nexport enum REALTIME_POSTGRES_CHANGES_LISTEN_EVENT {\n ALL = '*',\n INSERT = 'INSERT',\n UPDATE = 'UPDATE',\n DELETE = 'DELETE',\n}\n\nexport enum REALTIME_LISTEN_TYPES {\n BROADCAST = 'broadcast',\n PRESENCE = 'presence',\n POSTGRES_CHANGES = 'postgres_changes',\n SYSTEM = 'system',\n}\n\nexport enum REALTIME_SUBSCRIBE_STATES {\n SUBSCRIBED = 'SUBSCRIBED',\n TIMED_OUT = 'TIMED_OUT',\n CLOSED = 'CLOSED',\n CHANNEL_ERROR = 'CHANNEL_ERROR',\n}\n\nexport const REALTIME_CHANNEL_STATES = CHANNEL_STATES\n\ninterface PostgresChangesFilters {\n postgres_changes: {\n id: string\n event: string\n schema?: string\n table?: string\n filter?: string\n }[]\n}\n/** A channel is the basic building block of Realtime\n * and narrows the scope of data flow to subscribed clients.\n * You can think of a channel as a chatroom where participants are able to see who's online\n * and send and receive messages.\n */\nexport default class RealtimeChannel {\n bindings: {\n [key: string]: {\n type: string\n filter: { [key: string]: any }\n callback: Function\n id?: string\n }[]\n } = {}\n timeout: number\n state: CHANNEL_STATES = CHANNEL_STATES.closed\n joinedOnce = false\n joinPush: Push\n rejoinTimer: Timer\n pushBuffer: Push[] = []\n presence: RealtimePresence\n broadcastEndpointURL: string\n subTopic: string\n private: boolean\n\n /**\n * Creates a channel that can broadcast messages, sync presence, and listen to Postgres changes.\n *\n * The topic determines which realtime stream you are subscribing to. Config options let you\n * enable acknowledgement for broadcasts, presence tracking, or private channels.\n *\n * @example\n * ```ts\n * import RealtimeClient from '@supabase/realtime-js'\n *\n * const client = new RealtimeClient('https://xyzcompany.supabase.co/realtime/v1', {\n * params: { apikey: 'public-anon-key' },\n * })\n * const channel = new RealtimeChannel('realtime:public:messages', { config: {} }, client)\n * ```\n */\n constructor(\n /** Topic name can be any string. */\n public topic: string,\n public params: RealtimeChannelOptions = { config: {} },\n public socket: RealtimeClient\n ) {\n this.subTopic = topic.replace(/^realtime:/i, '')\n this.params.config = {\n ...{\n broadcast: { ack: false, self: false },\n presence: { key: '', enabled: false },\n private: false,\n },\n ...params.config,\n }\n this.timeout = this.socket.timeout\n this.joinPush = new Push(this, CHANNEL_EVENTS.join, this.params, this.timeout)\n this.rejoinTimer = new Timer(() => this._rejoinUntilConnected(), this.socket.reconnectAfterMs)\n this.joinPush.receive('ok', () => {\n this.state = CHANNEL_STATES.joined\n this.rejoinTimer.reset()\n this.pushBuffer.forEach((pushEvent: Push) => pushEvent.send())\n this.pushBuffer = []\n })\n this._onClose(() => {\n this.rejoinTimer.reset()\n this.socket.log('channel', `close ${this.topic} ${this._joinRef()}`)\n this.state = CHANNEL_STATES.closed\n this.socket._remove(this)\n })\n this._onError((reason: string) => {\n if (this._isLeaving() || this._isClosed()) {\n return\n }\n this.socket.log('channel', `error ${this.topic}`, reason)\n this.state = CHANNEL_STATES.errored\n this.rejoinTimer.scheduleTimeout()\n })\n this.joinPush.receive('timeout', () => {\n if (!this._isJoining()) {\n return\n }\n this.socket.log('channel', `timeout ${this.topic}`, this.joinPush.timeout)\n this.state = CHANNEL_STATES.errored\n this.rejoinTimer.scheduleTimeout()\n })\n\n this.joinPush.receive('error', (reason: any) => {\n if (this._isLeaving() || this._isClosed()) {\n return\n }\n this.socket.log('channel', `error ${this.topic}`, reason)\n this.state = CHANNEL_STATES.errored\n this.rejoinTimer.scheduleTimeout()\n })\n this._on(CHANNEL_EVENTS.reply, {}, (payload: any, ref: string) => {\n this._trigger(this._replyEventName(ref), payload)\n })\n\n this.presence = new RealtimePresence(this)\n\n this.broadcastEndpointURL = httpEndpointURL(this.socket.endPoint)\n this.private = this.params.config.private || false\n\n if (!this.private && this.params.config?.broadcast?.replay) {\n throw `tried to use replay on public channel '${this.topic}'. It must be a private channel.`\n }\n }\n\n /** Subscribe registers your client with the server */\n subscribe(\n callback?: (status: REALTIME_SUBSCRIBE_STATES, err?: Error) => void,\n timeout = this.timeout\n ): RealtimeChannel {\n if (!this.socket.isConnected()) {\n this.socket.connect()\n }\n if (this.state == CHANNEL_STATES.closed) {\n const {\n config: { broadcast, presence, private: isPrivate },\n } = this.params\n\n const postgres_changes = this.bindings.postgres_changes?.map((r) => r.filter) ?? []\n\n const presence_enabled =\n (!!this.bindings[REALTIME_LISTEN_TYPES.PRESENCE] &&\n this.bindings[REALTIME_LISTEN_TYPES.PRESENCE].length > 0) ||\n this.params.config.presence?.enabled === true\n const accessTokenPayload: { access_token?: string } = {}\n const config = {\n broadcast,\n presence: { ...presence, enabled: presence_enabled },\n postgres_changes,\n private: isPrivate,\n }\n\n if (this.socket.accessTokenValue) {\n accessTokenPayload.access_token = this.socket.accessTokenValue\n }\n\n this._onError((e: Error) => callback?.(REALTIME_SUBSCRIBE_STATES.CHANNEL_ERROR, e))\n\n this._onClose(() => callback?.(REALTIME_SUBSCRIBE_STATES.CLOSED))\n\n this.updateJoinPayload({ ...{ config }, ...accessTokenPayload })\n\n this.joinedOnce = true\n this._rejoin(timeout)\n\n this.joinPush\n .receive('ok', async ({ postgres_changes }: PostgresChangesFilters) => {\n // Only refresh auth if using callback-based tokens\n if (!this.socket._isManualToken()) {\n this.socket.setAuth()\n }\n if (postgres_changes === undefined) {\n callback?.(REALTIME_SUBSCRIBE_STATES.SUBSCRIBED)\n return\n } else {\n const clientPostgresBindings = this.bindings.postgres_changes\n const bindingsLen = clientPostgresBindings?.length ?? 0\n const newPostgresBindings = []\n\n for (let i = 0; i < bindingsLen; i++) {\n const clientPostgresBinding = clientPostgresBindings[i]\n const {\n filter: { event, schema, table, filter },\n } = clientPostgresBinding\n const serverPostgresFilter = postgres_changes && postgres_changes[i]\n\n if (\n serverPostgresFilter &&\n serverPostgresFilter.event === event &&\n RealtimeChannel.isFilterValueEqual(serverPostgresFilter.schema, schema) &&\n RealtimeChannel.isFilterValueEqual(serverPostgresFilter.table, table) &&\n RealtimeChannel.isFilterValueEqual(serverPostgresFilter.filter, filter)\n ) {\n newPostgresBindings.push({\n ...clientPostgresBinding,\n id: serverPostgresFilter.id,\n })\n } else {\n this.unsubscribe()\n this.state = CHANNEL_STATES.errored\n\n callback?.(\n REALTIME_SUBSCRIBE_STATES.CHANNEL_ERROR,\n new Error('mismatch between server and client bindings for postgres changes')\n )\n return\n }\n }\n\n this.bindings.postgres_changes = newPostgresBindings\n\n callback && callback(REALTIME_SUBSCRIBE_STATES.SUBSCRIBED)\n return\n }\n })\n .receive('error', (error: { [key: string]: any }) => {\n this.state = CHANNEL_STATES.errored\n callback?.(\n REALTIME_SUBSCRIBE_STATES.CHANNEL_ERROR,\n new Error(JSON.stringify(Object.values(error).join(', ') || 'error'))\n )\n return\n })\n .receive('timeout', () => {\n callback?.(REALTIME_SUBSCRIBE_STATES.TIMED_OUT)\n return\n })\n }\n return this\n }\n\n /**\n * Returns the current presence state for this channel.\n *\n * The shape is a map keyed by presence key (for example a user id) where each entry contains the\n * tracked metadata for that user.\n */\n presenceState<T extends { [key: string]: any } = {}>(): RealtimePresenceState<T> {\n return this.presence.state as RealtimePresenceState<T>\n }\n\n /**\n * Sends the supplied payload to the presence tracker so other subscribers can see that this\n * client is online. Use `untrack` to stop broadcasting presence for the same key.\n */\n async track(\n payload: { [key: string]: any },\n opts: { [key: string]: any } = {}\n ): Promise<RealtimeChannelSendResponse> {\n return await this.send(\n {\n type: 'presence',\n event: 'track',\n payload,\n },\n opts.timeout || this.timeout\n )\n }\n\n /**\n * Removes the current presence state for this client.\n */\n async untrack(opts: { [key: string]: any } = {}): Promise<RealtimeChannelSendResponse> {\n return await this.send(\n {\n type: 'presence',\n event: 'untrack',\n },\n opts\n )\n }\n\n /**\n * Creates an event handler that listens to changes.\n */\n on(\n type: `${REALTIME_LISTEN_TYPES.PRESENCE}`,\n filter: { event: `${REALTIME_PRESENCE_LISTEN_EVENTS.SYNC}` },\n callback: () => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.PRESENCE}`,\n filter: { event: `${REALTIME_PRESENCE_LISTEN_EVENTS.JOIN}` },\n callback: (payload: RealtimePresenceJoinPayload<T>) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.PRESENCE}`,\n filter: { event: `${REALTIME_PRESENCE_LISTEN_EVENTS.LEAVE}` },\n callback: (payload: RealtimePresenceLeavePayload<T>) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.POSTGRES_CHANGES}`,\n filter: RealtimePostgresChangesFilter<`${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.ALL}`>,\n callback: (payload: RealtimePostgresChangesPayload<T>) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.POSTGRES_CHANGES}`,\n filter: RealtimePostgresChangesFilter<`${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.INSERT}`>,\n callback: (payload: RealtimePostgresInsertPayload<T>) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.POSTGRES_CHANGES}`,\n filter: RealtimePostgresChangesFilter<`${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.UPDATE}`>,\n callback: (payload: RealtimePostgresUpdatePayload<T>) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.POSTGRES_CHANGES}`,\n filter: RealtimePostgresChangesFilter<`${REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.DELETE}`>,\n callback: (payload: RealtimePostgresDeletePayload<T>) => void\n ): RealtimeChannel\n /**\n * The following is placed here to display on supabase.com/docs/reference/javascript/subscribe.\n * @param type One of \"broadcast\", \"presence\", or \"postgres_changes\".\n * @param filter Custom object specific to the Realtime feature detailing which payloads to receive.\n * @param callback Function to be invoked when event handler is triggered.\n */\n on(\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`,\n filter: { event: string },\n callback: (payload: {\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`\n event: string\n meta?: {\n replayed?: boolean\n id: string\n }\n [key: string]: any\n }) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`,\n filter: { event: string },\n callback: (payload: {\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`\n event: string\n meta?: {\n replayed?: boolean\n id: string\n }\n payload: T\n }) => void\n ): RealtimeChannel\n on<T extends Record<string, unknown>>(\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`,\n filter: { event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.ALL },\n callback: (payload: {\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`\n event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.ALL\n payload: RealtimeBroadcastPayload<T>\n }) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`,\n filter: { event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.INSERT },\n callback: (payload: {\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`\n event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.INSERT\n payload: RealtimeBroadcastInsertPayload<T>\n }) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`,\n filter: { event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.UPDATE },\n callback: (payload: {\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`\n event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.UPDATE\n payload: RealtimeBroadcastUpdatePayload<T>\n }) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`,\n filter: { event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.DELETE },\n callback: (payload: {\n type: `${REALTIME_LISTEN_TYPES.BROADCAST}`\n event: REALTIME_POSTGRES_CHANGES_LISTEN_EVENT.DELETE\n payload: RealtimeBroadcastDeletePayload<T>\n }) => void\n ): RealtimeChannel\n on<T extends { [key: string]: any }>(\n type: `${REALTIME_LISTEN_TYPES.SYSTEM}`,\n filter: {},\n callback: (payload: any) => void\n ): RealtimeChannel\n on(\n type: `${REALTIME_LISTEN_TYPES}`,\n filter: { event: string; [key: string]: string },\n callback: (payload: any) => void\n ): RealtimeChannel {\n if (this.state === CHANNEL_STATES.joined && type === REALTIME_LISTEN_TYPES.PRESENCE) {\n this.socket.log(\n 'channel',\n `resubscribe to ${this.topic} due to change in presence callbacks on joined channel`\n )\n this.unsubscribe().then(async () => await this.subscribe())\n }\n return this._on(type, filter, callback)\n }\n /**\n * Sends a broadcast message explicitly via REST API.\n *\n * This method always uses the REST API endpoint regardless of WebSocket connection state.\n * Useful when you want to guarantee REST delivery or when gradually migrating from implicit REST fallback.\n *\n * @param event The name of the broadcast event\n * @param payload Payload to be sent (required)\n * @param opts Options including timeout\n * @returns Promise resolving to object with success status, and error details if failed\n */\n async httpSend(\n event: string,\n payload: any,\n opts: { timeout?: number } = {}\n ): Promise<{ success: true } | { success: false; status: number; error: string }> {\n if (payload === undefined || payload === null) {\n return Promise.reject('Payload is required for httpSend()')\n }\n\n const headers: Record<string, string> = {\n apikey: this.socket.apiKey ? this.socket.apiKey : '',\n 'Content-Type': 'application/json',\n }\n\n if (this.socket.accessTokenValue) {\n headers['Authorization'] = `Bearer ${this.socket.accessTokenValue}`\n }\n\n const options = {\n method: 'POST',\n headers,\n body: JSON.stringify({\n messages: [\n {\n topic: this.subTopic,\n event,\n payload: payload,\n private: this.private,\n },\n ],\n }),\n }\n\n const response = await this._fetchWithTimeout(\n this.broadcastEndpointURL,\n options,\n opts.timeout ?? this.timeout\n )\n\n if (response.status === 202) {\n return { success: true }\n }\n\n let errorMessage = response.statusText\n try {\n const errorBody = await response.json()\n errorMessage = errorBody.error || errorBody.message || errorMessage\n } catch {}\n\n return Promise.reject(new Error(errorMessage))\n }\n\n /**\n * Sends a message into the channel.\n *\n * @param args Arguments to send to channel\n * @param args.type The type of event to send\n * @param args.event The name of the event being sent\n * @param args.payload Payload to be sent\n * @param opts Options to be used during the send process\n */\n async send(\n args: {\n type: 'broadcast' | 'presence' | 'postgres_changes'\n event: string\n payload?: any\n [key: string]: any\n },\n opts: { [key: string]: any } = {}\n ): Promise<RealtimeChannelSendResponse> {\n if (!this._canPush() && args.type === 'broadcast') {\n console.warn(\n 'Realtime send() is automatically falling back to REST API. ' +\n 'This behavior will be deprecated in the future. ' +\n 'Please use httpSend() explicitly for REST delivery.'\n )\n\n const { event, payload: endpoint_payload } = args\n const headers: Record<string, string> = {\n apikey: this.socket.apiKey ? this.socket.apiKey : '',\n 'Content-Type': 'application/json',\n }\n\n if (this.socket.accessTokenValue) {\n headers['Authorization'] = `Bearer ${this.socket.accessTokenValue}`\n }\n\n const options = {\n method: 'POST',\n headers,\n body: JSON.stringify({\n messages: [\n {\n topic: this.subTopic,\n event,\n payload: endpoint_payload,\n private: this.private,\n },\n ],\n }),\n }\n\n try {\n const response = await this._fetchWithTimeout(\n this.broadcastEndpointURL,\n options,\n opts.timeout ?? this.timeout\n )\n\n await response.body?.cancel()\n return response.ok ? 'ok' : 'error'\n } catch (error: any) {\n if (error.name === 'AbortError') {\n return 'timed out'\n } else {\n return 'error'\n }\n }\n } else {\n return new Promise((resolve) => {\n const push = this._push(args.type, args, opts.timeout || this.timeout)\n\n if (args.type === 'broadcast' && !this.params?.config?.broadcast?.ack) {\n resolve('ok')\n }\n\n push.receive('ok', () => resolve('ok'))\n push.receive('error', () => resolve('error'))\n push.receive('timeout', () => resolve('timed out'))\n })\n }\n }\n\n /**\n * Updates the payload that will be sent the next time the channel joins (reconnects).\n * Useful for rotating access tokens or updating config without re-creating the channel.\n */\n updateJoinPayload(payload: { [key: string]: any }): void {\n this.joinPush.updatePayload(payload)\n }\n\n /**\n * Leaves the channel.\n *\n * Unsubscribes from server events, and instructs channel to terminate on server.\n * Triggers onClose() hooks.\n *\n * To receive leave acknowledgements, use the a `receive` hook to bind to the server ack, ie:\n * channel.unsubscribe().receive(\"ok\", () => alert(\"left!\") )\n */\n unsubscribe(timeout = this.timeout): Promise<'ok' | 'timed out' | 'error'> {\n this.state = CHANNEL_STATES.leaving\n const onClose = () => {\n this.socket.log('channel', `leave ${this.topic}`)\n this._trigger(CHANNEL_EVENTS.close, 'leave', this._joinRef())\n }\n\n this.joinPush.destroy()\n\n let leavePush: Push | null = null\n\n return new Promise<RealtimeChannelSendResponse>((resolve) => {\n leavePush = new Push(this, CHANNEL_EVENTS.leave, {}, timeout)\n leavePush\n .receive('ok', () => {\n onClose()\n resolve('ok')\n })\n .receive('timeout', () => {\n onClose()\n resolve('timed out')\n })\n .receive('error', () => {\n resolve('error')\n })\n\n leavePush.send()\n if (!this._canPush()) {\n leavePush.trigger('ok', {})\n }\n }).finally(() => {\n leavePush?.destroy()\n })\n }\n /**\n * Teardown the channel.\n *\n * Destroys and stops related timers.\n */\n teardown() {\n this.pushBuffer.forEach((push: Push) => push.destroy())\n this.pushBuffer = []\n this.rejoinTimer.reset()\n this.joinPush.destroy()\n this.state = CHANNEL_STATES.closed\n this.bindings = {}\n }\n\n /** @internal */\n\n async _fetchWithTimeout(url: string, options: { [key: string]: any }, timeout: number) {\n const controller = new AbortController()\n const id = setTimeout(() => controller.abort(), timeout)\n\n const response = await this.socket.fetch(url, {\n ...options,\n signal: controller.signal,\n })\n\n clearTimeout(id)\n\n return response\n }\n\n /** @internal */\n _push(event: string, payload: { [key: string]: any }, timeout = this.timeout) {\n if (!this.joinedOnce) {\n throw `tried to push '${event}' to '${this.topic}' before joining. Use channel.subscribe() before pushing events`\n }\n let pushEvent = new Push(this, event, payload, timeout)\n if (this._canPush()) {\n pushEvent.send()\n } else {\n this._addToPushBuffer(pushEvent)\n }\n\n return pushEvent\n }\n\n /** @internal */\n _addToPushBuffer(pushEvent: Push) {\n pushEvent.startTimeout()\n this.pushBuffer.push(pushEvent)\n\n // Enforce buffer size limit\n if (this.pushBuffer.length > MAX_PUSH_BUFFER_SIZE) {\n const removedPush = this.pushBuffer.shift()\n if (removedPush) {\n removedPush.destroy()\n this.socket.log(\n 'channel',\n `discarded push due to buffer overflow: ${removedPush.event}`,\n removedPush.payload\n )\n }\n }\n }\n\n /**\n * Overridable message hook\n *\n * Receives all events for specialized message handling before dispatching to the channel callbacks.\n * Must return the payload, modified or unmodified.\n *\n * @internal\n */\n _onMessage(_event: string, payload: any, _ref?: string) {\n return payload\n }\n\n /** @internal */\n _isMember(topic: string): boolean {\n return this.topic === topic\n }\n\n /** @internal */\n _joinRef(): string {\n return this.joinPush.ref\n }\n\n /** @internal */\n _trigger(type: string, payload?: any, ref?: string) {\n const typeLower = type.toLocaleLowerCase()\n const { close, error, leave, join } = CHANNEL_EVENTS\n const events: string[] = [close, error, leave, join]\n if (ref && events.indexOf(typeLower) >= 0 && ref !== this._joinRef()) {\n return\n }\n let handledPayload = this._onMessage(typeLower, payload, ref)\n if (payload && !handledPayload) {\n throw 'channel onMessage callbacks must return the payload, modified or unmodified'\n }\n\n if (['insert', 'update', 'delete'].includes(typeLower)) {\n this.bindings.postgres_changes\n ?.filter((bind) => {\n return bind.filter?.event === '*' || bind.filter?.event?.toLocaleLowerCase() === typeLower\n })\n .map((bind) => bind.callback(handledPayload, ref))\n } else {\n this.bindings[typeLower]\n ?.filter((bind) => {\n if (['broadcast', 'presence', 'postgres_changes'].includes(typeLower)) {\n if ('id' in bind) {\n const bindId = bind.id\n const bindEvent = bind.filter?.event\n return (\n bindId &&\n payload.ids?.includes(bindId) &&\n (bindEvent === '*' ||\n bindEvent?.toLocaleLowerCase() === payload.data?.type.toLocaleLowerCase()) &&\n (!bind.filter?.table || bind.filter.table === payload.data?.table)\n )\n } else {\n const bindEvent = bind?.filter?.event?.toLocaleLowerCase()\n return bindEvent === '*' || bindEvent === payload?.event?.toLocaleLowerCase()\n }\n } else {\n return bind.type.toLocaleLowerCase() === typeLower\n }\n })\n .map((bind) => {\n if (typeof handledPayload === 'object' && 'ids' in handledPayload) {\n const postgresChanges = handledPayload.data\n const { schema, table, commit_timestamp, type, errors } = postgresChanges\n const enrichedPayload = {\n schema: schema,\n table: table,\n commit_timestamp: commit_timestamp,\n eventType: type,\n new: {},\n old: {},\n errors: errors,\n }\n handledPayload = {\n ...enrichedPayload,\n ...this._getPayloadRecords(postgresChanges),\n }\n }\n bind.callback(handledPayload, ref)\n })\n }\n }\n\n /** @internal */\n _isClosed(): boolean {\n return this.state === CHANNEL_STATES.closed\n }\n\n /** @internal */\n _isJoined(): boolean {\n return this.state === CHANNEL_STATES.joined\n }\n\n /** @internal */\n _isJoining(): boolean {\n return this.state === CHANNEL_STATES.joining\n }\n\n /** @internal */\n _isLeaving(): boolean {\n return this.state === CHANNEL_STATES.leaving\n }\n\n /** @internal */\n _replyEventName(ref: string): string {\n return `chan_reply_${ref}`\n }\n\n /** @internal */\n _on(type: string, filter: { [key: string]: any }, callback: Function) {\n const typeLower = type.toLocaleLowerCase()\n const binding = {\n type: typeLower,\n filter: filter,\n callback: callback,\n }\n\n if (this.bindings[typeLower]) {\n this.bindings[typeLower].push(binding)\n } else {\n this.bindings[typeLower] = [binding]\n }\n\n return this\n }\n\n /** @internal */\n _off(type: string, filter: { [key: string]: any }) {\n const typeLower = type.toLocaleLowerCase()\n\n if (this.bindings[typeLower]) {\n this.bindings[typeLower] = this.bindings[typeLower].filter((bind) => {\n return !(\n bind.type?.toLocaleLowerCase() === typeLower &&\n RealtimeChannel.isEqual(bind.filter, filter)\n )\n })\n }\n return this\n }\n\n /** @internal */\n private static isEqual(obj1: { [key: string]: string }, obj2: { [key: string]: string }) {\n if (Object.keys(obj1).length !== Object.keys(obj2).length) {\n return false\n }\n\n for (const k in obj1) {\n if (obj1[k] !== obj2[k]) {\n return false\n }\n }\n\n return true\n }\n\n /**\n * Compares two optional filter values for equality.\n * Treats undefined, null, and empty string as equivalent empty values.\n * @internal\n */\n private static isFilterValueEqual(\n serverValue: string | undefined | null,\n clientValue: string | undefined\n ): boolean {\n const normalizedServer = serverValue ?? undefined\n const normalizedClient = clientValue ?? undefined\n return normalizedServer === normalizedClient\n }\n\n /** @internal */\n private _rejoinUntilConnected() {\n this.rejoinTimer.scheduleTimeout()\n if (this.socket.isConnected()) {\n this._rejoin()\n }\n }\n\n /**\n * Registers a callback that will be executed when the channel closes.\n *\n * @internal\n */\n private _onClose(callback: Function) {\n this._on(CHANNEL_EVENTS.close, {}, callback)\n }\n\n /**\n * Registers a callback that will be executed when the channel encounteres an error.\n *\n * @internal\n */\n private _onError(callback: Function) {\n this._on(CHANNEL_EVENTS.error, {}, (reason: string) => callback(reason))\n }\n\n /**\n * Returns `true` if the socket is connected and the channel has been joined.\n *\n * @internal\n */\n private _canPush(): boolean {\n return this.socket.isConnected() && this._isJoined()\n }\n\n /** @internal */\n private _rejoin(timeout = this.timeout): void {\n if (this._isLeaving()) {\n return\n }\n this.socket._leaveOpenTopic(this.topic)\n this.state = CHANNEL_STATES.joining\n this.joinPush.resend(timeout)\n }\n\n /** @internal */\n private _getPayloadRecords(payload: any) {\n const records = {\n new: {},\n old: {},\n }\n\n if (payload.type === 'INSERT' || payload.type === 'UPDATE') {\n records.new = Transformers.convertChangeData(payload.columns, payload.record)\n }\n\n if (payload.type === 'UPDATE' || payload.type === 'DELETE') {\n records.old = Transformers.convertChangeData(payload.columns, payload.old_record)\n }\n\n return records\n }\n}\n","import WebSocketFactory, { WebSocketLike } from './lib/websocket-factory'\n\nimport {\n CHANNEL_EVENTS,\n CONNECTION_STATE,\n DEFAULT_VERSION,\n DEFAULT_TIMEOUT,\n SOCKET_STATES,\n TRANSPORTS,\n DEFAULT_VSN,\n VSN_1_0_0,\n VSN_2_0_0,\n WS_CLOSE_NORMAL,\n} from './lib/constants'\n\nimport Serializer from './lib/serializer'\nimport Timer from './lib/timer'\n\nimport { httpEndpointURL } from './lib/transformers'\nimport RealtimeChannel from './RealtimeChannel'\nimport type { RealtimeChannelOptions } from './RealtimeChannel'\n\ntype Fetch = typeof fetch\n\nexport type Channel = {\n name: string\n inserted_at: string\n updated_at: string\n id: number\n}\nexport type LogLevel = 'info' | 'warn' | 'error'\n\nexport type RealtimeMessage = {\n topic: string\n event: string\n payload: any\n ref: string\n join_ref?: string\n}\n\nexport type RealtimeRemoveChannelResponse = 'ok' | 'timed out' | 'error'\nexport type HeartbeatStatus = 'sent' | 'ok' | 'error' | 'timeout' | 'disconnected'\n\nconst noop = () => {}\n\ntype RealtimeClientState = 'connecting' | 'connected' | 'disconnecting' | 'disconnected'\n\n// Connection-related constants\nconst CONNECTION_TIMEOUTS = {\n HEARTBEAT_INTERVAL: 25000,\n RECONNECT_DELAY: 10,\n HEARTBEAT_TIMEOUT_FALLBACK: 100,\n} as const\n\nconst RECONNECT_INTERVALS = [1000, 2000, 5000, 10000] as const\nconst DEFAULT_RECONNECT_FALLBACK = 10000\n\n/**\n * Minimal WebSocket constructor interface that RealtimeClient can work with.\n * Supply a compatible implementation (native WebSocket, `ws`, etc) when running outside the browser.\n */\nexport interface WebSocketLikeConstructor {\n new (address: string | URL, subprotocols?: string | string[] | undefined): WebSocketLike\n // Allow additional properties that may exist on WebSocket constructors\n [key: string]: any\n}\n\nexport interface WebSocketLikeError {\n error: any\n message: string\n type: string\n}\n\nexport type RealtimeClientOptions = {\n transport?: WebSocketLikeConstructor\n timeout?: number\n heartbeatIntervalMs?: number\n heartbeatCallback?: (status: HeartbeatStatus, latency?: number) => void\n vsn?: string\n logger?: Function\n encode?: Function\n decode?: Function\n reconnectAfterMs?: Function\n headers?: { [key: string]: string }\n params?: { [key: string]: any }\n //Deprecated: Use it in favour of correct casing `logLevel`\n log_level?: LogLevel\n logLevel?: LogLevel\n fetch?: Fetch\n worker?: boolean\n workerUrl?: string\n accessToken?: () => Promise<string | null>\n}\n\nconst WORKER_SCRIPT = `\n addEventListener(\"message\", (e) => {\n if (e.data.event === \"start\") {\n setInterval(() => postMessage({ event: \"keepAlive\" }), e.data.interval);\n }\n });`\n\nexport default class RealtimeClient {\n accessTokenValue: string | null = null\n apiKey: string | null = null\n private _manuallySetToken: boolean = false\n channels: RealtimeChannel[] = new Array()\n endPoint: string = ''\n httpEndpoint: string = ''\n /** @deprecated headers cannot be set on websocket connections */\n headers?: { [key: string]: string } = {}\n params?: { [key: string]: string } = {}\n timeout: number = DEFAULT_TIMEOUT\n transport: WebSocketLikeConstructor | null = null\n heartbeatIntervalMs: number = CONNECTION_TIMEOUTS.HEARTBEAT_INTERVAL\n heartbeatTimer: ReturnType<typeof setInterval> | undefined = undefined\n pendingHeartbeatRef: string | null = null\n heartbeatCallback: (status: HeartbeatStatus, latency?: number) => void = noop\n ref: number = 0\n reconnectTimer: Timer | null = null\n vsn: string = DEFAULT_VSN\n logger: Function = noop\n logLevel?: LogLevel\n encode!: Function\n decode!: Function\n reconnectAfterMs!: Function\n conn: WebSocketLike | null = null\n sendBuffer: Function[] = []\n serializer: Serializer = new Serializer()\n stateChangeCallbacks: {\n open: Function[]\n close: Function[]\n error: Function[]\n message: Function[]\n } = {\n open: [],\n close: [],\n error: [],\n message: [],\n }\n fetch: Fetch\n accessToken: (() => Promise<string | null>) | null = null\n worker?: boolean\n workerUrl?: string\n workerRef?: Worker\n private _connectionState: RealtimeClientState = 'disconnected'\n private _wasManualDisconnect: boolean = false\n private _authPromise: Promise<void> | null = null\n private _heartbeatSentAt: number | null = null\n\n /**\n * Initializes the Socket.\n *\n * @param endPoint The string WebSocket endpoint, ie, \"ws://example.com/socket\", \"wss://example.com\", \"/socket\" (inherited host & protocol)\n * @param httpEndpoint The string HTTP endpoint, ie, \"https://example.com\", \"/\" (inherited host & protocol)\n * @param options.transport The Websocket Transport, for example WebSocket. This can be a custom implementation\n * @param options.timeout The default timeout in milliseconds to trigger push timeouts.\n * @param options.params The optional params to pass when connecting.\n * @param options.headers Deprecated: headers cannot be set on websocket connections and this option will be removed in the future.\n * @param options.heartbeatIntervalMs The millisec interval to send a heartbeat message.\n * @param options.heartbeatCallback The optional function to handle heartbeat status and latency.\n * @param options.logger The optional function for specialized logging, ie: logger: (kind, msg, data) => { console.log(`${kind}: ${msg}`, data) }\n * @param options.logLevel Sets the log level for Realtime\n * @param options.encode The function to encode outgoing messages. Defaults to JSON: (payload, callback) => callback(JSON.stringify(payload))\n * @param options.decode The function to decode incoming messages. Defaults to Serializer's decode.\n * @param options.reconnectAfterMs he optional function that returns the millsec reconnect interval. Defaults to stepped backoff off.\n * @param options.worker Use Web Worker to set a side flow. Defaults to false.\n * @param options.workerUrl The URL of the worker script. Defaults to https://realtime.supabase.com/worker.js that includes a heartbeat event call to keep the connection alive.\n * @example\n * ```ts\n * import RealtimeClient from '@supabase/realtime-js'\n *\n * const client = new RealtimeClient('https://xyzcompany.supabase.co/realtime/v1', {\n * params: { apikey: 'public-anon-key' },\n * })\n * client.connect()\n * ```\n */\n constructor(endPoint: string, options?: RealtimeClientOptions) {\n // Validate required parameters\n if (!options?.params?.apikey) {\n throw new Error('API key is required to connect to Realtime')\n }\n this.apiKey = options.params.apikey\n\n // Initialize endpoint URLs\n this.endPoint = `${endPoint}/${TRANSPORTS.websocket}`\n this.httpEndpoint = httpEndpointURL(endPoint)\n\n this._initializeOptions(options)\n this._setupReconnectionTimer()\n this.fetch = this._resolveFetch(options?.fetch)\n }\n\n /**\n * Connects the socket, unless already connected.\n */\n connect(): void {\n // Skip if already connecting, disconnecting, or connected\n if (\n this.isConnecting() ||\n this.isDisconnecting() ||\n (this.conn !== null && this.isConnected())\n ) {\n return\n }\n\n this._setConnectionState('connecting')\n\n // Trigger auth if needed and not already in progress\n // This ensures auth is called for standalone RealtimeClient usage\n // while avoiding race conditions with SupabaseClient's immediate setAuth call\n if (this.accessToken && !this._authPromise) {\n this._setAuthSafely('connect')\n }\n\n // Establish WebSocket connection\n if (this.transport) {\n // Use custom transport if provided\n this.conn = new this.transport(this.endpointURL()) as WebSocketLike\n } else {\n // Try to use native WebSocket\n try {\n this.conn = WebSocketFactory.createWebSocket(this.endpointURL())\n } catch (error) {\n this._setConnectionState('disconnected')\n const errorMessage = (error as Error).message\n\n // Provide helpful error message based on environment\n if (errorMessage.includes('Node.js')) {\n throw new Error(\n `${errorMessage}\\n\\n` +\n 'To use Realtime in Node.js, you need to provide a WebSocket implementation:\\n\\n' +\n 'Option 1: Use Node.js 22+ which has native WebSocket support\\n' +\n 'Option 2: Install and provide the \"ws\" package:\\n\\n' +\n ' npm install ws\\n\\n' +\n ' import ws from \"ws\"\\n' +\n ' const client = new RealtimeClient(url, {\\n' +\n ' ...options,\\n' +\n ' transport: ws\\n' +\n ' })'\n )\n }\n throw new Error(`WebSocket not available: ${errorMessage}`)\n }\n }\n this._setupConnectionHandlers()\n }\n\n /**\n * Returns the URL of the websocket.\n * @returns string The URL of the websocket.\n */\n endpointURL(): string {\n return this._appendParams(this.endPoint, Object.assign({}, this.params, { vsn: this.vsn }))\n }\n\n /**\n * Disconnects the socket.\n *\n * @param code A numeric status code to send on disconnect.\n * @param reason A custom reason for the disconnect.\n */\n disconnect(code?: number, reason?: string): void {\n if (this.isDisconnecting()) {\n return\n }\n\n this._setConnectionState('disconnecting', true)\n\n if (this.conn) {\n // Setup fallback timer to prevent hanging in disconnecting state\n const fallbackTimer = setTimeout(() => {\n this._setConnectionState('disconnected')\n }, 100)\n\n this.conn.onclose = () => {\n clearTimeout(fallbackTimer)\n this._setConnectionState('disconnected')\n }\n\n // Close the WebSocket connection if close method exists\n if (typeof this.conn.close === 'function') {\n if (code) {\n this.conn.close(code, reason ?? '')\n } else {\n this.conn.close()\n }\n }\n\n this._teardownConnection()\n } else {\n this._setConnectionState('disconnected')\n }\n }\n\n /**\n * Returns all created channels\n */\n getChannels(): RealtimeChannel[] {\n return this.channels\n }\n\n /**\n * Unsubscribes and removes a single channel\n * @param channel A RealtimeChannel instance\n */\n async removeChannel(channel: RealtimeChannel): Promise<RealtimeRemoveChannelResponse> {\n const status = await channel.unsubscribe()\n\n if (this.channels.length === 0) {\n this.disconnect()\n }\n\n return status\n }\n\n /**\n * Unsubscribes and removes all channels\n */\n async removeAllChannels(): Promise<RealtimeRemoveChannelResponse[]> {\n const values_1 = await Promise.all(this.channels.map((channel) => channel.unsubscribe()))\n this.channels = []\n this.disconnect()\n return values_1\n }\n\n /**\n * Logs the message.\n *\n * For customized logging, `this.logger` can be overridden.\n */\n log(kind: string, msg: string, data?: any) {\n this.logger(kind, msg, data)\n }\n\n /**\n * Returns the current state of the socket.\n */\n connectionState(): CONNECTION_STATE {\n switch (this.conn && this.conn.readyState) {\n case SOCKET_STATES.connecting:\n return CONNECTION_STATE.Connecting\n case SOCKET_STATES.open:\n return CONNECTION_STATE.Open\n case SOCKET_STATES.closing:\n return CONNECTION_STATE.Closing\n default:\n return CONNECTION_STATE.Closed\n }\n }\n\n /**\n * Returns `true` is the connection is open.\n */\n isConnected(): boolean {\n return this.connectionState() === CONNECTION_STATE.Open\n }\n\n /**\n * Returns `true` if the connection is currently connecting.\n */\n isConnecting(): boolean {\n return this._connectionState === 'connecting'\n }\n\n /**\n * Returns `true` if the connection is currently disconnecting.\n */\n isDisconnecting(): boolean {\n return this._connectionState === 'disconnecting'\n }\n\n /**\n * Creates (or reuses) a {@link RealtimeChannel} for the provided topic.\n *\n * Topics are automatically prefixed with `realtime:` to match the Realtime service.\n * If a channel with the same topic already exists it will be returned instead of creating\n * a duplicate connection.\n */\n channel(topic: string, params: RealtimeChannelOptions = { config: {} }): RealtimeChannel {\n const realtimeTopic = `realtime:${topic}`\n const exists = this.getChannels().find((c: RealtimeChannel) => c.topic === realtimeTopic)\n\n if (!exists) {\n const chan = new RealtimeChannel(`realtime:${topic}`, params, this)\n this.channels.push(chan)\n\n return chan\n } else {\n return exists\n }\n }\n\n /**\n * Push out a message if the socket is connected.\n *\n * If the socket is not connected, the message gets enqueued within a local buffer, and sent out when a connection is next established.\n */\n push(data: RealtimeMessage): void {\n const { topic, event, payload, ref } = data\n const callback = () => {\n this.encode(data, (result: any) => {\n this.conn?.send(result)\n })\n }\n this.log('push', `${topic} ${event} (${ref})`, payload)\n if (this.isConnected()) {\n callback()\n } else {\n this.sendBuffer.push(callback)\n }\n }\n\n /**\n * Sets the JWT access token used for channel subscription authorization and Realtime RLS.\n *\n * If param is null it will use the `accessToken` callback function or the token set on the client.\n *\n * On callback used, it will set the value of the token internal to the client.\n *\n * When a token is explicitly provided, it will be preserved across channel operations\n * (including removeChannel and resubscribe). The `accessToken` callback will not be\n * invoked until `setAuth()` is called without arguments.\n *\n * @param token A JWT string to override the token set on the client.\n *\n * @example\n * // Use a manual token (preserved across resubscribes, ignores accessToken callback)\n * client.realtime.setAuth('my-custom-jwt')\n *\n * // Switch back to using the accessToken callback\n * client.realtime.setAuth()\n */\n async setAuth(token: string | null = null): Promise<void> {\n this._authPromise = this._performAuth(token)\n try {\n await this._authPromise\n } finally {\n this._authPromise = null\n }\n }\n\n /**\n * Returns true if the current access token was explicitly set via setAuth(token),\n * false if it was obtained via the accessToken callback.\n * @internal\n */\n _isManualToken(): boolean {\n return this._manuallySetToken\n }\n\n /**\n * Sends a heartbeat message if the socket is connected.\n */\n async sendHeartbeat() {\n if (!this.isConnected()) {\n try {\n this.heartbeatCallback('disconnected')\n } catch (e) {\n this.log('error', 'error in heartbeat callback', e)\n }\n return\n }\n\n // Handle heartbeat timeout and force reconnection if needed\n if (this.pendingHeartbeatRef) {\n this.pendingHeartbeatRef = null\n this._heartbeatSentAt = null\n this.log('transport', 'heartbeat timeout. Attempting to re-establish connection')\n try {\n this.heartbeatCallback('timeout')\n } catch (e) {\n this.log('error', 'error in heartbeat callback', e)\n }\n\n // Force reconnection after heartbeat timeout\n this._wasManualDisconnect = false\n this.conn?.close(WS_CLOSE_NORMAL, 'heartbeat timeout')\n\n setTimeout(() => {\n if (!this.isConnected()) {\n this.reconnectTimer?.scheduleTimeout()\n }\n }, CONNECTION_TIMEOUTS.HEARTBEAT_TIMEOUT_FALLBACK)\n return\n }\n\n // Send heartbeat message to server\n this._heartbeatSentAt = Date.now()\n this.pendingHeartbeatRef = this._makeRef()\n this.push({\n topic: 'phoenix',\n event: 'heartbeat',\n payload: {},\n ref: this.pendingHeartbeatRef,\n })\n try {\n this.heartbeatCallback('sent')\n } catch (e) {\n this.log('error', 'error in heartbeat callback', e)\n }\n\n this._setAuthSafely('heartbeat')\n }\n\n /**\n * Sets a callback that receives lifecycle events for internal heartbeat messages.\n * Useful for instrumenting connection health (e.g. sent/ok/timeout/disconnected).\n */\n onHeartbeat(callback: (status: HeartbeatStatus, latency?: number) => void): void {\n this.heartbeatCallback = callback\n }\n /**\n * Flushes send buffer\n */\n flushSendBuffer() {\n if (this.isConnected() && this.sendBuffer.length > 0) {\n this.sendBuffer.forEach((callback) => callback())\n this.sendBuffer = []\n }\n }\n\n /**\n * Use either custom fetch, if provided, or default fetch to make HTTP requests\n *\n * @internal\n */\n _resolveFetch = (customFetch?: Fetch): Fetch => {\n if (customFetch) {\n return (...args) => customFetch(...args)\n }\n return (...args) => fetch(...args)\n }\n\n /**\n * Return the next message ref, accounting for overflows\n *\n * @internal\n */\n _makeRef(): string {\n let newRef = this.ref + 1\n if (newRef === this.ref) {\n this.ref = 0\n } else {\n this.ref = newRef\n }\n\n return this.ref.toString()\n }\n\n /**\n * Unsubscribe from channels with the specified topic.\n *\n * @internal\n */\n _leaveOpenTopic(topic: string): void {\n let dupChannel = this.channels.find(\n (c) => c.topic === topic && (c._isJoined() || c._isJoining())\n )\n if (dupChannel) {\n this.log('transport', `leaving duplicate topic \"${topic}\"`)\n dupChannel.unsubscribe()\n }\n }\n\n /**\n * Removes a subscription from the socket.\n *\n * @param channel An open subscription.\n *\n * @internal\n */\n _remove(channel: RealtimeChannel) {\n this.channels = this.channels.filter((c) => c.topic !== channel.topic)\n }\n\n /** @internal */\n private _onConnMessage(rawMessage: { data: any }) {\n this.decode(rawMessage.data, (msg: RealtimeMessage) => {\n // Handle heartbeat responses\n if (\n msg.topic === 'phoenix' &&\n msg.event === 'phx_reply' &&\n msg.ref &&\n msg.ref === this.pendingHeartbeatRef\n ) {\n const latency = this._heartbeatSentAt ? Date.now() - this._heartbeatSentAt : undefined\n try {\n this.heartbeatCallback(msg.payload.status === 'ok' ? 'ok' : 'error', latency)\n } catch (e) {\n this.log('error', 'error in heartbeat callback', e)\n }\n this._heartbeatSentAt = null\n this.pendingHeartbeatRef = null\n }\n\n // Log incoming message\n const { topic, event, payload, ref } = msg\n const refString = ref ? `(${ref})` : ''\n const status = payload.status || ''\n this.log('receive', `${status} ${topic} ${event} ${refString}`.trim(), payload)\n\n // Route message to appropriate channels\n this.channels\n .filter((channel: RealtimeChannel) => channel._isMember(topic))\n .forEach((channel: RealtimeChannel) => channel._trigger(event, payload, ref))\n\n this._triggerStateCallbacks('message', msg)\n })\n }\n\n /**\n * Clear specific timer\n * @internal\n */\n private _clearTimer(timer: 'heartbeat' | 'reconnect'): void {\n if (timer === 'heartbeat' && this.heartbeatTimer) {\n clearInterval(this.heartbeatTimer)\n this.heartbeatTimer = undefined\n } else if (timer === 'reconnect') {\n this.reconnectTimer?.reset()\n }\n }\n\n /**\n * Clear all timers\n * @internal\n */\n private _clearAllTimers(): void {\n this._clearTimer('heartbeat')\n this._clearTimer('reconnect')\n }\n\n /**\n * Setup connection handlers for WebSocket events\n * @internal\n */\n private _setupConnectionHandlers(): void {\n if (!this.conn) return\n\n // Set binary type if supported (browsers and most WebSocket implementations)\n if ('binaryType' in this.conn) {\n ;(this.conn as any).binaryType = 'arraybuffer'\n }\n\n this.conn.onopen = () => this._onConnOpen()\n this.conn.onerror = (error: Event) => this._onConnError(error)\n this.conn.onmessage = (event: any) => this._onConnMessage(event)\n this.conn.onclose = (event: any) => this._onConnClose(event)\n\n if (this.conn.readyState === SOCKET_STATES.open) {\n this._onConnOpen()\n }\n }\n\n /**\n * Teardown connection and cleanup resources\n * @internal\n */\n private _teardownConnection(): void {\n if (this.conn) {\n if (\n this.conn.readyState === SOCKET_STATES.open ||\n this.conn.readyState === SOCKET_STATES.connecting\n ) {\n try {\n this.conn.close()\n } catch (e) {\n this.log('error', 'Error closing connection', e)\n }\n }\n\n this.conn.onopen = null\n this.conn.onerror = null\n this.conn.onmessage = null\n this.conn.onclose = null\n this.conn = null\n }\n this._clearAllTimers()\n this._terminateWorker()\n this.channels.forEach((channel) => channel.teardown())\n }\n\n /** @internal */\n private _onConnOpen() {\n this._setConnectionState('connected')\n this.log('transport', `connected to ${this.endpointURL()}`)\n\n // Wait for any pending auth operations before flushing send buffer\n // This ensures channel join messages include the correct access token\n const authPromise =\n this._authPromise ||\n (this.accessToken && !this.accessTokenValue ? this.setAuth() : Promise.resolve())\n\n authPromise\n .then(() => {\n this.flushSendBuffer()\n })\n .catch((e) => {\n this.log('error', 'error waiting for auth on connect', e)\n // Proceed anyway to avoid hanging connections\n this.flushSendBuffer()\n })\n\n this._clearTimer('reconnect')\n\n if (!this.worker) {\n this._startHeartbeat()\n } else {\n if (!this.workerRef) {\n this._startWorkerHeartbeat()\n }\n }\n\n this._triggerStateCallbacks('open')\n }\n /** @internal */\n private _startHeartbeat() {\n this.heartbeatTimer && clearInterval(this.heartbeatTimer)\n this.heartbeatTimer = setInterval(() => this.sendHeartbeat(), this.heartbeatIntervalMs)\n }\n\n /** @internal */\n private _startWorkerHeartbeat() {\n if (this.workerUrl) {\n this.log('worker', `starting worker for from ${this.workerUrl}`)\n } else {\n this.log('worker', `starting default worker`)\n }\n const objectUrl = this._workerObjectUrl(this.workerUrl!)\n this.workerRef = new Worker(objectUrl)\n this.workerRef.onerror = (error) => {\n this.log('worker', 'worker error', (error as ErrorEvent).message)\n this._terminateWorker()\n }\n this.workerRef.onmessage = (event) => {\n if (event.data.event === 'keepAlive') {\n this.sendHeartbeat()\n }\n }\n this.workerRef.postMessage({\n event: 'start',\n interval: this.heartbeatIntervalMs,\n })\n }\n\n /**\n * Terminate the Web Worker and clear the reference\n * @internal\n */\n private _terminateWorker(): void {\n if (this.workerRef) {\n this.log('worker', 'terminating worker')\n this.workerRef.terminate()\n this.workerRef = undefined\n }\n }\n /** @internal */\n private _onConnClose(event: any) {\n this._setConnectionState('disconnected')\n this.log('transport', 'close', event)\n this._triggerChanError()\n this._clearTimer('heartbeat')\n\n // Only schedule reconnection if it wasn't a manual disconnect\n if (!this._wasManualDisconnect) {\n this.reconnectTimer?.scheduleTimeout()\n }\n\n this._triggerStateCallbacks('close', event)\n }\n\n /** @internal */\n private _onConnError(error: Event) {\n this._setConnectionState('disconnected')\n this.log('transport', `${error}`)\n this._triggerChanError()\n this._triggerStateCallbacks('error', error)\n }\n\n /** @internal */\n private _triggerChanError() {\n this.channels.forEach((channel: RealtimeChannel) => channel._trigger(CHANNEL_EVENTS.error))\n }\n\n /** @internal */\n private _appendParams(url: string, params: { [key: string]: string }): string {\n if (Object.keys(params).length === 0) {\n return url\n }\n const prefix = url.match(/\\?/) ? '&' : '?'\n const query = new URLSearchParams(params)\n return `${url}${prefix}${query}`\n }\n\n private _workerObjectUrl(url: string | undefined): string {\n let result_url: string\n if (url) {\n result_url = url\n } else {\n const blob = new Blob([WORKER_SCRIPT], { type: 'application/javascript' })\n result_url = URL.createObjectURL(blob)\n }\n return result_url\n }\n\n /**\n * Set connection state with proper state management\n * @internal\n */\n private _setConnectionState(state: RealtimeClientState, manual = false): void {\n this._connectionState = state\n\n if (state === 'connecting') {\n this._wasManualDisconnect = false\n } else if (state === 'disconnecting') {\n this._wasManualDisconnect = manual\n }\n }\n\n /**\n * Perform the actual auth operation\n * @internal\n */\n private async _performAuth(token: string | null = null): Promise<void> {\n let tokenToSend: string | null\n let isManualToken = false\n\n if (token) {\n tokenToSend = token\n // Track if this is a manually-provided token\n isManualToken = true\n } else if (this.accessToken) {\n // Call the accessToken callback to get fresh token\n try {\n tokenToSend = await this.accessToken()\n } catch (e) {\n this.log('error', 'Error fetching access token from callback', e)\n // Fall back to cached value if callback fails\n tokenToSend = this.accessTokenValue\n }\n } else {\n tokenToSend = this.accessTokenValue\n }\n\n // Track whether this token was manually set or fetched via callback\n if (isManualToken) {\n this._manuallySetToken = true\n } else if (this.accessToken) {\n // If we used the callback, clear the manual flag\n this._manuallySetToken = false\n }\n\n if (this.accessTokenValue != tokenToSend) {\n this.accessTokenValue = tokenToSend\n this.channels.forEach((channel) => {\n const payload = {\n access_token: tokenToSend,\n version: DEFAULT_VERSION,\n }\n\n tokenToSend && channel.updateJoinPayload(payload)\n\n if (channel.joinedOnce && channel._isJoined()) {\n channel._push(CHANNEL_EVENTS.access_token, {\n access_token: tokenToSend,\n })\n }\n })\n }\n }\n\n /**\n * Wait for any in-flight auth operations to complete\n * @internal\n */\n private async _waitForAuthIfNeeded(): Promise<void> {\n if (this._authPromise) {\n await this._authPromise\n }\n }\n\n /**\n * Safely call setAuth with standardized error handling\n * @internal\n */\n private _setAuthSafely(context = 'general'): void {\n // Only refresh auth if using callback-based tokens\n if (!this._isManualToken()) {\n this.setAuth().catch((e) => {\n this.log('error', `Error setting auth in ${context}`, e)\n })\n }\n }\n\n /**\n * Trigger state change callbacks with proper error handling\n * @internal\n */\n private _triggerStateCallbacks(event: keyof typeof this.stateChangeCallbacks, data?: any): void {\n try {\n this.stateChangeCallbacks[event].forEach((callback) => {\n try {\n callback(data)\n } catch (e) {\n this.log('error', `error in ${event} callback`, e)\n }\n })\n } catch (e) {\n this.log('error', `error triggering ${event} callbacks`, e)\n }\n }\n\n /**\n * Setup reconnection timer with proper configuration\n * @internal\n */\n private _setupReconnectionTimer(): void {\n this.reconnectTimer = new Timer(async () => {\n setTimeout(async () => {\n await this._waitForAuthIfNeeded()\n if (!this.isConnected()) {\n this.connect()\n }\n }, CONNECTION_TIMEOUTS.RECONNECT_DELAY)\n }, this.reconnectAfterMs)\n }\n\n /**\n * Initialize client options with defaults\n * @internal\n */\n private _initializeOptions(options?: RealtimeClientOptions): void {\n // Set defaults\n this.transport = options?.transport ?? null\n this.timeout = options?.timeout ?? DEFAULT_TIMEOUT\n this.heartbeatIntervalMs =\n options?.heartbeatIntervalMs ?? CONNECTION_TIMEOUTS.HEARTBEAT_INTERVAL\n this.worker = options?.worker ?? false\n this.accessToken = options?.accessToken ?? null\n this.heartbeatCallback = options?.heartbeatCallback ?? noop\n this.vsn = options?.vsn ?? DEFAULT_VSN\n\n // Handle special cases\n if (options?.params) this.params = options.params\n if (options?.logger) this.logger = options.logger\n if (options?.logLevel || options?.log_level) {\n this.logLevel = options.logLevel || options.log_level\n this.params = { ...this.params, log_level: this.logLevel as string }\n }\n\n // Set up functions with defaults\n this.reconnectAfterMs =\n options?.reconnectAfterMs ??\n ((tries: number) => {\n return RECONNECT_INTERVALS[tries - 1] || DEFAULT_RECONNECT_FALLBACK\n })\n\n switch (this.vsn) {\n case VSN_1_0_0:\n this.encode =\n options?.encode ??\n ((payload: JSON, callback: Function) => {\n return callback(JSON.stringify(payload))\n })\n\n this.decode =\n options?.decode ??\n ((payload: string, callback: Function) => {\n return callback(JSON.parse(payload))\n })\n break\n case VSN_2_0_0:\n this.encode = options?.encode ?? this.serializer.encode.bind(this.serializer)\n this.decode = options?.decode ?? this.serializer.decode.bind(this.serializer)\n break\n default:\n throw new Error(`Unsupported serializer version: ${this.vsn}`)\n }\n\n // Handle worker setup\n if (this.worker) {\n if (typeof window !== 'undefined' && !window.Worker) {\n throw new Error('Web Worker is not supported')\n }\n this.workerUrl = options?.workerUrl\n }\n }\n}\n","export interface IcebergErrorResponse {\n error: {\n message: string\n type: string\n code: number\n stack?: string[]\n }\n}\n\nexport class IcebergError extends Error {\n readonly status: number\n readonly icebergType?: string\n readonly icebergCode?: number\n readonly details?: unknown\n readonly isCommitStateUnknown: boolean\n\n constructor(\n message: string,\n opts: {\n status: number\n icebergType?: string\n icebergCode?: number\n details?: unknown\n }\n ) {\n super(message)\n this.name = 'IcebergError'\n this.status = opts.status\n this.icebergType = opts.icebergType\n this.icebergCode = opts.icebergCode\n this.details = opts.details\n\n // Detect CommitStateUnknownException (500, 502, 504 during table commits)\n this.isCommitStateUnknown =\n opts.icebergType === 'CommitStateUnknownException' ||\n ([500, 502, 504].includes(opts.status) && opts.icebergType?.includes('CommitState') === true)\n }\n\n /**\n * Returns true if the error is a 404 Not Found error.\n */\n isNotFound(): boolean {\n return this.status === 404\n }\n\n /**\n * Returns true if the error is a 409 Conflict error.\n */\n isConflict(): boolean {\n return this.status === 409\n }\n\n /**\n * Returns true if the error is a 419 Authentication Timeout error.\n */\n isAuthenticationTimeout(): boolean {\n return this.status === 419\n }\n}\n","export function buildUrl(\n baseUrl: string,\n path: string,\n query?: Record<string, string | undefined>\n): string {\n const url = new URL(path, baseUrl)\n\n if (query) {\n for (const [key, value] of Object.entries(query)) {\n if (value !== undefined) {\n url.searchParams.set(key, value)\n }\n }\n }\n\n return url.toString()\n}\n","import { IcebergError, type IcebergErrorResponse } from '../errors/IcebergError'\nimport { buildUrl } from '../utils/url'\nimport type { AuthConfig, HttpClient, HttpRequest, HttpResponse } from './types'\n\nasync function buildAuthHeaders(auth?: AuthConfig): Promise<Record<string, string>> {\n if (!auth || auth.type === 'none') {\n return {}\n }\n\n if (auth.type === 'bearer') {\n return { Authorization: `Bearer ${auth.token}` }\n }\n\n if (auth.type === 'header') {\n return { [auth.name]: auth.value }\n }\n\n if (auth.type === 'custom') {\n return await auth.getHeaders()\n }\n\n return {}\n}\n\nexport function createFetchClient(options: {\n baseUrl: string\n auth?: AuthConfig\n fetchImpl?: typeof fetch\n}): HttpClient {\n const fetchFn = options.fetchImpl ?? globalThis.fetch\n\n return {\n async request<T>({\n method,\n path,\n query,\n body,\n headers,\n }: HttpRequest): Promise<HttpResponse<T>> {\n const url = buildUrl(options.baseUrl, path, query)\n const authHeaders = await buildAuthHeaders(options.auth)\n\n const res = await fetchFn(url, {\n method,\n headers: {\n ...(body ? { 'Content-Type': 'application/json' } : {}),\n ...authHeaders,\n ...headers,\n },\n body: body ? JSON.stringify(body) : undefined,\n })\n\n const text = await res.text()\n const isJson = (res.headers.get('content-type') || '').includes('application/json')\n const data = isJson && text ? (JSON.parse(text) as T) : (text as T)\n\n if (!res.ok) {\n const errBody = isJson ? (data as IcebergErrorResponse) : undefined\n const errorDetail = errBody?.error\n throw new IcebergError(\n errorDetail?.message ?? `Request failed with status ${res.status}`,\n {\n status: res.status,\n icebergType: errorDetail?.type,\n icebergCode: errorDetail?.code,\n details: errBody,\n }\n )\n }\n\n return { status: res.status, headers: res.headers, data: data as T }\n },\n }\n}\n","import type { HttpClient } from '../http/types'\nimport { IcebergError } from '../errors/IcebergError'\nimport type {\n CreateNamespaceRequest,\n CreateNamespaceResponse,\n GetNamespaceResponse,\n ListNamespacesResponse,\n NamespaceIdentifier,\n NamespaceMetadata,\n} from './types'\n\nfunction namespaceToPath(namespace: string[]): string {\n return namespace.join('\\x1F')\n}\n\nexport class NamespaceOperations {\n constructor(\n private readonly client: HttpClient,\n private readonly prefix: string = ''\n ) {}\n\n async listNamespaces(parent?: NamespaceIdentifier): Promise<NamespaceIdentifier[]> {\n const query = parent ? { parent: namespaceToPath(parent.namespace) } : undefined\n\n const response = await this.client.request<ListNamespacesResponse>({\n method: 'GET',\n path: `${this.prefix}/namespaces`,\n query,\n })\n\n return response.data.namespaces.map((ns) => ({ namespace: ns }))\n }\n\n async createNamespace(\n id: NamespaceIdentifier,\n metadata?: NamespaceMetadata\n ): Promise<CreateNamespaceResponse> {\n const request: CreateNamespaceRequest = {\n namespace: id.namespace,\n properties: metadata?.properties,\n }\n\n const response = await this.client.request<CreateNamespaceResponse>({\n method: 'POST',\n path: `${this.prefix}/namespaces`,\n body: request,\n })\n\n return response.data\n }\n\n async dropNamespace(id: NamespaceIdentifier): Promise<void> {\n await this.client.request<void>({\n method: 'DELETE',\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`,\n })\n }\n\n async loadNamespaceMetadata(id: NamespaceIdentifier): Promise<NamespaceMetadata> {\n const response = await this.client.request<GetNamespaceResponse>({\n method: 'GET',\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`,\n })\n\n return {\n properties: response.data.properties,\n }\n }\n\n async namespaceExists(id: NamespaceIdentifier): Promise<boolean> {\n try {\n await this.client.request<void>({\n method: 'HEAD',\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}`,\n })\n return true\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false\n }\n throw error\n }\n }\n\n async createNamespaceIfNotExists(\n id: NamespaceIdentifier,\n metadata?: NamespaceMetadata\n ): Promise<CreateNamespaceResponse | void> {\n try {\n return await this.createNamespace(id, metadata)\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return\n }\n throw error\n }\n }\n}\n","import type { HttpClient } from '../http/types'\nimport { IcebergError } from '../errors/IcebergError'\nimport type {\n CreateTableRequest,\n CommitTableResponse,\n ListTablesResponse,\n LoadTableResponse,\n NamespaceIdentifier,\n TableIdentifier,\n TableMetadata,\n UpdateTableRequest,\n DropTableRequest,\n} from './types'\n\nfunction namespaceToPath(namespace: string[]): string {\n return namespace.join('\\x1F')\n}\n\nexport class TableOperations {\n constructor(\n private readonly client: HttpClient,\n private readonly prefix: string = '',\n private readonly accessDelegation?: string\n ) {}\n\n async listTables(namespace: NamespaceIdentifier): Promise<TableIdentifier[]> {\n const response = await this.client.request<ListTablesResponse>({\n method: 'GET',\n path: `${this.prefix}/namespaces/${namespaceToPath(namespace.namespace)}/tables`,\n })\n\n return response.data.identifiers\n }\n\n async createTable(\n namespace: NamespaceIdentifier,\n request: CreateTableRequest\n ): Promise<TableMetadata> {\n const headers: Record<string, string> = {}\n if (this.accessDelegation) {\n headers['X-Iceberg-Access-Delegation'] = this.accessDelegation\n }\n\n const response = await this.client.request<LoadTableResponse>({\n method: 'POST',\n path: `${this.prefix}/namespaces/${namespaceToPath(namespace.namespace)}/tables`,\n body: request,\n headers,\n })\n\n return response.data.metadata\n }\n\n async updateTable(id: TableIdentifier, request: UpdateTableRequest): Promise<CommitTableResponse> {\n const response = await this.client.request<LoadTableResponse>({\n method: 'POST',\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}/tables/${id.name}`,\n body: request,\n })\n\n return {\n 'metadata-location': response.data['metadata-location'],\n metadata: response.data.metadata,\n }\n }\n\n async dropTable(id: TableIdentifier, options?: DropTableRequest): Promise<void> {\n await this.client.request<void>({\n method: 'DELETE',\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}/tables/${id.name}`,\n query: { purgeRequested: String(options?.purge ?? false) },\n })\n }\n\n async loadTable(id: TableIdentifier): Promise<TableMetadata> {\n const headers: Record<string, string> = {}\n if (this.accessDelegation) {\n headers['X-Iceberg-Access-Delegation'] = this.accessDelegation\n }\n\n const response = await this.client.request<LoadTableResponse>({\n method: 'GET',\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}/tables/${id.name}`,\n headers,\n })\n\n return response.data.metadata\n }\n\n async tableExists(id: TableIdentifier): Promise<boolean> {\n const headers: Record<string, string> = {}\n if (this.accessDelegation) {\n headers['X-Iceberg-Access-Delegation'] = this.accessDelegation\n }\n\n try {\n await this.client.request<void>({\n method: 'HEAD',\n path: `${this.prefix}/namespaces/${namespaceToPath(id.namespace)}/tables/${id.name}`,\n headers,\n })\n return true\n } catch (error) {\n if (error instanceof IcebergError && error.status === 404) {\n return false\n }\n throw error\n }\n }\n\n async createTableIfNotExists(\n namespace: NamespaceIdentifier,\n request: CreateTableRequest\n ): Promise<TableMetadata> {\n try {\n return await this.createTable(namespace, request)\n } catch (error) {\n if (error instanceof IcebergError && error.status === 409) {\n return await this.loadTable({ namespace: namespace.namespace, name: request.name })\n }\n throw error\n }\n }\n}\n","import { createFetchClient } from '../http/createFetchClient'\nimport type { AuthConfig, HttpClient } from '../http/types'\nimport { NamespaceOperations } from './namespaces'\nimport { TableOperations } from './tables'\nimport type {\n CreateTableRequest,\n CreateNamespaceResponse,\n CommitTableResponse,\n NamespaceIdentifier,\n NamespaceMetadata,\n TableIdentifier,\n TableMetadata,\n UpdateTableRequest,\n DropTableRequest,\n} from './types'\n\n/**\n * Access delegation mechanisms supported by the Iceberg REST Catalog.\n *\n * - `vended-credentials`: Server provides temporary credentials for data access\n * - `remote-signing`: Server signs requests on behalf of the client\n */\nexport type AccessDelegation = 'vended-credentials' | 'remote-signing'\n\n/**\n * Configuration options for the Iceberg REST Catalog client.\n */\nexport interface IcebergRestCatalogOptions {\n /** Base URL of the Iceberg REST Catalog API */\n baseUrl: string\n /** Optional catalog name prefix for multi-catalog servers */\n catalogName?: string\n /** Authentication configuration */\n auth?: AuthConfig\n /** Custom fetch implementation (defaults to globalThis.fetch) */\n fetch?: typeof fetch\n /**\n * Access delegation mechanisms to request from the server.\n * When specified, the X-Iceberg-Access-Delegation header will be sent\n * with supported operations (createTable, loadTable).\n *\n * @example ['vended-credentials']\n * @example ['vended-credentials', 'remote-signing']\n */\n accessDelegation?: AccessDelegation[]\n}\n\n/**\n * Client for interacting with an Apache Iceberg REST Catalog.\n *\n * This class provides methods for managing namespaces and tables in an Iceberg catalog.\n * It handles authentication, request formatting, and error handling automatically.\n *\n * @example\n * ```typescript\n * const catalog = new IcebergRestCatalog({\n * baseUrl: 'https://my-catalog.example.com/iceberg/v1',\n * auth: { type: 'bearer', token: process.env.ICEBERG_TOKEN }\n * });\n *\n * // Create a namespace\n * await catalog.createNamespace({ namespace: ['analytics'] });\n *\n * // Create a table\n * await catalog.createTable(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: { type: 'struct', fields: [...] }\n * }\n * );\n * ```\n */\nexport class IcebergRestCatalog {\n private readonly client: HttpClient\n private readonly namespaceOps: NamespaceOperations\n private readonly tableOps: TableOperations\n private readonly accessDelegation?: string\n\n /**\n * Creates a new Iceberg REST Catalog client.\n *\n * @param options - Configuration options for the catalog client\n */\n constructor(options: IcebergRestCatalogOptions) {\n let prefix = 'v1'\n if (options.catalogName) {\n prefix += `/${options.catalogName}`\n }\n\n const baseUrl = options.baseUrl.endsWith('/') ? options.baseUrl : `${options.baseUrl}/`\n\n this.client = createFetchClient({\n baseUrl,\n auth: options.auth,\n fetchImpl: options.fetch,\n })\n\n // Format accessDelegation as comma-separated string per spec\n this.accessDelegation = options.accessDelegation?.join(',')\n\n this.namespaceOps = new NamespaceOperations(this.client, prefix)\n this.tableOps = new TableOperations(this.client, prefix, this.accessDelegation)\n }\n\n /**\n * Lists all namespaces in the catalog.\n *\n * @param parent - Optional parent namespace to list children under\n * @returns Array of namespace identifiers\n *\n * @example\n * ```typescript\n * // List all top-level namespaces\n * const namespaces = await catalog.listNamespaces();\n *\n * // List namespaces under a parent\n * const children = await catalog.listNamespaces({ namespace: ['analytics'] });\n * ```\n */\n async listNamespaces(parent?: NamespaceIdentifier): Promise<NamespaceIdentifier[]> {\n return this.namespaceOps.listNamespaces(parent)\n }\n\n /**\n * Creates a new namespace in the catalog.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespace(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * console.log(response.namespace); // ['analytics']\n * console.log(response.properties); // { owner: 'data-team', ... }\n * ```\n */\n async createNamespace(id: NamespaceIdentifier, metadata?: NamespaceMetadata): Promise<CreateNamespaceResponse> {\n return this.namespaceOps.createNamespace(id, metadata)\n }\n\n /**\n * Drops a namespace from the catalog.\n *\n * The namespace must be empty (contain no tables) before it can be dropped.\n *\n * @param id - Namespace identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropNamespace({ namespace: ['analytics'] });\n * ```\n */\n async dropNamespace(id: NamespaceIdentifier): Promise<void> {\n await this.namespaceOps.dropNamespace(id)\n }\n\n /**\n * Loads metadata for a namespace.\n *\n * @param id - Namespace identifier to load\n * @returns Namespace metadata including properties\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadNamespaceMetadata({ namespace: ['analytics'] });\n * console.log(metadata.properties);\n * ```\n */\n async loadNamespaceMetadata(id: NamespaceIdentifier): Promise<NamespaceMetadata> {\n return this.namespaceOps.loadNamespaceMetadata(id)\n }\n\n /**\n * Lists all tables in a namespace.\n *\n * @param namespace - Namespace identifier to list tables from\n * @returns Array of table identifiers\n *\n * @example\n * ```typescript\n * const tables = await catalog.listTables({ namespace: ['analytics'] });\n * console.log(tables); // [{ namespace: ['analytics'], name: 'events' }, ...]\n * ```\n */\n async listTables(namespace: NamespaceIdentifier): Promise<TableIdentifier[]> {\n return this.tableOps.listTables(namespace)\n }\n\n /**\n * Creates a new table in the catalog.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTable(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * },\n * 'partition-spec': {\n * 'spec-id': 0,\n * fields: [\n * { source_id: 2, field_id: 1000, name: 'ts_day', transform: 'day' }\n * ]\n * }\n * }\n * );\n * ```\n */\n async createTable(\n namespace: NamespaceIdentifier,\n request: CreateTableRequest\n ): Promise<TableMetadata> {\n return this.tableOps.createTable(namespace, request)\n }\n\n /**\n * Updates an existing table's metadata.\n *\n * Can update the schema, partition spec, or properties of a table.\n *\n * @param id - Table identifier to update\n * @param request - Update request with fields to modify\n * @returns Response containing the metadata location and updated table metadata\n *\n * @example\n * ```typescript\n * const response = await catalog.updateTable(\n * { namespace: ['analytics'], name: 'events' },\n * {\n * properties: { 'read.split.target-size': '134217728' }\n * }\n * );\n * console.log(response['metadata-location']); // s3://...\n * console.log(response.metadata); // TableMetadata object\n * ```\n */\n async updateTable(id: TableIdentifier, request: UpdateTableRequest): Promise<CommitTableResponse> {\n return this.tableOps.updateTable(id, request)\n }\n\n /**\n * Drops a table from the catalog.\n *\n * @param id - Table identifier to drop\n *\n * @example\n * ```typescript\n * await catalog.dropTable({ namespace: ['analytics'], name: 'events' });\n * ```\n */\n async dropTable(id: TableIdentifier, options?: DropTableRequest): Promise<void> {\n await this.tableOps.dropTable(id, options)\n }\n\n /**\n * Loads metadata for a table.\n *\n * @param id - Table identifier to load\n * @returns Table metadata including schema, partition spec, location, etc.\n *\n * @example\n * ```typescript\n * const metadata = await catalog.loadTable({ namespace: ['analytics'], name: 'events' });\n * console.log(metadata.schema);\n * console.log(metadata.location);\n * ```\n */\n async loadTable(id: TableIdentifier): Promise<TableMetadata> {\n return this.tableOps.loadTable(id)\n }\n\n /**\n * Checks if a namespace exists in the catalog.\n *\n * @param id - Namespace identifier to check\n * @returns True if the namespace exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.namespaceExists({ namespace: ['analytics'] });\n * console.log(exists); // true or false\n * ```\n */\n async namespaceExists(id: NamespaceIdentifier): Promise<boolean> {\n return this.namespaceOps.namespaceExists(id)\n }\n\n /**\n * Checks if a table exists in the catalog.\n *\n * @param id - Table identifier to check\n * @returns True if the table exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = await catalog.tableExists({ namespace: ['analytics'], name: 'events' });\n * console.log(exists); // true or false\n * ```\n */\n async tableExists(id: TableIdentifier): Promise<boolean> {\n return this.tableOps.tableExists(id)\n }\n\n /**\n * Creates a namespace if it does not exist.\n *\n * If the namespace already exists, returns void. If created, returns the response.\n *\n * @param id - Namespace identifier to create\n * @param metadata - Optional metadata properties for the namespace\n * @returns Response containing the created namespace and its properties, or void if it already exists\n *\n * @example\n * ```typescript\n * const response = await catalog.createNamespaceIfNotExists(\n * { namespace: ['analytics'] },\n * { properties: { owner: 'data-team' } }\n * );\n * if (response) {\n * console.log('Created:', response.namespace);\n * } else {\n * console.log('Already exists');\n * }\n * ```\n */\n async createNamespaceIfNotExists(\n id: NamespaceIdentifier,\n metadata?: NamespaceMetadata\n ): Promise<CreateNamespaceResponse | void> {\n return this.namespaceOps.createNamespaceIfNotExists(id, metadata)\n }\n\n /**\n * Creates a table if it does not exist.\n *\n * If the table already exists, returns its metadata instead.\n *\n * @param namespace - Namespace to create the table in\n * @param request - Table creation request including name, schema, partition spec, etc.\n * @returns Table metadata for the created or existing table\n *\n * @example\n * ```typescript\n * const metadata = await catalog.createTableIfNotExists(\n * { namespace: ['analytics'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true }\n * ],\n * 'schema-id': 0\n * }\n * }\n * );\n * ```\n */\n async createTableIfNotExists(\n namespace: NamespaceIdentifier,\n request: CreateTableRequest\n ): Promise<TableMetadata> {\n return this.tableOps.createTableIfNotExists(namespace, request)\n }\n}\n","export interface NamespaceIdentifier {\n namespace: string[]\n}\n\nexport interface NamespaceMetadata {\n properties: Record<string, string>\n}\n\nexport interface TableIdentifier {\n namespace: string[]\n name: string\n}\n\n/**\n * Primitive types in Iceberg - all represented as strings.\n * Parameterized types use string format: decimal(precision,scale) and fixed[length]\n *\n * Note: The OpenAPI spec defines PrimitiveType as `type: string`, so any string is valid.\n * We include known types for autocomplete, plus a catch-all for flexibility.\n */\nexport type PrimitiveType =\n | 'boolean'\n | 'int'\n | 'long'\n | 'float'\n | 'double'\n | 'string'\n | 'timestamp'\n | 'date'\n | 'time'\n | 'timestamptz'\n | 'uuid'\n | 'binary'\n | `decimal(${number},${number})`\n | `fixed[${number}]`\n | (string & {}) // catch-all for any format (e.g., \"decimal(10, 2)\" with spaces) and future types\n\n/**\n * Regex patterns for parsing parameterized types.\n * These allow flexible whitespace matching.\n */\nconst DECIMAL_REGEX = /^decimal\\s*\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*\\)$/\nconst FIXED_REGEX = /^fixed\\s*\\[\\s*(\\d+)\\s*\\]$/\n\n/**\n * Parse a decimal type string into its components.\n * Handles any whitespace formatting (e.g., \"decimal(10,2)\", \"decimal(10, 2)\", \"decimal( 10 , 2 )\").\n *\n * @param type - The type string to parse\n * @returns Object with precision and scale, or null if not a valid decimal type\n */\nexport function parseDecimalType(type: string): { precision: number; scale: number } | null {\n const match = type.match(DECIMAL_REGEX)\n if (!match) return null\n return {\n precision: parseInt(match[1], 10),\n scale: parseInt(match[2], 10),\n }\n}\n\n/**\n * Parse a fixed type string into its length.\n * Handles any whitespace formatting (e.g., \"fixed[16]\", \"fixed[ 16 ]\").\n *\n * @param type - The type string to parse\n * @returns Object with length, or null if not a valid fixed type\n */\nexport function parseFixedType(type: string): { length: number } | null {\n const match = type.match(FIXED_REGEX)\n if (!match) return null\n return {\n length: parseInt(match[1], 10),\n }\n}\n\n/**\n * Check if a type string is a decimal type.\n */\nexport function isDecimalType(type: string): boolean {\n return DECIMAL_REGEX.test(type)\n}\n\n/**\n * Check if a type string is a fixed type.\n */\nexport function isFixedType(type: string): boolean {\n return FIXED_REGEX.test(type)\n}\n\n/**\n * Compare two Iceberg type strings for equality, ignoring whitespace differences.\n * This is useful when comparing types from user input vs catalog responses,\n * as catalogs may normalize whitespace differently.\n *\n * @param a - First type string\n * @param b - Second type string\n * @returns true if the types are equivalent\n */\nexport function typesEqual(a: string, b: string): boolean {\n // For decimal types, compare parsed values\n const decimalA = parseDecimalType(a)\n const decimalB = parseDecimalType(b)\n if (decimalA && decimalB) {\n return decimalA.precision === decimalB.precision && decimalA.scale === decimalB.scale\n }\n\n // For fixed types, compare parsed values\n const fixedA = parseFixedType(a)\n const fixedB = parseFixedType(b)\n if (fixedA && fixedB) {\n return fixedA.length === fixedB.length\n }\n\n // For other types, direct string comparison\n return a === b\n}\n\n/**\n * Struct type - a nested structure containing fields.\n * Used for nested records within a field.\n */\nexport interface StructType {\n type: 'struct'\n fields: StructField[]\n}\n\n/**\n * List type - an array of elements.\n */\nexport interface ListType {\n type: 'list'\n 'element-id': number\n element: IcebergType\n 'element-required': boolean\n}\n\n/**\n * Map type - a key-value mapping.\n */\nexport interface MapType {\n type: 'map'\n 'key-id': number\n key: IcebergType\n 'value-id': number\n value: IcebergType\n 'value-required': boolean\n}\n\n/**\n * Union of all Iceberg types.\n * Can be a primitive type (string) or a complex type (struct, list, map).\n */\nexport type IcebergType = PrimitiveType | StructType | ListType | MapType\n\n/**\n * Primitive type values for default values.\n * Represents the possible values for initial-default and write-default.\n */\nexport type PrimitiveTypeValue = boolean | number | string\n\n/**\n * A field within a struct (used in nested StructType).\n */\nexport interface StructField {\n id: number\n name: string\n type: IcebergType\n required: boolean\n doc?: string\n 'initial-default'?: PrimitiveTypeValue\n 'write-default'?: PrimitiveTypeValue\n}\n\n/**\n * A field within a table schema (top-level).\n * Equivalent to StructField but kept for backwards compatibility.\n */\nexport interface TableField {\n id: number\n name: string\n type: IcebergType\n required: boolean\n doc?: string\n 'initial-default'?: PrimitiveTypeValue\n 'write-default'?: PrimitiveTypeValue\n}\n\nexport interface TableSchema {\n type: 'struct'\n fields: TableField[]\n 'schema-id'?: number\n 'identifier-field-ids'?: number[]\n}\n\nexport interface PartitionField {\n source_id: number\n field_id: number\n name: string\n transform: string\n}\n\nexport interface PartitionSpec {\n 'spec-id': number\n fields: PartitionField[]\n}\n\nexport interface SortField {\n source_id: number\n transform: string\n direction: 'asc' | 'desc'\n null_order: 'nulls-first' | 'nulls-last'\n}\n\nexport interface SortOrder {\n 'order-id': number\n fields: SortField[]\n}\n\nexport interface CreateTableRequest {\n name: string\n schema: TableSchema\n 'partition-spec'?: PartitionSpec\n 'write-order'?: SortOrder\n properties?: Record<string, string>\n 'stage-create'?: boolean\n}\n\nexport interface UpdateTableRequest {\n schema?: TableSchema\n 'partition-spec'?: PartitionSpec\n properties?: Record<string, string>\n}\n\nexport interface DropTableRequest {\n purge?: boolean\n}\n\nexport interface TableMetadata {\n name?: string\n location: string\n schemas: TableSchema[]\n 'current-schema-id': number\n 'partition-specs': PartitionSpec[]\n 'default-spec-id'?: number\n 'sort-orders': SortOrder[]\n 'default-sort-order-id'?: number\n properties: Record<string, string>\n 'metadata-location'?: string\n 'current-snapshot-id'?: number\n snapshots?: unknown[]\n 'snapshot-log'?: unknown[]\n 'metadata-log'?: unknown[]\n refs?: Record<string, unknown>\n 'last-updated-ms'?: number\n 'last-column-id'?: number\n 'last-sequence-number'?: number\n 'table-uuid'?: string\n 'format-version'?: number\n 'last-partition-id'?: number\n}\n\nexport interface CreateNamespaceRequest {\n namespace: string[]\n properties?: Record<string, string>\n}\n\nexport interface CreateNamespaceResponse {\n namespace: string[]\n properties?: Record<string, string>\n}\n\nexport interface GetNamespaceResponse {\n namespace: string[]\n properties: Record<string, string>\n}\n\nexport interface ListNamespacesResponse {\n namespaces: string[][]\n 'next-page-token'?: string\n}\n\nexport interface ListTablesResponse {\n identifiers: TableIdentifier[]\n 'next-page-token'?: string\n}\n\nexport interface LoadTableResponse {\n 'metadata-location': string\n metadata: TableMetadata\n config?: Record<string, string>\n}\n\nexport interface CommitTableResponse {\n 'metadata-location': string\n metadata: TableMetadata\n}\n\n/**\n * Gets the current (active) schema from table metadata.\n *\n * @param metadata - Table metadata containing schemas array and current-schema-id\n * @returns The current table schema, or undefined if not found\n */\nexport function getCurrentSchema(metadata: TableMetadata): TableSchema | undefined {\n return metadata.schemas.find((s) => s['schema-id'] === metadata['current-schema-id'])\n}\n","export class StorageError extends Error {\n protected __isStorageError = true\n\n constructor(message: string) {\n super(message)\n this.name = 'StorageError'\n }\n}\n\nexport function isStorageError(error: unknown): error is StorageError {\n return typeof error === 'object' && error !== null && '__isStorageError' in error\n}\n\nexport class StorageApiError extends StorageError {\n status: number\n statusCode: string\n\n constructor(message: string, status: number, statusCode: string) {\n super(message)\n this.name = 'StorageApiError'\n this.status = status\n this.statusCode = statusCode\n }\n\n toJSON() {\n return {\n name: this.name,\n message: this.message,\n status: this.status,\n statusCode: this.statusCode,\n }\n }\n}\n\nexport class StorageUnknownError extends StorageError {\n originalError: unknown\n\n constructor(message: string, originalError: unknown) {\n super(message)\n this.name = 'StorageUnknownError'\n this.originalError = originalError\n }\n}\n","type Fetch = typeof fetch\n\nexport const resolveFetch = (customFetch?: Fetch): Fetch => {\n if (customFetch) {\n return (...args) => customFetch(...args)\n }\n return (...args) => fetch(...args)\n}\n\nexport const resolveResponse = (): typeof Response => {\n return Response\n}\n\nexport const recursiveToCamel = (item: Record<string, any>): unknown => {\n if (Array.isArray(item)) {\n return item.map((el) => recursiveToCamel(el))\n } else if (typeof item === 'function' || item !== Object(item)) {\n return item\n }\n\n const result: Record<string, any> = {}\n Object.entries(item).forEach(([key, value]) => {\n const newKey = key.replace(/([-_][a-z])/gi, (c) => c.toUpperCase().replace(/[-_]/g, ''))\n result[newKey] = recursiveToCamel(value)\n })\n\n return result\n}\n\n/**\n * Determine if input is a plain object\n * An object is plain if it's created by either {}, new Object(), or Object.create(null)\n * source: https://github.com/sindresorhus/is-plain-obj\n */\nexport const isPlainObject = (value: object): boolean => {\n if (typeof value !== 'object' || value === null) {\n return false\n }\n\n const prototype = Object.getPrototypeOf(value)\n return (\n (prototype === null ||\n prototype === Object.prototype ||\n Object.getPrototypeOf(prototype) === null) &&\n !(Symbol.toStringTag in value) &&\n !(Symbol.iterator in value)\n )\n}\n\n/**\n * Validates if a given bucket name is valid according to Supabase Storage API rules\n * Mirrors backend validation from: storage/src/storage/limits.ts:isValidBucketName()\n *\n * Rules:\n * - Length: 1-100 characters\n * - Allowed characters: alphanumeric (a-z, A-Z, 0-9), underscore (_), and safe special characters\n * - Safe special characters: ! - . * ' ( ) space & $ @ = ; : + , ?\n * - Forbidden: path separators (/, \\), path traversal (..), leading/trailing whitespace\n *\n * AWS S3 Reference: https://docs.aws.amazon.com/AmazonS3/latest/userguide/object-keys.html\n *\n * @param bucketName - The bucket name to validate\n * @returns true if valid, false otherwise\n */\nexport const isValidBucketName = (bucketName: string): boolean => {\n if (!bucketName || typeof bucketName !== 'string') {\n return false\n }\n\n // Check length constraints (1-100 characters)\n if (bucketName.length === 0 || bucketName.length > 100) {\n return false\n }\n\n // Check for leading/trailing whitespace\n if (bucketName.trim() !== bucketName) {\n return false\n }\n\n // Explicitly reject path separators (security)\n // Note: Consecutive periods (..) are allowed by backend - the AWS restriction\n // on relative paths applies to object keys, not bucket names\n if (bucketName.includes('/') || bucketName.includes('\\\\')) {\n return false\n }\n\n // Validate against allowed character set\n // Pattern matches backend regex: /^(\\w|!|-|\\.|\\*|'|\\(|\\)| |&|\\$|@|=|;|:|\\+|,|\\?)*$/\n // This explicitly excludes path separators (/, \\) and other problematic characters\n const bucketNameRegex = /^[\\w!.\\*'() &$@=;:+,?-]+$/\n return bucketNameRegex.test(bucketName)\n}\n","import { StorageApiError, StorageUnknownError } from './errors'\nimport { isPlainObject, resolveResponse } from './helpers'\nimport { FetchParameters } from './types'\n\nexport type Fetch = typeof fetch\n\nexport interface FetchOptions {\n headers?: {\n [key: string]: string\n }\n duplex?: string\n noResolveJson?: boolean\n}\n\nexport type RequestMethodType = 'GET' | 'POST' | 'PUT' | 'DELETE' | 'HEAD'\n\nconst _getErrorMessage = (err: any): string =>\n err.msg ||\n err.message ||\n err.error_description ||\n (typeof err.error === 'string' ? err.error : err.error?.message) ||\n JSON.stringify(err)\n\nconst handleError = async (\n error: unknown,\n reject: (reason?: any) => void,\n options?: FetchOptions\n) => {\n const Res = await resolveResponse()\n\n if (error instanceof Res && !options?.noResolveJson) {\n error\n .json()\n .then((err) => {\n const status = error.status || 500\n const statusCode = err?.statusCode || status + ''\n reject(new StorageApiError(_getErrorMessage(err), status, statusCode))\n })\n .catch((err) => {\n reject(new StorageUnknownError(_getErrorMessage(err), err))\n })\n } else {\n reject(new StorageUnknownError(_getErrorMessage(error), error))\n }\n}\n\nconst _getRequestParams = (\n method: RequestMethodType,\n options?: FetchOptions,\n parameters?: FetchParameters,\n body?: object\n) => {\n const params: { [k: string]: any } = { method, headers: options?.headers || {} }\n\n if (method === 'GET' || !body) {\n return params\n }\n\n if (isPlainObject(body)) {\n params.headers = { 'Content-Type': 'application/json', ...options?.headers }\n params.body = JSON.stringify(body)\n } else {\n params.body = body\n }\n\n if (options?.duplex) {\n params.duplex = options.duplex\n }\n\n return { ...params, ...parameters }\n}\n\nasync function _handleRequest(\n fetcher: Fetch,\n method: RequestMethodType,\n url: string,\n options?: FetchOptions,\n parameters?: FetchParameters,\n body?: object\n): Promise<any> {\n return new Promise((resolve, reject) => {\n fetcher(url, _getRequestParams(method, options, parameters, body))\n .then((result) => {\n if (!result.ok) throw result\n if (options?.noResolveJson) return result\n return result.json()\n })\n .then((data) => resolve(data))\n .catch((error) => handleError(error, reject, options))\n })\n}\n\nexport async function get(\n fetcher: Fetch,\n url: string,\n options?: FetchOptions,\n parameters?: FetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'GET', url, options, parameters)\n}\n\nexport async function post(\n fetcher: Fetch,\n url: string,\n body: object,\n options?: FetchOptions,\n parameters?: FetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'POST', url, options, parameters, body)\n}\n\nexport async function put(\n fetcher: Fetch,\n url: string,\n body: object,\n options?: FetchOptions,\n parameters?: FetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'PUT', url, options, parameters, body)\n}\n\nexport async function head(\n fetcher: Fetch,\n url: string,\n options?: FetchOptions,\n parameters?: FetchParameters\n): Promise<any> {\n return _handleRequest(\n fetcher,\n 'HEAD',\n url,\n {\n ...options,\n noResolveJson: true,\n },\n parameters\n )\n}\n\nexport async function remove(\n fetcher: Fetch,\n url: string,\n body: object,\n options?: FetchOptions,\n parameters?: FetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'DELETE', url, options, parameters, body)\n}\n","import { isStorageError } from '../lib/errors'\nimport { DownloadResult } from '../lib/types'\n\nexport default class StreamDownloadBuilder implements PromiseLike<DownloadResult<ReadableStream>> {\n constructor(\n private downloadFn: () => Promise<Response>,\n private shouldThrowOnError: boolean\n ) {}\n\n then<TResult1 = DownloadResult<ReadableStream>, TResult2 = never>(\n onfulfilled?:\n | ((value: DownloadResult<ReadableStream>) => TResult1 | PromiseLike<TResult1>)\n | null,\n onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null\n ): Promise<TResult1 | TResult2> {\n return this.execute().then(onfulfilled, onrejected)\n }\n\n private async execute(): Promise<DownloadResult<ReadableStream>> {\n try {\n const result = await this.downloadFn()\n\n return {\n data: result.body as ReadableStream,\n error: null,\n }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n}\n","import { isStorageError } from '../lib/errors'\nimport { DownloadResult } from '../lib/types'\nimport StreamDownloadBuilder from './StreamDownloadBuilder'\n\nexport default class BlobDownloadBuilder implements Promise<DownloadResult<Blob>> {\n readonly [Symbol.toStringTag]: string = 'BlobDownloadBuilder'\n private promise: Promise<DownloadResult<Blob>> | null = null\n\n constructor(\n private downloadFn: () => Promise<Response>,\n private shouldThrowOnError: boolean\n ) {}\n\n asStream(): StreamDownloadBuilder {\n return new StreamDownloadBuilder(this.downloadFn, this.shouldThrowOnError)\n }\n\n then<TResult1 = DownloadResult<Blob>, TResult2 = never>(\n onfulfilled?: ((value: DownloadResult<Blob>) => TResult1 | PromiseLike<TResult1>) | null,\n onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null\n ): Promise<TResult1 | TResult2> {\n return this.getPromise().then(onfulfilled, onrejected)\n }\n\n catch<TResult = never>(\n onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | null\n ): Promise<DownloadResult<Blob> | TResult> {\n return this.getPromise().catch(onrejected)\n }\n\n finally(onfinally?: (() => void) | null): Promise<DownloadResult<Blob>> {\n return this.getPromise().finally(onfinally)\n }\n\n private getPromise(): Promise<DownloadResult<Blob>> {\n if (!this.promise) {\n this.promise = this.execute()\n }\n return this.promise\n }\n\n private async execute(): Promise<DownloadResult<Blob>> {\n try {\n const result = await this.downloadFn()\n\n return {\n data: await result.blob(),\n error: null,\n }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n}\n","import { isStorageError, StorageError, StorageUnknownError } from '../lib/errors'\nimport { Fetch, get, head, post, put, remove } from '../lib/fetch'\nimport { recursiveToCamel, resolveFetch } from '../lib/helpers'\nimport {\n FileObject,\n FileOptions,\n SearchOptions,\n FetchParameters,\n TransformOptions,\n DestinationOptions,\n FileObjectV2,\n Camelize,\n SearchV2Options,\n SearchV2Result,\n} from '../lib/types'\nimport BlobDownloadBuilder from './BlobDownloadBuilder'\n\nconst DEFAULT_SEARCH_OPTIONS = {\n limit: 100,\n offset: 0,\n sortBy: {\n column: 'name',\n order: 'asc',\n },\n}\n\nconst DEFAULT_FILE_OPTIONS: FileOptions = {\n cacheControl: '3600',\n contentType: 'text/plain;charset=UTF-8',\n upsert: false,\n}\n\ntype FileBody =\n | ArrayBuffer\n | ArrayBufferView\n | Blob\n | Buffer\n | File\n | FormData\n | NodeJS.ReadableStream\n | ReadableStream<Uint8Array>\n | URLSearchParams\n | string\n\nexport default class StorageFileApi {\n protected url: string\n protected headers: { [key: string]: string }\n protected bucketId?: string\n protected fetch: Fetch\n protected shouldThrowOnError = false\n\n constructor(\n url: string,\n headers: { [key: string]: string } = {},\n bucketId?: string,\n fetch?: Fetch\n ) {\n this.url = url\n this.headers = headers\n this.bucketId = bucketId\n this.fetch = resolveFetch(fetch)\n }\n\n /**\n * Enable throwing errors instead of returning them.\n *\n * @category File Buckets\n */\n public throwOnError(): this {\n this.shouldThrowOnError = true\n return this\n }\n\n /**\n * Uploads a file to an existing bucket or replaces an existing file at the specified path with a new one.\n *\n * @param method HTTP method.\n * @param path The relative file path. Should be of the format `folder/subfolder/filename.png`. The bucket must already exist before attempting to upload.\n * @param fileBody The body of the file to be stored in the bucket.\n */\n private async uploadOrUpdate(\n method: 'POST' | 'PUT',\n path: string,\n fileBody: FileBody,\n fileOptions?: FileOptions\n ): Promise<\n | {\n data: { id: string; path: string; fullPath: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n let body\n const options = { ...DEFAULT_FILE_OPTIONS, ...fileOptions }\n let headers: Record<string, string> = {\n ...this.headers,\n ...(method === 'POST' && { 'x-upsert': String(options.upsert as boolean) }),\n }\n\n const metadata = options.metadata\n\n if (typeof Blob !== 'undefined' && fileBody instanceof Blob) {\n body = new FormData()\n body.append('cacheControl', options.cacheControl as string)\n if (metadata) {\n body.append('metadata', this.encodeMetadata(metadata))\n }\n body.append('', fileBody)\n } else if (typeof FormData !== 'undefined' && fileBody instanceof FormData) {\n body = fileBody\n // Only append if not already present\n if (!body.has('cacheControl')) {\n body.append('cacheControl', options.cacheControl as string)\n }\n if (metadata && !body.has('metadata')) {\n body.append('metadata', this.encodeMetadata(metadata))\n }\n } else {\n body = fileBody\n headers['cache-control'] = `max-age=${options.cacheControl}`\n headers['content-type'] = options.contentType as string\n\n if (metadata) {\n headers['x-metadata'] = this.toBase64(this.encodeMetadata(metadata))\n }\n\n // Node.js streams require duplex option for fetch in Node 20+\n // Check for both web ReadableStream and Node.js streams\n const isStream =\n (typeof ReadableStream !== 'undefined' && body instanceof ReadableStream) ||\n (body && typeof body === 'object' && 'pipe' in body && typeof body.pipe === 'function')\n\n if (isStream && !options.duplex) {\n options.duplex = 'half'\n }\n }\n\n if (fileOptions?.headers) {\n headers = { ...headers, ...fileOptions.headers }\n }\n\n const cleanPath = this._removeEmptyFolders(path)\n const _path = this._getFinalPath(cleanPath)\n const data = await (method == 'PUT' ? put : post)(\n this.fetch,\n `${this.url}/object/${_path}`,\n body as object,\n { headers, ...(options?.duplex ? { duplex: options.duplex } : {}) }\n )\n\n return {\n data: { path: cleanPath, id: data.Id, fullPath: data.Key },\n error: null,\n }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Uploads a file to an existing bucket.\n *\n * @category File Buckets\n * @param path The file path, including the file name. Should be of the format `folder/subfolder/filename.png`. The bucket must already exist before attempting to upload.\n * @param fileBody The body of the file to be stored in the bucket.\n * @param fileOptions Optional file upload options including cacheControl, contentType, upsert, and metadata.\n * @returns Promise with response containing file path, id, and fullPath or error\n *\n * @example Upload file\n * ```js\n * const avatarFile = event.target.files[0]\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .upload('public/avatar1.png', avatarFile, {\n * cacheControl: '3600',\n * upsert: false\n * })\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"path\": \"public/avatar1.png\",\n * \"fullPath\": \"avatars/public/avatar1.png\"\n * },\n * \"error\": null\n * }\n * ```\n *\n * @example Upload file using `ArrayBuffer` from base64 file data\n * ```js\n * import { decode } from 'base64-arraybuffer'\n *\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .upload('public/avatar1.png', decode('base64FileData'), {\n * contentType: 'image/png'\n * })\n * ```\n */\n async upload(\n path: string,\n fileBody: FileBody,\n fileOptions?: FileOptions\n ): Promise<\n | {\n data: { id: string; path: string; fullPath: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n return this.uploadOrUpdate('POST', path, fileBody, fileOptions)\n }\n\n /**\n * Upload a file with a token generated from `createSignedUploadUrl`.\n *\n * @category File Buckets\n * @param path The file path, including the file name. Should be of the format `folder/subfolder/filename.png`. The bucket must already exist before attempting to upload.\n * @param token The token generated from `createSignedUploadUrl`\n * @param fileBody The body of the file to be stored in the bucket.\n * @param fileOptions HTTP headers (cacheControl, contentType, etc.).\n * **Note:** The `upsert` option has no effect here. To enable upsert behavior,\n * pass `{ upsert: true }` when calling `createSignedUploadUrl()` instead.\n * @returns Promise with response containing file path and fullPath or error\n *\n * @example Upload to a signed URL\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .uploadToSignedUrl('folder/cat.jpg', 'token-from-createSignedUploadUrl', file)\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"path\": \"folder/cat.jpg\",\n * \"fullPath\": \"avatars/folder/cat.jpg\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async uploadToSignedUrl(\n path: string,\n token: string,\n fileBody: FileBody,\n fileOptions?: FileOptions\n ) {\n const cleanPath = this._removeEmptyFolders(path)\n const _path = this._getFinalPath(cleanPath)\n\n const url = new URL(this.url + `/object/upload/sign/${_path}`)\n url.searchParams.set('token', token)\n\n try {\n let body\n const options = { upsert: DEFAULT_FILE_OPTIONS.upsert, ...fileOptions }\n const headers: Record<string, string> = {\n ...this.headers,\n ...{ 'x-upsert': String(options.upsert as boolean) },\n }\n\n if (typeof Blob !== 'undefined' && fileBody instanceof Blob) {\n body = new FormData()\n body.append('cacheControl', options.cacheControl as string)\n body.append('', fileBody)\n } else if (typeof FormData !== 'undefined' && fileBody instanceof FormData) {\n body = fileBody\n body.append('cacheControl', options.cacheControl as string)\n } else {\n body = fileBody\n headers['cache-control'] = `max-age=${options.cacheControl}`\n headers['content-type'] = options.contentType as string\n }\n\n const data = await put(this.fetch, url.toString(), body as object, { headers })\n\n return {\n data: { path: cleanPath, fullPath: data.Key },\n error: null,\n }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Creates a signed upload URL.\n * Signed upload URLs can be used to upload files to the bucket without further authentication.\n * They are valid for 2 hours.\n *\n * @category File Buckets\n * @param path The file path, including the current file name. For example `folder/image.png`.\n * @param options.upsert If set to true, allows the file to be overwritten if it already exists.\n * @returns Promise with response containing signed upload URL, token, and path or error\n *\n * @example Create Signed Upload URL\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .createSignedUploadUrl('folder/cat.jpg')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"signedUrl\": \"https://example.supabase.co/storage/v1/object/upload/sign/avatars/folder/cat.jpg?token=<TOKEN>\",\n * \"path\": \"folder/cat.jpg\",\n * \"token\": \"<TOKEN>\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async createSignedUploadUrl(\n path: string,\n options?: { upsert: boolean }\n ): Promise<\n | {\n data: { signedUrl: string; token: string; path: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n let _path = this._getFinalPath(path)\n\n const headers = { ...this.headers }\n\n if (options?.upsert) {\n headers['x-upsert'] = 'true'\n }\n\n const data = await post(\n this.fetch,\n `${this.url}/object/upload/sign/${_path}`,\n {},\n { headers }\n )\n\n const url = new URL(this.url + data.url)\n\n const token = url.searchParams.get('token')\n\n if (!token) {\n throw new StorageError('No token returned by API')\n }\n\n return { data: { signedUrl: url.toString(), path, token }, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Replaces an existing file at the specified path with a new one.\n *\n * @category File Buckets\n * @param path The relative file path. Should be of the format `folder/subfolder/filename.png`. The bucket must already exist before attempting to update.\n * @param fileBody The body of the file to be stored in the bucket.\n * @param fileOptions Optional file upload options including cacheControl, contentType, upsert, and metadata.\n * @returns Promise with response containing file path, id, and fullPath or error\n *\n * @example Update file\n * ```js\n * const avatarFile = event.target.files[0]\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .update('public/avatar1.png', avatarFile, {\n * cacheControl: '3600',\n * upsert: true\n * })\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"path\": \"public/avatar1.png\",\n * \"fullPath\": \"avatars/public/avatar1.png\"\n * },\n * \"error\": null\n * }\n * ```\n *\n * @example Update file using `ArrayBuffer` from base64 file data\n * ```js\n * import {decode} from 'base64-arraybuffer'\n *\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .update('public/avatar1.png', decode('base64FileData'), {\n * contentType: 'image/png'\n * })\n * ```\n */\n async update(\n path: string,\n fileBody:\n | ArrayBuffer\n | ArrayBufferView\n | Blob\n | Buffer\n | File\n | FormData\n | NodeJS.ReadableStream\n | ReadableStream<Uint8Array>\n | URLSearchParams\n | string,\n fileOptions?: FileOptions\n ): Promise<\n | {\n data: { id: string; path: string; fullPath: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n return this.uploadOrUpdate('PUT', path, fileBody, fileOptions)\n }\n\n /**\n * Moves an existing file to a new path in the same bucket.\n *\n * @category File Buckets\n * @param fromPath The original file path, including the current file name. For example `folder/image.png`.\n * @param toPath The new file path, including the new file name. For example `folder/image-new.png`.\n * @param options The destination options.\n * @returns Promise with response containing success message or error\n *\n * @example Move file\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .move('public/avatar1.png', 'private/avatar2.png')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"message\": \"Successfully moved\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async move(\n fromPath: string,\n toPath: string,\n options?: DestinationOptions\n ): Promise<\n | {\n data: { message: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/object/move`,\n {\n bucketId: this.bucketId,\n sourceKey: fromPath,\n destinationKey: toPath,\n destinationBucket: options?.destinationBucket,\n },\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Copies an existing file to a new path in the same bucket.\n *\n * @category File Buckets\n * @param fromPath The original file path, including the current file name. For example `folder/image.png`.\n * @param toPath The new file path, including the new file name. For example `folder/image-copy.png`.\n * @param options The destination options.\n * @returns Promise with response containing copied file path or error\n *\n * @example Copy file\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .copy('public/avatar1.png', 'private/avatar2.png')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"path\": \"avatars/private/avatar2.png\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async copy(\n fromPath: string,\n toPath: string,\n options?: DestinationOptions\n ): Promise<\n | {\n data: { path: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/object/copy`,\n {\n bucketId: this.bucketId,\n sourceKey: fromPath,\n destinationKey: toPath,\n destinationBucket: options?.destinationBucket,\n },\n { headers: this.headers }\n )\n return { data: { path: data.Key }, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Creates a signed URL. Use a signed URL to share a file for a fixed amount of time.\n *\n * @category File Buckets\n * @param path The file path, including the current file name. For example `folder/image.png`.\n * @param expiresIn The number of seconds until the signed URL expires. For example, `60` for a URL which is valid for one minute.\n * @param options.download triggers the file as a download if set to true. Set this parameter as the name of the file if you want to trigger the download with a different filename.\n * @param options.transform Transform the asset before serving it to the client.\n * @returns Promise with response containing signed URL or error\n *\n * @example Create Signed URL\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .createSignedUrl('folder/avatar1.png', 60)\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"signedUrl\": \"https://example.supabase.co/storage/v1/object/sign/avatars/folder/avatar1.png?token=<TOKEN>\"\n * },\n * \"error\": null\n * }\n * ```\n *\n * @example Create a signed URL for an asset with transformations\n * ```js\n * const { data } = await supabase\n * .storage\n * .from('avatars')\n * .createSignedUrl('folder/avatar1.png', 60, {\n * transform: {\n * width: 100,\n * height: 100,\n * }\n * })\n * ```\n *\n * @example Create a signed URL which triggers the download of the asset\n * ```js\n * const { data } = await supabase\n * .storage\n * .from('avatars')\n * .createSignedUrl('folder/avatar1.png', 60, {\n * download: true,\n * })\n * ```\n */\n async createSignedUrl(\n path: string,\n expiresIn: number,\n options?: { download?: string | boolean; transform?: TransformOptions }\n ): Promise<\n | {\n data: { signedUrl: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n let _path = this._getFinalPath(path)\n\n let data = await post(\n this.fetch,\n `${this.url}/object/sign/${_path}`,\n { expiresIn, ...(options?.transform ? { transform: options.transform } : {}) },\n { headers: this.headers }\n )\n const downloadQueryParam = options?.download\n ? `&download=${options.download === true ? '' : options.download}`\n : ''\n const signedUrl = encodeURI(`${this.url}${data.signedURL}${downloadQueryParam}`)\n data = { signedUrl }\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Creates multiple signed URLs. Use a signed URL to share a file for a fixed amount of time.\n *\n * @category File Buckets\n * @param paths The file paths to be downloaded, including the current file names. For example `['folder/image.png', 'folder2/image2.png']`.\n * @param expiresIn The number of seconds until the signed URLs expire. For example, `60` for URLs which are valid for one minute.\n * @param options.download triggers the file as a download if set to true. Set this parameter as the name of the file if you want to trigger the download with a different filename.\n * @returns Promise with response containing array of objects with signedUrl, path, and error or error\n *\n * @example Create Signed URLs\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .createSignedUrls(['folder/avatar1.png', 'folder/avatar2.png'], 60)\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": [\n * {\n * \"error\": null,\n * \"path\": \"folder/avatar1.png\",\n * \"signedURL\": \"/object/sign/avatars/folder/avatar1.png?token=<TOKEN>\",\n * \"signedUrl\": \"https://example.supabase.co/storage/v1/object/sign/avatars/folder/avatar1.png?token=<TOKEN>\"\n * },\n * {\n * \"error\": null,\n * \"path\": \"folder/avatar2.png\",\n * \"signedURL\": \"/object/sign/avatars/folder/avatar2.png?token=<TOKEN>\",\n * \"signedUrl\": \"https://example.supabase.co/storage/v1/object/sign/avatars/folder/avatar2.png?token=<TOKEN>\"\n * }\n * ],\n * \"error\": null\n * }\n * ```\n */\n async createSignedUrls(\n paths: string[],\n expiresIn: number,\n options?: { download: string | boolean }\n ): Promise<\n | {\n data: { error: string | null; path: string | null; signedUrl: string }[]\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/object/sign/${this.bucketId}`,\n { expiresIn, paths },\n { headers: this.headers }\n )\n\n const downloadQueryParam = options?.download\n ? `&download=${options.download === true ? '' : options.download}`\n : ''\n return {\n data: data.map((datum: { signedURL: string }) => ({\n ...datum,\n signedUrl: datum.signedURL\n ? encodeURI(`${this.url}${datum.signedURL}${downloadQueryParam}`)\n : null,\n })),\n error: null,\n }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Downloads a file from a private bucket. For public buckets, make a request to the URL returned from `getPublicUrl` instead.\n *\n * @category File Buckets\n * @param path The full path and file name of the file to be downloaded. For example `folder/image.png`.\n * @param options.transform Transform the asset before serving it to the client.\n * @returns BlobDownloadBuilder instance for downloading the file\n *\n * @example Download file\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .download('folder/avatar1.png')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": <BLOB>,\n * \"error\": null\n * }\n * ```\n *\n * @example Download file with transformations\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .download('folder/avatar1.png', {\n * transform: {\n * width: 100,\n * height: 100,\n * quality: 80\n * }\n * })\n * ```\n */\n download<Options extends { transform?: TransformOptions }>(\n path: string,\n options?: Options\n ): BlobDownloadBuilder {\n const wantsTransformation = typeof options?.transform !== 'undefined'\n const renderPath = wantsTransformation ? 'render/image/authenticated' : 'object'\n const transformationQuery = this.transformOptsToQueryString(options?.transform || {})\n const queryString = transformationQuery ? `?${transformationQuery}` : ''\n const _path = this._getFinalPath(path)\n const downloadFn = () =>\n get(this.fetch, `${this.url}/${renderPath}/${_path}${queryString}`, {\n headers: this.headers,\n noResolveJson: true,\n })\n return new BlobDownloadBuilder(downloadFn, this.shouldThrowOnError)\n }\n\n /**\n * Retrieves the details of an existing file.\n *\n * @category File Buckets\n * @param path The file path, including the file name. For example `folder/image.png`.\n * @returns Promise with response containing file metadata or error\n *\n * @example Get file info\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .info('folder/avatar1.png')\n * ```\n */\n async info(path: string): Promise<\n | {\n data: Camelize<FileObjectV2>\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n const _path = this._getFinalPath(path)\n\n try {\n const data = await get(this.fetch, `${this.url}/object/info/${_path}`, {\n headers: this.headers,\n })\n\n return { data: recursiveToCamel(data) as Camelize<FileObjectV2>, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Checks the existence of a file.\n *\n * @category File Buckets\n * @param path The file path, including the file name. For example `folder/image.png`.\n * @returns Promise with response containing boolean indicating file existence or error\n *\n * @example Check file existence\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .exists('folder/avatar1.png')\n * ```\n */\n async exists(path: string): Promise<\n | {\n data: boolean\n error: null\n }\n | {\n data: boolean\n error: StorageError\n }\n > {\n const _path = this._getFinalPath(path)\n\n try {\n await head(this.fetch, `${this.url}/object/${_path}`, {\n headers: this.headers,\n })\n\n return { data: true, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error) && error instanceof StorageUnknownError) {\n const originalError = error.originalError as unknown as { status: number }\n\n if ([400, 404].includes(originalError?.status)) {\n return { data: false, error }\n }\n }\n\n throw error\n }\n }\n\n /**\n * A simple convenience function to get the URL for an asset in a public bucket. If you do not want to use this function, you can construct the public URL by concatenating the bucket URL with the path to the asset.\n * This function does not verify if the bucket is public. If a public URL is created for a bucket which is not public, you will not be able to download the asset.\n *\n * @category File Buckets\n * @param path The path and name of the file to generate the public URL for. For example `folder/image.png`.\n * @param options.download Triggers the file as a download if set to true. Set this parameter as the name of the file if you want to trigger the download with a different filename.\n * @param options.transform Transform the asset before serving it to the client.\n * @returns Object with public URL\n *\n * @example Returns the URL for an asset in a public bucket\n * ```js\n * const { data } = supabase\n * .storage\n * .from('public-bucket')\n * .getPublicUrl('folder/avatar1.png')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"publicUrl\": \"https://example.supabase.co/storage/v1/object/public/public-bucket/folder/avatar1.png\"\n * }\n * }\n * ```\n *\n * @example Returns the URL for an asset in a public bucket with transformations\n * ```js\n * const { data } = supabase\n * .storage\n * .from('public-bucket')\n * .getPublicUrl('folder/avatar1.png', {\n * transform: {\n * width: 100,\n * height: 100,\n * }\n * })\n * ```\n *\n * @example Returns the URL which triggers the download of an asset in a public bucket\n * ```js\n * const { data } = supabase\n * .storage\n * .from('public-bucket')\n * .getPublicUrl('folder/avatar1.png', {\n * download: true,\n * })\n * ```\n */\n getPublicUrl(\n path: string,\n options?: { download?: string | boolean; transform?: TransformOptions }\n ): { data: { publicUrl: string } } {\n const _path = this._getFinalPath(path)\n const _queryString: string[] = []\n\n const downloadQueryParam = options?.download\n ? `download=${options.download === true ? '' : options.download}`\n : ''\n\n if (downloadQueryParam !== '') {\n _queryString.push(downloadQueryParam)\n }\n\n const wantsTransformation = typeof options?.transform !== 'undefined'\n const renderPath = wantsTransformation ? 'render/image' : 'object'\n const transformationQuery = this.transformOptsToQueryString(options?.transform || {})\n\n if (transformationQuery !== '') {\n _queryString.push(transformationQuery)\n }\n\n let queryString = _queryString.join('&')\n if (queryString !== '') {\n queryString = `?${queryString}`\n }\n\n return {\n data: { publicUrl: encodeURI(`${this.url}/${renderPath}/public/${_path}${queryString}`) },\n }\n }\n\n /**\n * Deletes files within the same bucket\n *\n * @category File Buckets\n * @param paths An array of files to delete, including the path and file name. For example [`'folder/image.png'`].\n * @returns Promise with response containing array of deleted file objects or error\n *\n * @example Delete file\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .remove(['folder/avatar1.png'])\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": [],\n * \"error\": null\n * }\n * ```\n */\n async remove(paths: string[]): Promise<\n | {\n data: FileObject[]\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await remove(\n this.fetch,\n `${this.url}/object/${this.bucketId}`,\n { prefixes: paths },\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Get file metadata\n * @param id the file id to retrieve metadata\n */\n // async getMetadata(\n // id: string\n // ): Promise<\n // | {\n // data: Metadata\n // error: null\n // }\n // | {\n // data: null\n // error: StorageError\n // }\n // > {\n // try {\n // const data = await get(this.fetch, `${this.url}/metadata/${id}`, { headers: this.headers })\n // return { data, error: null }\n // } catch (error) {\n // if (isStorageError(error)) {\n // return { data: null, error }\n // }\n\n // throw error\n // }\n // }\n\n /**\n * Update file metadata\n * @param id the file id to update metadata\n * @param meta the new file metadata\n */\n // async updateMetadata(\n // id: string,\n // meta: Metadata\n // ): Promise<\n // | {\n // data: Metadata\n // error: null\n // }\n // | {\n // data: null\n // error: StorageError\n // }\n // > {\n // try {\n // const data = await post(\n // this.fetch,\n // `${this.url}/metadata/${id}`,\n // { ...meta },\n // { headers: this.headers }\n // )\n // return { data, error: null }\n // } catch (error) {\n // if (isStorageError(error)) {\n // return { data: null, error }\n // }\n\n // throw error\n // }\n // }\n\n /**\n * Lists all the files and folders within a path of the bucket.\n *\n * @category File Buckets\n * @param path The folder path.\n * @param options Search options including limit (defaults to 100), offset, sortBy, and search\n * @param parameters Optional fetch parameters including signal for cancellation\n * @returns Promise with response containing array of files or error\n *\n * @example List files in a bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .list('folder', {\n * limit: 100,\n * offset: 0,\n * sortBy: { column: 'name', order: 'asc' },\n * })\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": [\n * {\n * \"name\": \"avatar1.png\",\n * \"id\": \"e668cf7f-821b-4a2f-9dce-7dfa5dd1cfd2\",\n * \"updated_at\": \"2024-05-22T23:06:05.580Z\",\n * \"created_at\": \"2024-05-22T23:04:34.443Z\",\n * \"last_accessed_at\": \"2024-05-22T23:04:34.443Z\",\n * \"metadata\": {\n * \"eTag\": \"\\\"c5e8c553235d9af30ef4f6e280790b92\\\"\",\n * \"size\": 32175,\n * \"mimetype\": \"image/png\",\n * \"cacheControl\": \"max-age=3600\",\n * \"lastModified\": \"2024-05-22T23:06:05.574Z\",\n * \"contentLength\": 32175,\n * \"httpStatusCode\": 200\n * }\n * }\n * ],\n * \"error\": null\n * }\n * ```\n *\n * @example Search files in a bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .from('avatars')\n * .list('folder', {\n * limit: 100,\n * offset: 0,\n * sortBy: { column: 'name', order: 'asc' },\n * search: 'jon'\n * })\n * ```\n */\n async list(\n path?: string,\n options?: SearchOptions,\n parameters?: FetchParameters\n ): Promise<\n | {\n data: FileObject[]\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const body = { ...DEFAULT_SEARCH_OPTIONS, ...options, prefix: path || '' }\n const data = await post(\n this.fetch,\n `${this.url}/object/list/${this.bucketId}`,\n body,\n { headers: this.headers },\n parameters\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * @experimental this method signature might change in the future\n *\n * @category File Buckets\n * @param options search options\n * @param parameters\n */\n async listV2(\n options?: SearchV2Options,\n parameters?: FetchParameters\n ): Promise<\n | {\n data: SearchV2Result\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const body = { ...options }\n const data = await post(\n this.fetch,\n `${this.url}/object/list-v2/${this.bucketId}`,\n body,\n { headers: this.headers },\n parameters\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n protected encodeMetadata(metadata: Record<string, any>) {\n return JSON.stringify(metadata)\n }\n\n toBase64(data: string) {\n if (typeof Buffer !== 'undefined') {\n return Buffer.from(data).toString('base64')\n }\n return btoa(data)\n }\n\n private _getFinalPath(path: string) {\n return `${this.bucketId}/${path.replace(/^\\/+/, '')}`\n }\n\n private _removeEmptyFolders(path: string) {\n return path.replace(/^\\/|\\/$/g, '').replace(/\\/+/g, '/')\n }\n\n private transformOptsToQueryString(transform: TransformOptions) {\n const params: string[] = []\n if (transform.width) {\n params.push(`width=${transform.width}`)\n }\n\n if (transform.height) {\n params.push(`height=${transform.height}`)\n }\n\n if (transform.resize) {\n params.push(`resize=${transform.resize}`)\n }\n\n if (transform.format) {\n params.push(`format=${transform.format}`)\n }\n\n if (transform.quality) {\n params.push(`quality=${transform.quality}`)\n }\n\n return params.join('&')\n }\n}\n","// Generated automatically during releases by scripts/update-version-files.ts\n// This file provides runtime access to the package version for:\n// - HTTP request headers (e.g., X-Client-Info header for API requests)\n// - Debugging and support (identifying which version is running)\n// - Telemetry and logging (version reporting in errors/analytics)\n// - Ensuring build artifacts match the published package version\nexport const version = '2.90.1'\n","import { version } from './version'\nexport const DEFAULT_HEADERS = {\n 'X-Client-Info': `storage-js/${version}`,\n}\n","import { DEFAULT_HEADERS } from '../lib/constants'\nimport { isStorageError, StorageError } from '../lib/errors'\nimport { Fetch, get, post, put, remove } from '../lib/fetch'\nimport { resolveFetch } from '../lib/helpers'\nimport { Bucket, BucketType, ListBucketOptions } from '../lib/types'\nimport { StorageClientOptions } from '../StorageClient'\n\nexport default class StorageBucketApi {\n protected url: string\n protected headers: { [key: string]: string }\n protected fetch: Fetch\n protected shouldThrowOnError = false\n\n constructor(\n url: string,\n headers: { [key: string]: string } = {},\n fetch?: Fetch,\n opts?: StorageClientOptions\n ) {\n const baseUrl = new URL(url)\n\n // if legacy uri is used, replace with new storage host (disables request buffering to allow > 50GB uploads)\n // \"project-ref.supabase.co\" becomes \"project-ref.storage.supabase.co\"\n if (opts?.useNewHostname) {\n const isSupabaseHost = /supabase\\.(co|in|red)$/.test(baseUrl.hostname)\n if (isSupabaseHost && !baseUrl.hostname.includes('storage.supabase.')) {\n baseUrl.hostname = baseUrl.hostname.replace('supabase.', 'storage.supabase.')\n }\n }\n\n this.url = baseUrl.href.replace(/\\/$/, '')\n this.headers = { ...DEFAULT_HEADERS, ...headers }\n this.fetch = resolveFetch(fetch)\n }\n\n /**\n * Enable throwing errors instead of returning them.\n *\n * @category File Buckets\n */\n public throwOnError(): this {\n this.shouldThrowOnError = true\n return this\n }\n\n /**\n * Retrieves the details of all Storage buckets within an existing project.\n *\n * @category File Buckets\n * @param options Query parameters for listing buckets\n * @param options.limit Maximum number of buckets to return\n * @param options.offset Number of buckets to skip\n * @param options.sortColumn Column to sort by ('id', 'name', 'created_at', 'updated_at')\n * @param options.sortOrder Sort order ('asc' or 'desc')\n * @param options.search Search term to filter bucket names\n * @returns Promise with response containing array of buckets or error\n *\n * @example List buckets\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .listBuckets()\n * ```\n *\n * @example List buckets with options\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .listBuckets({\n * limit: 10,\n * offset: 0,\n * sortColumn: 'created_at',\n * sortOrder: 'desc',\n * search: 'prod'\n * })\n * ```\n */\n async listBuckets(options?: ListBucketOptions): Promise<\n | {\n data: Bucket[]\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const queryString = this.listBucketOptionsToQueryString(options)\n const data = await get(this.fetch, `${this.url}/bucket${queryString}`, {\n headers: this.headers,\n })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Retrieves the details of an existing Storage bucket.\n *\n * @category File Buckets\n * @param id The unique identifier of the bucket you would like to retrieve.\n * @returns Promise with response containing bucket details or error\n *\n * @example Get bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .getBucket('avatars')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"id\": \"avatars\",\n * \"name\": \"avatars\",\n * \"owner\": \"\",\n * \"public\": false,\n * \"file_size_limit\": 1024,\n * \"allowed_mime_types\": [\n * \"image/png\"\n * ],\n * \"created_at\": \"2024-05-22T22:26:05.100Z\",\n * \"updated_at\": \"2024-05-22T22:26:05.100Z\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async getBucket(id: string): Promise<\n | {\n data: Bucket\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await get(this.fetch, `${this.url}/bucket/${id}`, { headers: this.headers })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Creates a new Storage bucket\n *\n * @category File Buckets\n * @param id A unique identifier for the bucket you are creating.\n * @param options.public The visibility of the bucket. Public buckets don't require an authorization token to download objects, but still require a valid token for all other operations. By default, buckets are private.\n * @param options.fileSizeLimit specifies the max file size in bytes that can be uploaded to this bucket.\n * The global file size limit takes precedence over this value.\n * The default value is null, which doesn't set a per bucket file size limit.\n * @param options.allowedMimeTypes specifies the allowed mime types that this bucket can accept during upload.\n * The default value is null, which allows files with all mime types to be uploaded.\n * Each mime type specified can be a wildcard, e.g. image/*, or a specific mime type, e.g. image/png.\n * @param options.type (private-beta) specifies the bucket type. see `BucketType` for more details.\n * - default bucket type is `STANDARD`\n * @returns Promise with response containing newly created bucket name or error\n *\n * @example Create bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .createBucket('avatars', {\n * public: false,\n * allowedMimeTypes: ['image/png'],\n * fileSizeLimit: 1024\n * })\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"name\": \"avatars\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async createBucket(\n id: string,\n options: {\n public: boolean\n fileSizeLimit?: number | string | null\n allowedMimeTypes?: string[] | null\n type?: BucketType\n } = {\n public: false,\n }\n ): Promise<\n | {\n data: Pick<Bucket, 'name'>\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/bucket`,\n {\n id,\n name: id,\n type: options.type,\n public: options.public,\n file_size_limit: options.fileSizeLimit,\n allowed_mime_types: options.allowedMimeTypes,\n },\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Updates a Storage bucket\n *\n * @category File Buckets\n * @param id A unique identifier for the bucket you are updating.\n * @param options.public The visibility of the bucket. Public buckets don't require an authorization token to download objects, but still require a valid token for all other operations.\n * @param options.fileSizeLimit specifies the max file size in bytes that can be uploaded to this bucket.\n * The global file size limit takes precedence over this value.\n * The default value is null, which doesn't set a per bucket file size limit.\n * @param options.allowedMimeTypes specifies the allowed mime types that this bucket can accept during upload.\n * The default value is null, which allows files with all mime types to be uploaded.\n * Each mime type specified can be a wildcard, e.g. image/*, or a specific mime type, e.g. image/png.\n * @returns Promise with response containing success message or error\n *\n * @example Update bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .updateBucket('avatars', {\n * public: false,\n * allowedMimeTypes: ['image/png'],\n * fileSizeLimit: 1024\n * })\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"message\": \"Successfully updated\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async updateBucket(\n id: string,\n options: {\n public: boolean\n fileSizeLimit?: number | string | null\n allowedMimeTypes?: string[] | null\n }\n ): Promise<\n | {\n data: { message: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await put(\n this.fetch,\n `${this.url}/bucket/${id}`,\n {\n id,\n name: id,\n public: options.public,\n file_size_limit: options.fileSizeLimit,\n allowed_mime_types: options.allowedMimeTypes,\n },\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Removes all objects inside a single bucket.\n *\n * @category File Buckets\n * @param id The unique identifier of the bucket you would like to empty.\n * @returns Promise with success message or error\n *\n * @example Empty bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .emptyBucket('avatars')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"message\": \"Successfully emptied\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async emptyBucket(id: string): Promise<\n | {\n data: { message: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/bucket/${id}/empty`,\n {},\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Deletes an existing bucket. A bucket can't be deleted with existing objects inside it.\n * You must first `empty()` the bucket.\n *\n * @category File Buckets\n * @param id The unique identifier of the bucket you would like to delete.\n * @returns Promise with success message or error\n *\n * @example Delete bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .deleteBucket('avatars')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"message\": \"Successfully deleted\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async deleteBucket(id: string): Promise<\n | {\n data: { message: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await remove(\n this.fetch,\n `${this.url}/bucket/${id}`,\n {},\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n private listBucketOptionsToQueryString(options?: ListBucketOptions): string {\n const params: Record<string, string> = {}\n if (options) {\n if ('limit' in options) {\n params.limit = String(options.limit)\n }\n if ('offset' in options) {\n params.offset = String(options.offset)\n }\n if (options.search) {\n params.search = options.search\n }\n if (options.sortColumn) {\n params.sortColumn = options.sortColumn\n }\n if (options.sortOrder) {\n params.sortOrder = options.sortOrder\n }\n }\n return Object.keys(params).length > 0 ? '?' + new URLSearchParams(params).toString() : ''\n }\n}\n","import { IcebergRestCatalog, IcebergError } from 'iceberg-js'\nimport { DEFAULT_HEADERS } from '../lib/constants'\nimport { isStorageError, StorageError } from '../lib/errors'\nimport { Fetch, get, post, remove } from '../lib/fetch'\nimport { isValidBucketName, resolveFetch } from '../lib/helpers'\nimport { AnalyticBucket } from '../lib/types'\n\ntype WrapAsyncMethod<T> = T extends (...args: infer A) => Promise<infer R>\n ? (...args: A) => Promise<{ data: R; error: null } | { data: null; error: IcebergError }>\n : T\n\nexport type WrappedIcebergRestCatalog = {\n [K in keyof IcebergRestCatalog]: WrapAsyncMethod<IcebergRestCatalog[K]>\n}\n\n/**\n * Client class for managing Analytics Buckets using Iceberg tables\n * Provides methods for creating, listing, and deleting analytics buckets\n */\nexport default class StorageAnalyticsClient {\n protected url: string\n protected headers: { [key: string]: string }\n protected fetch: Fetch\n protected shouldThrowOnError = false\n\n /**\n * @alpha\n *\n * Creates a new StorageAnalyticsClient instance\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Analytics Buckets\n * @param url - The base URL for the storage API\n * @param headers - HTTP headers to include in requests\n * @param fetch - Optional custom fetch implementation\n *\n * @example\n * ```typescript\n * const client = new StorageAnalyticsClient(url, headers)\n * ```\n */\n constructor(url: string, headers: { [key: string]: string } = {}, fetch?: Fetch) {\n this.url = url.replace(/\\/$/, '')\n this.headers = { ...DEFAULT_HEADERS, ...headers }\n this.fetch = resolveFetch(fetch)\n }\n\n /**\n * @alpha\n *\n * Enable throwing errors instead of returning them in the response\n * When enabled, failed operations will throw instead of returning { data: null, error }\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Analytics Buckets\n * @returns This instance for method chaining\n */\n public throwOnError(): this {\n this.shouldThrowOnError = true\n return this\n }\n\n /**\n * @alpha\n *\n * Creates a new analytics bucket using Iceberg tables\n * Analytics buckets are optimized for analytical queries and data processing\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Analytics Buckets\n * @param name A unique name for the bucket you are creating\n * @returns Promise with response containing newly created analytics bucket or error\n *\n * @example Create analytics bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .analytics\n * .createBucket('analytics-data')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"name\": \"analytics-data\",\n * \"type\": \"ANALYTICS\",\n * \"format\": \"iceberg\",\n * \"created_at\": \"2024-05-22T22:26:05.100Z\",\n * \"updated_at\": \"2024-05-22T22:26:05.100Z\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async createBucket(name: string): Promise<\n | {\n data: AnalyticBucket\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await post(this.fetch, `${this.url}/bucket`, { name }, { headers: this.headers })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * @alpha\n *\n * Retrieves the details of all Analytics Storage buckets within an existing project\n * Only returns buckets of type 'ANALYTICS'\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Analytics Buckets\n * @param options Query parameters for listing buckets\n * @param options.limit Maximum number of buckets to return\n * @param options.offset Number of buckets to skip\n * @param options.sortColumn Column to sort by ('name', 'created_at', 'updated_at')\n * @param options.sortOrder Sort order ('asc' or 'desc')\n * @param options.search Search term to filter bucket names\n * @returns Promise with response containing array of analytics buckets or error\n *\n * @example List analytics buckets\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .analytics\n * .listBuckets({\n * limit: 10,\n * offset: 0,\n * sortColumn: 'created_at',\n * sortOrder: 'desc'\n * })\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": [\n * {\n * \"name\": \"analytics-data\",\n * \"type\": \"ANALYTICS\",\n * \"format\": \"iceberg\",\n * \"created_at\": \"2024-05-22T22:26:05.100Z\",\n * \"updated_at\": \"2024-05-22T22:26:05.100Z\"\n * }\n * ],\n * \"error\": null\n * }\n * ```\n */\n async listBuckets(options?: {\n limit?: number\n offset?: number\n sortColumn?: 'name' | 'created_at' | 'updated_at'\n sortOrder?: 'asc' | 'desc'\n search?: string\n }): Promise<\n | {\n data: AnalyticBucket[]\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n // Build query string from options\n const queryParams = new URLSearchParams()\n if (options?.limit !== undefined) queryParams.set('limit', options.limit.toString())\n if (options?.offset !== undefined) queryParams.set('offset', options.offset.toString())\n if (options?.sortColumn) queryParams.set('sortColumn', options.sortColumn)\n if (options?.sortOrder) queryParams.set('sortOrder', options.sortOrder)\n if (options?.search) queryParams.set('search', options.search)\n\n const queryString = queryParams.toString()\n const url = queryString ? `${this.url}/bucket?${queryString}` : `${this.url}/bucket`\n\n const data = await get(this.fetch, url, { headers: this.headers })\n\n return { data: data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * @alpha\n *\n * Deletes an existing analytics bucket\n * A bucket can't be deleted with existing objects inside it\n * You must first empty the bucket before deletion\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Analytics Buckets\n * @param bucketName The unique identifier of the bucket you would like to delete\n * @returns Promise with response containing success message or error\n *\n * @example Delete analytics bucket\n * ```js\n * const { data, error } = await supabase\n * .storage\n * .analytics\n * .deleteBucket('analytics-data')\n * ```\n *\n * Response:\n * ```json\n * {\n * \"data\": {\n * \"message\": \"Successfully deleted\"\n * },\n * \"error\": null\n * }\n * ```\n */\n async deleteBucket(bucketName: string): Promise<\n | {\n data: { message: string }\n error: null\n }\n | {\n data: null\n error: StorageError\n }\n > {\n try {\n const data = await remove(\n this.fetch,\n `${this.url}/bucket/${bucketName}`,\n {},\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * @alpha\n *\n * Get an Iceberg REST Catalog client configured for a specific analytics bucket\n * Use this to perform advanced table and namespace operations within the bucket\n * The returned client provides full access to the Apache Iceberg REST Catalog API\n * with the Supabase `{ data, error }` pattern for consistent error handling on all operations.\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Analytics Buckets\n * @param bucketName - The name of the analytics bucket (warehouse) to connect to\n * @returns The wrapped Iceberg catalog client\n * @throws {StorageError} If the bucket name is invalid\n *\n * @example Get catalog and create table\n * ```js\n * // First, create an analytics bucket\n * const { data: bucket, error: bucketError } = await supabase\n * .storage\n * .analytics\n * .createBucket('analytics-data')\n *\n * // Get the Iceberg catalog for that bucket\n * const catalog = supabase.storage.analytics.from('analytics-data')\n *\n * // Create a namespace\n * const { error: nsError } = await catalog.createNamespace({ namespace: ['default'] })\n *\n * // Create a table with schema\n * const { data: tableMetadata, error: tableError } = await catalog.createTable(\n * { namespace: ['default'] },\n * {\n * name: 'events',\n * schema: {\n * type: 'struct',\n * fields: [\n * { id: 1, name: 'id', type: 'long', required: true },\n * { id: 2, name: 'timestamp', type: 'timestamp', required: true },\n * { id: 3, name: 'user_id', type: 'string', required: false }\n * ],\n * 'schema-id': 0,\n * 'identifier-field-ids': [1]\n * },\n * 'partition-spec': {\n * 'spec-id': 0,\n * fields: []\n * },\n * 'write-order': {\n * 'order-id': 0,\n * fields: []\n * },\n * properties: {\n * 'write.format.default': 'parquet'\n * }\n * }\n * )\n * ```\n *\n * @example List tables in namespace\n * ```js\n * const catalog = supabase.storage.analytics.from('analytics-data')\n *\n * // List all tables in the default namespace\n * const { data: tables, error: listError } = await catalog.listTables({ namespace: ['default'] })\n * if (listError) {\n * if (listError.isNotFound()) {\n * console.log('Namespace not found')\n * }\n * return\n * }\n * console.log(tables) // [{ namespace: ['default'], name: 'events' }]\n * ```\n *\n * @example Working with namespaces\n * ```js\n * const catalog = supabase.storage.analytics.from('analytics-data')\n *\n * // List all namespaces\n * const { data: namespaces } = await catalog.listNamespaces()\n *\n * // Create namespace with properties\n * await catalog.createNamespace(\n * { namespace: ['production'] },\n * { properties: { owner: 'data-team', env: 'prod' } }\n * )\n * ```\n *\n * @example Cleanup operations\n * ```js\n * const catalog = supabase.storage.analytics.from('analytics-data')\n *\n * // Drop table with purge option (removes all data)\n * const { error: dropError } = await catalog.dropTable(\n * { namespace: ['default'], name: 'events' },\n * { purge: true }\n * )\n *\n * if (dropError?.isNotFound()) {\n * console.log('Table does not exist')\n * }\n *\n * // Drop namespace (must be empty)\n * await catalog.dropNamespace({ namespace: ['default'] })\n * ```\n *\n * @remarks\n * This method provides a bridge between Supabase's bucket management and the standard\n * Apache Iceberg REST Catalog API. The bucket name maps to the Iceberg warehouse parameter.\n * All authentication and configuration is handled automatically using your Supabase credentials.\n *\n * **Error Handling**: Invalid bucket names throw immediately. All catalog\n * operations return `{ data, error }` where errors are `IcebergError` instances from iceberg-js.\n * Use helper methods like `error.isNotFound()` or check `error.status` for specific error handling.\n * Use `.throwOnError()` on the analytics client if you prefer exceptions for catalog operations.\n *\n * **Cleanup Operations**: When using `dropTable`, the `purge: true` option permanently\n * deletes all table data. Without it, the table is marked as deleted but data remains.\n *\n * **Library Dependency**: The returned catalog wraps `IcebergRestCatalog` from iceberg-js.\n * For complete API documentation and advanced usage, refer to the\n * [iceberg-js documentation](https://supabase.github.io/iceberg-js/).\n */\n from(bucketName: string): WrappedIcebergRestCatalog {\n // Validate bucket name using same rules as Supabase Storage API backend\n if (!isValidBucketName(bucketName)) {\n throw new StorageError(\n 'Invalid bucket name: File, folder, and bucket names must follow AWS object key naming guidelines ' +\n 'and should avoid the use of any other characters.'\n )\n }\n\n // Construct the Iceberg REST Catalog URL\n // The base URL is /storage/v1/iceberg\n // Note: IcebergRestCatalog from iceberg-js automatically adds /v1/ prefix to API paths\n // so we should NOT append /v1 here (it would cause double /v1/v1/ in the URL)\n const catalog = new IcebergRestCatalog({\n baseUrl: this.url,\n catalogName: bucketName, // Maps to the warehouse parameter in Supabase's implementation\n auth: {\n type: 'custom',\n getHeaders: async () => this.headers,\n },\n fetch: this.fetch,\n })\n\n const shouldThrowOnError = this.shouldThrowOnError\n\n const wrappedCatalog = new Proxy(catalog, {\n get(target, prop: keyof IcebergRestCatalog) {\n const value = target[prop]\n if (typeof value !== 'function') {\n return value\n }\n\n return async (...args: unknown[]) => {\n try {\n const data = await (value as Function).apply(target, args)\n return { data, error: null }\n } catch (error) {\n if (shouldThrowOnError) {\n throw error\n }\n return { data: null, error: error as IcebergError }\n }\n }\n },\n }) as unknown as WrappedIcebergRestCatalog\n\n return wrappedCatalog\n }\n}\n","import { version } from '../version'\nexport const DEFAULT_HEADERS = {\n 'X-Client-Info': `storage-js/${version}`,\n 'Content-Type': 'application/json',\n}\n","/**\n * Base error class for all Storage Vectors errors\n */\nexport class StorageVectorsError extends Error {\n protected __isStorageVectorsError = true\n\n constructor(message: string) {\n super(message)\n this.name = 'StorageVectorsError'\n }\n}\n\n/**\n * Type guard to check if an error is a StorageVectorsError\n * @param error - The error to check\n * @returns True if the error is a StorageVectorsError\n */\nexport function isStorageVectorsError(error: unknown): error is StorageVectorsError {\n return typeof error === 'object' && error !== null && '__isStorageVectorsError' in error\n}\n\n/**\n * API error returned from S3 Vectors service\n * Includes HTTP status code and service-specific error code\n */\nexport class StorageVectorsApiError extends StorageVectorsError {\n status: number\n statusCode: string\n\n constructor(message: string, status: number, statusCode: string) {\n super(message)\n this.name = 'StorageVectorsApiError'\n this.status = status\n this.statusCode = statusCode\n }\n\n toJSON() {\n return {\n name: this.name,\n message: this.message,\n status: this.status,\n statusCode: this.statusCode,\n }\n }\n}\n\n/**\n * Unknown error that doesn't match expected error patterns\n * Wraps the original error for debugging\n */\nexport class StorageVectorsUnknownError extends StorageVectorsError {\n originalError: unknown\n\n constructor(message: string, originalError: unknown) {\n super(message)\n this.name = 'StorageVectorsUnknownError'\n this.originalError = originalError\n }\n}\n\n/**\n * Error codes specific to S3 Vectors API\n * Maps AWS service errors to application-friendly error codes\n */\nexport enum StorageVectorsErrorCode {\n /** Internal server fault (HTTP 500) */\n InternalError = 'InternalError',\n /** Resource already exists / conflict (HTTP 409) */\n S3VectorConflictException = 'S3VectorConflictException',\n /** Resource not found (HTTP 404) */\n S3VectorNotFoundException = 'S3VectorNotFoundException',\n /** Delete bucket while not empty (HTTP 400) */\n S3VectorBucketNotEmpty = 'S3VectorBucketNotEmpty',\n /** Exceeds bucket quota/limit (HTTP 400) */\n S3VectorMaxBucketsExceeded = 'S3VectorMaxBucketsExceeded',\n /** Exceeds index quota/limit (HTTP 400) */\n S3VectorMaxIndexesExceeded = 'S3VectorMaxIndexesExceeded',\n}\n","type Fetch = typeof fetch\n\n/**\n * Resolves the fetch implementation to use\n * Uses custom fetch if provided, otherwise uses native fetch\n *\n * @param customFetch - Optional custom fetch implementation\n * @returns Resolved fetch function\n */\nexport const resolveFetch = (customFetch?: Fetch): Fetch => {\n if (customFetch) {\n return (...args) => customFetch(...args)\n }\n return (...args) => fetch(...args)\n}\n\n/**\n * Resolves the Response constructor to use\n * Returns native Response constructor\n *\n * @returns Response constructor\n */\nexport const resolveResponse = (): typeof Response => {\n return Response\n}\n\n/**\n * Determine if input is a plain object\n * An object is plain if it's created by either {}, new Object(), or Object.create(null)\n *\n * @param value - Value to check\n * @returns True if value is a plain object\n * @source https://github.com/sindresorhus/is-plain-obj\n */\nexport const isPlainObject = (value: object): boolean => {\n if (typeof value !== 'object' || value === null) {\n return false\n }\n\n const prototype = Object.getPrototypeOf(value)\n return (\n (prototype === null ||\n prototype === Object.prototype ||\n Object.getPrototypeOf(prototype) === null) &&\n !(Symbol.toStringTag in value) &&\n !(Symbol.iterator in value)\n )\n}\n\n/**\n * Normalizes a number array to float32 format\n * Ensures all vector values are valid 32-bit floats\n *\n * @param values - Array of numbers to normalize\n * @returns Normalized float32 array\n */\nexport const normalizeToFloat32 = (values: number[]): number[] => {\n // Use Float32Array to ensure proper precision\n return Array.from(new Float32Array(values))\n}\n\n/**\n * Validates vector dimensions match expected dimension\n * Throws error if dimensions don't match\n *\n * @param vector - Vector data to validate\n * @param expectedDimension - Expected vector dimension\n * @throws Error if dimensions don't match\n */\nexport const validateVectorDimension = (\n vector: { float32: number[] },\n expectedDimension?: number\n): void => {\n if (expectedDimension !== undefined && vector.float32.length !== expectedDimension) {\n throw new Error(\n `Vector dimension mismatch: expected ${expectedDimension}, got ${vector.float32.length}`\n )\n }\n}\n","import { StorageVectorsApiError, StorageVectorsUnknownError } from './errors'\nimport { isPlainObject, resolveResponse } from './helpers'\nimport { VectorFetchParameters } from './types'\n\nexport type Fetch = typeof fetch\n\n/**\n * Options for fetch requests\n * @property headers - Custom HTTP headers\n * @property noResolveJson - If true, return raw Response instead of parsing JSON\n */\nexport interface FetchOptions {\n headers?: {\n [key: string]: string\n }\n noResolveJson?: boolean\n}\n\n/**\n * HTTP methods supported by the API\n */\nexport type RequestMethodType = 'GET' | 'POST' | 'PUT' | 'DELETE'\n\n/**\n * Extracts error message from various error response formats\n * @param err - Error object from API\n * @returns Human-readable error message\n */\nconst _getErrorMessage = (err: any): string =>\n err.msg || err.message || err.error_description || err.error || JSON.stringify(err)\n\n/**\n * Handles fetch errors and converts them to StorageVectors error types\n * @param error - The error caught from fetch\n * @param reject - Promise rejection function\n * @param options - Fetch options that may affect error handling\n */\nconst handleError = async (\n error: unknown,\n reject: (reason?: any) => void,\n options?: FetchOptions\n) => {\n // Check if error is a Response-like object (has status and ok properties)\n // This is more reliable than instanceof which can fail across realms\n const isResponseLike =\n error &&\n typeof error === 'object' &&\n 'status' in error &&\n 'ok' in error &&\n typeof (error as any).status === 'number'\n\n if (isResponseLike && !options?.noResolveJson) {\n const status = (error as any).status || 500\n const responseError = error as any\n\n // Try to parse JSON body if available\n if (typeof responseError.json === 'function') {\n responseError\n .json()\n .then((err: any) => {\n const statusCode = err?.statusCode || err?.code || status + ''\n reject(new StorageVectorsApiError(_getErrorMessage(err), status, statusCode))\n })\n .catch(() => {\n // If JSON parsing fails, create an ApiError with the HTTP status code\n const statusCode = status + ''\n const message = responseError.statusText || `HTTP ${status} error`\n reject(new StorageVectorsApiError(message, status, statusCode))\n })\n } else {\n // No json() method available, create error from status\n const statusCode = status + ''\n const message = responseError.statusText || `HTTP ${status} error`\n reject(new StorageVectorsApiError(message, status, statusCode))\n }\n } else {\n reject(new StorageVectorsUnknownError(_getErrorMessage(error), error))\n }\n}\n\n/**\n * Builds request parameters for fetch calls\n * @param method - HTTP method\n * @param options - Custom fetch options\n * @param parameters - Additional fetch parameters like AbortSignal\n * @param body - Request body (will be JSON stringified if plain object)\n * @returns Complete fetch request parameters\n */\nconst _getRequestParams = (\n method: RequestMethodType,\n options?: FetchOptions,\n parameters?: VectorFetchParameters,\n body?: object\n) => {\n const params: { [k: string]: any } = { method, headers: options?.headers || {} }\n\n if (method === 'GET' || !body) {\n return params\n }\n\n if (isPlainObject(body)) {\n params.headers = { 'Content-Type': 'application/json', ...options?.headers }\n params.body = JSON.stringify(body)\n } else {\n params.body = body\n }\n\n return { ...params, ...parameters }\n}\n\n/**\n * Internal request handler that wraps fetch with error handling\n * @param fetcher - Fetch function to use\n * @param method - HTTP method\n * @param url - Request URL\n * @param options - Custom fetch options\n * @param parameters - Additional fetch parameters\n * @param body - Request body\n * @returns Promise with parsed response or error\n */\nasync function _handleRequest(\n fetcher: Fetch,\n method: RequestMethodType,\n url: string,\n options?: FetchOptions,\n parameters?: VectorFetchParameters,\n body?: object\n): Promise<any> {\n return new Promise((resolve, reject) => {\n fetcher(url, _getRequestParams(method, options, parameters, body))\n .then((result) => {\n if (!result.ok) throw result\n if (options?.noResolveJson) return result\n // Handle empty responses (204, empty body)\n const contentType = result.headers.get('content-type')\n if (!contentType || !contentType.includes('application/json')) {\n return {}\n }\n return result.json()\n })\n .then((data) => resolve(data))\n .catch((error) => handleError(error, reject, options))\n })\n}\n\n/**\n * Performs a GET request\n * @param fetcher - Fetch function to use\n * @param url - Request URL\n * @param options - Custom fetch options\n * @param parameters - Additional fetch parameters\n * @returns Promise with parsed response\n */\nexport async function get(\n fetcher: Fetch,\n url: string,\n options?: FetchOptions,\n parameters?: VectorFetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'GET', url, options, parameters)\n}\n\n/**\n * Performs a POST request\n * @param fetcher - Fetch function to use\n * @param url - Request URL\n * @param body - Request body to be JSON stringified\n * @param options - Custom fetch options\n * @param parameters - Additional fetch parameters\n * @returns Promise with parsed response\n */\nexport async function post(\n fetcher: Fetch,\n url: string,\n body: object,\n options?: FetchOptions,\n parameters?: VectorFetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'POST', url, options, parameters, body)\n}\n\n/**\n * Performs a PUT request\n * @param fetcher - Fetch function to use\n * @param url - Request URL\n * @param body - Request body to be JSON stringified\n * @param options - Custom fetch options\n * @param parameters - Additional fetch parameters\n * @returns Promise with parsed response\n */\nexport async function put(\n fetcher: Fetch,\n url: string,\n body: object,\n options?: FetchOptions,\n parameters?: VectorFetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'PUT', url, options, parameters, body)\n}\n\n/**\n * Performs a DELETE request\n * @param fetcher - Fetch function to use\n * @param url - Request URL\n * @param body - Request body to be JSON stringified\n * @param options - Custom fetch options\n * @param parameters - Additional fetch parameters\n * @returns Promise with parsed response\n */\nexport async function remove(\n fetcher: Fetch,\n url: string,\n body: object,\n options?: FetchOptions,\n parameters?: VectorFetchParameters\n): Promise<any> {\n return _handleRequest(fetcher, 'DELETE', url, options, parameters, body)\n}\n","import { DEFAULT_HEADERS } from './constants'\nimport { isStorageVectorsError } from './errors'\nimport { Fetch, post } from './fetch'\nimport { resolveFetch } from './helpers'\nimport {\n ApiResponse,\n VectorIndex,\n ListIndexesOptions,\n ListIndexesResponse,\n VectorDataType,\n DistanceMetric,\n MetadataConfiguration,\n} from './types'\n\n/**\n * @alpha\n *\n * Options for creating a vector index\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n */\nexport interface CreateIndexOptions {\n vectorBucketName: string\n indexName: string\n dataType: VectorDataType\n dimension: number\n distanceMetric: DistanceMetric\n metadataConfiguration?: MetadataConfiguration\n}\n\n/**\n * @hidden\n * Base implementation for vector index operations.\n * Use {@link VectorBucketScope} via `supabase.storage.vectors.from('bucket')` instead.\n */\nexport default class VectorIndexApi {\n protected url: string\n protected headers: { [key: string]: string }\n protected fetch: Fetch\n protected shouldThrowOnError = false\n\n /** Creates a new VectorIndexApi instance */\n constructor(url: string, headers: { [key: string]: string } = {}, fetch?: Fetch) {\n this.url = url.replace(/\\/$/, '')\n this.headers = { ...DEFAULT_HEADERS, ...headers }\n this.fetch = resolveFetch(fetch)\n }\n\n /** Enable throwing errors instead of returning them in the response */\n public throwOnError(): this {\n this.shouldThrowOnError = true\n return this\n }\n\n /** Creates a new vector index within a bucket */\n async createIndex(options: CreateIndexOptions): Promise<ApiResponse<undefined>> {\n try {\n const data = await post(this.fetch, `${this.url}/CreateIndex`, options, {\n headers: this.headers,\n })\n return { data: data || {}, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Retrieves metadata for a specific vector index */\n async getIndex(\n vectorBucketName: string,\n indexName: string\n ): Promise<ApiResponse<{ index: VectorIndex }>> {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/GetIndex`,\n { vectorBucketName, indexName },\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Lists vector indexes within a bucket with optional filtering and pagination */\n async listIndexes(options: ListIndexesOptions): Promise<ApiResponse<ListIndexesResponse>> {\n try {\n const data = await post(this.fetch, `${this.url}/ListIndexes`, options, {\n headers: this.headers,\n })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Deletes a vector index and all its data */\n async deleteIndex(vectorBucketName: string, indexName: string): Promise<ApiResponse<undefined>> {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/DeleteIndex`,\n { vectorBucketName, indexName },\n { headers: this.headers }\n )\n return { data: data || {}, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n}\n","import { DEFAULT_HEADERS } from './constants'\nimport { isStorageVectorsError } from './errors'\nimport { Fetch, post } from './fetch'\nimport { resolveFetch } from './helpers'\nimport {\n ApiResponse,\n PutVectorsOptions,\n GetVectorsOptions,\n GetVectorsResponse,\n DeleteVectorsOptions,\n ListVectorsOptions,\n ListVectorsResponse,\n QueryVectorsOptions,\n QueryVectorsResponse,\n} from './types'\n\n/**\n * @hidden\n * Base implementation for vector data operations.\n * Use {@link VectorIndexScope} via `supabase.storage.vectors.from('bucket').index('idx')` instead.\n */\nexport default class VectorDataApi {\n protected url: string\n protected headers: { [key: string]: string }\n protected fetch: Fetch\n protected shouldThrowOnError = false\n\n /** Creates a new VectorDataApi instance */\n constructor(url: string, headers: { [key: string]: string } = {}, fetch?: Fetch) {\n this.url = url.replace(/\\/$/, '')\n this.headers = { ...DEFAULT_HEADERS, ...headers }\n this.fetch = resolveFetch(fetch)\n }\n\n /** Enable throwing errors instead of returning them in the response */\n public throwOnError(): this {\n this.shouldThrowOnError = true\n return this\n }\n\n /** Inserts or updates vectors in batch (1-500 per request) */\n async putVectors(options: PutVectorsOptions): Promise<ApiResponse<undefined>> {\n try {\n // Validate batch size\n if (options.vectors.length < 1 || options.vectors.length > 500) {\n throw new Error('Vector batch size must be between 1 and 500 items')\n }\n\n const data = await post(this.fetch, `${this.url}/PutVectors`, options, {\n headers: this.headers,\n })\n return { data: data || {}, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Retrieves vectors by their keys in batch */\n async getVectors(options: GetVectorsOptions): Promise<ApiResponse<GetVectorsResponse>> {\n try {\n const data = await post(this.fetch, `${this.url}/GetVectors`, options, {\n headers: this.headers,\n })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Lists vectors in an index with pagination */\n async listVectors(options: ListVectorsOptions): Promise<ApiResponse<ListVectorsResponse>> {\n try {\n // Validate segment configuration\n if (options.segmentCount !== undefined) {\n if (options.segmentCount < 1 || options.segmentCount > 16) {\n throw new Error('segmentCount must be between 1 and 16')\n }\n if (options.segmentIndex !== undefined) {\n if (options.segmentIndex < 0 || options.segmentIndex >= options.segmentCount) {\n throw new Error(`segmentIndex must be between 0 and ${options.segmentCount - 1}`)\n }\n }\n }\n\n const data = await post(this.fetch, `${this.url}/ListVectors`, options, {\n headers: this.headers,\n })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Queries for similar vectors using approximate nearest neighbor search */\n async queryVectors(options: QueryVectorsOptions): Promise<ApiResponse<QueryVectorsResponse>> {\n try {\n const data = await post(this.fetch, `${this.url}/QueryVectors`, options, {\n headers: this.headers,\n })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Deletes vectors by their keys in batch (1-500 per request) */\n async deleteVectors(options: DeleteVectorsOptions): Promise<ApiResponse<undefined>> {\n try {\n // Validate batch size\n if (options.keys.length < 1 || options.keys.length > 500) {\n throw new Error('Keys batch size must be between 1 and 500 items')\n }\n\n const data = await post(this.fetch, `${this.url}/DeleteVectors`, options, {\n headers: this.headers,\n })\n return { data: data || {}, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n}\n","import { DEFAULT_HEADERS } from './constants'\nimport { isStorageVectorsError } from './errors'\nimport { Fetch, post } from './fetch'\nimport { resolveFetch } from './helpers'\nimport {\n ApiResponse,\n VectorBucket,\n ListVectorBucketsOptions,\n ListVectorBucketsResponse,\n} from './types'\n\n/**\n * @hidden\n * Base implementation for vector bucket operations.\n * Use {@link StorageVectorsClient} via `supabase.storage.vectors` instead.\n */\nexport default class VectorBucketApi {\n protected url: string\n protected headers: { [key: string]: string }\n protected fetch: Fetch\n protected shouldThrowOnError = false\n\n /** Creates a new VectorBucketApi instance */\n constructor(url: string, headers: { [key: string]: string } = {}, fetch?: Fetch) {\n this.url = url.replace(/\\/$/, '')\n this.headers = { ...DEFAULT_HEADERS, ...headers }\n this.fetch = resolveFetch(fetch)\n }\n\n /** Enable throwing errors instead of returning them in the response */\n public throwOnError(): this {\n this.shouldThrowOnError = true\n return this\n }\n\n /** Creates a new vector bucket */\n async createBucket(vectorBucketName: string): Promise<ApiResponse<undefined>> {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/CreateVectorBucket`,\n { vectorBucketName },\n { headers: this.headers }\n )\n return { data: data || {}, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Retrieves metadata for a specific vector bucket */\n async getBucket(vectorBucketName: string): Promise<ApiResponse<{ vectorBucket: VectorBucket }>> {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/GetVectorBucket`,\n { vectorBucketName },\n { headers: this.headers }\n )\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Lists vector buckets with optional filtering and pagination */\n async listBuckets(\n options: ListVectorBucketsOptions = {}\n ): Promise<ApiResponse<ListVectorBucketsResponse>> {\n try {\n const data = await post(this.fetch, `${this.url}/ListVectorBuckets`, options, {\n headers: this.headers,\n })\n return { data, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n\n /** Deletes a vector bucket (must be empty first) */\n async deleteBucket(vectorBucketName: string): Promise<ApiResponse<undefined>> {\n try {\n const data = await post(\n this.fetch,\n `${this.url}/DeleteVectorBucket`,\n { vectorBucketName },\n { headers: this.headers }\n )\n return { data: data || {}, error: null }\n } catch (error) {\n if (this.shouldThrowOnError) {\n throw error\n }\n if (isStorageVectorsError(error)) {\n return { data: null, error }\n }\n throw error\n }\n }\n}\n","import VectorIndexApi, { CreateIndexOptions } from './VectorIndexApi'\nimport VectorDataApi from './VectorDataApi'\nimport { Fetch } from './fetch'\nimport VectorBucketApi from './VectorBucketApi'\nimport {\n ApiResponse,\n DeleteVectorsOptions,\n GetVectorsOptions,\n ListIndexesOptions,\n ListVectorsOptions,\n ListVectorBucketsOptions,\n ListVectorBucketsResponse,\n PutVectorsOptions,\n QueryVectorsOptions,\n VectorBucket,\n} from './types'\n\n/**\n *\n * @alpha\n *\n * Configuration options for the Storage Vectors client\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n */\nexport interface StorageVectorsClientOptions {\n /**\n * Custom headers to include in all requests\n */\n headers?: { [key: string]: string }\n /**\n * Custom fetch implementation (optional)\n * Useful for testing or custom request handling\n */\n fetch?: Fetch\n}\n\n/**\n *\n * @alpha\n *\n * Main client for interacting with S3 Vectors API\n * Provides access to bucket, index, and vector data operations\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * **Usage Patterns:**\n *\n * ```typescript\n * const { data, error } = await supabase\n * .storage\n * .vectors\n * .createBucket('embeddings-prod')\n *\n * // Access index operations via buckets\n * const bucket = supabase.storage.vectors.from('embeddings-prod')\n * await bucket.createIndex({\n * indexName: 'documents',\n * dataType: 'float32',\n * dimension: 1536,\n * distanceMetric: 'cosine'\n * })\n *\n * // Access vector operations via index\n * const index = bucket.index('documents')\n * await index.putVectors({\n * vectors: [\n * { key: 'doc-1', data: { float32: [...] }, metadata: { title: 'Intro' } }\n * ]\n * })\n *\n * // Query similar vectors\n * const { data } = await index.queryVectors({\n * queryVector: { float32: [...] },\n * topK: 5,\n * returnDistance: true\n * })\n * ```\n */\nexport class StorageVectorsClient extends VectorBucketApi {\n /**\n * @alpha\n *\n * Creates a StorageVectorsClient that can manage buckets, indexes, and vectors.\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param url - Base URL of the Storage Vectors REST API.\n * @param options.headers - Optional headers (for example `Authorization`) applied to every request.\n * @param options.fetch - Optional custom `fetch` implementation for non-browser runtimes.\n *\n * @example\n * ```typescript\n * const client = new StorageVectorsClient(url, options)\n * ```\n */\n constructor(url: string, options: StorageVectorsClientOptions = {}) {\n super(url, options.headers || {}, options.fetch)\n }\n\n /**\n *\n * @alpha\n *\n * Access operations for a specific vector bucket\n * Returns a scoped client for index and vector operations within the bucket\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param vectorBucketName - Name of the vector bucket\n * @returns Bucket-scoped client with index and vector operations\n *\n * @example\n * ```typescript\n * const bucket = supabase.storage.vectors.from('embeddings-prod')\n * ```\n */\n from(vectorBucketName: string): VectorBucketScope {\n return new VectorBucketScope(this.url, this.headers, vectorBucketName, this.fetch)\n }\n\n /**\n *\n * @alpha\n *\n * Creates a new vector bucket\n * Vector buckets are containers for vector indexes and their data\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param vectorBucketName - Unique name for the vector bucket\n * @returns Promise with empty response on success or error\n *\n * @example\n * ```typescript\n * const { data, error } = await supabase\n * .storage\n * .vectors\n * .createBucket('embeddings-prod')\n * ```\n */\n async createBucket(vectorBucketName: string): Promise<ApiResponse<undefined>> {\n return super.createBucket(vectorBucketName)\n }\n\n /**\n *\n * @alpha\n *\n * Retrieves metadata for a specific vector bucket\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param vectorBucketName - Name of the vector bucket\n * @returns Promise with bucket metadata or error\n *\n * @example\n * ```typescript\n * const { data, error } = await supabase\n * .storage\n * .vectors\n * .getBucket('embeddings-prod')\n *\n * console.log('Bucket created:', data?.vectorBucket.creationTime)\n * ```\n */\n async getBucket(vectorBucketName: string): Promise<ApiResponse<{ vectorBucket: VectorBucket }>> {\n return super.getBucket(vectorBucketName)\n }\n\n /**\n *\n * @alpha\n *\n * Lists all vector buckets with optional filtering and pagination\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Optional filters (prefix, maxResults, nextToken)\n * @returns Promise with list of buckets or error\n *\n * @example\n * ```typescript\n * const { data, error } = await supabase\n * .storage\n * .vectors\n * .listBuckets({ prefix: 'embeddings-' })\n *\n * data?.vectorBuckets.forEach(bucket => {\n * console.log(bucket.vectorBucketName)\n * })\n * ```\n */\n async listBuckets(\n options: ListVectorBucketsOptions = {}\n ): Promise<ApiResponse<ListVectorBucketsResponse>> {\n return super.listBuckets(options)\n }\n\n /**\n *\n * @alpha\n *\n * Deletes a vector bucket (bucket must be empty)\n * All indexes must be deleted before deleting the bucket\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param vectorBucketName - Name of the vector bucket to delete\n * @returns Promise with empty response on success or error\n *\n * @example\n * ```typescript\n * const { data, error } = await supabase\n * .storage\n * .vectors\n * .deleteBucket('embeddings-old')\n * ```\n */\n async deleteBucket(vectorBucketName: string): Promise<ApiResponse<undefined>> {\n return super.deleteBucket(vectorBucketName)\n }\n}\n\n/**\n *\n * @alpha\n *\n * Scoped client for operations within a specific vector bucket\n * Provides index management and access to vector operations\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n */\nexport class VectorBucketScope extends VectorIndexApi {\n private vectorBucketName: string\n\n /**\n * @alpha\n *\n * Creates a helper that automatically scopes all index operations to the provided bucket.\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @example\n * ```typescript\n * const bucket = supabase.storage.vectors.from('embeddings-prod')\n * ```\n */\n constructor(\n url: string,\n headers: { [key: string]: string },\n vectorBucketName: string,\n fetch?: Fetch\n ) {\n super(url, headers, fetch)\n this.vectorBucketName = vectorBucketName\n }\n\n /**\n *\n * @alpha\n *\n * Creates a new vector index in this bucket\n * Convenience method that automatically includes the bucket name\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Index configuration (vectorBucketName is automatically set)\n * @returns Promise with empty response on success or error\n *\n * @example\n * ```typescript\n * const bucket = supabase.storage.vectors.from('embeddings-prod')\n * await bucket.createIndex({\n * indexName: 'documents-openai',\n * dataType: 'float32',\n * dimension: 1536,\n * distanceMetric: 'cosine',\n * metadataConfiguration: {\n * nonFilterableMetadataKeys: ['raw_text']\n * }\n * })\n * ```\n */\n override async createIndex(options: Omit<CreateIndexOptions, 'vectorBucketName'>) {\n return super.createIndex({\n ...options,\n vectorBucketName: this.vectorBucketName,\n })\n }\n\n /**\n *\n * @alpha\n *\n * Lists indexes in this bucket\n * Convenience method that automatically includes the bucket name\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Listing options (vectorBucketName is automatically set)\n * @returns Promise with response containing indexes array and pagination token or error\n *\n * @example\n * ```typescript\n * const bucket = supabase.storage.vectors.from('embeddings-prod')\n * const { data } = await bucket.listIndexes({ prefix: 'documents-' })\n * ```\n */\n override async listIndexes(options: Omit<ListIndexesOptions, 'vectorBucketName'> = {}) {\n return super.listIndexes({\n ...options,\n vectorBucketName: this.vectorBucketName,\n })\n }\n\n /**\n *\n * @alpha\n *\n * Retrieves metadata for a specific index in this bucket\n * Convenience method that automatically includes the bucket name\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param indexName - Name of the index to retrieve\n * @returns Promise with index metadata or error\n *\n * @example\n * ```typescript\n * const bucket = supabase.storage.vectors.from('embeddings-prod')\n * const { data } = await bucket.getIndex('documents-openai')\n * console.log('Dimension:', data?.index.dimension)\n * ```\n */\n override async getIndex(indexName: string) {\n return super.getIndex(this.vectorBucketName, indexName)\n }\n\n /**\n *\n * @alpha\n *\n * Deletes an index from this bucket\n * Convenience method that automatically includes the bucket name\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param indexName - Name of the index to delete\n * @returns Promise with empty response on success or error\n *\n * @example\n * ```typescript\n * const bucket = supabase.storage.vectors.from('embeddings-prod')\n * await bucket.deleteIndex('old-index')\n * ```\n */\n override async deleteIndex(indexName: string) {\n return super.deleteIndex(this.vectorBucketName, indexName)\n }\n\n /**\n *\n * @alpha\n *\n * Access operations for a specific index within this bucket\n * Returns a scoped client for vector data operations\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param indexName - Name of the index\n * @returns Index-scoped client with vector data operations\n *\n * @example\n * ```typescript\n * const index = supabase.storage.vectors.from('embeddings-prod').index('documents-openai')\n *\n * // Insert vectors\n * await index.putVectors({\n * vectors: [\n * { key: 'doc-1', data: { float32: [...] }, metadata: { title: 'Intro' } }\n * ]\n * })\n *\n * // Query similar vectors\n * const { data } = await index.queryVectors({\n * queryVector: { float32: [...] },\n * topK: 5\n * })\n * ```\n */\n index(indexName: string): VectorIndexScope {\n return new VectorIndexScope(\n this.url,\n this.headers,\n this.vectorBucketName,\n indexName,\n this.fetch\n )\n }\n}\n\n/**\n *\n * @alpha\n *\n * Scoped client for operations within a specific vector index\n * Provides vector data operations (put, get, list, query, delete)\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n */\nexport class VectorIndexScope extends VectorDataApi {\n private vectorBucketName: string\n private indexName: string\n\n /**\n *\n * @alpha\n *\n * Creates a helper that automatically scopes all vector operations to the provided bucket/index names.\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @example\n * ```typescript\n * const index = supabase.storage.vectors.from('embeddings-prod').index('documents-openai')\n * ```\n */\n constructor(\n url: string,\n headers: { [key: string]: string },\n vectorBucketName: string,\n indexName: string,\n fetch?: Fetch\n ) {\n super(url, headers, fetch)\n this.vectorBucketName = vectorBucketName\n this.indexName = indexName\n }\n\n /**\n *\n * @alpha\n *\n * Inserts or updates vectors in this index\n * Convenience method that automatically includes bucket and index names\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Vector insertion options (bucket and index names automatically set)\n * @returns Promise with empty response on success or error\n *\n * @example\n * ```typescript\n * const index = supabase.storage.vectors.from('embeddings-prod').index('documents-openai')\n * await index.putVectors({\n * vectors: [\n * {\n * key: 'doc-1',\n * data: { float32: [0.1, 0.2, ...] },\n * metadata: { title: 'Introduction', page: 1 }\n * }\n * ]\n * })\n * ```\n */\n override async putVectors(options: Omit<PutVectorsOptions, 'vectorBucketName' | 'indexName'>) {\n return super.putVectors({\n ...options,\n vectorBucketName: this.vectorBucketName,\n indexName: this.indexName,\n })\n }\n\n /**\n *\n * @alpha\n *\n * Retrieves vectors by keys from this index\n * Convenience method that automatically includes bucket and index names\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Vector retrieval options (bucket and index names automatically set)\n * @returns Promise with response containing vectors array or error\n *\n * @example\n * ```typescript\n * const index = supabase.storage.vectors.from('embeddings-prod').index('documents-openai')\n * const { data } = await index.getVectors({\n * keys: ['doc-1', 'doc-2'],\n * returnMetadata: true\n * })\n * ```\n */\n override async getVectors(options: Omit<GetVectorsOptions, 'vectorBucketName' | 'indexName'>) {\n return super.getVectors({\n ...options,\n vectorBucketName: this.vectorBucketName,\n indexName: this.indexName,\n })\n }\n\n /**\n *\n * @alpha\n *\n * Lists vectors in this index with pagination\n * Convenience method that automatically includes bucket and index names\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Listing options (bucket and index names automatically set)\n * @returns Promise with response containing vectors array and pagination token or error\n *\n * @example\n * ```typescript\n * const index = supabase.storage.vectors.from('embeddings-prod').index('documents-openai')\n * const { data } = await index.listVectors({\n * maxResults: 500,\n * returnMetadata: true\n * })\n * ```\n */\n override async listVectors(\n options: Omit<ListVectorsOptions, 'vectorBucketName' | 'indexName'> = {}\n ) {\n return super.listVectors({\n ...options,\n vectorBucketName: this.vectorBucketName,\n indexName: this.indexName,\n })\n }\n\n /**\n *\n * @alpha\n *\n * Queries for similar vectors in this index\n * Convenience method that automatically includes bucket and index names\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Query options (bucket and index names automatically set)\n * @returns Promise with response containing matches array of similar vectors ordered by distance or error\n *\n * @example\n * ```typescript\n * const index = supabase.storage.vectors.from('embeddings-prod').index('documents-openai')\n * const { data } = await index.queryVectors({\n * queryVector: { float32: [0.1, 0.2, ...] },\n * topK: 5,\n * filter: { category: 'technical' },\n * returnDistance: true,\n * returnMetadata: true\n * })\n * ```\n */\n override async queryVectors(\n options: Omit<QueryVectorsOptions, 'vectorBucketName' | 'indexName'>\n ) {\n return super.queryVectors({\n ...options,\n vectorBucketName: this.vectorBucketName,\n indexName: this.indexName,\n })\n }\n\n /**\n *\n * @alpha\n *\n * Deletes vectors by keys from this index\n * Convenience method that automatically includes bucket and index names\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @param options - Deletion options (bucket and index names automatically set)\n * @returns Promise with empty response on success or error\n *\n * @example\n * ```typescript\n * const index = supabase.storage.vectors.from('embeddings-prod').index('documents-openai')\n * await index.deleteVectors({\n * keys: ['doc-1', 'doc-2', 'doc-3']\n * })\n * ```\n */\n override async deleteVectors(\n options: Omit<DeleteVectorsOptions, 'vectorBucketName' | 'indexName'>\n ) {\n return super.deleteVectors({\n ...options,\n vectorBucketName: this.vectorBucketName,\n indexName: this.indexName,\n })\n }\n}\n","import StorageFileApi from './packages/StorageFileApi'\nimport StorageBucketApi from './packages/StorageBucketApi'\nimport StorageAnalyticsClient from './packages/StorageAnalyticsClient'\nimport { Fetch } from './lib/fetch'\nimport { StorageVectorsClient } from './lib/vectors'\n\nexport interface StorageClientOptions {\n useNewHostname?: boolean\n}\n\nexport class StorageClient extends StorageBucketApi {\n /**\n * Creates a client for Storage buckets, files, analytics, and vectors.\n *\n * @category File Buckets\n * @example\n * ```ts\n * import { StorageClient } from '@supabase/storage-js'\n *\n * const storage = new StorageClient('https://xyzcompany.supabase.co/storage/v1', {\n * apikey: 'public-anon-key',\n * })\n * const avatars = storage.from('avatars')\n * ```\n */\n constructor(\n url: string,\n headers: { [key: string]: string } = {},\n fetch?: Fetch,\n opts?: StorageClientOptions\n ) {\n super(url, headers, fetch, opts)\n }\n\n /**\n * Perform file operation in a bucket.\n *\n * @category File Buckets\n * @param id The bucket id to operate on.\n *\n * @example\n * ```typescript\n * const avatars = supabase.storage.from('avatars')\n * ```\n */\n from(id: string): StorageFileApi {\n return new StorageFileApi(this.url, this.headers, id, this.fetch)\n }\n\n /**\n *\n * @alpha\n *\n * Access vector storage operations.\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Vector Buckets\n * @returns A StorageVectorsClient instance configured with the current storage settings.\n */\n get vectors(): StorageVectorsClient {\n return new StorageVectorsClient(this.url + '/vector', {\n headers: this.headers,\n fetch: this.fetch,\n })\n }\n\n /**\n *\n * @alpha\n *\n * Access analytics storage operations using Iceberg tables.\n *\n * **Public alpha:** This API is part of a public alpha release and may not be available to your account type.\n *\n * @category Analytics Buckets\n * @returns A StorageAnalyticsClient instance configured with the current storage settings.\n */\n get analytics(): StorageAnalyticsClient {\n return new StorageAnalyticsClient(this.url + '/iceberg', this.headers, this.fetch)\n }\n}\n","// Generated automatically during releases by scripts/update-version-files.ts\n// This file provides runtime access to the package version for:\n// - HTTP request headers (e.g., X-Client-Info header for API requests)\n// - Debugging and support (identifying which version is running)\n// - Telemetry and logging (version reporting in errors/analytics)\n// - Ensuring build artifacts match the published package version\nexport const version = '2.90.1'\n","import { version } from './version'\n\n/** Current session will be checked for refresh at this interval. */\nexport const AUTO_REFRESH_TICK_DURATION_MS = 30 * 1000\n\n/**\n * A token refresh will be attempted this many ticks before the current session expires. */\nexport const AUTO_REFRESH_TICK_THRESHOLD = 3\n\n/*\n * Earliest time before an access token expires that the session should be refreshed.\n */\nexport const EXPIRY_MARGIN_MS = AUTO_REFRESH_TICK_THRESHOLD * AUTO_REFRESH_TICK_DURATION_MS\n\nexport const GOTRUE_URL = 'http://localhost:9999'\nexport const STORAGE_KEY = 'supabase.auth.token'\nexport const AUDIENCE = ''\nexport const DEFAULT_HEADERS = { 'X-Client-Info': `gotrue-js/${version}` }\nexport const NETWORK_FAILURE = {\n MAX_RETRIES: 10,\n RETRY_INTERVAL: 2, // in deciseconds\n}\n\nexport const API_VERSION_HEADER_NAME = 'X-Supabase-Api-Version'\nexport const API_VERSIONS = {\n '2024-01-01': {\n timestamp: Date.parse('2024-01-01T00:00:00.0Z'),\n name: '2024-01-01',\n },\n}\n\nexport const BASE64URL_REGEX = /^([a-z0-9_-]{4})*($|[a-z0-9_-]{3}$|[a-z0-9_-]{2}$)$/i\n\nexport const JWKS_TTL = 10 * 60 * 1000 // 10 minutes\n","import { WeakPasswordReasons } from './types'\nimport { ErrorCode } from './error-codes'\n\n/**\n * Base error thrown by Supabase Auth helpers.\n *\n * @example\n * ```ts\n * import { AuthError } from '@supabase/auth-js'\n *\n * throw new AuthError('Unexpected auth error', 500, 'unexpected')\n * ```\n */\nexport class AuthError extends Error {\n /**\n * Error code associated with the error. Most errors coming from\n * HTTP responses will have a code, though some errors that occur\n * before a response is received will not have one present. In that\n * case {@link #status} will also be undefined.\n */\n code: ErrorCode | (string & {}) | undefined\n\n /** HTTP status code that caused the error. */\n status: number | undefined\n\n protected __isAuthError = true\n\n constructor(message: string, status?: number, code?: string) {\n super(message)\n this.name = 'AuthError'\n this.status = status\n this.code = code\n }\n}\n\nexport function isAuthError(error: unknown): error is AuthError {\n return typeof error === 'object' && error !== null && '__isAuthError' in error\n}\n\n/**\n * Error returned directly from the GoTrue REST API.\n *\n * @example\n * ```ts\n * import { AuthApiError } from '@supabase/auth-js'\n *\n * throw new AuthApiError('Invalid credentials', 400, 'invalid_credentials')\n * ```\n */\nexport class AuthApiError extends AuthError {\n status: number\n\n constructor(message: string, status: number, code: string | undefined) {\n super(message, status, code)\n this.name = 'AuthApiError'\n this.status = status\n this.code = code\n }\n}\n\nexport function isAuthApiError(error: unknown): error is AuthApiError {\n return isAuthError(error) && error.name === 'AuthApiError'\n}\n\n/**\n * Wraps non-standard errors so callers can inspect the root cause.\n *\n * @example\n * ```ts\n * import { AuthUnknownError } from '@supabase/auth-js'\n *\n * try {\n * await someAuthCall()\n * } catch (err) {\n * throw new AuthUnknownError('Auth failed', err)\n * }\n * ```\n */\nexport class AuthUnknownError extends AuthError {\n originalError: unknown\n\n constructor(message: string, originalError: unknown) {\n super(message)\n this.name = 'AuthUnknownError'\n this.originalError = originalError\n }\n}\n\n/**\n * Flexible error class used to create named auth errors at runtime.\n *\n * @example\n * ```ts\n * import { CustomAuthError } from '@supabase/auth-js'\n *\n * throw new CustomAuthError('My custom auth error', 'MyAuthError', 400, 'custom_code')\n * ```\n */\nexport class CustomAuthError extends AuthError {\n name: string\n status: number\n\n constructor(message: string, name: string, status: number, code: string | undefined) {\n super(message, status, code)\n this.name = name\n this.status = status\n }\n}\n\n/**\n * Error thrown when an operation requires a session but none is present.\n *\n * @example\n * ```ts\n * import { AuthSessionMissingError } from '@supabase/auth-js'\n *\n * throw new AuthSessionMissingError()\n * ```\n */\nexport class AuthSessionMissingError extends CustomAuthError {\n constructor() {\n super('Auth session missing!', 'AuthSessionMissingError', 400, undefined)\n }\n}\n\nexport function isAuthSessionMissingError(error: any): error is AuthSessionMissingError {\n return isAuthError(error) && error.name === 'AuthSessionMissingError'\n}\n\n/**\n * Error thrown when the token response is malformed.\n *\n * @example\n * ```ts\n * import { AuthInvalidTokenResponseError } from '@supabase/auth-js'\n *\n * throw new AuthInvalidTokenResponseError()\n * ```\n */\nexport class AuthInvalidTokenResponseError extends CustomAuthError {\n constructor() {\n super('Auth session or user missing', 'AuthInvalidTokenResponseError', 500, undefined)\n }\n}\n\n/**\n * Error thrown when email/password credentials are invalid.\n *\n * @example\n * ```ts\n * import { AuthInvalidCredentialsError } from '@supabase/auth-js'\n *\n * throw new AuthInvalidCredentialsError('Email or password is incorrect')\n * ```\n */\nexport class AuthInvalidCredentialsError extends CustomAuthError {\n constructor(message: string) {\n super(message, 'AuthInvalidCredentialsError', 400, undefined)\n }\n}\n\n/**\n * Error thrown when implicit grant redirects contain an error.\n *\n * @example\n * ```ts\n * import { AuthImplicitGrantRedirectError } from '@supabase/auth-js'\n *\n * throw new AuthImplicitGrantRedirectError('OAuth redirect failed', {\n * error: 'access_denied',\n * code: 'oauth_error',\n * })\n * ```\n */\nexport class AuthImplicitGrantRedirectError extends CustomAuthError {\n details: { error: string; code: string } | null = null\n constructor(message: string, details: { error: string; code: string } | null = null) {\n super(message, 'AuthImplicitGrantRedirectError', 500, undefined)\n this.details = details\n }\n\n toJSON() {\n return {\n name: this.name,\n message: this.message,\n status: this.status,\n details: this.details,\n }\n }\n}\n\nexport function isAuthImplicitGrantRedirectError(\n error: any\n): error is AuthImplicitGrantRedirectError {\n return isAuthError(error) && error.name === 'AuthImplicitGrantRedirectError'\n}\n\n/**\n * Error thrown during PKCE code exchanges.\n *\n * @example\n * ```ts\n * import { AuthPKCEGrantCodeExchangeError } from '@supabase/auth-js'\n *\n * throw new AuthPKCEGrantCodeExchangeError('PKCE exchange failed')\n * ```\n */\nexport class AuthPKCEGrantCodeExchangeError extends CustomAuthError {\n details: { error: string; code: string } | null = null\n\n constructor(message: string, details: { error: string; code: string } | null = null) {\n super(message, 'AuthPKCEGrantCodeExchangeError', 500, undefined)\n this.details = details\n }\n\n toJSON() {\n return {\n name: this.name,\n message: this.message,\n status: this.status,\n details: this.details,\n }\n }\n}\n\n/**\n * Error thrown when the PKCE code verifier is not found in storage.\n * This typically happens when the auth flow was initiated in a different\n * browser, device, or the storage was cleared.\n *\n * @example\n * ```ts\n * import { AuthPKCECodeVerifierMissingError } from '@supabase/auth-js'\n *\n * throw new AuthPKCECodeVerifierMissingError()\n * ```\n */\nexport class AuthPKCECodeVerifierMissingError extends CustomAuthError {\n constructor() {\n super(\n 'PKCE code verifier not found in storage. ' +\n 'This can happen if the auth flow was initiated in a different browser or device, ' +\n 'or if the storage was cleared. For SSR frameworks (Next.js, SvelteKit, etc.), ' +\n 'use @supabase/ssr on both the server and client to store the code verifier in cookies.',\n 'AuthPKCECodeVerifierMissingError',\n 400,\n 'pkce_code_verifier_not_found'\n )\n }\n}\n\nexport function isAuthPKCECodeVerifierMissingError(\n error: unknown\n): error is AuthPKCECodeVerifierMissingError {\n return isAuthError(error) && error.name === 'AuthPKCECodeVerifierMissingError'\n}\n\n/**\n * Error thrown when a transient fetch issue occurs.\n *\n * @example\n * ```ts\n * import { AuthRetryableFetchError } from '@supabase/auth-js'\n *\n * throw new AuthRetryableFetchError('Service temporarily unavailable', 503)\n * ```\n */\nexport class AuthRetryableFetchError extends CustomAuthError {\n constructor(message: string, status: number) {\n super(message, 'AuthRetryableFetchError', status, undefined)\n }\n}\n\nexport function isAuthRetryableFetchError(error: unknown): error is AuthRetryableFetchError {\n return isAuthError(error) && error.name === 'AuthRetryableFetchError'\n}\n\n/**\n * This error is thrown on certain methods when the password used is deemed\n * weak. Inspect the reasons to identify what password strength rules are\n * inadequate.\n */\n/**\n * Error thrown when a supplied password is considered weak.\n *\n * @example\n * ```ts\n * import { AuthWeakPasswordError } from '@supabase/auth-js'\n *\n * throw new AuthWeakPasswordError('Password too short', 400, ['min_length'])\n * ```\n */\nexport class AuthWeakPasswordError extends CustomAuthError {\n /**\n * Reasons why the password is deemed weak.\n */\n reasons: WeakPasswordReasons[]\n\n constructor(message: string, status: number, reasons: WeakPasswordReasons[]) {\n super(message, 'AuthWeakPasswordError', status, 'weak_password')\n\n this.reasons = reasons\n }\n}\n\nexport function isAuthWeakPasswordError(error: unknown): error is AuthWeakPasswordError {\n return isAuthError(error) && error.name === 'AuthWeakPasswordError'\n}\n\n/**\n * Error thrown when a JWT cannot be verified or parsed.\n *\n * @example\n * ```ts\n * import { AuthInvalidJwtError } from '@supabase/auth-js'\n *\n * throw new AuthInvalidJwtError('Token signature is invalid')\n * ```\n */\nexport class AuthInvalidJwtError extends CustomAuthError {\n constructor(message: string) {\n super(message, 'AuthInvalidJwtError', 400, 'invalid_jwt')\n }\n}\n","/**\n * Avoid modifying this file. It's part of\n * https://github.com/supabase-community/base64url-js. Submit all fixes on\n * that repo!\n */\n\nimport { Uint8Array_ } from './webauthn.dom'\n\n/**\n * An array of characters that encode 6 bits into a Base64-URL alphabet\n * character.\n */\nconst TO_BASE64URL = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_'.split('')\n\n/**\n * An array of characters that can appear in a Base64-URL encoded string but\n * should be ignored.\n */\nconst IGNORE_BASE64URL = ' \\t\\n\\r='.split('')\n\n/**\n * An array of 128 numbers that map a Base64-URL character to 6 bits, or if -2\n * used to skip the character, or if -1 used to error out.\n */\nconst FROM_BASE64URL = (() => {\n const charMap: number[] = new Array(128)\n\n for (let i = 0; i < charMap.length; i += 1) {\n charMap[i] = -1\n }\n\n for (let i = 0; i < IGNORE_BASE64URL.length; i += 1) {\n charMap[IGNORE_BASE64URL[i].charCodeAt(0)] = -2\n }\n\n for (let i = 0; i < TO_BASE64URL.length; i += 1) {\n charMap[TO_BASE64URL[i].charCodeAt(0)] = i\n }\n\n return charMap\n})()\n\n/**\n * Converts a byte to a Base64-URL string.\n *\n * @param byte The byte to convert, or null to flush at the end of the byte sequence.\n * @param state The Base64 conversion state. Pass an initial value of `{ queue: 0, queuedBits: 0 }`.\n * @param emit A function called with the next Base64 character when ready.\n */\nexport function byteToBase64URL(\n byte: number | null,\n state: { queue: number; queuedBits: number },\n emit: (char: string) => void\n) {\n if (byte !== null) {\n state.queue = (state.queue << 8) | byte\n state.queuedBits += 8\n\n while (state.queuedBits >= 6) {\n const pos = (state.queue >> (state.queuedBits - 6)) & 63\n emit(TO_BASE64URL[pos])\n state.queuedBits -= 6\n }\n } else if (state.queuedBits > 0) {\n state.queue = state.queue << (6 - state.queuedBits)\n state.queuedBits = 6\n\n while (state.queuedBits >= 6) {\n const pos = (state.queue >> (state.queuedBits - 6)) & 63\n emit(TO_BASE64URL[pos])\n state.queuedBits -= 6\n }\n }\n}\n\n/**\n * Converts a String char code (extracted using `string.charCodeAt(position)`) to a sequence of Base64-URL characters.\n *\n * @param charCode The char code of the JavaScript string.\n * @param state The Base64 state. Pass an initial value of `{ queue: 0, queuedBits: 0 }`.\n * @param emit A function called with the next byte.\n */\nexport function byteFromBase64URL(\n charCode: number,\n state: { queue: number; queuedBits: number },\n emit: (byte: number) => void\n) {\n const bits = FROM_BASE64URL[charCode]\n\n if (bits > -1) {\n // valid Base64-URL character\n state.queue = (state.queue << 6) | bits\n state.queuedBits += 6\n\n while (state.queuedBits >= 8) {\n emit((state.queue >> (state.queuedBits - 8)) & 0xff)\n state.queuedBits -= 8\n }\n } else if (bits === -2) {\n // ignore spaces, tabs, newlines, =\n return\n } else {\n throw new Error(`Invalid Base64-URL character \"${String.fromCharCode(charCode)}\"`)\n }\n}\n\n/**\n * Converts a JavaScript string (which may include any valid character) into a\n * Base64-URL encoded string. The string is first encoded in UTF-8 which is\n * then encoded as Base64-URL.\n *\n * @param str The string to convert.\n */\nexport function stringToBase64URL(str: string) {\n const base64: string[] = []\n\n const emitter = (char: string) => {\n base64.push(char)\n }\n\n const state = { queue: 0, queuedBits: 0 }\n\n stringToUTF8(str, (byte: number) => {\n byteToBase64URL(byte, state, emitter)\n })\n\n byteToBase64URL(null, state, emitter)\n\n return base64.join('')\n}\n\n/**\n * Converts a Base64-URL encoded string into a JavaScript string. It is assumed\n * that the underlying string has been encoded as UTF-8.\n *\n * @param str The Base64-URL encoded string.\n */\nexport function stringFromBase64URL(str: string) {\n const conv: string[] = []\n\n const utf8Emit = (codepoint: number) => {\n conv.push(String.fromCodePoint(codepoint))\n }\n\n const utf8State = {\n utf8seq: 0,\n codepoint: 0,\n }\n\n const b64State = { queue: 0, queuedBits: 0 }\n\n const byteEmit = (byte: number) => {\n stringFromUTF8(byte, utf8State, utf8Emit)\n }\n\n for (let i = 0; i < str.length; i += 1) {\n byteFromBase64URL(str.charCodeAt(i), b64State, byteEmit)\n }\n\n return conv.join('')\n}\n\n/**\n * Converts a Unicode codepoint to a multi-byte UTF-8 sequence.\n *\n * @param codepoint The Unicode codepoint.\n * @param emit Function which will be called for each UTF-8 byte that represents the codepoint.\n */\nexport function codepointToUTF8(codepoint: number, emit: (byte: number) => void) {\n if (codepoint <= 0x7f) {\n emit(codepoint)\n return\n } else if (codepoint <= 0x7ff) {\n emit(0xc0 | (codepoint >> 6))\n emit(0x80 | (codepoint & 0x3f))\n return\n } else if (codepoint <= 0xffff) {\n emit(0xe0 | (codepoint >> 12))\n emit(0x80 | ((codepoint >> 6) & 0x3f))\n emit(0x80 | (codepoint & 0x3f))\n return\n } else if (codepoint <= 0x10ffff) {\n emit(0xf0 | (codepoint >> 18))\n emit(0x80 | ((codepoint >> 12) & 0x3f))\n emit(0x80 | ((codepoint >> 6) & 0x3f))\n emit(0x80 | (codepoint & 0x3f))\n return\n }\n\n throw new Error(`Unrecognized Unicode codepoint: ${codepoint.toString(16)}`)\n}\n\n/**\n * Converts a JavaScript string to a sequence of UTF-8 bytes.\n *\n * @param str The string to convert to UTF-8.\n * @param emit Function which will be called for each UTF-8 byte of the string.\n */\nexport function stringToUTF8(str: string, emit: (byte: number) => void) {\n for (let i = 0; i < str.length; i += 1) {\n let codepoint = str.charCodeAt(i)\n\n if (codepoint > 0xd7ff && codepoint <= 0xdbff) {\n // most UTF-16 codepoints are Unicode codepoints, except values in this\n // range where the next UTF-16 codepoint needs to be combined with the\n // current one to get the Unicode codepoint\n const highSurrogate = ((codepoint - 0xd800) * 0x400) & 0xffff\n const lowSurrogate = (str.charCodeAt(i + 1) - 0xdc00) & 0xffff\n codepoint = (lowSurrogate | highSurrogate) + 0x10000\n i += 1\n }\n\n codepointToUTF8(codepoint, emit)\n }\n}\n\n/**\n * Converts a UTF-8 byte to a Unicode codepoint.\n *\n * @param byte The UTF-8 byte next in the sequence.\n * @param state The shared state between consecutive UTF-8 bytes in the\n * sequence, an object with the shape `{ utf8seq: 0, codepoint: 0 }`.\n * @param emit Function which will be called for each codepoint.\n */\nexport function stringFromUTF8(\n byte: number,\n state: { utf8seq: number; codepoint: number },\n emit: (codepoint: number) => void\n) {\n if (state.utf8seq === 0) {\n if (byte <= 0x7f) {\n emit(byte)\n return\n }\n\n // count the number of 1 leading bits until you reach 0\n for (let leadingBit = 1; leadingBit < 6; leadingBit += 1) {\n if (((byte >> (7 - leadingBit)) & 1) === 0) {\n state.utf8seq = leadingBit\n break\n }\n }\n\n if (state.utf8seq === 2) {\n state.codepoint = byte & 31\n } else if (state.utf8seq === 3) {\n state.codepoint = byte & 15\n } else if (state.utf8seq === 4) {\n state.codepoint = byte & 7\n } else {\n throw new Error('Invalid UTF-8 sequence')\n }\n\n state.utf8seq -= 1\n } else if (state.utf8seq > 0) {\n if (byte <= 0x7f) {\n throw new Error('Invalid UTF-8 sequence')\n }\n\n state.codepoint = (state.codepoint << 6) | (byte & 63)\n state.utf8seq -= 1\n\n if (state.utf8seq === 0) {\n emit(state.codepoint)\n }\n }\n}\n\n/**\n * Helper functions to convert different types of strings to Uint8Array\n */\n\nexport function base64UrlToUint8Array(str: string): Uint8Array_ {\n const result: number[] = []\n const state = { queue: 0, queuedBits: 0 }\n\n const onByte = (byte: number) => {\n result.push(byte)\n }\n\n for (let i = 0; i < str.length; i += 1) {\n byteFromBase64URL(str.charCodeAt(i), state, onByte)\n }\n\n return new Uint8Array(result)\n}\n\nexport function stringToUint8Array(str: string): Uint8Array_ {\n const result: number[] = []\n stringToUTF8(str, (byte: number) => result.push(byte))\n return new Uint8Array(result)\n}\n\nexport function bytesToBase64URL(bytes: Uint8Array) {\n const result: string[] = []\n const state = { queue: 0, queuedBits: 0 }\n\n const onChar = (char: string) => {\n result.push(char)\n }\n\n bytes.forEach((byte) => byteToBase64URL(byte, state, onChar))\n\n // always call with `null` after processing all bytes\n byteToBase64URL(null, state, onChar)\n\n return result.join('')\n}\n","import { API_VERSION_HEADER_NAME, BASE64URL_REGEX } from './constants'\nimport { AuthInvalidJwtError } from './errors'\nimport { base64UrlToUint8Array, stringFromBase64URL } from './base64url'\nimport { JwtHeader, JwtPayload, SupportedStorage, User } from './types'\nimport { Uint8Array_ } from './webauthn.dom'\n\nexport function expiresAt(expiresIn: number) {\n const timeNow = Math.round(Date.now() / 1000)\n return timeNow + expiresIn\n}\n\n/**\n * Generates a unique identifier for internal callback subscriptions.\n *\n * This function uses JavaScript Symbols to create guaranteed-unique identifiers\n * for auth state change callbacks. Symbols are ideal for this use case because:\n * - They are guaranteed unique by the JavaScript runtime\n * - They work in all environments (browser, SSR, Node.js)\n * - They avoid issues with Next.js 16 deterministic rendering requirements\n * - They are perfect for internal, non-serializable identifiers\n *\n * Note: This function is only used for internal subscription management,\n * not for security-critical operations like session tokens.\n */\nexport function generateCallbackId(): symbol {\n return Symbol('auth-callback')\n}\n\nexport const isBrowser = () => typeof window !== 'undefined' && typeof document !== 'undefined'\n\nconst localStorageWriteTests = {\n tested: false,\n writable: false,\n}\n\n/**\n * Checks whether localStorage is supported on this browser.\n */\nexport const supportsLocalStorage = () => {\n if (!isBrowser()) {\n return false\n }\n\n try {\n if (typeof globalThis.localStorage !== 'object') {\n return false\n }\n } catch (e) {\n // DOM exception when accessing `localStorage`\n return false\n }\n\n if (localStorageWriteTests.tested) {\n return localStorageWriteTests.writable\n }\n\n const randomKey = `lswt-${Math.random()}${Math.random()}`\n\n try {\n globalThis.localStorage.setItem(randomKey, randomKey)\n globalThis.localStorage.removeItem(randomKey)\n\n localStorageWriteTests.tested = true\n localStorageWriteTests.writable = true\n } catch (e) {\n // localStorage can't be written to\n // https://www.chromium.org/for-testers/bug-reporting-guidelines/uncaught-securityerror-failed-to-read-the-localstorage-property-from-window-access-is-denied-for-this-document\n\n localStorageWriteTests.tested = true\n localStorageWriteTests.writable = false\n }\n\n return localStorageWriteTests.writable\n}\n\n/**\n * Extracts parameters encoded in the URL both in the query and fragment.\n */\nexport function parseParametersFromURL(href: string) {\n const result: { [parameter: string]: string } = {}\n\n const url = new URL(href)\n\n if (url.hash && url.hash[0] === '#') {\n try {\n const hashSearchParams = new URLSearchParams(url.hash.substring(1))\n hashSearchParams.forEach((value, key) => {\n result[key] = value\n })\n } catch (e: any) {\n // hash is not a query string\n }\n }\n\n // search parameters take precedence over hash parameters\n url.searchParams.forEach((value, key) => {\n result[key] = value\n })\n\n return result\n}\n\ntype Fetch = typeof fetch\n\nexport const resolveFetch = (customFetch?: Fetch): Fetch => {\n if (customFetch) {\n return (...args) => customFetch(...args)\n }\n return (...args) => fetch(...args)\n}\n\nexport const looksLikeFetchResponse = (maybeResponse: unknown): maybeResponse is Response => {\n return (\n typeof maybeResponse === 'object' &&\n maybeResponse !== null &&\n 'status' in maybeResponse &&\n 'ok' in maybeResponse &&\n 'json' in maybeResponse &&\n typeof (maybeResponse as any).json === 'function'\n )\n}\n\n// Storage helpers\nexport const setItemAsync = async (\n storage: SupportedStorage,\n key: string,\n data: any\n): Promise<void> => {\n await storage.setItem(key, JSON.stringify(data))\n}\n\nexport const getItemAsync = async (storage: SupportedStorage, key: string): Promise<unknown> => {\n const value = await storage.getItem(key)\n\n if (!value) {\n return null\n }\n\n try {\n return JSON.parse(value)\n } catch {\n return value\n }\n}\n\nexport const removeItemAsync = async (storage: SupportedStorage, key: string): Promise<void> => {\n await storage.removeItem(key)\n}\n\n/**\n * A deferred represents some asynchronous work that is not yet finished, which\n * may or may not culminate in a value.\n * Taken from: https://github.com/mike-north/types/blob/master/src/async.ts\n */\nexport class Deferred<T = any> {\n public static promiseConstructor: PromiseConstructor = Promise\n\n public readonly promise!: PromiseLike<T>\n\n public readonly resolve!: (value?: T | PromiseLike<T>) => void\n\n public readonly reject!: (reason?: any) => any\n\n public constructor() {\n // eslint-disable-next-line @typescript-eslint/no-extra-semi\n ;(this as any).promise = new Deferred.promiseConstructor((res, rej) => {\n // eslint-disable-next-line @typescript-eslint/no-extra-semi\n ;(this as any).resolve = res\n // eslint-disable-next-line @typescript-eslint/no-extra-semi\n ;(this as any).reject = rej\n })\n }\n}\n\nexport function decodeJWT(token: string): {\n header: JwtHeader\n payload: JwtPayload\n signature: Uint8Array_\n raw: {\n header: string\n payload: string\n }\n} {\n const parts = token.split('.')\n\n if (parts.length !== 3) {\n throw new AuthInvalidJwtError('Invalid JWT structure')\n }\n\n // Regex checks for base64url format\n for (let i = 0; i < parts.length; i++) {\n if (!BASE64URL_REGEX.test(parts[i] as string)) {\n throw new AuthInvalidJwtError('JWT not in base64url format')\n }\n }\n const data = {\n // using base64url lib\n header: JSON.parse(stringFromBase64URL(parts[0])),\n payload: JSON.parse(stringFromBase64URL(parts[1])),\n signature: base64UrlToUint8Array(parts[2]),\n raw: {\n header: parts[0],\n payload: parts[1],\n },\n }\n return data\n}\n\n/**\n * Creates a promise that resolves to null after some time.\n */\nexport async function sleep(time: number): Promise<null> {\n return await new Promise((accept) => {\n setTimeout(() => accept(null), time)\n })\n}\n\n/**\n * Converts the provided async function into a retryable function. Each result\n * or thrown error is sent to the isRetryable function which should return true\n * if the function should run again.\n */\nexport function retryable<T>(\n fn: (attempt: number) => Promise<T>,\n isRetryable: (attempt: number, error: any | null, result?: T) => boolean\n): Promise<T> {\n const promise = new Promise<T>((accept, reject) => {\n // eslint-disable-next-line @typescript-eslint/no-extra-semi\n ;(async () => {\n for (let attempt = 0; attempt < Infinity; attempt++) {\n try {\n const result = await fn(attempt)\n\n if (!isRetryable(attempt, null, result)) {\n accept(result)\n return\n }\n } catch (e: any) {\n if (!isRetryable(attempt, e)) {\n reject(e)\n return\n }\n }\n }\n })()\n })\n\n return promise\n}\n\nfunction dec2hex(dec: number) {\n return ('0' + dec.toString(16)).substr(-2)\n}\n\n// Functions below taken from: https://stackoverflow.com/questions/63309409/creating-a-code-verifier-and-challenge-for-pkce-auth-on-spotify-api-in-reactjs\nexport function generatePKCEVerifier() {\n const verifierLength = 56\n const array = new Uint32Array(verifierLength)\n if (typeof crypto === 'undefined') {\n const charSet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~'\n const charSetLen = charSet.length\n let verifier = ''\n for (let i = 0; i < verifierLength; i++) {\n verifier += charSet.charAt(Math.floor(Math.random() * charSetLen))\n }\n return verifier\n }\n crypto.getRandomValues(array)\n return Array.from(array, dec2hex).join('')\n}\n\nasync function sha256(randomString: string) {\n const encoder = new TextEncoder()\n const encodedData = encoder.encode(randomString)\n const hash = await crypto.subtle.digest('SHA-256', encodedData)\n const bytes = new Uint8Array(hash)\n\n return Array.from(bytes)\n .map((c) => String.fromCharCode(c))\n .join('')\n}\n\nexport async function generatePKCEChallenge(verifier: string) {\n const hasCryptoSupport =\n typeof crypto !== 'undefined' &&\n typeof crypto.subtle !== 'undefined' &&\n typeof TextEncoder !== 'undefined'\n\n if (!hasCryptoSupport) {\n console.warn(\n 'WebCrypto API is not supported. Code challenge method will default to use plain instead of sha256.'\n )\n return verifier\n }\n const hashed = await sha256(verifier)\n return btoa(hashed).replace(/\\+/g, '-').replace(/\\//g, '_').replace(/=+$/, '')\n}\n\nexport async function getCodeChallengeAndMethod(\n storage: SupportedStorage,\n storageKey: string,\n isPasswordRecovery = false\n) {\n const codeVerifier = generatePKCEVerifier()\n let storedCodeVerifier = codeVerifier\n if (isPasswordRecovery) {\n storedCodeVerifier += '/PASSWORD_RECOVERY'\n }\n await setItemAsync(storage, `${storageKey}-code-verifier`, storedCodeVerifier)\n const codeChallenge = await generatePKCEChallenge(codeVerifier)\n const codeChallengeMethod = codeVerifier === codeChallenge ? 'plain' : 's256'\n return [codeChallenge, codeChallengeMethod]\n}\n\n/** Parses the API version which is 2YYY-MM-DD. */\nconst API_VERSION_REGEX = /^2[0-9]{3}-(0[1-9]|1[0-2])-(0[1-9]|1[0-9]|2[0-9]|3[0-1])$/i\n\nexport function parseResponseAPIVersion(response: Response) {\n const apiVersion = response.headers.get(API_VERSION_HEADER_NAME)\n\n if (!apiVersion) {\n return null\n }\n\n if (!apiVersion.match(API_VERSION_REGEX)) {\n return null\n }\n\n try {\n const date = new Date(`${apiVersion}T00:00:00.0Z`)\n return date\n } catch (e: any) {\n return null\n }\n}\n\nexport function validateExp(exp: number) {\n if (!exp) {\n throw new Error('Missing exp claim')\n }\n const timeNow = Math.floor(Date.now() / 1000)\n if (exp <= timeNow) {\n throw new Error('JWT has expired')\n }\n}\n\nexport function getAlgorithm(\n alg: 'HS256' | 'RS256' | 'ES256'\n): RsaHashedImportParams | EcKeyImportParams {\n switch (alg) {\n case 'RS256':\n return {\n name: 'RSASSA-PKCS1-v1_5',\n hash: { name: 'SHA-256' },\n }\n case 'ES256':\n return {\n name: 'ECDSA',\n namedCurve: 'P-256',\n hash: { name: 'SHA-256' },\n }\n default:\n throw new Error('Invalid alg claim')\n }\n}\n\nconst UUID_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/\n\nexport function validateUUID(str: string) {\n if (!UUID_REGEX.test(str)) {\n throw new Error('@supabase/auth-js: Expected parameter to be UUID but is not')\n }\n}\n\nexport function userNotAvailableProxy(): User {\n const proxyTarget = {} as User\n\n return new Proxy(proxyTarget, {\n get: (target: any, prop: string) => {\n if (prop === '__isUserNotAvailableProxy') {\n return true\n }\n // Preventative check for common problematic symbols during cloning/inspection\n // These symbols might be accessed by structuredClone or other internal mechanisms.\n if (typeof prop === 'symbol') {\n const sProp = (prop as symbol).toString()\n if (\n sProp === 'Symbol(Symbol.toPrimitive)' ||\n sProp === 'Symbol(Symbol.toStringTag)' ||\n sProp === 'Symbol(util.inspect.custom)'\n ) {\n // Node.js util.inspect\n return undefined\n }\n }\n throw new Error(\n `@supabase/auth-js: client was created with userStorage option and there was no user stored in the user storage. Accessing the \"${prop}\" property of the session object is not supported. Please use getUser() instead.`\n )\n },\n set: (_target: any, prop: string) => {\n throw new Error(\n `@supabase/auth-js: client was created with userStorage option and there was no user stored in the user storage. Setting the \"${prop}\" property of the session object is not supported. Please use getUser() to fetch a user object you can manipulate.`\n )\n },\n deleteProperty: (_target: any, prop: string) => {\n throw new Error(\n `@supabase/auth-js: client was created with userStorage option and there was no user stored in the user storage. Deleting the \"${prop}\" property of the session object is not supported. Please use getUser() to fetch a user object you can manipulate.`\n )\n },\n })\n}\n\n/**\n * Creates a proxy around a user object that warns when properties are accessed on the server.\n * This is used to alert developers that using user data from getSession() on the server is insecure.\n *\n * @param user The actual user object to wrap\n * @param suppressWarningRef An object with a 'value' property that controls warning suppression\n * @returns A proxied user object that warns on property access\n */\nexport function insecureUserWarningProxy(user: User, suppressWarningRef: { value: boolean }): User {\n return new Proxy(user, {\n get: (target: any, prop: string | symbol, receiver: any) => {\n // Allow internal checks without warning\n if (prop === '__isInsecureUserWarningProxy') {\n return true\n }\n\n // Preventative check for common problematic symbols during cloning/inspection\n // These symbols might be accessed by structuredClone or other internal mechanisms\n if (typeof prop === 'symbol') {\n const sProp = prop.toString()\n if (\n sProp === 'Symbol(Symbol.toPrimitive)' ||\n sProp === 'Symbol(Symbol.toStringTag)' ||\n sProp === 'Symbol(util.inspect.custom)' ||\n sProp === 'Symbol(nodejs.util.inspect.custom)'\n ) {\n // Return the actual value for these symbols to allow proper inspection\n return Reflect.get(target, prop, receiver)\n }\n }\n\n // Emit warning on first property access\n if (!suppressWarningRef.value && typeof prop === 'string') {\n console.warn(\n 'Using the user object as returned from supabase.auth.getSession() or from some supabase.auth.onAuthStateChange() events could be insecure! This value comes directly from the storage medium (usually cookies on the server) and may not be authentic. Use supabase.auth.getUser() instead which authenticates the data by contacting the Supabase Auth server.'\n )\n suppressWarningRef.value = true\n }\n\n return Reflect.get(target, prop, receiver)\n },\n })\n}\n\n/**\n * Deep clones a JSON-serializable object using JSON.parse(JSON.stringify(obj)).\n * Note: Only works for JSON-safe data.\n */\nexport function deepClone<T>(obj: T): T {\n return JSON.parse(JSON.stringify(obj))\n}\n","import { API_VERSIONS, API_VERSION_HEADER_NAME } from './constants'\nimport { expiresAt, looksLikeFetchResponse, parseResponseAPIVersion } from './helpers'\nimport {\n AuthResponse,\n AuthResponsePassword,\n SSOResponse,\n GenerateLinkProperties,\n GenerateLinkResponse,\n User,\n UserResponse,\n} from './types'\nimport {\n AuthApiError,\n AuthRetryableFetchError,\n AuthWeakPasswordError,\n AuthUnknownError,\n AuthSessionMissingError,\n} from './errors'\n\nexport type Fetch = typeof fetch\n\nexport interface FetchOptions {\n headers?: {\n [key: string]: string\n }\n noResolveJson?: boolean\n}\n\nexport interface FetchParameters {\n signal?: AbortSignal\n}\n\nexport type RequestMethodType = 'GET' | 'POST' | 'PUT' | 'DELETE'\n\nconst _getErrorMessage = (err: any): string =>\n err.msg || err.message || err.error_description || err.error || JSON.stringify(err)\n\nconst NETWORK_ERROR_CODES = [502, 503, 504]\n\nexport async function handleError(error: unknown) {\n if (!looksLikeFetchResponse(error)) {\n throw new AuthRetryableFetchError(_getErrorMessage(error), 0)\n }\n\n if (NETWORK_ERROR_CODES.includes(error.status)) {\n // status in 500...599 range - server had an error, request might be retryed.\n throw new AuthRetryableFetchError(_getErrorMessage(error), error.status)\n }\n\n let data: any\n try {\n data = await error.json()\n } catch (e: any) {\n throw new AuthUnknownError(_getErrorMessage(e), e)\n }\n\n let errorCode: string | undefined = undefined\n\n const responseAPIVersion = parseResponseAPIVersion(error)\n if (\n responseAPIVersion &&\n responseAPIVersion.getTime() >= API_VERSIONS['2024-01-01'].timestamp &&\n typeof data === 'object' &&\n data &&\n typeof data.code === 'string'\n ) {\n errorCode = data.code\n } else if (typeof data === 'object' && data && typeof data.error_code === 'string') {\n errorCode = data.error_code\n }\n\n if (!errorCode) {\n // Legacy support for weak password errors, when there were no error codes\n if (\n typeof data === 'object' &&\n data &&\n typeof data.weak_password === 'object' &&\n data.weak_password &&\n Array.isArray(data.weak_password.reasons) &&\n data.weak_password.reasons.length &&\n data.weak_password.reasons.reduce((a: boolean, i: any) => a && typeof i === 'string', true)\n ) {\n throw new AuthWeakPasswordError(\n _getErrorMessage(data),\n error.status,\n data.weak_password.reasons\n )\n }\n } else if (errorCode === 'weak_password') {\n throw new AuthWeakPasswordError(\n _getErrorMessage(data),\n error.status,\n data.weak_password?.reasons || []\n )\n } else if (errorCode === 'session_not_found') {\n // The `session_id` inside the JWT does not correspond to a row in the\n // `sessions` table. This usually means the user has signed out, has been\n // deleted, or their session has somehow been terminated.\n throw new AuthSessionMissingError()\n }\n\n throw new AuthApiError(_getErrorMessage(data), error.status || 500, errorCode)\n}\n\nconst _getRequestParams = (\n method: RequestMethodType,\n options?: FetchOptions,\n parameters?: FetchParameters,\n body?: object\n) => {\n const params: { [k: string]: any } = { method, headers: options?.headers || {} }\n\n if (method === 'GET') {\n return params\n }\n\n params.headers = { 'Content-Type': 'application/json;charset=UTF-8', ...options?.headers }\n params.body = JSON.stringify(body)\n return { ...params, ...parameters }\n}\n\ninterface GotrueRequestOptions extends FetchOptions {\n jwt?: string\n redirectTo?: string\n body?: object\n query?: { [key: string]: string }\n /**\n * Function that transforms api response from gotrue into a desirable / standardised format\n */\n xform?: (data: any) => any\n}\n\nexport async function _request(\n fetcher: Fetch,\n method: RequestMethodType,\n url: string,\n options?: GotrueRequestOptions\n) {\n const headers = {\n ...options?.headers,\n }\n\n if (!headers[API_VERSION_HEADER_NAME]) {\n headers[API_VERSION_HEADER_NAME] = API_VERSIONS['2024-01-01'].name\n }\n\n if (options?.jwt) {\n headers['Authorization'] = `Bearer ${options.jwt}`\n }\n\n const qs = options?.query ?? {}\n if (options?.redirectTo) {\n qs['redirect_to'] = options.redirectTo\n }\n\n const queryString = Object.keys(qs).length ? '?' + new URLSearchParams(qs).toString() : ''\n const data = await _handleRequest(\n fetcher,\n method,\n url + queryString,\n {\n headers,\n noResolveJson: options?.noResolveJson,\n },\n {},\n options?.body\n )\n return options?.xform ? options?.xform(data) : { data: { ...data }, error: null }\n}\n\nasync function _handleRequest(\n fetcher: Fetch,\n method: RequestMethodType,\n url: string,\n options?: FetchOptions,\n parameters?: FetchParameters,\n body?: object\n): Promise<any> {\n const requestParams = _getRequestParams(method, options, parameters, body)\n\n let result: any\n\n try {\n result = await fetcher(url, {\n ...requestParams,\n })\n } catch (e) {\n console.error(e)\n\n // fetch failed, likely due to a network or CORS error\n throw new AuthRetryableFetchError(_getErrorMessage(e), 0)\n }\n\n if (!result.ok) {\n await handleError(result)\n }\n\n if (options?.noResolveJson) {\n return result\n }\n\n try {\n return await result.json()\n } catch (e: any) {\n await handleError(e)\n }\n}\n\nexport function _sessionResponse(data: any): AuthResponse {\n let session = null\n if (hasSession(data)) {\n session = { ...data }\n\n if (!data.expires_at) {\n session.expires_at = expiresAt(data.expires_in)\n }\n }\n\n const user: User = data.user ?? (data as User)\n return { data: { session, user }, error: null }\n}\n\nexport function _sessionResponsePassword(data: any): AuthResponsePassword {\n const response = _sessionResponse(data) as AuthResponsePassword\n\n if (\n !response.error &&\n data.weak_password &&\n typeof data.weak_password === 'object' &&\n Array.isArray(data.weak_password.reasons) &&\n data.weak_password.reasons.length &&\n data.weak_password.message &&\n typeof data.weak_password.message === 'string' &&\n data.weak_password.reasons.reduce((a: boolean, i: any) => a && typeof i === 'string', true)\n ) {\n response.data.weak_password = data.weak_password\n }\n\n return response\n}\n\nexport function _userResponse(data: any): UserResponse {\n const user: User = data.user ?? (data as User)\n return { data: { user }, error: null }\n}\n\nexport function _ssoResponse(data: any): SSOResponse {\n return { data, error: null }\n}\n\nexport function _generateLinkResponse(data: any): GenerateLinkResponse {\n const { action_link, email_otp, hashed_token, redirect_to, verification_type, ...rest } = data\n\n const properties: GenerateLinkProperties = {\n action_link,\n email_otp,\n hashed_token,\n redirect_to,\n verification_type,\n }\n\n const user: User = { ...rest }\n return {\n data: {\n properties,\n user,\n },\n error: null,\n }\n}\n\nexport function _noResolveJsonResponse(data: any): Response {\n return data\n}\n\n/**\n * hasSession checks if the response object contains a valid session\n * @param data A response object\n * @returns true if a session is in the response\n */\nfunction hasSession(data: any): boolean {\n return data.access_token && data.refresh_token && data.expires_in\n}\n","import { AuthError } from './errors'\nimport { Fetch } from './fetch'\nimport { EIP1193Provider, EthereumSignInInput, Hex } from './web3/ethereum'\nimport type { SolanaSignInInput, SolanaSignInOutput } from './web3/solana'\nimport {\n ServerCredentialCreationOptions,\n ServerCredentialRequestOptions,\n WebAuthnApi,\n} from './webauthn'\nimport {\n AuthenticationCredential,\n PublicKeyCredentialCreationOptionsFuture,\n PublicKeyCredentialRequestOptionsFuture,\n RegistrationCredential,\n} from './webauthn.dom'\n\n/** One of the providers supported by GoTrue. */\nexport type Provider =\n | 'apple'\n | 'azure'\n | 'bitbucket'\n | 'discord'\n | 'facebook'\n | 'figma'\n | 'github'\n | 'gitlab'\n | 'google'\n | 'kakao'\n | 'keycloak'\n | 'linkedin'\n | 'linkedin_oidc'\n | 'notion'\n | 'slack'\n | 'slack_oidc'\n | 'spotify'\n | 'twitch'\n /** Uses OAuth 1.0a */\n | 'twitter'\n /** Uses OAuth 2.0 */\n | 'x'\n | 'workos'\n | 'zoom'\n | 'fly'\n\nexport type AuthChangeEventMFA = 'MFA_CHALLENGE_VERIFIED'\n\nexport type AuthChangeEvent =\n | 'INITIAL_SESSION'\n | 'PASSWORD_RECOVERY'\n | 'SIGNED_IN'\n | 'SIGNED_OUT'\n | 'TOKEN_REFRESHED'\n | 'USER_UPDATED'\n | AuthChangeEventMFA\n\n/**\n * Provide your own global lock implementation instead of the default\n * implementation. The function should acquire a lock for the duration of the\n * `fn` async function, such that no other client instances will be able to\n * hold it at the same time.\n *\n * @experimental\n *\n * @param name Name of the lock to be acquired.\n * @param acquireTimeout If negative, no timeout should occur. If positive it\n * should throw an Error with an `isAcquireTimeout`\n * property set to true if the operation fails to be\n * acquired after this much time (ms).\n * @param fn The operation to execute when the lock is acquired.\n */\nexport type LockFunc = <R>(name: string, acquireTimeout: number, fn: () => Promise<R>) => Promise<R>\n\nexport type GoTrueClientOptions = {\n /* The URL of the GoTrue server. */\n url?: string\n /* Any additional headers to send to the GoTrue server. */\n headers?: { [key: string]: string }\n /* Optional key name used for storing tokens in local storage. */\n storageKey?: string\n /**\n * Set to \"true\" if you want to automatically detect OAuth grants in the URL and sign in the user.\n * Set to \"false\" to disable automatic detection.\n * Set to a function to provide custom logic for determining if a URL contains a Supabase auth callback.\n * The function receives the current URL and parsed parameters, and should return true if the URL\n * should be processed as a Supabase auth callback, or false to ignore it.\n *\n * This is useful when your app uses other OAuth providers (e.g., Facebook Login) that also return\n * access_token in the URL fragment, which would otherwise be incorrectly intercepted by Supabase Auth.\n *\n * @example\n * ```ts\n * detectSessionInUrl: (url, params) => {\n * // Ignore Facebook OAuth redirects\n * if (url.pathname === '/facebook/redirect') return false\n * // Use default detection for other URLs\n * return Boolean(params.access_token || params.error_description)\n * }\n * ```\n */\n detectSessionInUrl?: boolean | ((url: URL, params: { [parameter: string]: string }) => boolean)\n /* Set to \"true\" if you want to automatically refresh the token before expiring. */\n autoRefreshToken?: boolean\n /* Set to \"true\" if you want to automatically save the user session into local storage. If set to false, session will just be saved in memory. */\n persistSession?: boolean\n /* Provide your own local storage implementation to use instead of the browser's local storage. */\n storage?: SupportedStorage\n /**\n * Stores the user object in a separate storage location from the rest of the session data. When non-null, `storage` will only store a JSON object containing the access and refresh token and some adjacent metadata, while `userStorage` will only contain the user object under the key `storageKey + '-user'`.\n *\n * When this option is set and cookie storage is used, `getSession()` and other functions that load a session from the cookie store might not return back a user. It's very important to always use `getUser()` to fetch a user object in those scenarios.\n *\n * @experimental\n */\n userStorage?: SupportedStorage\n /* A custom fetch implementation. */\n fetch?: Fetch\n /* If set to 'pkce' PKCE flow. Defaults to the 'implicit' flow otherwise */\n flowType?: AuthFlowType\n /* If debug messages are emitted. Can be used to inspect the behavior of the library. If set to a function, the provided function will be used instead of `console.log()` to perform the logging. */\n debug?: boolean | ((message: string, ...args: any[]) => void)\n /**\n * Provide your own locking mechanism based on the environment. By default no locking is done at this time.\n *\n * @experimental\n */\n lock?: LockFunc\n /**\n * Set to \"true\" if there is a custom authorization header set globally.\n * @experimental\n */\n hasCustomAuthorizationHeader?: boolean\n /**\n * If there is an error with the query, throwOnError will reject the promise by\n * throwing the error instead of returning it as part of a successful response.\n */\n throwOnError?: boolean\n /**\n * The maximum time in milliseconds to wait for acquiring a cross-tab synchronization lock.\n *\n * When multiple browser tabs or windows use the auth client simultaneously, they coordinate\n * via the Web Locks API to prevent race conditions during session refresh and other operations.\n * This timeout controls how long to wait for the lock before failing.\n *\n * If the lock cannot be acquired within this time, a `LockAcquireTimeoutError` is thrown.\n * You can catch this by checking `error.isAcquireTimeout === true`.\n *\n * - **Positive value**: Wait up to this many milliseconds before timing out\n * - **Zero (0)**: Fail immediately if the lock is unavailable\n * - **Negative value**: Wait indefinitely (not recommended - can cause deadlocks)\n *\n * @default 10000\n *\n * @example\n * ```ts\n * const client = createClient(url, key, {\n * auth: {\n * lockAcquireTimeout: 10000, // 10 seconds\n * },\n * })\n *\n * try {\n * await client.auth.getSession()\n * } catch (error) {\n * if (error.isAcquireTimeout) {\n * // Lock held by another tab/instance, or a previous operation is stuck.\n * // Consider: closing other tabs, increasing timeout, or restarting the browser.\n * console.error('Could not acquire lock within timeout period.')\n * }\n * }\n * ```\n */\n lockAcquireTimeout?: number\n}\n\nconst WeakPasswordReasons = ['length', 'characters', 'pwned'] as const\n\nexport type WeakPasswordReasons = (typeof WeakPasswordReasons)[number]\nexport type WeakPassword = {\n reasons: WeakPasswordReasons[]\n message: string\n}\n\n/**\n * Resolve mapped types and show the derived keys and their types when hovering in\n * VS Code, instead of just showing the names those mapped types are defined with.\n */\nexport type Prettify<T> = T extends Function ? T : { [K in keyof T]: T[K] }\n\n/**\n * A stricter version of TypeScript's Omit that only allows omitting keys that actually exist.\n * This prevents typos and ensures type safety at compile time.\n * Unlike regular Omit, this will error if you try to omit a non-existent key.\n */\nexport type StrictOmit<T, K extends keyof T> = Omit<T, K>\n\n/**\n * a shared result type that encapsulates errors instead of throwing them, allows you to optionally specify the ErrorType\n */\nexport type RequestResult<T, ErrorType extends Error = AuthError> =\n | {\n data: T\n error: null\n }\n | {\n data: null\n error: Error extends AuthError ? AuthError : ErrorType\n }\n\n/**\n * similar to RequestResult except it allows you to destructure the possible shape of the success response\n * {@see RequestResult}\n */\nexport type RequestResultSafeDestructure<T> =\n | { data: T; error: null }\n | {\n data: T extends object ? { [K in keyof T]: null } : null\n error: AuthError\n }\n\nexport type AuthResponse = RequestResultSafeDestructure<{\n user: User | null\n session: Session | null\n}>\n\nexport type AuthResponsePassword = RequestResultSafeDestructure<{\n user: User | null\n session: Session | null\n weak_password?: WeakPassword | null\n}>\n\n/**\n * AuthOtpResponse is returned when OTP is used.\n *\n * {@see AuthResponse}\n */\nexport type AuthOtpResponse = RequestResultSafeDestructure<{\n user: null\n session: null\n messageId?: string | null\n}>\n\nexport type AuthTokenResponse = RequestResultSafeDestructure<{\n user: User\n session: Session\n}>\n\nexport type AuthTokenResponsePassword = RequestResultSafeDestructure<{\n user: User\n session: Session\n weakPassword?: WeakPassword\n}>\n\nexport type OAuthResponse =\n | {\n data: {\n provider: Provider\n url: string\n }\n error: null\n }\n | {\n data: {\n provider: Provider\n url: null\n }\n error: AuthError\n }\n\nexport type SSOResponse = RequestResult<{\n /**\n * URL to open in a browser which will complete the sign-in flow by\n * taking the user to the identity provider's authentication flow.\n *\n * On browsers you can set the URL to `window.location.href` to take\n * the user to the authentication flow.\n */\n url: string\n}>\n\nexport type UserResponse = RequestResultSafeDestructure<{\n user: User\n}>\n\nexport interface Session {\n /**\n * The oauth provider token. If present, this can be used to make external API requests to the oauth provider used.\n */\n provider_token?: string | null\n /**\n * The oauth provider refresh token. If present, this can be used to refresh the provider_token via the oauth provider's API.\n * Not all oauth providers return a provider refresh token. If the provider_refresh_token is missing, please refer to the oauth provider's documentation for information on how to obtain the provider refresh token.\n */\n provider_refresh_token?: string | null\n /**\n * The access token jwt. It is recommended to set the JWT_EXPIRY to a shorter expiry value.\n */\n access_token: string\n /**\n * A one-time used refresh token that never expires.\n */\n refresh_token: string\n /**\n * The number of seconds until the token expires (since it was issued). Returned when a login is confirmed.\n */\n expires_in: number\n /**\n * A timestamp of when the token will expire. Returned when a login is confirmed.\n */\n expires_at?: number\n token_type: 'bearer'\n\n /**\n * When using a separate user storage, accessing properties of this object will throw an error.\n */\n user: User\n}\n\nconst AMRMethods = [\n 'password',\n 'otp',\n 'oauth',\n 'totp',\n 'mfa/totp',\n 'mfa/phone',\n 'mfa/webauthn',\n 'anonymous',\n 'sso/saml',\n 'magiclink',\n 'web3',\n 'oauth_provider/authorization_code',\n] as const\n\nexport type AMRMethod = (typeof AMRMethods)[number] | (string & {})\n\n/**\n * An authentication method reference (AMR) entry.\n *\n * An entry designates what method was used by the user to verify their\n * identity and at what time.\n *\n * Note: Custom access token hooks can return AMR claims as either:\n * - An array of AMREntry objects (detailed format with timestamps)\n * - An array of strings (RFC-8176 compliant format)\n *\n * @see {@link GoTrueMFAApi#getAuthenticatorAssuranceLevel}.\n */\nexport interface AMREntry {\n /** Authentication method name. */\n method: AMRMethod\n\n /**\n * Timestamp when the method was successfully used. Represents number of\n * seconds since 1st January 1970 (UNIX epoch) in UTC.\n */\n timestamp: number\n}\n\nexport interface UserIdentity {\n id: string\n user_id: string\n identity_data?: {\n [key: string]: any\n }\n identity_id: string\n provider: string\n created_at?: string\n last_sign_in_at?: string\n updated_at?: string\n}\n\nconst FactorTypes = ['totp', 'phone', 'webauthn'] as const\n\n/**\n * Type of factor. `totp` and `phone` supported with this version\n */\nexport type FactorType = (typeof FactorTypes)[number]\n\nconst FactorVerificationStatuses = ['verified', 'unverified'] as const\n\n/**\n * The verification status of the factor, default is `unverified` after `.enroll()`, then `verified` after the user verifies it with `.verify()`\n */\ntype FactorVerificationStatus = (typeof FactorVerificationStatuses)[number]\n\n/**\n * A MFA factor.\n *\n * @see {@link GoTrueMFAApi#enroll}\n * @see {@link GoTrueMFAApi#listFactors}\n * @see {@link GoTrueMFAAdminApi#listFactors}\n */\nexport type Factor<\n Type extends FactorType = FactorType,\n Status extends FactorVerificationStatus = (typeof FactorVerificationStatuses)[number],\n> = {\n /** ID of the factor. */\n id: string\n\n /** Friendly name of the factor, useful to disambiguate between multiple factors. */\n friendly_name?: string\n\n /**\n * Type of factor. `totp` and `phone` supported with this version\n */\n factor_type: Type\n\n /**\n * The verification status of the factor, default is `unverified` after `.enroll()`, then `verified` after the user verifies it with `.verify()`\n */\n status: Status\n\n created_at: string\n updated_at: string\n last_challenged_at?: string\n}\n\nexport interface UserAppMetadata {\n /**\n * The first provider that the user used to sign up with.\n */\n provider?: string\n /**\n * A list of all providers that the user has linked to their account.\n */\n providers?: string[]\n [key: string]: any\n}\n\nexport interface UserMetadata {\n [key: string]: any\n}\n\nexport interface User {\n id: string\n app_metadata: UserAppMetadata\n user_metadata: UserMetadata\n aud: string\n confirmation_sent_at?: string\n recovery_sent_at?: string\n email_change_sent_at?: string\n new_email?: string\n new_phone?: string\n invited_at?: string\n action_link?: string\n email?: string\n phone?: string\n created_at: string\n confirmed_at?: string\n email_confirmed_at?: string\n phone_confirmed_at?: string\n last_sign_in_at?: string\n role?: string\n updated_at?: string\n identities?: UserIdentity[]\n is_anonymous?: boolean\n is_sso_user?: boolean\n factors?: (Factor<FactorType, 'verified'> | Factor<FactorType, 'unverified'>)[]\n deleted_at?: string\n banned_until?: string\n}\n\nexport interface UserAttributes {\n /**\n * The user's email.\n */\n email?: string\n\n /**\n * The user's phone.\n */\n phone?: string\n\n /**\n * The user's password.\n */\n password?: string\n\n /**\n * The nonce sent for reauthentication if the user's password is to be updated.\n *\n * Call reauthenticate() to obtain the nonce first.\n */\n nonce?: string\n\n /**\n * A custom data object to store the user's metadata. This maps to the `auth.users.raw_user_meta_data` column.\n *\n * The `data` should be a JSON object that includes user-specific info, such as their first and last name.\n *\n */\n data?: object\n}\n\nexport interface AdminUserAttributes extends Omit<UserAttributes, 'data'> {\n /**\n * A custom data object to store the user's metadata. This maps to the `auth.users.raw_user_meta_data` column.\n *\n *\n * The `user_metadata` should be a JSON object that includes user-specific info, such as their first and last name.\n *\n * Note: When using the GoTrueAdminApi and wanting to modify a user's metadata,\n * this attribute is used instead of UserAttributes data.\n *\n */\n user_metadata?: object\n\n /**\n * A custom data object to store the user's application specific metadata. This maps to the `auth.users.app_metadata` column.\n *\n * Only a service role can modify.\n *\n * The `app_metadata` should be a JSON object that includes app-specific info, such as identity providers, roles, and other\n * access control information.\n */\n app_metadata?: object\n\n /**\n * Confirms the user's email address if set to true.\n *\n * Only a service role can modify.\n */\n email_confirm?: boolean\n\n /**\n * Confirms the user's phone number if set to true.\n *\n * Only a service role can modify.\n */\n phone_confirm?: boolean\n\n /**\n * Determines how long a user is banned for.\n *\n * The format for the ban duration follows a strict sequence of decimal numbers with a unit suffix.\n * Valid time units are \"ns\", \"us\" (or \"µs\"), \"ms\", \"s\", \"m\", \"h\".\n *\n * For example, some possible durations include: '300ms', '2h45m'.\n *\n * Setting the ban duration to 'none' lifts the ban on the user.\n */\n ban_duration?: string | 'none'\n\n /**\n * The `role` claim set in the user's access token JWT.\n *\n * When a user signs up, this role is set to `authenticated` by default. You should only modify the `role` if you need to provision several levels of admin access that have different permissions on individual columns in your database.\n *\n * Setting this role to `service_role` is not recommended as it grants the user admin privileges.\n */\n role?: string\n\n /**\n * The `password_hash` for the user's password.\n *\n * Allows you to specify a password hash for the user. This is useful for migrating a user's password hash from another service.\n *\n * Supports bcrypt, scrypt (firebase), and argon2 password hashes.\n */\n password_hash?: string\n\n /**\n * The `id` for the user.\n *\n * Allows you to overwrite the default `id` set for the user.\n */\n id?: string\n}\n\nexport interface Subscription {\n /**\n * A unique identifier for this subscription, set by the client.\n * This is an internal identifier used for managing callbacks and should not be\n * relied upon by application code. Use the unsubscribe() method to remove listeners.\n */\n id: string | symbol\n /**\n * The function to call every time there is an event. eg: (eventName) => {}\n */\n callback: (event: AuthChangeEvent, session: Session | null) => void\n /**\n * Call this to remove the listener.\n */\n unsubscribe: () => void\n}\n\nexport type SignInAnonymouslyCredentials = {\n options?: {\n /**\n * A custom data object to store the user's metadata. This maps to the `auth.users.raw_user_meta_data` column.\n *\n * The `data` should be a JSON object that includes user-specific info, such as their first and last name.\n */\n data?: object\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n }\n}\n\nexport type SignUpWithPasswordCredentials = Prettify<\n PasswordCredentialsBase & {\n options?: {\n emailRedirectTo?: string // only for email\n data?: object\n captchaToken?: string\n channel?: 'sms' | 'whatsapp' // only for phone\n }\n }\n>\n\ntype PasswordCredentialsBase =\n | { email: string; password: string }\n | { phone: string; password: string }\n\nexport type SignInWithPasswordCredentials = PasswordCredentialsBase & {\n options?: {\n captchaToken?: string\n }\n}\n\nexport type SignInWithPasswordlessCredentials =\n | {\n /** The user's email address. */\n email: string\n options?: {\n /** The redirect url embedded in the email link */\n emailRedirectTo?: string\n /** If set to false, this method will not create a new user. Defaults to true. */\n shouldCreateUser?: boolean\n /**\n * A custom data object to store the user's metadata. This maps to the `auth.users.raw_user_meta_data` column.\n *\n * The `data` should be a JSON object that includes user-specific info, such as their first and last name.\n */\n data?: object\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n }\n }\n | {\n /** The user's phone number. */\n phone: string\n options?: {\n /** If set to false, this method will not create a new user. Defaults to true. */\n shouldCreateUser?: boolean\n /**\n * A custom data object to store the user's metadata. This maps to the `auth.users.raw_user_meta_data` column.\n *\n * The `data` should be a JSON object that includes user-specific info, such as their first and last name.\n */\n data?: object\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n /** Messaging channel to use (e.g. whatsapp or sms) */\n channel?: 'sms' | 'whatsapp'\n }\n }\n\nexport type AuthFlowType = 'implicit' | 'pkce'\nexport type SignInWithOAuthCredentials = {\n /** One of the providers supported by GoTrue. */\n provider: Provider\n options?: {\n /** A URL to send the user to after they are confirmed. */\n redirectTo?: string\n /** A space-separated list of scopes granted to the OAuth application. */\n scopes?: string\n /** An object of query params */\n queryParams?: { [key: string]: string }\n /** If set to true does not immediately redirect the current browser context to visit the OAuth authorization page for the provider. */\n skipBrowserRedirect?: boolean\n }\n}\n\nexport type SignInWithIdTokenCredentials = {\n /** Provider name or OIDC `iss` value identifying which provider should be used to verify the provided token. Supported names: `google`, `apple`, `azure`, `facebook`, `kakao`, `keycloak` (deprecated). */\n provider: 'google' | 'apple' | 'azure' | 'facebook' | 'kakao' | (string & {})\n /** OIDC ID token issued by the specified provider. The `iss` claim in the ID token must match the supplied provider. Some ID tokens contain an `at_hash` which require that you provide an `access_token` value to be accepted properly. If the token contains a `nonce` claim you must supply the nonce used to obtain the ID token. */\n token: string\n /** If the ID token contains an `at_hash` claim, then the hash of this value is compared to the value in the ID token. */\n access_token?: string\n /** If the ID token contains a `nonce` claim, then the hash of this value is compared to the value in the ID token. */\n nonce?: string\n options?: {\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n }\n}\n\nexport type SolanaWallet = {\n signIn?: (...inputs: SolanaSignInInput[]) => Promise<SolanaSignInOutput | SolanaSignInOutput[]>\n publicKey?: {\n toBase58: () => string\n } | null\n\n signMessage?: (message: Uint8Array, encoding?: 'utf8' | string) => Promise<Uint8Array> | undefined\n}\n\nexport type SolanaWeb3Credentials =\n | {\n chain: 'solana'\n\n /** Wallet interface to use. If not specified will default to `window.solana`. */\n wallet?: SolanaWallet\n\n /** Optional statement to include in the Sign in with Solana message. Must not include new line characters. Most wallets like Phantom **require specifying a statement!** */\n statement?: string\n\n options?: {\n /** URL to use with the wallet interface. Some wallets do not allow signing a message for URLs different from the current page. */\n url?: string\n\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n\n signInWithSolana?: Partial<\n Omit<SolanaSignInInput, 'version' | 'chain' | 'domain' | 'uri' | 'statement'>\n >\n }\n }\n | {\n chain: 'solana'\n\n /** Sign in with Solana compatible message. Must include `Issued At`, `URI` and `Version`. */\n message: string\n\n /** Ed25519 signature of the message. */\n signature: Uint8Array\n\n options?: {\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n }\n }\n\nexport type EthereumWallet = EIP1193Provider\n\nexport type EthereumWeb3Credentials =\n | {\n chain: 'ethereum'\n\n /** Wallet interface to use. If not specified will default to `window.ethereum`. */\n wallet?: EthereumWallet\n\n /** Optional statement to include in the Sign in with Ethereum message. Must not include new line characters. Most wallets like Phantom **require specifying a statement!** */\n statement?: string\n\n options?: {\n /** URL to use with the wallet interface. Some wallets do not allow signing a message for URLs different from the current page. */\n url?: string\n\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n\n signInWithEthereum?: Partial<\n Omit<EthereumSignInInput, 'version' | 'domain' | 'uri' | 'statement'>\n >\n }\n }\n | {\n chain: 'ethereum'\n\n /** Sign in with Ethereum compatible message. Must include `Issued At`, `URI` and `Version`. */\n message: string\n\n /** Ethereum curve (secp256k1) signature of the message. */\n signature: Hex\n\n options?: {\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n }\n }\n\nexport type Web3Credentials = SolanaWeb3Credentials | EthereumWeb3Credentials\n\nexport type VerifyOtpParams = VerifyMobileOtpParams | VerifyEmailOtpParams | VerifyTokenHashParams\nexport interface VerifyMobileOtpParams {\n /** The user's phone number. */\n phone: string\n /** The otp sent to the user's phone number. */\n token: string\n /** The user's verification type. */\n type: MobileOtpType\n options?: {\n /** A URL to send the user to after they are confirmed. */\n redirectTo?: string\n\n /**\n * Verification token received when the user completes the captcha on the site.\n *\n * @deprecated\n */\n captchaToken?: string\n }\n}\nexport interface VerifyEmailOtpParams {\n /** The user's email address. */\n email: string\n /** The otp sent to the user's email address. */\n token: string\n /** The user's verification type. */\n type: EmailOtpType\n options?: {\n /** A URL to send the user to after they are confirmed. */\n redirectTo?: string\n\n /** Verification token received when the user completes the captcha on the site.\n *\n * @deprecated\n */\n captchaToken?: string\n }\n}\n\nexport interface VerifyTokenHashParams {\n /** The token hash used in an email link */\n token_hash: string\n\n /** The user's verification type. */\n type: EmailOtpType\n}\n\nexport type MobileOtpType = 'sms' | 'phone_change'\nexport type EmailOtpType = 'signup' | 'invite' | 'magiclink' | 'recovery' | 'email_change' | 'email'\n\nexport type ResendParams =\n | {\n type: Extract<EmailOtpType, 'signup' | 'email_change'>\n email: string\n options?: {\n /** A URL to send the user to after they have signed-in. */\n emailRedirectTo?: string\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n }\n }\n | {\n type: Extract<MobileOtpType, 'sms' | 'phone_change'>\n phone: string\n options?: {\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n }\n }\n\nexport type SignInWithSSO =\n | {\n /** UUID of the SSO provider to invoke single-sign on to. */\n providerId: string\n\n options?: {\n /** A URL to send the user to after they have signed-in. */\n redirectTo?: string\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n /**\n * If set to true, the redirect will not happen on the client side.\n * This parameter is used when you wish to handle the redirect yourself.\n * Defaults to false.\n */\n skipBrowserRedirect?: boolean\n }\n }\n | {\n /** Domain name of the organization for which to invoke single-sign on. */\n domain: string\n\n options?: {\n /** A URL to send the user to after they have signed-in. */\n redirectTo?: string\n /** Verification token received when the user completes the captcha on the site. */\n captchaToken?: string\n /**\n * If set to true, the redirect will not happen on the client side.\n * This parameter is used when you wish to handle the redirect yourself.\n * Defaults to false.\n */\n skipBrowserRedirect?: boolean\n }\n }\n\nexport type GenerateSignupLinkParams = {\n type: 'signup'\n email: string\n password: string\n options?: Pick<GenerateLinkOptions, 'data' | 'redirectTo'>\n}\n\nexport type GenerateInviteOrMagiclinkParams = {\n type: 'invite' | 'magiclink'\n /** The user's email */\n email: string\n options?: Pick<GenerateLinkOptions, 'data' | 'redirectTo'>\n}\n\nexport type GenerateRecoveryLinkParams = {\n type: 'recovery'\n /** The user's email */\n email: string\n options?: Pick<GenerateLinkOptions, 'redirectTo'>\n}\n\nexport type GenerateEmailChangeLinkParams = {\n type: 'email_change_current' | 'email_change_new'\n /** The user's email */\n email: string\n /**\n * The user's new email. Only required if type is 'email_change_current' or 'email_change_new'.\n */\n newEmail: string\n options?: Pick<GenerateLinkOptions, 'redirectTo'>\n}\n\nexport interface GenerateLinkOptions {\n /**\n * A custom data object to store the user's metadata. This maps to the `auth.users.raw_user_meta_data` column.\n *\n * The `data` should be a JSON object that includes user-specific info, such as their first and last name.\n */\n data?: object\n /** The URL which will be appended to the email link generated. */\n redirectTo?: string\n}\n\nexport type GenerateLinkParams =\n | GenerateSignupLinkParams\n | GenerateInviteOrMagiclinkParams\n | GenerateRecoveryLinkParams\n | GenerateEmailChangeLinkParams\n\nexport type GenerateLinkResponse = RequestResultSafeDestructure<{\n properties: GenerateLinkProperties\n user: User\n}>\n\n/** The properties related to the email link generated */\nexport type GenerateLinkProperties = {\n /**\n * The email link to send to the user.\n * The action_link follows the following format: auth/v1/verify?type={verification_type}&token={hashed_token}&redirect_to={redirect_to}\n * */\n action_link: string\n /**\n * The raw email OTP.\n * You should send this in the email if you want your users to verify using an OTP instead of the action link.\n * */\n email_otp: string\n /**\n * The hashed token appended to the action link.\n * */\n hashed_token: string\n /** The URL appended to the action link. */\n redirect_to: string\n /** The verification type that the email link is associated to. */\n verification_type: GenerateLinkType\n}\n\nexport type GenerateLinkType =\n | 'signup'\n | 'invite'\n | 'magiclink'\n | 'recovery'\n | 'email_change_current'\n | 'email_change_new'\n\nexport type MFAEnrollParams = MFAEnrollTOTPParams | MFAEnrollPhoneParams | MFAEnrollWebauthnParams\n\nexport type MFAUnenrollParams = {\n /** ID of the factor being unenrolled. */\n factorId: string\n}\n\ntype MFAVerifyParamsBase = {\n /** ID of the factor being verified. Returned in enroll(). */\n factorId: string\n /** ID of the challenge being verified. Returned in challenge(). */\n challengeId: string\n}\n\ntype MFAVerifyTOTPParamFields = {\n /** Verification code provided by the user. */\n code: string\n}\n\nexport type MFAVerifyTOTPParams = Prettify<MFAVerifyParamsBase & MFAVerifyTOTPParamFields>\n\ntype MFAVerifyPhoneParamFields = MFAVerifyTOTPParamFields\n\nexport type MFAVerifyPhoneParams = Prettify<MFAVerifyParamsBase & MFAVerifyPhoneParamFields>\n\ntype MFAVerifyWebauthnParamFieldsBase = {\n /** Relying party ID */\n rpId: string\n /** Relying party origins */\n rpOrigins?: string[]\n}\n\ntype MFAVerifyWebauthnCredentialParamFields<T extends 'create' | 'request' = 'create' | 'request'> =\n {\n /** Operation type */\n type: T\n /** Creation response from the authenticator (for enrollment/unverified factors) */\n credential_response: T extends 'create' ? RegistrationCredential : AuthenticationCredential\n }\n\n/**\n * WebAuthn-specific fields for MFA verification.\n * Supports both credential creation (registration) and request (authentication) flows.\n * @template T - Type of WebAuthn operation: 'create' for registration, 'request' for authentication\n */\nexport type MFAVerifyWebauthnParamFields<T extends 'create' | 'request' = 'create' | 'request'> = {\n webauthn: MFAVerifyWebauthnParamFieldsBase & MFAVerifyWebauthnCredentialParamFields<T>\n}\n\n/**\n * Parameters for WebAuthn MFA verification.\n * Used to verify WebAuthn credentials after challenge.\n * @template T - Type of WebAuthn operation: 'create' for registration, 'request' for authentication\n * @see {@link https://w3c.github.io/webauthn/#sctn-verifying-assertion W3C WebAuthn Spec - Verifying an Authentication Assertion}\n */\nexport type MFAVerifyWebauthnParams<T extends 'create' | 'request' = 'create' | 'request'> =\n Prettify<MFAVerifyParamsBase & MFAVerifyWebauthnParamFields<T>>\n\nexport type MFAVerifyParams = MFAVerifyTOTPParams | MFAVerifyPhoneParams | MFAVerifyWebauthnParams\n\ntype MFAChallengeParamsBase = {\n /** ID of the factor to be challenged. Returned in enroll(). */\n factorId: string\n}\n\nconst MFATOTPChannels = ['sms', 'whatsapp'] as const\nexport type MFATOTPChannel = (typeof MFATOTPChannels)[number]\n\nexport type MFAChallengeTOTPParams = Prettify<MFAChallengeParamsBase>\n\ntype MFAChallengePhoneParamFields<Channel extends MFATOTPChannel = MFATOTPChannel> = {\n /** Messaging channel to use (e.g. whatsapp or sms). Only relevant for phone factors */\n channel: Channel\n}\n\nexport type MFAChallengePhoneParams = Prettify<\n MFAChallengeParamsBase & MFAChallengePhoneParamFields\n>\n\n/** WebAuthn parameters for WebAuthn factor challenge */\ntype MFAChallengeWebauthnParamFields = {\n webauthn: {\n /** Relying party ID */\n rpId: string\n /** Relying party origins*/\n rpOrigins?: string[]\n }\n}\n\n/**\n * Parameters for initiating a WebAuthn MFA challenge.\n * Includes Relying Party information needed for WebAuthn ceremonies.\n * @see {@link https://w3c.github.io/webauthn/#sctn-rp-operations W3C WebAuthn Spec - Relying Party Operations}\n */\nexport type MFAChallengeWebauthnParams = Prettify<\n MFAChallengeParamsBase & MFAChallengeWebauthnParamFields\n>\n\nexport type MFAChallengeParams =\n | MFAChallengeTOTPParams\n | MFAChallengePhoneParams\n | MFAChallengeWebauthnParams\n\ntype MFAChallengeAndVerifyParamsBase = Omit<MFAVerifyParamsBase, 'challengeId'>\n\ntype MFAChallengeAndVerifyTOTPParamFields = MFAVerifyTOTPParamFields\n\ntype MFAChallengeAndVerifyTOTPParams = Prettify<\n MFAChallengeAndVerifyParamsBase & MFAChallengeAndVerifyTOTPParamFields\n>\n\nexport type MFAChallengeAndVerifyParams = MFAChallengeAndVerifyTOTPParams\n\n/**\n * Data returned after successful MFA verification.\n * Contains new session tokens and updated user information.\n */\nexport type AuthMFAVerifyResponseData = {\n /** New access token (JWT) after successful verification. */\n access_token: string\n\n /** Type of token, always `bearer`. */\n token_type: 'bearer'\n\n /** Number of seconds in which the access token will expire. */\n expires_in: number\n\n /** Refresh token you can use to obtain new access tokens when expired. */\n refresh_token: string\n\n /** Updated user profile. */\n user: User\n}\n\n/**\n * Response type for MFA verification operations.\n * Returns session tokens on successful verification.\n */\nexport type AuthMFAVerifyResponse = RequestResult<AuthMFAVerifyResponseData>\n\nexport type AuthMFAEnrollResponse =\n | AuthMFAEnrollTOTPResponse\n | AuthMFAEnrollPhoneResponse\n | AuthMFAEnrollWebauthnResponse\n\nexport type AuthMFAUnenrollResponse = RequestResult<{\n /** ID of the factor that was successfully unenrolled. */\n id: string\n}>\n\ntype AuthMFAChallengeResponseBase<T extends FactorType> = {\n /** ID of the newly created challenge. */\n id: string\n\n /** Factor Type which generated the challenge */\n type: T\n\n /** Timestamp in UNIX seconds when this challenge will no longer be usable. */\n expires_at: number\n}\n\ntype AuthMFAChallengeTOTPResponseFields = {\n /** no extra fields for now, kept for consistency and for possible future changes */\n}\n\nexport type AuthMFAChallengeTOTPResponse = RequestResult<\n Prettify<AuthMFAChallengeResponseBase<'totp'> & AuthMFAChallengeTOTPResponseFields>\n>\n\ntype AuthMFAChallengePhoneResponseFields = {\n /** no extra fields for now, kept for consistency and for possible future changes */\n}\n\nexport type AuthMFAChallengePhoneResponse = RequestResult<\n Prettify<AuthMFAChallengeResponseBase<'phone'> & AuthMFAChallengePhoneResponseFields>\n>\n\ntype AuthMFAChallengeWebauthnResponseFields = {\n webauthn:\n | {\n type: 'create'\n credential_options: { publicKey: PublicKeyCredentialCreationOptionsFuture }\n }\n | {\n type: 'request'\n credential_options: { publicKey: PublicKeyCredentialRequestOptionsFuture }\n }\n}\n\n/**\n * Response type for WebAuthn MFA challenge.\n * Contains credential creation or request options from the server.\n * @see {@link https://w3c.github.io/webauthn/#sctn-credential-creation W3C WebAuthn Spec - Credential Creation}\n */\nexport type AuthMFAChallengeWebauthnResponse = RequestResult<\n Prettify<AuthMFAChallengeResponseBase<'webauthn'> & AuthMFAChallengeWebauthnResponseFields>\n>\n\ntype AuthMFAChallengeWebauthnResponseFieldsJSON = {\n webauthn:\n | {\n type: 'create'\n credential_options: { publicKey: ServerCredentialCreationOptions }\n }\n | {\n type: 'request'\n credential_options: { publicKey: ServerCredentialRequestOptions }\n }\n}\n\n/**\n * JSON-serializable version of WebAuthn challenge response.\n * Used for server communication with base64url-encoded binary fields.\n */\nexport type AuthMFAChallengeWebauthnResponseDataJSON = Prettify<\n AuthMFAChallengeResponseBase<'webauthn'> & AuthMFAChallengeWebauthnResponseFieldsJSON\n>\n\n/**\n * Server response type for WebAuthn MFA challenge.\n * Contains JSON-formatted WebAuthn options ready for browser API.\n */\nexport type AuthMFAChallengeWebauthnServerResponse =\n RequestResult<AuthMFAChallengeWebauthnResponseDataJSON>\n\nexport type AuthMFAChallengeResponse =\n | AuthMFAChallengeTOTPResponse\n | AuthMFAChallengePhoneResponse\n | AuthMFAChallengeWebauthnResponse\n\n/** response of ListFactors, which should contain all the types of factors that are available, this ensures we always include all */\nexport type AuthMFAListFactorsResponse<T extends typeof FactorTypes = typeof FactorTypes> =\n RequestResult<\n {\n /** All available factors (verified and unverified). */\n all: Prettify<Factor>[]\n\n // Dynamically create a property for each factor type with only verified factors\n } & {\n [K in T[number]]: Prettify<Factor<K, 'verified'>>[]\n }\n >\n\nexport type AuthenticatorAssuranceLevels = 'aal1' | 'aal2'\n\nexport type AuthMFAGetAuthenticatorAssuranceLevelResponse = RequestResult<{\n /** Current AAL level of the session. */\n currentLevel: AuthenticatorAssuranceLevels | null\n\n /**\n * Next possible AAL level for the session. If the next level is higher\n * than the current one, the user should go through MFA.\n *\n * @see {@link GoTrueMFAApi#challenge}\n */\n nextLevel: AuthenticatorAssuranceLevels | null\n\n /**\n * A list of all authentication methods attached to this session. Use\n * the information here to detect the last time a user verified a\n * factor, for example if implementing a step-up scenario.\n *\n * Supports both RFC-8176 compliant format (string[]) and detailed format (AMREntry[]).\n * - String format: ['password', 'otp'] - RFC-8176 compliant\n * - Object format: [{ method: 'password', timestamp: 1234567890 }] - includes timestamps\n */\n currentAuthenticationMethods: AMREntry[] | string[]\n}>\n\n/**\n * Contains the full multi-factor authentication API.\n *\n */\nexport interface GoTrueMFAApi {\n /**\n * Starts the enrollment process for a new Multi-Factor Authentication (MFA)\n * factor. This method creates a new `unverified` factor.\n * To verify a factor, present the QR code or secret to the user and ask them to add it to their\n * authenticator app.\n * The user has to enter the code from their authenticator app to verify it.\n *\n * Upon verifying a factor, all other sessions are logged out and the current session's authenticator level is promoted to `aal2`.\n */\n enroll(params: MFAEnrollTOTPParams): Promise<AuthMFAEnrollTOTPResponse>\n enroll(params: MFAEnrollPhoneParams): Promise<AuthMFAEnrollPhoneResponse>\n enroll(params: MFAEnrollWebauthnParams): Promise<AuthMFAEnrollWebauthnResponse>\n enroll(params: MFAEnrollParams): Promise<AuthMFAEnrollResponse>\n\n /**\n * Prepares a challenge used to verify that a user has access to a MFA\n * factor.\n */\n challenge(params: MFAChallengeTOTPParams): Promise<Prettify<AuthMFAChallengeTOTPResponse>>\n challenge(params: MFAChallengePhoneParams): Promise<Prettify<AuthMFAChallengePhoneResponse>>\n challenge(params: MFAChallengeWebauthnParams): Promise<Prettify<AuthMFAChallengeWebauthnResponse>>\n challenge(params: MFAChallengeParams): Promise<AuthMFAChallengeResponse>\n\n /**\n * Verifies a code against a challenge. The verification code is\n * provided by the user by entering a code seen in their authenticator app.\n */\n verify(params: MFAVerifyTOTPParams): Promise<AuthMFAVerifyResponse>\n verify(params: MFAVerifyPhoneParams): Promise<AuthMFAVerifyResponse>\n verify(params: MFAVerifyWebauthnParams): Promise<AuthMFAVerifyResponse>\n verify(params: MFAVerifyParams): Promise<AuthMFAVerifyResponse>\n\n /**\n * Unenroll removes a MFA factor.\n * A user has to have an `aal2` authenticator level in order to unenroll a `verified` factor.\n */\n unenroll(params: MFAUnenrollParams): Promise<AuthMFAUnenrollResponse>\n\n /**\n * Helper method which creates a challenge and immediately uses the given code to verify against it thereafter. The verification code is\n * provided by the user by entering a code seen in their authenticator app.\n */\n challengeAndVerify(params: MFAChallengeAndVerifyParams): Promise<AuthMFAVerifyResponse>\n\n /**\n * Returns the list of MFA factors enabled for this user.\n *\n * @see {@link GoTrueMFAApi#enroll}\n * @see {@link GoTrueMFAApi#getAuthenticatorAssuranceLevel}\n * @see {@link GoTrueClient#getUser}\n *\n */\n listFactors(): Promise<AuthMFAListFactorsResponse>\n\n /**\n * Returns the Authenticator Assurance Level (AAL) for the active session.\n *\n * - `aal1` (or `null`) means that the user's identity has been verified only\n * with a conventional login (email+password, OTP, magic link, social login,\n * etc.).\n * - `aal2` means that the user's identity has been verified both with a conventional login and at least one MFA factor.\n *\n * Although this method returns a promise, it's fairly quick (microseconds)\n * and rarely uses the network. You can use this to check whether the current\n * user needs to be shown a screen to verify their MFA factors.\n *\n */\n getAuthenticatorAssuranceLevel(): Promise<AuthMFAGetAuthenticatorAssuranceLevelResponse>\n\n // namespace for the webauthn methods\n webauthn: WebAuthnApi\n}\n\n/**\n * @expermental\n */\nexport type AuthMFAAdminDeleteFactorResponse = RequestResult<{\n /** ID of the factor that was successfully deleted. */\n id: string\n}>\n/**\n * @expermental\n */\nexport type AuthMFAAdminDeleteFactorParams = {\n /** ID of the MFA factor to delete. */\n id: string\n\n /** ID of the user whose factor is being deleted. */\n userId: string\n}\n\n/**\n * @expermental\n */\nexport type AuthMFAAdminListFactorsResponse = RequestResult<{\n /** All factors attached to the user. */\n factors: Factor[]\n}>\n\n/**\n * @expermental\n */\nexport type AuthMFAAdminListFactorsParams = {\n /** ID of the user. */\n userId: string\n}\n\n/**\n * Contains the full multi-factor authentication administration API.\n *\n * @expermental\n */\nexport interface GoTrueAdminMFAApi {\n /**\n * Lists all factors associated to a user.\n *\n */\n listFactors(params: AuthMFAAdminListFactorsParams): Promise<AuthMFAAdminListFactorsResponse>\n\n /**\n * Deletes a factor on a user. This will log the user out of all active\n * sessions if the deleted factor was verified.\n *\n * @see {@link GoTrueMFAApi#unenroll}\n *\n * @expermental\n */\n deleteFactor(params: AuthMFAAdminDeleteFactorParams): Promise<AuthMFAAdminDeleteFactorResponse>\n}\n\ntype AnyFunction = (...args: any[]) => any\ntype MaybePromisify<T> = T | Promise<T>\n\ntype PromisifyMethods<T> = {\n [K in keyof T]: T[K] extends AnyFunction\n ? (...args: Parameters<T[K]>) => MaybePromisify<ReturnType<T[K]>>\n : T[K]\n}\n\nexport type SupportedStorage = PromisifyMethods<\n Pick<Storage, 'getItem' | 'setItem' | 'removeItem'>\n> & {\n /**\n * If set to `true` signals to the library that the storage medium is used\n * on a server and the values may not be authentic, such as reading from\n * request cookies. Implementations should not set this to true if the client\n * is used on a server that reads storage information from authenticated\n * sources, such as a secure database or file.\n */\n isServer?: boolean\n}\n\nexport type InitializeResult = { error: AuthError | null }\n\nexport type CallRefreshTokenResult = RequestResult<Session>\n\nexport type Pagination = {\n [key: string]: any\n nextPage: number | null\n lastPage: number\n total: number\n}\n\nexport type PageParams = {\n /** The page number */\n page?: number\n /** Number of items returned per page */\n perPage?: number\n}\n\nexport type SignOut = {\n /**\n * Determines which sessions should be\n * logged out. Global means all\n * sessions by this account. Local\n * means only this session. Others\n * means all other sessions except the\n * current one. When using others,\n * there is no sign-out event fired on\n * the current session!\n */\n scope?: 'global' | 'local' | 'others'\n}\n\ntype MFAEnrollParamsBase<T extends FactorType> = {\n /** The type of factor being enrolled. */\n factorType: T\n /** Human readable name assigned to the factor. */\n friendlyName?: string\n}\n\ntype MFAEnrollTOTPParamFields = {\n /** Domain which the user is enrolled with. */\n issuer?: string\n}\n\nexport type MFAEnrollTOTPParams = Prettify<MFAEnrollParamsBase<'totp'> & MFAEnrollTOTPParamFields>\n\ntype MFAEnrollPhoneParamFields = {\n /** Phone number associated with a factor. Number should conform to E.164 format */\n phone: string\n}\nexport type MFAEnrollPhoneParams = Prettify<\n MFAEnrollParamsBase<'phone'> & MFAEnrollPhoneParamFields\n>\n\ntype MFAEnrollWebauthnFields = {\n /** no extra fields for now, kept for consistency and for possible future changes */\n}\n\n/**\n * Parameters for enrolling a WebAuthn factor.\n * Creates an unverified WebAuthn factor that must be verified with a credential.\n * @see {@link https://w3c.github.io/webauthn/#sctn-registering-a-new-credential W3C WebAuthn Spec - Registering a New Credential}\n */\nexport type MFAEnrollWebauthnParams = Prettify<\n MFAEnrollParamsBase<'webauthn'> & MFAEnrollWebauthnFields\n>\n\ntype AuthMFAEnrollResponseBase<T extends FactorType> = {\n /** ID of the factor that was just enrolled (in an unverified state). */\n id: string\n\n /** Type of MFA factor.*/\n type: T\n\n /** Friendly name of the factor, useful for distinguishing between factors **/\n friendly_name?: string\n}\n\ntype AuthMFAEnrollTOTPResponseFields = {\n /** TOTP enrollment information. */\n totp: {\n /** Contains a QR code encoding the authenticator URI. You can\n * convert it to a URL by prepending `data:image/svg+xml;utf-8,` to\n * the value. Avoid logging this value to the console. */\n qr_code: string\n\n /** The TOTP secret (also encoded in the QR code). Show this secret\n * in a password-style field to the user, in case they are unable to\n * scan the QR code. Avoid logging this value to the console. */\n secret: string\n\n /** The authenticator URI encoded within the QR code, should you need\n * to use it. Avoid loggin this value to the console. */\n uri: string\n }\n}\n\nexport type AuthMFAEnrollTOTPResponse = RequestResult<\n Prettify<AuthMFAEnrollResponseBase<'totp'> & AuthMFAEnrollTOTPResponseFields>\n>\n\ntype AuthMFAEnrollPhoneResponseFields = {\n /** Phone number of the MFA factor in E.164 format. Used to send messages */\n phone: string\n}\n\nexport type AuthMFAEnrollPhoneResponse = RequestResult<\n Prettify<AuthMFAEnrollResponseBase<'phone'> & AuthMFAEnrollPhoneResponseFields>\n>\n\ntype AuthMFAEnrollWebauthnFields = {\n /** no extra fields for now, kept for consistency and for possible future changes */\n}\n\n/**\n * Response type for WebAuthn factor enrollment.\n * Returns the enrolled factor ID and metadata.\n * @see {@link https://w3c.github.io/webauthn/#sctn-registering-a-new-credential W3C WebAuthn Spec - Registering a New Credential}\n */\nexport type AuthMFAEnrollWebauthnResponse = RequestResult<\n Prettify<AuthMFAEnrollResponseBase<'webauthn'> & AuthMFAEnrollWebauthnFields>\n>\n\nexport type JwtHeader = {\n alg: 'RS256' | 'ES256' | 'HS256'\n kid: string\n typ: string\n}\n\nexport type RequiredClaims = {\n iss: string\n sub: string\n aud: string | string[]\n exp: number\n iat: number\n role: string\n aal: AuthenticatorAssuranceLevels\n session_id: string\n}\n\n/**\n * JWT Payload containing claims for Supabase authentication tokens.\n *\n * Required claims (iss, aud, exp, iat, sub, role, aal, session_id) are inherited from RequiredClaims.\n * All other claims are optional as they can be customized via Custom Access Token Hooks.\n *\n * @see https://supabase.com/docs/guides/auth/jwt-fields\n */\nexport interface JwtPayload extends RequiredClaims {\n // Standard optional claims (can be customized via custom access token hooks)\n email?: string\n phone?: string\n is_anonymous?: boolean\n\n // Optional claims\n jti?: string\n nbf?: number\n app_metadata?: UserAppMetadata\n user_metadata?: UserMetadata\n /**\n * Authentication Method References.\n * Supports both RFC-8176 compliant format (string[]) and detailed format (AMREntry[]).\n * - String format: ['password', 'otp'] - RFC-8176 compliant\n * - Object format: [{ method: 'password', timestamp: 1234567890 }] - includes timestamps\n */\n amr?: AMREntry[] | string[]\n\n // Special claims (only in anon/service role tokens)\n ref?: string\n\n // Allow custom claims via custom access token hooks\n [key: string]: any\n}\n\nexport interface JWK {\n kty: 'RSA' | 'EC' | 'oct'\n key_ops: string[]\n alg?: string\n kid?: string\n [key: string]: any\n}\n\nexport const SIGN_OUT_SCOPES = ['global', 'local', 'others'] as const\nexport type SignOutScope = (typeof SIGN_OUT_SCOPES)[number]\n\n/**\n * OAuth client grant types supported by the OAuth 2.1 server.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthClientGrantType = 'authorization_code' | 'refresh_token'\n\n/**\n * OAuth client response types supported by the OAuth 2.1 server.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthClientResponseType = 'code'\n\n/**\n * OAuth client type indicating whether the client can keep credentials confidential.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthClientType = 'public' | 'confidential'\n\n/**\n * OAuth client registration type.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthClientRegistrationType = 'dynamic' | 'manual'\n\n/**\n * OAuth client object returned from the OAuth 2.1 server.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthClient = {\n /** Unique identifier for the OAuth client */\n client_id: string\n /** Human-readable name of the OAuth client */\n client_name: string\n /** Client secret (only returned on registration and regeneration) */\n client_secret?: string\n /** Type of OAuth client */\n client_type: OAuthClientType\n /** Token endpoint authentication method */\n token_endpoint_auth_method: string\n /** Registration type of the client */\n registration_type: OAuthClientRegistrationType\n /** URI of the OAuth client */\n client_uri?: string\n /** URI of the OAuth client's logo */\n logo_uri?: string\n /** Array of allowed redirect URIs */\n redirect_uris: string[]\n /** Array of allowed grant types */\n grant_types: OAuthClientGrantType[]\n /** Array of allowed response types */\n response_types: OAuthClientResponseType[]\n /** Scope of the OAuth client */\n scope?: string\n /** Timestamp when the client was created */\n created_at: string\n /** Timestamp when the client was last updated */\n updated_at: string\n}\n\n/**\n * Parameters for creating a new OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type CreateOAuthClientParams = {\n /** Human-readable name of the OAuth client */\n client_name: string\n /** URI of the OAuth client */\n client_uri?: string\n /** Array of allowed redirect URIs */\n redirect_uris: string[]\n /** Array of allowed grant types (optional, defaults to authorization_code and refresh_token) */\n grant_types?: OAuthClientGrantType[]\n /** Array of allowed response types (optional, defaults to code) */\n response_types?: OAuthClientResponseType[]\n /** Scope of the OAuth client */\n scope?: string\n}\n\n/**\n * Parameters for updating an existing OAuth client.\n * All fields are optional. Only provided fields will be updated.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type UpdateOAuthClientParams = {\n /** Human-readable name of the OAuth client */\n client_name?: string\n /** URI of the OAuth client */\n client_uri?: string\n /** URI of the OAuth client's logo */\n logo_uri?: string\n /** Array of allowed redirect URIs */\n redirect_uris?: string[]\n /** Array of allowed grant types */\n grant_types?: OAuthClientGrantType[]\n}\n\n/**\n * Response type for OAuth client operations.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthClientResponse = RequestResult<OAuthClient>\n\n/**\n * Response type for listing OAuth clients.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthClientListResponse =\n | {\n data: { clients: OAuthClient[]; aud: string } & Pagination\n error: null\n }\n | {\n data: { clients: [] }\n error: AuthError\n }\n\n/**\n * Contains all OAuth client administration methods.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport interface GoTrueAdminOAuthApi {\n /**\n * Lists all OAuth clients with optional pagination.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n listClients(params?: PageParams): Promise<OAuthClientListResponse>\n\n /**\n * Creates a new OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n createClient(params: CreateOAuthClientParams): Promise<OAuthClientResponse>\n\n /**\n * Gets details of a specific OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n getClient(clientId: string): Promise<OAuthClientResponse>\n\n /**\n * Updates an existing OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n updateClient(clientId: string, params: UpdateOAuthClientParams): Promise<OAuthClientResponse>\n\n /**\n * Deletes an OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n deleteClient(clientId: string): Promise<{ data: null; error: AuthError | null }>\n\n /**\n * Regenerates the secret for an OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n regenerateClientSecret(clientId: string): Promise<OAuthClientResponse>\n}\n\n/**\n * OAuth client details in an authorization request.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthAuthorizationClient = {\n /** Unique identifier for the OAuth client (UUID) */\n id: string\n /** Human-readable name of the OAuth client */\n name: string\n /** URI of the OAuth client's website */\n uri: string\n /** URI of the OAuth client's logo */\n logo_uri: string\n}\n\n/**\n * OAuth authorization details for the consent flow.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthAuthorizationDetails = {\n /** The authorization ID */\n authorization_id: string\n /** Redirect URL - present if user already consented (can be used to trigger immediate redirect) */\n redirect_url?: string\n /** OAuth client requesting authorization */\n client: OAuthAuthorizationClient\n /** User object associated with the authorization */\n user: {\n /** User ID (UUID) */\n id: string\n /** User email */\n email: string\n }\n /** Space-separated list of requested scopes */\n scope: string\n}\n\n/**\n * Response type for getting OAuth authorization details.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type AuthOAuthAuthorizationDetailsResponse = RequestResult<OAuthAuthorizationDetails>\n\n/**\n * Response type for OAuth consent decision (approve/deny).\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type AuthOAuthConsentResponse = RequestResult<{\n /** URL to redirect the user back to the OAuth client */\n redirect_url: string\n}>\n\n/**\n * An OAuth grant representing a user's authorization of an OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type OAuthGrant = {\n /** OAuth client information */\n client: OAuthAuthorizationClient\n /** Array of scopes granted to this client */\n scopes: string[]\n /** Timestamp when the grant was created (ISO 8601 date-time) */\n granted_at: string\n}\n\n/**\n * Response type for listing user's OAuth grants.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type AuthOAuthGrantsResponse = RequestResult<OAuthGrant[]>\n\n/**\n * Response type for revoking an OAuth grant.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\nexport type AuthOAuthRevokeGrantResponse = RequestResult<{}>\n\n/**\n * Contains all OAuth 2.1 authorization server user-facing methods.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * These methods are used to implement the consent page.\n */\nexport interface AuthOAuthServerApi {\n /**\n * Retrieves details about an OAuth authorization request.\n * Used to display consent information to the user.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This method returns authorization details including client info, scopes, and user information.\n * If the response includes a redirect_uri, it means consent was already given - the caller\n * should handle the redirect manually if needed.\n *\n * @param authorizationId - The authorization ID from the authorization request\n * @returns Authorization details including client info and requested scopes\n */\n getAuthorizationDetails(authorizationId: string): Promise<AuthOAuthAuthorizationDetailsResponse>\n\n /**\n * Approves an OAuth authorization request.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * @param authorizationId - The authorization ID to approve\n * @param options - Optional parameters including skipBrowserRedirect\n * @returns Redirect URL to send the user back to the OAuth client\n */\n approveAuthorization(\n authorizationId: string,\n options?: { skipBrowserRedirect?: boolean }\n ): Promise<AuthOAuthConsentResponse>\n\n /**\n * Denies an OAuth authorization request.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * @param authorizationId - The authorization ID to deny\n * @param options - Optional parameters including skipBrowserRedirect\n * @returns Redirect URL to send the user back to the OAuth client\n */\n denyAuthorization(\n authorizationId: string,\n options?: { skipBrowserRedirect?: boolean }\n ): Promise<AuthOAuthConsentResponse>\n\n /**\n * Lists all OAuth grants that the authenticated user has authorized.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * @returns Response with array of OAuth grants with client information and granted scopes\n */\n listGrants(): Promise<AuthOAuthGrantsResponse>\n\n /**\n * Revokes a user's OAuth grant for a specific client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * Revocation marks consent as revoked, deletes active sessions for that OAuth client,\n * and invalidates associated refresh tokens.\n *\n * @param options - Revocation options\n * @param options.clientId - The OAuth client identifier (UUID) to revoke access for\n * @returns Empty response on successful revocation\n */\n revokeGrant(options: { clientId: string }): Promise<AuthOAuthRevokeGrantResponse>\n}\n","import {\n Fetch,\n _generateLinkResponse,\n _noResolveJsonResponse,\n _request,\n _userResponse,\n} from './lib/fetch'\nimport { resolveFetch, validateUUID } from './lib/helpers'\nimport {\n AdminUserAttributes,\n GenerateLinkParams,\n GenerateLinkResponse,\n Pagination,\n User,\n UserResponse,\n GoTrueAdminMFAApi,\n AuthMFAAdminDeleteFactorParams,\n AuthMFAAdminDeleteFactorResponse,\n AuthMFAAdminListFactorsParams,\n AuthMFAAdminListFactorsResponse,\n PageParams,\n SIGN_OUT_SCOPES,\n SignOutScope,\n GoTrueAdminOAuthApi,\n CreateOAuthClientParams,\n UpdateOAuthClientParams,\n OAuthClientResponse,\n OAuthClientListResponse,\n} from './lib/types'\nimport { AuthError, isAuthError } from './lib/errors'\n\nexport default class GoTrueAdminApi {\n /** Contains all MFA administration methods. */\n mfa: GoTrueAdminMFAApi\n\n /**\n * Contains all OAuth client administration methods.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\n oauth: GoTrueAdminOAuthApi\n\n protected url: string\n protected headers: {\n [key: string]: string\n }\n protected fetch: Fetch\n\n /**\n * Creates an admin API client that can be used to manage users and OAuth clients.\n *\n * @example\n * ```ts\n * import { GoTrueAdminApi } from '@supabase/auth-js'\n *\n * const admin = new GoTrueAdminApi({\n * url: 'https://xyzcompany.supabase.co/auth/v1',\n * headers: { Authorization: `Bearer ${process.env.SUPABASE_SERVICE_ROLE_KEY}` },\n * })\n * ```\n */\n constructor({\n url = '',\n headers = {},\n fetch,\n }: {\n url: string\n headers?: {\n [key: string]: string\n }\n fetch?: Fetch\n }) {\n this.url = url\n this.headers = headers\n this.fetch = resolveFetch(fetch)\n this.mfa = {\n listFactors: this._listFactors.bind(this),\n deleteFactor: this._deleteFactor.bind(this),\n }\n this.oauth = {\n listClients: this._listOAuthClients.bind(this),\n createClient: this._createOAuthClient.bind(this),\n getClient: this._getOAuthClient.bind(this),\n updateClient: this._updateOAuthClient.bind(this),\n deleteClient: this._deleteOAuthClient.bind(this),\n regenerateClientSecret: this._regenerateOAuthClientSecret.bind(this),\n }\n }\n\n /**\n * Removes a logged-in session.\n * @param jwt A valid, logged-in JWT.\n * @param scope The logout sope.\n */\n async signOut(\n jwt: string,\n scope: SignOutScope = SIGN_OUT_SCOPES[0]\n ): Promise<{ data: null; error: AuthError | null }> {\n if (SIGN_OUT_SCOPES.indexOf(scope) < 0) {\n throw new Error(\n `@supabase/auth-js: Parameter scope must be one of ${SIGN_OUT_SCOPES.join(', ')}`\n )\n }\n\n try {\n await _request(this.fetch, 'POST', `${this.url}/logout?scope=${scope}`, {\n headers: this.headers,\n jwt,\n noResolveJson: true,\n })\n return { data: null, error: null }\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Sends an invite link to an email address.\n * @param email The email address of the user.\n * @param options Additional options to be included when inviting.\n */\n async inviteUserByEmail(\n email: string,\n options: {\n /** A custom data object to store additional metadata about the user. This maps to the `auth.users.user_metadata` column. */\n data?: object\n\n /** The URL which will be appended to the email link sent to the user's email address. Once clicked the user will end up on this URL. */\n redirectTo?: string\n } = {}\n ): Promise<UserResponse> {\n try {\n return await _request(this.fetch, 'POST', `${this.url}/invite`, {\n body: { email, data: options.data },\n headers: this.headers,\n redirectTo: options.redirectTo,\n xform: _userResponse,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: { user: null }, error }\n }\n\n throw error\n }\n }\n\n /**\n * Generates email links and OTPs to be sent via a custom email provider.\n * @param email The user's email.\n * @param options.password User password. For signup only.\n * @param options.data Optional user metadata. For signup only.\n * @param options.redirectTo The redirect url which should be appended to the generated link\n */\n async generateLink(params: GenerateLinkParams): Promise<GenerateLinkResponse> {\n try {\n const { options, ...rest } = params\n const body: any = { ...rest, ...options }\n if ('newEmail' in rest) {\n // replace newEmail with new_email in request body\n body.new_email = rest?.newEmail\n delete body['newEmail']\n }\n return await _request(this.fetch, 'POST', `${this.url}/admin/generate_link`, {\n body: body,\n headers: this.headers,\n xform: _generateLinkResponse,\n redirectTo: options?.redirectTo,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return {\n data: {\n properties: null,\n user: null,\n },\n error,\n }\n }\n throw error\n }\n }\n\n // User Admin API\n /**\n * Creates a new user.\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n async createUser(attributes: AdminUserAttributes): Promise<UserResponse> {\n try {\n return await _request(this.fetch, 'POST', `${this.url}/admin/users`, {\n body: attributes,\n headers: this.headers,\n xform: _userResponse,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: { user: null }, error }\n }\n\n throw error\n }\n }\n\n /**\n * Get a list of users.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n * @param params An object which supports `page` and `perPage` as numbers, to alter the paginated results.\n */\n async listUsers(\n params?: PageParams\n ): Promise<\n | { data: { users: User[]; aud: string } & Pagination; error: null }\n | { data: { users: [] }; error: AuthError }\n > {\n try {\n const pagination: Pagination = { nextPage: null, lastPage: 0, total: 0 }\n const response = await _request(this.fetch, 'GET', `${this.url}/admin/users`, {\n headers: this.headers,\n noResolveJson: true,\n query: {\n page: params?.page?.toString() ?? '',\n per_page: params?.perPage?.toString() ?? '',\n },\n xform: _noResolveJsonResponse,\n })\n if (response.error) throw response.error\n\n const users = await response.json()\n const total = response.headers.get('x-total-count') ?? 0\n const links = response.headers.get('link')?.split(',') ?? []\n if (links.length > 0) {\n links.forEach((link: string) => {\n const page = parseInt(link.split(';')[0].split('=')[1].substring(0, 1))\n const rel = JSON.parse(link.split(';')[1].split('=')[1])\n pagination[`${rel}Page`] = page\n })\n\n pagination.total = parseInt(total)\n }\n return { data: { ...users, ...pagination }, error: null }\n } catch (error) {\n if (isAuthError(error)) {\n return { data: { users: [] }, error }\n }\n throw error\n }\n }\n\n /**\n * Get user by id.\n *\n * @param uid The user's unique identifier\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n async getUserById(uid: string): Promise<UserResponse> {\n validateUUID(uid)\n\n try {\n return await _request(this.fetch, 'GET', `${this.url}/admin/users/${uid}`, {\n headers: this.headers,\n xform: _userResponse,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: { user: null }, error }\n }\n\n throw error\n }\n }\n\n /**\n * Updates the user data.\n *\n * @param attributes The data you want to update.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n async updateUserById(uid: string, attributes: AdminUserAttributes): Promise<UserResponse> {\n validateUUID(uid)\n\n try {\n return await _request(this.fetch, 'PUT', `${this.url}/admin/users/${uid}`, {\n body: attributes,\n headers: this.headers,\n xform: _userResponse,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: { user: null }, error }\n }\n\n throw error\n }\n }\n\n /**\n * Delete a user. Requires a `service_role` key.\n *\n * @param id The user id you want to remove.\n * @param shouldSoftDelete If true, then the user will be soft-deleted from the auth schema. Soft deletion allows user identification from the hashed user ID but is not reversible.\n * Defaults to false for backward compatibility.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n async deleteUser(id: string, shouldSoftDelete = false): Promise<UserResponse> {\n validateUUID(id)\n\n try {\n return await _request(this.fetch, 'DELETE', `${this.url}/admin/users/${id}`, {\n headers: this.headers,\n body: {\n should_soft_delete: shouldSoftDelete,\n },\n xform: _userResponse,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: { user: null }, error }\n }\n\n throw error\n }\n }\n\n private async _listFactors(\n params: AuthMFAAdminListFactorsParams\n ): Promise<AuthMFAAdminListFactorsResponse> {\n validateUUID(params.userId)\n\n try {\n const { data, error } = await _request(\n this.fetch,\n 'GET',\n `${this.url}/admin/users/${params.userId}/factors`,\n {\n headers: this.headers,\n xform: (factors: any) => {\n return { data: { factors }, error: null }\n },\n }\n )\n return { data, error }\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n private async _deleteFactor(\n params: AuthMFAAdminDeleteFactorParams\n ): Promise<AuthMFAAdminDeleteFactorResponse> {\n validateUUID(params.userId)\n validateUUID(params.id)\n\n try {\n const data = await _request(\n this.fetch,\n 'DELETE',\n `${this.url}/admin/users/${params.userId}/factors/${params.id}`,\n {\n headers: this.headers,\n }\n )\n\n return { data, error: null }\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Lists all OAuth clients with optional pagination.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n private async _listOAuthClients(params?: PageParams): Promise<OAuthClientListResponse> {\n try {\n const pagination: Pagination = { nextPage: null, lastPage: 0, total: 0 }\n const response = await _request(this.fetch, 'GET', `${this.url}/admin/oauth/clients`, {\n headers: this.headers,\n noResolveJson: true,\n query: {\n page: params?.page?.toString() ?? '',\n per_page: params?.perPage?.toString() ?? '',\n },\n xform: _noResolveJsonResponse,\n })\n if (response.error) throw response.error\n\n const clients = await response.json()\n const total = response.headers.get('x-total-count') ?? 0\n const links = response.headers.get('link')?.split(',') ?? []\n if (links.length > 0) {\n links.forEach((link: string) => {\n const page = parseInt(link.split(';')[0].split('=')[1].substring(0, 1))\n const rel = JSON.parse(link.split(';')[1].split('=')[1])\n pagination[`${rel}Page`] = page\n })\n\n pagination.total = parseInt(total)\n }\n return { data: { ...clients, ...pagination }, error: null }\n } catch (error) {\n if (isAuthError(error)) {\n return { data: { clients: [] }, error }\n }\n throw error\n }\n }\n\n /**\n * Creates a new OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n private async _createOAuthClient(params: CreateOAuthClientParams): Promise<OAuthClientResponse> {\n try {\n return await _request(this.fetch, 'POST', `${this.url}/admin/oauth/clients`, {\n body: params,\n headers: this.headers,\n xform: (client: any) => {\n return { data: client, error: null }\n },\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Gets details of a specific OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n private async _getOAuthClient(clientId: string): Promise<OAuthClientResponse> {\n try {\n return await _request(this.fetch, 'GET', `${this.url}/admin/oauth/clients/${clientId}`, {\n headers: this.headers,\n xform: (client: any) => {\n return { data: client, error: null }\n },\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Updates an existing OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n private async _updateOAuthClient(\n clientId: string,\n params: UpdateOAuthClientParams\n ): Promise<OAuthClientResponse> {\n try {\n return await _request(this.fetch, 'PUT', `${this.url}/admin/oauth/clients/${clientId}`, {\n body: params,\n headers: this.headers,\n xform: (client: any) => {\n return { data: client, error: null }\n },\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Deletes an OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n private async _deleteOAuthClient(\n clientId: string\n ): Promise<{ data: null; error: AuthError | null }> {\n try {\n await _request(this.fetch, 'DELETE', `${this.url}/admin/oauth/clients/${clientId}`, {\n headers: this.headers,\n noResolveJson: true,\n })\n return { data: null, error: null }\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n\n /**\n * Regenerates the secret for an OAuth client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * This function should only be called on a server. Never expose your `service_role` key in the browser.\n */\n private async _regenerateOAuthClientSecret(clientId: string): Promise<OAuthClientResponse> {\n try {\n return await _request(\n this.fetch,\n 'POST',\n `${this.url}/admin/oauth/clients/${clientId}/regenerate_secret`,\n {\n headers: this.headers,\n xform: (client: any) => {\n return { data: client, error: null }\n },\n }\n )\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n\n throw error\n }\n }\n}\n","import { SupportedStorage } from './types'\n\n/**\n * Returns a localStorage-like object that stores the key-value pairs in\n * memory.\n */\nexport function memoryLocalStorageAdapter(store: { [key: string]: string } = {}): SupportedStorage {\n return {\n getItem: (key) => {\n return store[key] || null\n },\n\n setItem: (key, value) => {\n store[key] = value\n },\n\n removeItem: (key) => {\n delete store[key]\n },\n }\n}\n","import { supportsLocalStorage } from './helpers'\n\n/**\n * @experimental\n */\nexport const internals = {\n /**\n * @experimental\n */\n debug: !!(\n globalThis &&\n supportsLocalStorage() &&\n globalThis.localStorage &&\n globalThis.localStorage.getItem('supabase.gotrue-js.locks.debug') === 'true'\n ),\n}\n\n/**\n * An error thrown when a lock cannot be acquired after some amount of time.\n *\n * Use the {@link #isAcquireTimeout} property instead of checking with `instanceof`.\n *\n * @example\n * ```ts\n * import { LockAcquireTimeoutError } from '@supabase/auth-js'\n *\n * class CustomLockError extends LockAcquireTimeoutError {\n * constructor() {\n * super('Lock timed out')\n * }\n * }\n * ```\n */\nexport abstract class LockAcquireTimeoutError extends Error {\n public readonly isAcquireTimeout = true\n\n constructor(message: string) {\n super(message)\n }\n}\n\n/**\n * Error thrown when the browser Navigator Lock API fails to acquire a lock.\n *\n * @example\n * ```ts\n * import { NavigatorLockAcquireTimeoutError } from '@supabase/auth-js'\n *\n * throw new NavigatorLockAcquireTimeoutError('Lock timed out')\n * ```\n */\nexport class NavigatorLockAcquireTimeoutError extends LockAcquireTimeoutError {}\n/**\n * Error thrown when the process-level lock helper cannot acquire a lock.\n *\n * @example\n * ```ts\n * import { ProcessLockAcquireTimeoutError } from '@supabase/auth-js'\n *\n * throw new ProcessLockAcquireTimeoutError('Lock timed out')\n * ```\n */\nexport class ProcessLockAcquireTimeoutError extends LockAcquireTimeoutError {}\n\n/**\n * Implements a global exclusive lock using the Navigator LockManager API. It\n * is available on all browsers released after 2022-03-15 with Safari being the\n * last one to release support. If the API is not available, this function will\n * throw. Make sure you check availablility before configuring {@link\n * GoTrueClient}.\n *\n * You can turn on debugging by setting the `supabase.gotrue-js.locks.debug`\n * local storage item to `true`.\n *\n * Internals:\n *\n * Since the LockManager API does not preserve stack traces for the async\n * function passed in the `request` method, a trick is used where acquiring the\n * lock releases a previously started promise to run the operation in the `fn`\n * function. The lock waits for that promise to finish (with or without error),\n * while the function will finally wait for the result anyway.\n *\n * @param name Name of the lock to be acquired.\n * @param acquireTimeout If negative, no timeout. If 0 an error is thrown if\n * the lock can't be acquired without waiting. If positive, the lock acquire\n * will time out after so many milliseconds. An error is\n * a timeout if it has `isAcquireTimeout` set to true.\n * @param fn The operation to run once the lock is acquired.\n * @example\n * ```ts\n * await navigatorLock('sync-user', 1000, async () => {\n * await refreshSession()\n * })\n * ```\n */\nexport async function navigatorLock<R>(\n name: string,\n acquireTimeout: number,\n fn: () => Promise<R>\n): Promise<R> {\n if (internals.debug) {\n console.log('@supabase/gotrue-js: navigatorLock: acquire lock', name, acquireTimeout)\n }\n\n const abortController = new globalThis.AbortController()\n\n if (acquireTimeout > 0) {\n setTimeout(() => {\n abortController.abort()\n if (internals.debug) {\n console.log('@supabase/gotrue-js: navigatorLock acquire timed out', name)\n }\n }, acquireTimeout)\n }\n\n // MDN article: https://developer.mozilla.org/en-US/docs/Web/API/LockManager/request\n\n // Wrapping navigator.locks.request() with a plain Promise is done as some\n // libraries like zone.js patch the Promise object to track the execution\n // context. However, it appears that most browsers use an internal promise\n // implementation when using the navigator.locks.request() API causing them\n // to lose context and emit confusing log messages or break certain features.\n // This wrapping is believed to help zone.js track the execution context\n // better.\n return await Promise.resolve().then(() =>\n globalThis.navigator.locks.request(\n name,\n acquireTimeout === 0\n ? {\n mode: 'exclusive',\n ifAvailable: true,\n }\n : {\n mode: 'exclusive',\n signal: abortController.signal,\n },\n async (lock) => {\n if (lock) {\n if (internals.debug) {\n console.log('@supabase/gotrue-js: navigatorLock: acquired', name, lock.name)\n }\n\n try {\n return await fn()\n } finally {\n if (internals.debug) {\n console.log('@supabase/gotrue-js: navigatorLock: released', name, lock.name)\n }\n }\n } else {\n if (acquireTimeout === 0) {\n if (internals.debug) {\n console.log('@supabase/gotrue-js: navigatorLock: not immediately available', name)\n }\n\n throw new NavigatorLockAcquireTimeoutError(\n `Acquiring an exclusive Navigator LockManager lock \"${name}\" immediately failed`\n )\n } else {\n if (internals.debug) {\n try {\n const result = await globalThis.navigator.locks.query()\n\n console.log(\n '@supabase/gotrue-js: Navigator LockManager state',\n JSON.stringify(result, null, ' ')\n )\n } catch (e: any) {\n console.warn(\n '@supabase/gotrue-js: Error when querying Navigator LockManager state',\n e\n )\n }\n }\n\n // Browser is not following the Navigator LockManager spec, it\n // returned a null lock when we didn't use ifAvailable. So we can\n // pretend the lock is acquired in the name of backward compatibility\n // and user experience and just run the function.\n console.warn(\n '@supabase/gotrue-js: Navigator LockManager returned a null lock when using #request without ifAvailable set to true, it appears this browser is not following the LockManager spec https://developer.mozilla.org/en-US/docs/Web/API/LockManager/request'\n )\n\n return await fn()\n }\n }\n }\n )\n )\n}\n\nconst PROCESS_LOCKS: { [name: string]: Promise<any> } = {}\n\n/**\n * Implements a global exclusive lock that works only in the current process.\n * Useful for environments like React Native or other non-browser\n * single-process (i.e. no concept of \"tabs\") environments.\n *\n * Use {@link #navigatorLock} in browser environments.\n *\n * @param name Name of the lock to be acquired.\n * @param acquireTimeout If negative, no timeout. If 0 an error is thrown if\n * the lock can't be acquired without waiting. If positive, the lock acquire\n * will time out after so many milliseconds. An error is\n * a timeout if it has `isAcquireTimeout` set to true.\n * @param fn The operation to run once the lock is acquired.\n * @example\n * ```ts\n * await processLock('migrate', 5000, async () => {\n * await runMigration()\n * })\n * ```\n */\nexport async function processLock<R>(\n name: string,\n acquireTimeout: number,\n fn: () => Promise<R>\n): Promise<R> {\n const previousOperation = PROCESS_LOCKS[name] ?? Promise.resolve()\n\n const currentOperation = Promise.race(\n [\n previousOperation.catch(() => {\n // ignore error of previous operation that we're waiting to finish\n return null\n }),\n acquireTimeout >= 0\n ? new Promise((_, reject) => {\n setTimeout(() => {\n console.warn(\n `@supabase/gotrue-js: Lock \"${name}\" acquisition timed out after ${acquireTimeout}ms. ` +\n 'This may be caused by another operation holding the lock. ' +\n 'Consider increasing lockAcquireTimeout or checking for stuck operations.'\n )\n\n reject(\n new ProcessLockAcquireTimeoutError(\n `Acquiring process lock with name \"${name}\" timed out`\n )\n )\n }, acquireTimeout)\n })\n : null,\n ].filter((x) => x)\n )\n .catch((e: any) => {\n if (e && e.isAcquireTimeout) {\n throw e\n }\n\n return null\n })\n .then(async () => {\n // previous operations finished and we didn't get a race on the acquire\n // timeout, so the current operation can finally start\n return await fn()\n })\n\n PROCESS_LOCKS[name] = currentOperation.catch(async (e: any) => {\n if (e && e.isAcquireTimeout) {\n // if the current operation timed out, it doesn't mean that the previous\n // operation finished, so we need contnue waiting for it to finish\n await previousOperation\n\n return null\n }\n\n throw e\n })\n\n // finally wait for the current operation to finish successfully, with an\n // error or with an acquire timeout error\n return await currentOperation\n}\n","/**\n * https://mathiasbynens.be/notes/globalthis\n */\nexport function polyfillGlobalThis() {\n if (typeof globalThis === 'object') return\n try {\n Object.defineProperty(Object.prototype, '__magic__', {\n get: function () {\n return this\n },\n configurable: true,\n })\n // @ts-expect-error 'Allow access to magic'\n __magic__.globalThis = __magic__\n // @ts-expect-error 'Allow access to magic'\n delete Object.prototype.__magic__\n } catch (e) {\n if (typeof self !== 'undefined') {\n // @ts-expect-error 'Allow access to globals'\n self.globalThis = self\n }\n }\n}\n","// types and functions copied over from viem so this library doesn't depend on it\n\nexport type Hex = `0x${string}`\n\nexport type Address = Hex\n\nexport type EIP1193EventMap = {\n accountsChanged(accounts: Address[]): void\n chainChanged(chainId: string): void\n connect(connectInfo: { chainId: string }): void\n disconnect(error: { code: number; message: string }): void\n message(message: { type: string; data: unknown }): void\n}\n\nexport type EIP1193Events = {\n on<event extends keyof EIP1193EventMap>(event: event, listener: EIP1193EventMap[event]): void\n removeListener<event extends keyof EIP1193EventMap>(\n event: event,\n listener: EIP1193EventMap[event]\n ): void\n}\n\nexport type EIP1193RequestFn = (args: { method: string; params?: unknown }) => Promise<unknown>\n\nexport type EIP1193Provider = EIP1193Events & {\n address: string\n request: EIP1193RequestFn\n}\n\nexport type EthereumWallet = EIP1193Provider\n\n/**\n * EIP-4361 message fields\n */\nexport type SiweMessage = {\n /**\n * The Ethereum address performing the signing.\n */\n address: Address\n /**\n * The [EIP-155](https://eips.ethereum.org/EIPS/eip-155) Chain ID to which the session is bound,\n */\n chainId: number\n /**\n * [RFC 3986](https://www.rfc-editor.org/rfc/rfc3986) authority that is requesting the signing.\n */\n domain: string\n /**\n * Time when the signed authentication message is no longer valid.\n */\n expirationTime?: Date | undefined\n /**\n * Time when the message was generated, typically the current time.\n */\n issuedAt?: Date | undefined\n /**\n * A random string typically chosen by the relying party and used to prevent replay attacks.\n */\n nonce?: string\n /**\n * Time when the signed authentication message will become valid.\n */\n notBefore?: Date | undefined\n /**\n * A system-specific identifier that may be used to uniquely refer to the sign-in request.\n */\n requestId?: string | undefined\n /**\n * A list of information or references to information the user wishes to have resolved as part of authentication by the relying party.\n */\n resources?: string[] | undefined\n /**\n * [RFC 3986](https://www.rfc-editor.org/rfc/rfc3986#section-3.1) URI scheme of the origin of the request.\n */\n scheme?: string | undefined\n /**\n * A human-readable ASCII assertion that the user will sign.\n */\n statement?: string | undefined\n /**\n * [RFC 3986](https://www.rfc-editor.org/rfc/rfc3986) URI referring to the resource that is the subject of the signing (as in the subject of a claim).\n */\n uri: string\n /**\n * The current version of the SIWE Message.\n */\n version: '1'\n}\n\nexport type EthereumSignInInput = SiweMessage\n\nexport function getAddress(address: string): Address {\n if (!/^0x[a-fA-F0-9]{40}$/.test(address)) {\n throw new Error(`@supabase/auth-js: Address \"${address}\" is invalid.`)\n }\n return address.toLowerCase() as Address\n}\n\nexport function fromHex(hex: Hex): number {\n return parseInt(hex, 16)\n}\n\nexport function toHex(value: string): Hex {\n const bytes = new TextEncoder().encode(value)\n const hex = Array.from(bytes, (byte) => byte.toString(16).padStart(2, '0')).join('')\n return ('0x' + hex) as Hex\n}\n\n/**\n * Creates EIP-4361 formatted message.\n */\nexport function createSiweMessage(parameters: SiweMessage): string {\n const {\n chainId,\n domain,\n expirationTime,\n issuedAt = new Date(),\n nonce,\n notBefore,\n requestId,\n resources,\n scheme,\n uri,\n version,\n } = parameters\n\n // Validate fields\n {\n if (!Number.isInteger(chainId))\n throw new Error(\n `@supabase/auth-js: Invalid SIWE message field \"chainId\". Chain ID must be a EIP-155 chain ID. Provided value: ${chainId}`\n )\n\n if (!domain)\n throw new Error(\n `@supabase/auth-js: Invalid SIWE message field \"domain\". Domain must be provided.`\n )\n\n if (nonce && nonce.length < 8)\n throw new Error(\n `@supabase/auth-js: Invalid SIWE message field \"nonce\". Nonce must be at least 8 characters. Provided value: ${nonce}`\n )\n\n if (!uri)\n throw new Error(`@supabase/auth-js: Invalid SIWE message field \"uri\". URI must be provided.`)\n\n if (version !== '1')\n throw new Error(\n `@supabase/auth-js: Invalid SIWE message field \"version\". Version must be '1'. Provided value: ${version}`\n )\n\n if (parameters.statement?.includes('\\n'))\n throw new Error(\n `@supabase/auth-js: Invalid SIWE message field \"statement\". Statement must not include '\\\\n'. Provided value: ${parameters.statement}`\n )\n }\n\n // Construct message\n const address = getAddress(parameters.address)\n const origin = scheme ? `${scheme}://${domain}` : domain\n const statement = parameters.statement ? `${parameters.statement}\\n` : ''\n const prefix = `${origin} wants you to sign in with your Ethereum account:\\n${address}\\n\\n${statement}`\n\n let suffix = `URI: ${uri}\\nVersion: ${version}\\nChain ID: ${chainId}${\n nonce ? `\\nNonce: ${nonce}` : ''\n }\\nIssued At: ${issuedAt.toISOString()}`\n\n if (expirationTime) suffix += `\\nExpiration Time: ${expirationTime.toISOString()}`\n if (notBefore) suffix += `\\nNot Before: ${notBefore.toISOString()}`\n if (requestId) suffix += `\\nRequest ID: ${requestId}`\n if (resources) {\n let content = '\\nResources:'\n for (const resource of resources) {\n if (!resource || typeof resource !== 'string')\n throw new Error(\n `@supabase/auth-js: Invalid SIWE message field \"resources\". Every resource must be a valid string. Provided value: ${resource}`\n )\n content += `\\n- ${resource}`\n }\n suffix += content\n }\n\n return `${prefix}\\n${suffix}`\n}\n","/* eslint-disable @typescript-eslint/ban-ts-comment */\n\nimport { StrictOmit } from './types'\nimport { isValidDomain } from './webauthn'\nimport {\n PublicKeyCredentialCreationOptionsFuture,\n PublicKeyCredentialRequestOptionsFuture,\n} from './webauthn.dom'\n\n/**\n * A custom Error used to return a more nuanced error detailing _why_ one of the eight documented\n * errors in the spec was raised after calling `navigator.credentials.create()` or\n * `navigator.credentials.get()`:\n *\n * - `AbortError`\n * - `ConstraintError`\n * - `InvalidStateError`\n * - `NotAllowedError`\n * - `NotSupportedError`\n * - `SecurityError`\n * - `TypeError`\n * - `UnknownError`\n *\n * Error messages were determined through investigation of the spec to determine under which\n * scenarios a given error would be raised.\n */\nexport class WebAuthnError extends Error {\n code: WebAuthnErrorCode\n\n protected __isWebAuthnError = true\n\n constructor({\n message,\n code,\n cause,\n name,\n }: {\n message: string\n code: WebAuthnErrorCode\n cause?: Error | unknown\n name?: string\n }) {\n // @ts-ignore: help Rollup understand that `cause` is okay to set\n super(message, { cause })\n this.name = name ?? (cause instanceof Error ? cause.name : undefined) ?? 'Unknown Error'\n this.code = code\n }\n}\n\n/**\n * Error class for unknown WebAuthn errors.\n * Wraps unexpected errors that don't match known WebAuthn error conditions.\n */\nexport class WebAuthnUnknownError extends WebAuthnError {\n originalError: unknown\n\n constructor(message: string, originalError: unknown) {\n super({\n code: 'ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY',\n cause: originalError,\n message,\n })\n this.name = 'WebAuthnUnknownError'\n this.originalError = originalError\n }\n}\n\n/**\n * Type guard to check if an error is a WebAuthnError.\n * @param {unknown} error - The error to check\n * @returns {boolean} True if the error is a WebAuthnError\n */\nexport function isWebAuthnError(error: unknown): error is WebAuthnError {\n return typeof error === 'object' && error !== null && '__isWebAuthnError' in error\n}\n\n/**\n * Error codes for WebAuthn operations.\n * These codes provide specific information about why a WebAuthn ceremony failed.\n * @see {@link https://w3c.github.io/webauthn/#sctn-defined-errors W3C WebAuthn Spec - Defined Errors}\n */\nexport type WebAuthnErrorCode =\n | 'ERROR_CEREMONY_ABORTED'\n | 'ERROR_INVALID_DOMAIN'\n | 'ERROR_INVALID_RP_ID'\n | 'ERROR_INVALID_USER_ID_LENGTH'\n | 'ERROR_MALFORMED_PUBKEYCREDPARAMS'\n | 'ERROR_AUTHENTICATOR_GENERAL_ERROR'\n | 'ERROR_AUTHENTICATOR_MISSING_DISCOVERABLE_CREDENTIAL_SUPPORT'\n | 'ERROR_AUTHENTICATOR_MISSING_USER_VERIFICATION_SUPPORT'\n | 'ERROR_AUTHENTICATOR_PREVIOUSLY_REGISTERED'\n | 'ERROR_AUTHENTICATOR_NO_SUPPORTED_PUBKEYCREDPARAMS_ALG'\n | 'ERROR_AUTO_REGISTER_USER_VERIFICATION_FAILURE'\n | 'ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY'\n\n/**\n * Attempt to intuit _why_ an error was raised after calling `navigator.credentials.create()`.\n * Maps browser errors to specific WebAuthn error codes for better debugging.\n * @param {Object} params - Error identification parameters\n * @param {Error} params.error - The error thrown by the browser\n * @param {CredentialCreationOptions} params.options - The options passed to credentials.create()\n * @returns {WebAuthnError} A WebAuthnError with a specific error code\n * @see {@link https://w3c.github.io/webauthn/#sctn-createCredential W3C WebAuthn Spec - Create Credential}\n */\nexport function identifyRegistrationError({\n error,\n options,\n}: {\n error: Error\n options: StrictOmit<CredentialCreationOptions, 'publicKey'> & {\n publicKey: PublicKeyCredentialCreationOptionsFuture\n }\n}): WebAuthnError {\n const { publicKey } = options\n\n if (!publicKey) {\n throw Error('options was missing required publicKey property')\n }\n\n if (error.name === 'AbortError') {\n if (options.signal instanceof AbortSignal) {\n // https://www.w3.org/TR/webauthn-2/#sctn-createCredential (Step 16)\n return new WebAuthnError({\n message: 'Registration ceremony was sent an abort signal',\n code: 'ERROR_CEREMONY_ABORTED',\n cause: error,\n })\n }\n } else if (error.name === 'ConstraintError') {\n if (publicKey.authenticatorSelection?.requireResidentKey === true) {\n // https://www.w3.org/TR/webauthn-2/#sctn-op-make-cred (Step 4)\n return new WebAuthnError({\n message:\n 'Discoverable credentials were required but no available authenticator supported it',\n code: 'ERROR_AUTHENTICATOR_MISSING_DISCOVERABLE_CREDENTIAL_SUPPORT',\n cause: error,\n })\n } else if (\n // @ts-ignore: `mediation` doesn't yet exist on CredentialCreationOptions but it's possible as of Sept 2024\n options.mediation === 'conditional' &&\n publicKey.authenticatorSelection?.userVerification === 'required'\n ) {\n // https://w3c.github.io/webauthn/#sctn-createCredential (Step 22.4)\n return new WebAuthnError({\n message:\n 'User verification was required during automatic registration but it could not be performed',\n code: 'ERROR_AUTO_REGISTER_USER_VERIFICATION_FAILURE',\n cause: error,\n })\n } else if (publicKey.authenticatorSelection?.userVerification === 'required') {\n // https://www.w3.org/TR/webauthn-2/#sctn-op-make-cred (Step 5)\n return new WebAuthnError({\n message: 'User verification was required but no available authenticator supported it',\n code: 'ERROR_AUTHENTICATOR_MISSING_USER_VERIFICATION_SUPPORT',\n cause: error,\n })\n }\n } else if (error.name === 'InvalidStateError') {\n // https://www.w3.org/TR/webauthn-2/#sctn-createCredential (Step 20)\n // https://www.w3.org/TR/webauthn-2/#sctn-op-make-cred (Step 3)\n return new WebAuthnError({\n message: 'The authenticator was previously registered',\n code: 'ERROR_AUTHENTICATOR_PREVIOUSLY_REGISTERED',\n cause: error,\n })\n } else if (error.name === 'NotAllowedError') {\n /**\n * Pass the error directly through. Platforms are overloading this error beyond what the spec\n * defines and we don't want to overwrite potentially useful error messages.\n */\n return new WebAuthnError({\n message: error.message,\n code: 'ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY',\n cause: error,\n })\n } else if (error.name === 'NotSupportedError') {\n const validPubKeyCredParams = publicKey.pubKeyCredParams.filter(\n (param) => param.type === 'public-key'\n )\n\n if (validPubKeyCredParams.length === 0) {\n // https://www.w3.org/TR/webauthn-2/#sctn-createCredential (Step 10)\n return new WebAuthnError({\n message: 'No entry in pubKeyCredParams was of type \"public-key\"',\n code: 'ERROR_MALFORMED_PUBKEYCREDPARAMS',\n cause: error,\n })\n }\n\n // https://www.w3.org/TR/webauthn-2/#sctn-op-make-cred (Step 2)\n return new WebAuthnError({\n message:\n 'No available authenticator supported any of the specified pubKeyCredParams algorithms',\n code: 'ERROR_AUTHENTICATOR_NO_SUPPORTED_PUBKEYCREDPARAMS_ALG',\n cause: error,\n })\n } else if (error.name === 'SecurityError') {\n const effectiveDomain = window.location.hostname\n if (!isValidDomain(effectiveDomain)) {\n // https://www.w3.org/TR/webauthn-2/#sctn-createCredential (Step 7)\n return new WebAuthnError({\n message: `${window.location.hostname} is an invalid domain`,\n code: 'ERROR_INVALID_DOMAIN',\n cause: error,\n })\n } else if (publicKey.rp.id !== effectiveDomain) {\n // https://www.w3.org/TR/webauthn-2/#sctn-createCredential (Step 8)\n return new WebAuthnError({\n message: `The RP ID \"${publicKey.rp.id}\" is invalid for this domain`,\n code: 'ERROR_INVALID_RP_ID',\n cause: error,\n })\n }\n } else if (error.name === 'TypeError') {\n if (publicKey.user.id.byteLength < 1 || publicKey.user.id.byteLength > 64) {\n // https://www.w3.org/TR/webauthn-2/#sctn-createCredential (Step 5)\n return new WebAuthnError({\n message: 'User ID was not between 1 and 64 characters',\n code: 'ERROR_INVALID_USER_ID_LENGTH',\n cause: error,\n })\n }\n } else if (error.name === 'UnknownError') {\n // https://www.w3.org/TR/webauthn-2/#sctn-op-make-cred (Step 1)\n // https://www.w3.org/TR/webauthn-2/#sctn-op-make-cred (Step 8)\n return new WebAuthnError({\n message:\n 'The authenticator was unable to process the specified options, or could not create a new credential',\n code: 'ERROR_AUTHENTICATOR_GENERAL_ERROR',\n cause: error,\n })\n }\n\n return new WebAuthnError({\n message: 'a Non-Webauthn related error has occurred',\n code: 'ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY',\n cause: error,\n })\n}\n\n/**\n * Attempt to intuit _why_ an error was raised after calling `navigator.credentials.get()`.\n * Maps browser errors to specific WebAuthn error codes for better debugging.\n * @param {Object} params - Error identification parameters\n * @param {Error} params.error - The error thrown by the browser\n * @param {CredentialRequestOptions} params.options - The options passed to credentials.get()\n * @returns {WebAuthnError} A WebAuthnError with a specific error code\n * @see {@link https://w3c.github.io/webauthn/#sctn-getAssertion W3C WebAuthn Spec - Get Assertion}\n */\nexport function identifyAuthenticationError({\n error,\n options,\n}: {\n error: Error\n options: StrictOmit<CredentialRequestOptions, 'publicKey'> & {\n publicKey: PublicKeyCredentialRequestOptionsFuture\n }\n}): WebAuthnError {\n const { publicKey } = options\n\n if (!publicKey) {\n throw Error('options was missing required publicKey property')\n }\n\n if (error.name === 'AbortError') {\n if (options.signal instanceof AbortSignal) {\n // https://www.w3.org/TR/webauthn-2/#sctn-createCredential (Step 16)\n return new WebAuthnError({\n message: 'Authentication ceremony was sent an abort signal',\n code: 'ERROR_CEREMONY_ABORTED',\n cause: error,\n })\n }\n } else if (error.name === 'NotAllowedError') {\n /**\n * Pass the error directly through. Platforms are overloading this error beyond what the spec\n * defines and we don't want to overwrite potentially useful error messages.\n */\n return new WebAuthnError({\n message: error.message,\n code: 'ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY',\n cause: error,\n })\n } else if (error.name === 'SecurityError') {\n const effectiveDomain = window.location.hostname\n if (!isValidDomain(effectiveDomain)) {\n // https://www.w3.org/TR/webauthn-2/#sctn-discover-from-external-source (Step 5)\n return new WebAuthnError({\n message: `${window.location.hostname} is an invalid domain`,\n code: 'ERROR_INVALID_DOMAIN',\n cause: error,\n })\n } else if (publicKey.rpId !== effectiveDomain) {\n // https://www.w3.org/TR/webauthn-2/#sctn-discover-from-external-source (Step 6)\n return new WebAuthnError({\n message: `The RP ID \"${publicKey.rpId}\" is invalid for this domain`,\n code: 'ERROR_INVALID_RP_ID',\n cause: error,\n })\n }\n } else if (error.name === 'UnknownError') {\n // https://www.w3.org/TR/webauthn-2/#sctn-op-get-assertion (Step 1)\n // https://www.w3.org/TR/webauthn-2/#sctn-op-get-assertion (Step 12)\n return new WebAuthnError({\n message:\n 'The authenticator was unable to process the specified options, or could not create a new assertion signature',\n code: 'ERROR_AUTHENTICATOR_GENERAL_ERROR',\n cause: error,\n })\n }\n\n return new WebAuthnError({\n message: 'a Non-Webauthn related error has occurred',\n code: 'ERROR_PASSTHROUGH_SEE_CAUSE_PROPERTY',\n cause: error,\n })\n}\n","import GoTrueClient from '../GoTrueClient'\nimport { base64UrlToUint8Array, bytesToBase64URL } from './base64url'\nimport { AuthError, AuthUnknownError, isAuthError } from './errors'\nimport {\n AuthMFAEnrollWebauthnResponse,\n AuthMFAVerifyResponse,\n AuthMFAVerifyResponseData,\n MFAChallengeWebauthnParams,\n MFAEnrollWebauthnParams,\n MFAVerifyWebauthnParamFields,\n MFAVerifyWebauthnParams,\n RequestResult,\n StrictOmit,\n} from './types'\nimport { isBrowser } from './helpers'\nimport type {\n AuthenticationCredential,\n AuthenticationResponseJSON,\n AuthenticatorAttachment,\n PublicKeyCredentialCreationOptionsFuture,\n PublicKeyCredentialCreationOptionsJSON,\n PublicKeyCredentialFuture,\n PublicKeyCredentialRequestOptionsFuture,\n PublicKeyCredentialRequestOptionsJSON,\n RegistrationCredential,\n RegistrationResponseJSON,\n} from './webauthn.dom'\n\nimport {\n identifyAuthenticationError,\n identifyRegistrationError,\n isWebAuthnError,\n WebAuthnError,\n WebAuthnUnknownError,\n} from './webauthn.errors'\n\nexport { WebAuthnError, isWebAuthnError, identifyRegistrationError, identifyAuthenticationError }\n// Re-export the JSON types for use in other files\nexport type { RegistrationResponseJSON, AuthenticationResponseJSON }\n\n/**\n * WebAuthn abort service to manage ceremony cancellation.\n * Ensures only one WebAuthn ceremony is active at a time to prevent \"operation already in progress\" errors.\n *\n * @experimental This class is experimental and may change in future releases\n * @see {@link https://w3c.github.io/webauthn/#sctn-automation-webdriver-capability W3C WebAuthn Spec - Aborting Ceremonies}\n */\nexport class WebAuthnAbortService {\n private controller: AbortController | undefined\n\n /**\n * Create an abort signal for a new WebAuthn operation.\n * Automatically cancels any existing operation.\n *\n * @returns {AbortSignal} Signal to pass to navigator.credentials.create() or .get()\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/AbortSignal MDN - AbortSignal}\n */\n createNewAbortSignal(): AbortSignal {\n // Abort any existing calls to navigator.credentials.create() or navigator.credentials.get()\n if (this.controller) {\n const abortError = new Error('Cancelling existing WebAuthn API call for new one')\n abortError.name = 'AbortError'\n this.controller.abort(abortError)\n }\n\n const newController = new AbortController()\n this.controller = newController\n return newController.signal\n }\n\n /**\n * Manually cancel the current WebAuthn operation.\n * Useful for cleaning up when user cancels or navigates away.\n *\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/AbortController/abort MDN - AbortController.abort}\n */\n cancelCeremony(): void {\n if (this.controller) {\n const abortError = new Error('Manually cancelling existing WebAuthn API call')\n abortError.name = 'AbortError'\n this.controller.abort(abortError)\n this.controller = undefined\n }\n }\n}\n\n/**\n * Singleton instance to ensure only one WebAuthn ceremony is active at a time.\n * This prevents \"operation already in progress\" errors when retrying WebAuthn operations.\n *\n * @experimental This instance is experimental and may change in future releases\n */\nexport const webAuthnAbortService = new WebAuthnAbortService()\n\n/**\n * Server response format for WebAuthn credential creation options.\n * Uses W3C standard JSON format with base64url-encoded binary fields.\n */\nexport type ServerCredentialCreationOptions = PublicKeyCredentialCreationOptionsJSON\n\n/**\n * Server response format for WebAuthn credential request options.\n * Uses W3C standard JSON format with base64url-encoded binary fields.\n */\nexport type ServerCredentialRequestOptions = PublicKeyCredentialRequestOptionsJSON\n\n/**\n * Convert base64url encoded strings in WebAuthn credential creation options to ArrayBuffers\n * as required by the WebAuthn browser API.\n * Supports both native WebAuthn Level 3 parseCreationOptionsFromJSON and manual fallback.\n *\n * @param {ServerCredentialCreationOptions} options - JSON options from server with base64url encoded fields\n * @returns {PublicKeyCredentialCreationOptionsFuture} Options ready for navigator.credentials.create()\n * @see {@link https://w3c.github.io/webauthn/#sctn-parseCreationOptionsFromJSON W3C WebAuthn Spec - parseCreationOptionsFromJSON}\n */\nexport function deserializeCredentialCreationOptions(\n options: ServerCredentialCreationOptions\n): PublicKeyCredentialCreationOptionsFuture {\n if (!options) {\n throw new Error('Credential creation options are required')\n }\n\n // Check if the native parseCreationOptionsFromJSON method is available\n if (\n typeof PublicKeyCredential !== 'undefined' &&\n 'parseCreationOptionsFromJSON' in PublicKeyCredential &&\n typeof (PublicKeyCredential as unknown as PublicKeyCredentialFuture)\n .parseCreationOptionsFromJSON === 'function'\n ) {\n // Use the native WebAuthn Level 3 method\n return (\n PublicKeyCredential as unknown as PublicKeyCredentialFuture\n ).parseCreationOptionsFromJSON(\n /** we assert the options here as typescript still doesn't know about future webauthn types */\n options as any\n ) as PublicKeyCredentialCreationOptionsFuture\n }\n\n // Fallback to manual parsing for browsers that don't support the native method\n // Destructure to separate fields that need transformation\n const { challenge: challengeStr, user: userOpts, excludeCredentials, ...restOptions } = options\n\n // Convert challenge from base64url to ArrayBuffer\n const challenge = base64UrlToUint8Array(challengeStr).buffer as ArrayBuffer\n\n // Convert user.id from base64url to ArrayBuffer\n const user: PublicKeyCredentialUserEntity = {\n ...userOpts,\n id: base64UrlToUint8Array(userOpts.id).buffer as ArrayBuffer,\n }\n\n // Build the result object\n const result: PublicKeyCredentialCreationOptionsFuture = {\n ...restOptions,\n challenge,\n user,\n }\n\n // Only add excludeCredentials if it exists\n if (excludeCredentials && excludeCredentials.length > 0) {\n result.excludeCredentials = new Array(excludeCredentials.length)\n\n for (let i = 0; i < excludeCredentials.length; i++) {\n const cred = excludeCredentials[i]\n result.excludeCredentials[i] = {\n ...cred,\n id: base64UrlToUint8Array(cred.id).buffer,\n type: cred.type || 'public-key',\n // Cast transports to handle future transport types like \"cable\"\n transports: cred.transports,\n }\n }\n }\n\n return result\n}\n\n/**\n * Convert base64url encoded strings in WebAuthn credential request options to ArrayBuffers\n * as required by the WebAuthn browser API.\n * Supports both native WebAuthn Level 3 parseRequestOptionsFromJSON and manual fallback.\n *\n * @param {ServerCredentialRequestOptions} options - JSON options from server with base64url encoded fields\n * @returns {PublicKeyCredentialRequestOptionsFuture} Options ready for navigator.credentials.get()\n * @see {@link https://w3c.github.io/webauthn/#sctn-parseRequestOptionsFromJSON W3C WebAuthn Spec - parseRequestOptionsFromJSON}\n */\nexport function deserializeCredentialRequestOptions(\n options: ServerCredentialRequestOptions\n): PublicKeyCredentialRequestOptionsFuture {\n if (!options) {\n throw new Error('Credential request options are required')\n }\n\n // Check if the native parseRequestOptionsFromJSON method is available\n if (\n typeof PublicKeyCredential !== 'undefined' &&\n 'parseRequestOptionsFromJSON' in PublicKeyCredential &&\n typeof (PublicKeyCredential as unknown as PublicKeyCredentialFuture)\n .parseRequestOptionsFromJSON === 'function'\n ) {\n // Use the native WebAuthn Level 3 method\n return (\n PublicKeyCredential as unknown as PublicKeyCredentialFuture\n ).parseRequestOptionsFromJSON(options) as PublicKeyCredentialRequestOptionsFuture\n }\n\n // Fallback to manual parsing for browsers that don't support the native method\n // Destructure to separate fields that need transformation\n const { challenge: challengeStr, allowCredentials, ...restOptions } = options\n\n // Convert challenge from base64url to ArrayBuffer\n const challenge = base64UrlToUint8Array(challengeStr).buffer as ArrayBuffer\n\n // Build the result object\n const result: PublicKeyCredentialRequestOptionsFuture = {\n ...restOptions,\n challenge,\n }\n\n // Only add allowCredentials if it exists\n if (allowCredentials && allowCredentials.length > 0) {\n result.allowCredentials = new Array(allowCredentials.length)\n\n for (let i = 0; i < allowCredentials.length; i++) {\n const cred = allowCredentials[i]\n result.allowCredentials[i] = {\n ...cred,\n id: base64UrlToUint8Array(cred.id).buffer,\n type: cred.type || 'public-key',\n // Cast transports to handle future transport types like \"cable\"\n transports: cred.transports,\n }\n }\n }\n\n return result\n}\n\n/**\n * Server format for credential response with base64url-encoded binary fields\n * Can be either a registration or authentication response\n */\nexport type ServerCredentialResponse = RegistrationResponseJSON | AuthenticationResponseJSON\n\n/**\n * Convert a registration/enrollment credential response to server format.\n * Serializes binary fields to base64url for JSON transmission.\n * Supports both native WebAuthn Level 3 toJSON and manual fallback.\n *\n * @param {RegistrationCredential} credential - Credential from navigator.credentials.create()\n * @returns {RegistrationResponseJSON} JSON-serializable credential for server\n * @see {@link https://w3c.github.io/webauthn/#dom-publickeycredential-tojson W3C WebAuthn Spec - toJSON}\n */\nexport function serializeCredentialCreationResponse(\n credential: RegistrationCredential\n): RegistrationResponseJSON {\n // Check if the credential instance has the toJSON method\n if ('toJSON' in credential && typeof credential.toJSON === 'function') {\n // Use the native WebAuthn Level 3 method\n return (credential as RegistrationCredential).toJSON()\n }\n const credentialWithAttachment = credential as PublicKeyCredential & {\n response: AuthenticatorAttestationResponse\n authenticatorAttachment?: string | null\n }\n\n return {\n id: credential.id,\n rawId: credential.id,\n response: {\n attestationObject: bytesToBase64URL(new Uint8Array(credential.response.attestationObject)),\n clientDataJSON: bytesToBase64URL(new Uint8Array(credential.response.clientDataJSON)),\n },\n type: 'public-key',\n clientExtensionResults: credential.getClientExtensionResults(),\n // Convert null to undefined and cast to AuthenticatorAttachment type\n authenticatorAttachment: (credentialWithAttachment.authenticatorAttachment ?? undefined) as\n | AuthenticatorAttachment\n | undefined,\n }\n}\n\n/**\n * Convert an authentication/verification credential response to server format.\n * Serializes binary fields to base64url for JSON transmission.\n * Supports both native WebAuthn Level 3 toJSON and manual fallback.\n *\n * @param {AuthenticationCredential} credential - Credential from navigator.credentials.get()\n * @returns {AuthenticationResponseJSON} JSON-serializable credential for server\n * @see {@link https://w3c.github.io/webauthn/#dom-publickeycredential-tojson W3C WebAuthn Spec - toJSON}\n */\nexport function serializeCredentialRequestResponse(\n credential: AuthenticationCredential\n): AuthenticationResponseJSON {\n // Check if the credential instance has the toJSON method\n if ('toJSON' in credential && typeof credential.toJSON === 'function') {\n // Use the native WebAuthn Level 3 method\n return (credential as AuthenticationCredential).toJSON()\n }\n\n // Fallback to manual conversion for browsers that don't support toJSON\n // Access authenticatorAttachment via type assertion to handle TypeScript version differences\n // @simplewebauthn/types includes this property but base TypeScript 4.7.4 doesn't\n const credentialWithAttachment = credential as PublicKeyCredential & {\n response: AuthenticatorAssertionResponse\n authenticatorAttachment?: string | null\n }\n\n const clientExtensionResults = credential.getClientExtensionResults()\n const assertionResponse = credential.response\n\n return {\n id: credential.id,\n rawId: credential.id, // W3C spec expects rawId to match id for JSON format\n response: {\n authenticatorData: bytesToBase64URL(new Uint8Array(assertionResponse.authenticatorData)),\n clientDataJSON: bytesToBase64URL(new Uint8Array(assertionResponse.clientDataJSON)),\n signature: bytesToBase64URL(new Uint8Array(assertionResponse.signature)),\n userHandle: assertionResponse.userHandle\n ? bytesToBase64URL(new Uint8Array(assertionResponse.userHandle))\n : undefined,\n },\n type: 'public-key',\n clientExtensionResults,\n // Convert null to undefined and cast to AuthenticatorAttachment type\n authenticatorAttachment: (credentialWithAttachment.authenticatorAttachment ?? undefined) as\n | AuthenticatorAttachment\n | undefined,\n }\n}\n\n/**\n * A simple test to determine if a hostname is a properly-formatted domain name.\n * Considers localhost valid for development environments.\n *\n * A \"valid domain\" is defined here: https://url.spec.whatwg.org/#valid-domain\n *\n * Regex sourced from here:\n * https://www.oreilly.com/library/view/regular-expressions-cookbook/9781449327453/ch08s15.html\n *\n * @param {string} hostname - The hostname to validate\n * @returns {boolean} True if valid domain or localhost\n * @see {@link https://url.spec.whatwg.org/#valid-domain WHATWG URL Spec - Valid Domain}\n */\nexport function isValidDomain(hostname: string): boolean {\n return (\n // Consider localhost valid as well since it's okay wrt Secure Contexts\n hostname === 'localhost' || /^([a-z0-9]+(-[a-z0-9]+)*\\.)+[a-z]{2,}$/i.test(hostname)\n )\n}\n\n/**\n * Determine if the browser is capable of WebAuthn.\n * Checks for necessary Web APIs: PublicKeyCredential and Credential Management.\n *\n * @returns {boolean} True if browser supports WebAuthn\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/PublicKeyCredential#browser_compatibility MDN - PublicKeyCredential Browser Compatibility}\n */\nfunction browserSupportsWebAuthn(): boolean {\n return !!(\n isBrowser() &&\n 'PublicKeyCredential' in window &&\n window.PublicKeyCredential &&\n 'credentials' in navigator &&\n typeof navigator?.credentials?.create === 'function' &&\n typeof navigator?.credentials?.get === 'function'\n )\n}\n\n/**\n * Create a WebAuthn credential using the browser's credentials API.\n * Wraps navigator.credentials.create() with error handling.\n *\n * @param {CredentialCreationOptions} options - Options including publicKey parameters\n * @returns {Promise<RequestResult<RegistrationCredential, WebAuthnError>>} Created credential or error\n * @see {@link https://w3c.github.io/webauthn/#sctn-createCredential W3C WebAuthn Spec - Create Credential}\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/CredentialsContainer/create MDN - credentials.create}\n */\nexport async function createCredential(\n options: StrictOmit<CredentialCreationOptions, 'publicKey'> & {\n publicKey: PublicKeyCredentialCreationOptionsFuture\n }\n): Promise<RequestResult<RegistrationCredential, WebAuthnError>> {\n try {\n const response = await navigator.credentials.create(\n /** we assert the type here until typescript types are updated */\n options as Parameters<typeof navigator.credentials.create>[0]\n )\n if (!response) {\n return {\n data: null,\n error: new WebAuthnUnknownError('Empty credential response', response),\n }\n }\n if (!(response instanceof PublicKeyCredential)) {\n return {\n data: null,\n error: new WebAuthnUnknownError('Browser returned unexpected credential type', response),\n }\n }\n return { data: response as RegistrationCredential, error: null }\n } catch (err) {\n return {\n data: null,\n error: identifyRegistrationError({\n error: err as Error,\n options,\n }),\n }\n }\n}\n\n/**\n * Get a WebAuthn credential using the browser's credentials API.\n * Wraps navigator.credentials.get() with error handling.\n *\n * @param {CredentialRequestOptions} options - Options including publicKey parameters\n * @returns {Promise<RequestResult<AuthenticationCredential, WebAuthnError>>} Retrieved credential or error\n * @see {@link https://w3c.github.io/webauthn/#sctn-getAssertion W3C WebAuthn Spec - Get Assertion}\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/CredentialsContainer/get MDN - credentials.get}\n */\nexport async function getCredential(\n options: StrictOmit<CredentialRequestOptions, 'publicKey'> & {\n publicKey: PublicKeyCredentialRequestOptionsFuture\n }\n): Promise<RequestResult<AuthenticationCredential, WebAuthnError>> {\n try {\n const response = await navigator.credentials.get(\n /** we assert the type here until typescript types are updated */\n options as Parameters<typeof navigator.credentials.get>[0]\n )\n if (!response) {\n return {\n data: null,\n error: new WebAuthnUnknownError('Empty credential response', response),\n }\n }\n if (!(response instanceof PublicKeyCredential)) {\n return {\n data: null,\n error: new WebAuthnUnknownError('Browser returned unexpected credential type', response),\n }\n }\n return { data: response as AuthenticationCredential, error: null }\n } catch (err) {\n return {\n data: null,\n error: identifyAuthenticationError({\n error: err as Error,\n options,\n }),\n }\n }\n}\n\nexport const DEFAULT_CREATION_OPTIONS: Partial<PublicKeyCredentialCreationOptionsFuture> = {\n hints: ['security-key'],\n authenticatorSelection: {\n authenticatorAttachment: 'cross-platform',\n requireResidentKey: false,\n /** set to preferred because older yubikeys don't have PIN/Biometric */\n userVerification: 'preferred',\n residentKey: 'discouraged',\n },\n attestation: 'direct',\n}\n\nexport const DEFAULT_REQUEST_OPTIONS: Partial<PublicKeyCredentialRequestOptionsFuture> = {\n /** set to preferred because older yubikeys don't have PIN/Biometric */\n userVerification: 'preferred',\n hints: ['security-key'],\n attestation: 'direct',\n}\n\nfunction deepMerge<T>(...sources: Partial<T>[]): T {\n const isObject = (val: unknown): val is Record<string, unknown> =>\n val !== null && typeof val === 'object' && !Array.isArray(val)\n\n const isArrayBufferLike = (val: unknown): val is ArrayBuffer | ArrayBufferView =>\n val instanceof ArrayBuffer || ArrayBuffer.isView(val)\n\n const result: Partial<T> = {}\n\n for (const source of sources) {\n if (!source) continue\n\n for (const key in source) {\n const value = source[key]\n if (value === undefined) continue\n\n if (Array.isArray(value)) {\n // preserve array reference, including unions like AuthenticatorTransport[]\n result[key] = value as T[typeof key]\n } else if (isArrayBufferLike(value)) {\n result[key] = value as T[typeof key]\n } else if (isObject(value)) {\n const existing = result[key]\n if (isObject(existing)) {\n result[key] = deepMerge(existing, value) as unknown as T[typeof key]\n } else {\n result[key] = deepMerge(value) as unknown as T[typeof key]\n }\n } else {\n result[key] = value as T[typeof key]\n }\n }\n }\n\n return result as T\n}\n\n/**\n * Merges WebAuthn credential creation options with overrides.\n * Sets sensible defaults for authenticator selection and extensions.\n *\n * @param {PublicKeyCredentialCreationOptionsFuture} baseOptions - The base options from the server\n * @param {PublicKeyCredentialCreationOptionsFuture} overrides - Optional overrides to apply\n * @param {string} friendlyName - Optional friendly name for the credential\n * @returns {PublicKeyCredentialCreationOptionsFuture} Merged credential creation options\n * @see {@link https://w3c.github.io/webauthn/#dictdef-authenticatorselectioncriteria W3C WebAuthn Spec - AuthenticatorSelectionCriteria}\n */\nexport function mergeCredentialCreationOptions(\n baseOptions: PublicKeyCredentialCreationOptionsFuture,\n overrides?: Partial<PublicKeyCredentialCreationOptionsFuture>\n): PublicKeyCredentialCreationOptionsFuture {\n return deepMerge(DEFAULT_CREATION_OPTIONS, baseOptions, overrides || {})\n}\n\n/**\n * Merges WebAuthn credential request options with overrides.\n * Sets sensible defaults for user verification and hints.\n *\n * @param {PublicKeyCredentialRequestOptionsFuture} baseOptions - The base options from the server\n * @param {PublicKeyCredentialRequestOptionsFuture} overrides - Optional overrides to apply\n * @returns {PublicKeyCredentialRequestOptionsFuture} Merged credential request options\n * @see {@link https://w3c.github.io/webauthn/#dictdef-publickeycredentialrequestoptions W3C WebAuthn Spec - PublicKeyCredentialRequestOptions}\n */\nexport function mergeCredentialRequestOptions(\n baseOptions: PublicKeyCredentialRequestOptionsFuture,\n overrides?: Partial<PublicKeyCredentialRequestOptionsFuture>\n): PublicKeyCredentialRequestOptionsFuture {\n return deepMerge(DEFAULT_REQUEST_OPTIONS, baseOptions, overrides || {})\n}\n\n/**\n * WebAuthn API wrapper for Supabase Auth.\n * Provides methods for enrolling, challenging, verifying, authenticating, and registering WebAuthn credentials.\n *\n * @experimental This API is experimental and may change in future releases\n * @see {@link https://w3c.github.io/webauthn/ W3C WebAuthn Specification}\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_Authentication_API MDN - Web Authentication API}\n */\nexport class WebAuthnApi {\n public enroll: typeof WebAuthnApi.prototype._enroll\n public challenge: typeof WebAuthnApi.prototype._challenge\n public verify: typeof WebAuthnApi.prototype._verify\n public authenticate: typeof WebAuthnApi.prototype._authenticate\n public register: typeof WebAuthnApi.prototype._register\n\n constructor(private client: GoTrueClient) {\n // Bind all methods so they can be destructured\n this.enroll = this._enroll.bind(this)\n this.challenge = this._challenge.bind(this)\n this.verify = this._verify.bind(this)\n this.authenticate = this._authenticate.bind(this)\n this.register = this._register.bind(this)\n }\n\n /**\n * Enroll a new WebAuthn factor.\n * Creates an unverified WebAuthn factor that must be verified with a credential.\n *\n * @experimental This method is experimental and may change in future releases\n * @param {Omit<MFAEnrollWebauthnParams, 'factorType'>} params - Enrollment parameters (friendlyName required)\n * @returns {Promise<AuthMFAEnrollWebauthnResponse>} Enrolled factor details or error\n * @see {@link https://w3c.github.io/webauthn/#sctn-registering-a-new-credential W3C WebAuthn Spec - Registering a New Credential}\n */\n public async _enroll(\n params: Omit<MFAEnrollWebauthnParams, 'factorType'>\n ): Promise<AuthMFAEnrollWebauthnResponse> {\n return this.client.mfa.enroll({ ...params, factorType: 'webauthn' })\n }\n\n /**\n * Challenge for WebAuthn credential creation or authentication.\n * Combines server challenge with browser credential operations.\n * Handles both registration (create) and authentication (request) flows.\n *\n * @experimental This method is experimental and may change in future releases\n * @param {MFAChallengeWebauthnParams & { friendlyName?: string; signal?: AbortSignal }} params - Challenge parameters including factorId\n * @param {Object} overrides - Allows you to override the parameters passed to navigator.credentials\n * @param {PublicKeyCredentialCreationOptionsFuture} overrides.create - Override options for credential creation\n * @param {PublicKeyCredentialRequestOptionsFuture} overrides.request - Override options for credential request\n * @returns {Promise<RequestResult>} Challenge response with credential or error\n * @see {@link https://w3c.github.io/webauthn/#sctn-credential-creation W3C WebAuthn Spec - Credential Creation}\n * @see {@link https://w3c.github.io/webauthn/#sctn-verifying-assertion W3C WebAuthn Spec - Verifying Assertion}\n */\n public async _challenge(\n {\n factorId,\n webauthn,\n friendlyName,\n signal,\n }: MFAChallengeWebauthnParams & { friendlyName?: string; signal?: AbortSignal },\n overrides?:\n | {\n create?: Partial<PublicKeyCredentialCreationOptionsFuture>\n request?: never\n }\n | {\n create?: never\n request?: Partial<PublicKeyCredentialRequestOptionsFuture>\n }\n ): Promise<\n RequestResult<\n { factorId: string; challengeId: string } & {\n webauthn: StrictOmit<\n MFAVerifyWebauthnParamFields<'create' | 'request'>['webauthn'],\n 'rpId' | 'rpOrigins'\n >\n },\n WebAuthnError | AuthError\n >\n > {\n try {\n // Get challenge from server using the client's MFA methods\n const { data: challengeResponse, error: challengeError } = await this.client.mfa.challenge({\n factorId,\n webauthn,\n })\n\n if (!challengeResponse) {\n return { data: null, error: challengeError }\n }\n\n const abortSignal = signal ?? webAuthnAbortService.createNewAbortSignal()\n\n /** webauthn will fail if either of the name/displayname are blank */\n if (challengeResponse.webauthn.type === 'create') {\n const { user } = challengeResponse.webauthn.credential_options.publicKey\n if (!user.name) {\n user.name = `${user.id}:${friendlyName}`\n }\n if (!user.displayName) {\n user.displayName = user.name\n }\n }\n\n switch (challengeResponse.webauthn.type) {\n case 'create': {\n const options = mergeCredentialCreationOptions(\n challengeResponse.webauthn.credential_options.publicKey,\n overrides?.create\n )\n\n const { data, error } = await createCredential({\n publicKey: options,\n signal: abortSignal,\n })\n\n if (data) {\n return {\n data: {\n factorId,\n challengeId: challengeResponse.id,\n webauthn: {\n type: challengeResponse.webauthn.type,\n credential_response: data,\n },\n },\n error: null,\n }\n }\n return { data: null, error }\n }\n\n case 'request': {\n const options = mergeCredentialRequestOptions(\n challengeResponse.webauthn.credential_options.publicKey,\n overrides?.request\n )\n\n const { data, error } = await getCredential({\n ...challengeResponse.webauthn.credential_options,\n publicKey: options,\n signal: abortSignal,\n })\n\n if (data) {\n return {\n data: {\n factorId,\n challengeId: challengeResponse.id,\n webauthn: {\n type: challengeResponse.webauthn.type,\n credential_response: data,\n },\n },\n error: null,\n }\n }\n return { data: null, error }\n }\n }\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n return {\n data: null,\n error: new AuthUnknownError('Unexpected error in challenge', error),\n }\n }\n }\n\n /**\n * Verify a WebAuthn credential with the server.\n * Completes the WebAuthn ceremony by sending the credential to the server for verification.\n *\n * @experimental This method is experimental and may change in future releases\n * @param {Object} params - Verification parameters\n * @param {string} params.challengeId - ID of the challenge being verified\n * @param {string} params.factorId - ID of the WebAuthn factor\n * @param {MFAVerifyWebauthnParams<T>['webauthn']} params.webauthn - WebAuthn credential response\n * @returns {Promise<AuthMFAVerifyResponse>} Verification result with session or error\n * @see {@link https://w3c.github.io/webauthn/#sctn-verifying-assertion W3C WebAuthn Spec - Verifying an Authentication Assertion}\n * */\n public async _verify<T extends 'create' | 'request'>({\n challengeId,\n factorId,\n webauthn,\n }: {\n challengeId: string\n factorId: string\n webauthn: MFAVerifyWebauthnParams<T>['webauthn']\n }): Promise<AuthMFAVerifyResponse> {\n return this.client.mfa.verify({\n factorId,\n challengeId,\n webauthn: webauthn,\n })\n }\n\n /**\n * Complete WebAuthn authentication flow.\n * Performs challenge and verification in a single operation for existing credentials.\n *\n * @experimental This method is experimental and may change in future releases\n * @param {Object} params - Authentication parameters\n * @param {string} params.factorId - ID of the WebAuthn factor to authenticate with\n * @param {Object} params.webauthn - WebAuthn configuration\n * @param {string} params.webauthn.rpId - Relying Party ID (defaults to current hostname)\n * @param {string[]} params.webauthn.rpOrigins - Allowed origins (defaults to current origin)\n * @param {AbortSignal} params.webauthn.signal - Optional abort signal\n * @param {PublicKeyCredentialRequestOptionsFuture} overrides - Override options for navigator.credentials.get\n * @returns {Promise<RequestResult<AuthMFAVerifyResponseData, WebAuthnError | AuthError>>} Authentication result\n * @see {@link https://w3c.github.io/webauthn/#sctn-authentication W3C WebAuthn Spec - Authentication Ceremony}\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/PublicKeyCredentialRequestOptions MDN - PublicKeyCredentialRequestOptions}\n */\n public async _authenticate(\n {\n factorId,\n webauthn: {\n rpId = typeof window !== 'undefined' ? window.location.hostname : undefined,\n rpOrigins = typeof window !== 'undefined' ? [window.location.origin] : undefined,\n signal,\n } = {},\n }: {\n factorId: string\n webauthn?: {\n rpId?: string\n rpOrigins?: string[]\n signal?: AbortSignal\n }\n },\n overrides?: PublicKeyCredentialRequestOptionsFuture\n ): Promise<RequestResult<AuthMFAVerifyResponseData, WebAuthnError | AuthError>> {\n if (!rpId) {\n return {\n data: null,\n error: new AuthError('rpId is required for WebAuthn authentication'),\n }\n }\n try {\n if (!browserSupportsWebAuthn()) {\n return {\n data: null,\n error: new AuthUnknownError('Browser does not support WebAuthn', null),\n }\n }\n\n // Get challenge and credential\n const { data: challengeResponse, error: challengeError } = await this.challenge(\n {\n factorId,\n webauthn: { rpId, rpOrigins },\n signal,\n },\n { request: overrides }\n )\n\n if (!challengeResponse) {\n return { data: null, error: challengeError }\n }\n\n const { webauthn } = challengeResponse\n\n // Verify credential\n return this._verify({\n factorId,\n challengeId: challengeResponse.challengeId,\n webauthn: {\n type: webauthn.type,\n rpId,\n rpOrigins,\n credential_response: webauthn.credential_response,\n },\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n return {\n data: null,\n error: new AuthUnknownError('Unexpected error in authenticate', error),\n }\n }\n }\n\n /**\n * Complete WebAuthn registration flow.\n * Performs enrollment, challenge, and verification in a single operation for new credentials.\n *\n * @experimental This method is experimental and may change in future releases\n * @param {Object} params - Registration parameters\n * @param {string} params.friendlyName - User-friendly name for the credential\n * @param {string} params.rpId - Relying Party ID (defaults to current hostname)\n * @param {string[]} params.rpOrigins - Allowed origins (defaults to current origin)\n * @param {AbortSignal} params.signal - Optional abort signal\n * @param {PublicKeyCredentialCreationOptionsFuture} overrides - Override options for navigator.credentials.create\n * @returns {Promise<RequestResult<AuthMFAVerifyResponseData, WebAuthnError | AuthError>>} Registration result\n * @see {@link https://w3c.github.io/webauthn/#sctn-registering-a-new-credential W3C WebAuthn Spec - Registration Ceremony}\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/PublicKeyCredentialCreationOptions MDN - PublicKeyCredentialCreationOptions}\n */\n public async _register(\n {\n friendlyName,\n webauthn: {\n rpId = typeof window !== 'undefined' ? window.location.hostname : undefined,\n rpOrigins = typeof window !== 'undefined' ? [window.location.origin] : undefined,\n signal,\n } = {},\n }: {\n friendlyName: string\n webauthn?: {\n rpId?: string\n rpOrigins?: string[]\n signal?: AbortSignal\n }\n },\n overrides?: Partial<PublicKeyCredentialCreationOptionsFuture>\n ): Promise<RequestResult<AuthMFAVerifyResponseData, WebAuthnError | AuthError>> {\n if (!rpId) {\n return {\n data: null,\n error: new AuthError('rpId is required for WebAuthn registration'),\n }\n }\n try {\n if (!browserSupportsWebAuthn()) {\n return {\n data: null,\n error: new AuthUnknownError('Browser does not support WebAuthn', null),\n }\n }\n\n // Enroll factor\n const { data: factor, error: enrollError } = await this._enroll({\n friendlyName,\n })\n\n if (!factor) {\n await this.client.mfa\n .listFactors()\n .then((factors) =>\n factors.data?.all.find(\n (v) =>\n v.factor_type === 'webauthn' &&\n v.friendly_name === friendlyName &&\n v.status !== 'unverified'\n )\n )\n .then((factor) => (factor ? this.client.mfa.unenroll({ factorId: factor?.id }) : void 0))\n return { data: null, error: enrollError }\n }\n\n // Get challenge and create credential\n const { data: challengeResponse, error: challengeError } = await this._challenge(\n {\n factorId: factor.id,\n friendlyName: factor.friendly_name,\n webauthn: { rpId, rpOrigins },\n signal,\n },\n {\n create: overrides,\n }\n )\n\n if (!challengeResponse) {\n return { data: null, error: challengeError }\n }\n\n return this._verify({\n factorId: factor.id,\n challengeId: challengeResponse.challengeId,\n webauthn: {\n rpId,\n rpOrigins,\n type: challengeResponse.webauthn.type,\n credential_response: challengeResponse.webauthn.credential_response,\n },\n })\n } catch (error) {\n if (isAuthError(error)) {\n return { data: null, error }\n }\n return {\n data: null,\n error: new AuthUnknownError('Unexpected error in register', error),\n }\n }\n }\n}\n","import GoTrueAdminApi from './GoTrueAdminApi'\nimport {\n AUTO_REFRESH_TICK_DURATION_MS,\n AUTO_REFRESH_TICK_THRESHOLD,\n DEFAULT_HEADERS,\n EXPIRY_MARGIN_MS,\n GOTRUE_URL,\n JWKS_TTL,\n STORAGE_KEY,\n} from './lib/constants'\nimport {\n AuthError,\n AuthImplicitGrantRedirectError,\n AuthInvalidCredentialsError,\n AuthInvalidJwtError,\n AuthInvalidTokenResponseError,\n AuthPKCECodeVerifierMissingError,\n AuthPKCEGrantCodeExchangeError,\n AuthSessionMissingError,\n AuthUnknownError,\n isAuthApiError,\n isAuthError,\n isAuthImplicitGrantRedirectError,\n isAuthRetryableFetchError,\n isAuthSessionMissingError,\n} from './lib/errors'\nimport {\n Fetch,\n _request,\n _sessionResponse,\n _sessionResponsePassword,\n _ssoResponse,\n _userResponse,\n} from './lib/fetch'\nimport {\n decodeJWT,\n deepClone,\n Deferred,\n generateCallbackId,\n getAlgorithm,\n getCodeChallengeAndMethod,\n getItemAsync,\n insecureUserWarningProxy,\n isBrowser,\n parseParametersFromURL,\n removeItemAsync,\n resolveFetch,\n retryable,\n setItemAsync,\n sleep,\n supportsLocalStorage,\n userNotAvailableProxy,\n validateExp,\n} from './lib/helpers'\nimport { memoryLocalStorageAdapter } from './lib/local-storage'\nimport { LockAcquireTimeoutError, navigatorLock } from './lib/locks'\nimport { polyfillGlobalThis } from './lib/polyfills'\nimport { version } from './lib/version'\n\nimport { bytesToBase64URL, stringToUint8Array } from './lib/base64url'\nimport type {\n AuthChangeEvent,\n AuthenticatorAssuranceLevels,\n AuthFlowType,\n AuthMFAChallengePhoneResponse,\n AuthMFAChallengeResponse,\n AuthMFAChallengeTOTPResponse,\n AuthMFAChallengeWebauthnResponse,\n AuthMFAChallengeWebauthnServerResponse,\n AuthMFAEnrollPhoneResponse,\n AuthMFAEnrollResponse,\n AuthMFAEnrollTOTPResponse,\n AuthMFAEnrollWebauthnResponse,\n AuthMFAGetAuthenticatorAssuranceLevelResponse,\n AuthMFAListFactorsResponse,\n AuthMFAUnenrollResponse,\n AuthMFAVerifyResponse,\n AuthOtpResponse,\n AuthResponse,\n AuthResponsePassword,\n AuthTokenResponse,\n AuthTokenResponsePassword,\n CallRefreshTokenResult,\n EthereumWallet,\n EthereumWeb3Credentials,\n Factor,\n GoTrueClientOptions,\n GoTrueMFAApi,\n InitializeResult,\n JWK,\n JwtHeader,\n JwtPayload,\n LockFunc,\n MFAChallengeAndVerifyParams,\n MFAChallengeParams,\n MFAChallengePhoneParams,\n MFAChallengeTOTPParams,\n MFAChallengeWebauthnParams,\n MFAEnrollParams,\n MFAEnrollPhoneParams,\n MFAEnrollTOTPParams,\n MFAEnrollWebauthnParams,\n MFAUnenrollParams,\n MFAVerifyParams,\n MFAVerifyPhoneParams,\n MFAVerifyTOTPParams,\n MFAVerifyWebauthnParamFields,\n MFAVerifyWebauthnParams,\n OAuthResponse,\n AuthOAuthServerApi,\n AuthOAuthAuthorizationDetailsResponse,\n AuthOAuthConsentResponse,\n AuthOAuthGrantsResponse,\n AuthOAuthRevokeGrantResponse,\n Prettify,\n Provider,\n ResendParams,\n Session,\n SignInAnonymouslyCredentials,\n SignInWithIdTokenCredentials,\n SignInWithOAuthCredentials,\n SignInWithPasswordCredentials,\n SignInWithPasswordlessCredentials,\n SignInWithSSO,\n SignOut,\n SignUpWithPasswordCredentials,\n SolanaWallet,\n SolanaWeb3Credentials,\n SSOResponse,\n StrictOmit,\n Subscription,\n SupportedStorage,\n User,\n UserAttributes,\n UserIdentity,\n UserResponse,\n VerifyOtpParams,\n Web3Credentials,\n} from './lib/types'\nimport {\n createSiweMessage,\n fromHex,\n getAddress,\n Hex,\n SiweMessage,\n toHex,\n} from './lib/web3/ethereum'\nimport {\n deserializeCredentialCreationOptions,\n deserializeCredentialRequestOptions,\n serializeCredentialCreationResponse,\n serializeCredentialRequestResponse,\n WebAuthnApi,\n} from './lib/webauthn'\nimport {\n AuthenticationCredential,\n PublicKeyCredentialJSON,\n RegistrationCredential,\n} from './lib/webauthn.dom'\n\npolyfillGlobalThis() // Make \"globalThis\" available\n\nconst DEFAULT_OPTIONS: Omit<\n Required<GoTrueClientOptions>,\n 'fetch' | 'storage' | 'userStorage' | 'lock'\n> = {\n url: GOTRUE_URL,\n storageKey: STORAGE_KEY,\n autoRefreshToken: true,\n persistSession: true,\n detectSessionInUrl: true,\n headers: DEFAULT_HEADERS,\n flowType: 'implicit',\n debug: false,\n hasCustomAuthorizationHeader: false,\n throwOnError: false,\n lockAcquireTimeout: 10000, // 10 seconds\n}\n\nasync function lockNoOp<R>(name: string, acquireTimeout: number, fn: () => Promise<R>): Promise<R> {\n return await fn()\n}\n\n/**\n * Caches JWKS values for all clients created in the same environment. This is\n * especially useful for shared-memory execution environments such as Vercel's\n * Fluid Compute, AWS Lambda or Supabase's Edge Functions. Regardless of how\n * many clients are created, if they share the same storage key they will use\n * the same JWKS cache, significantly speeding up getClaims() with asymmetric\n * JWTs.\n */\nconst GLOBAL_JWKS: { [storageKey: string]: { cachedAt: number; jwks: { keys: JWK[] } } } = {}\n\nexport default class GoTrueClient {\n private static nextInstanceID: Record<string, number> = {}\n\n private instanceID: number\n\n /**\n * Namespace for the GoTrue admin methods.\n * These methods should only be used in a trusted server-side environment.\n */\n admin: GoTrueAdminApi\n /**\n * Namespace for the MFA methods.\n */\n mfa: GoTrueMFAApi\n /**\n * Namespace for the OAuth 2.1 authorization server methods.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n * Used to implement the authorization code flow on the consent page.\n */\n oauth: AuthOAuthServerApi\n /**\n * The storage key used to identify the values saved in localStorage\n */\n protected storageKey: string\n\n protected flowType: AuthFlowType\n\n /**\n * The JWKS used for verifying asymmetric JWTs\n */\n protected get jwks() {\n return GLOBAL_JWKS[this.storageKey]?.jwks ?? { keys: [] }\n }\n\n protected set jwks(value: { keys: JWK[] }) {\n GLOBAL_JWKS[this.storageKey] = { ...GLOBAL_JWKS[this.storageKey], jwks: value }\n }\n\n protected get jwks_cached_at() {\n return GLOBAL_JWKS[this.storageKey]?.cachedAt ?? Number.MIN_SAFE_INTEGER\n }\n\n protected set jwks_cached_at(value: number) {\n GLOBAL_JWKS[this.storageKey] = { ...GLOBAL_JWKS[this.storageKey], cachedAt: value }\n }\n\n protected autoRefreshToken: boolean\n protected persistSession: boolean\n protected storage: SupportedStorage\n /**\n * @experimental\n */\n protected userStorage: SupportedStorage | null = null\n protected memoryStorage: { [key: string]: string } | null = null\n protected stateChangeEmitters: Map<string | symbol, Subscription> = new Map()\n protected autoRefreshTicker: ReturnType<typeof setInterval> | null = null\n protected autoRefreshTickTimeout: ReturnType<typeof setTimeout> | null = null\n protected visibilityChangedCallback: (() => Promise<any>) | null = null\n protected refreshingDeferred: Deferred<CallRefreshTokenResult> | null = null\n /**\n * Keeps track of the async client initialization.\n * When null or not yet resolved the auth state is `unknown`\n * Once resolved the auth state is known and it's safe to call any further client methods.\n * Keep extra care to never reject or throw uncaught errors\n */\n protected initializePromise: Promise<InitializeResult> | null = null\n protected detectSessionInUrl:\n | boolean\n | ((url: URL, params: { [parameter: string]: string }) => boolean) = true\n protected url: string\n protected headers: {\n [key: string]: string\n }\n protected hasCustomAuthorizationHeader = false\n protected suppressGetSessionWarning = false\n protected fetch: Fetch\n protected lock: LockFunc\n protected lockAcquired = false\n protected pendingInLock: Promise<any>[] = []\n protected throwOnError: boolean\n protected lockAcquireTimeout: number\n\n /**\n * Used to broadcast state change events to other tabs listening.\n */\n protected broadcastChannel: BroadcastChannel | null = null\n\n protected logDebugMessages: boolean\n protected logger: (message: string, ...args: any[]) => void = console.log\n\n /**\n * Create a new client for use in the browser.\n *\n * @example\n * ```ts\n * import { GoTrueClient } from '@supabase/auth-js'\n *\n * const auth = new GoTrueClient({\n * url: 'https://xyzcompany.supabase.co/auth/v1',\n * headers: { apikey: 'public-anon-key' },\n * storageKey: 'supabase-auth',\n * })\n * ```\n */\n constructor(options: GoTrueClientOptions) {\n const settings = { ...DEFAULT_OPTIONS, ...options }\n this.storageKey = settings.storageKey\n\n this.instanceID = GoTrueClient.nextInstanceID[this.storageKey] ?? 0\n GoTrueClient.nextInstanceID[this.storageKey] = this.instanceID + 1\n\n this.logDebugMessages = !!settings.debug\n if (typeof settings.debug === 'function') {\n this.logger = settings.debug\n }\n\n if (this.instanceID > 0 && isBrowser()) {\n const message = `${this._logPrefix()} Multiple GoTrueClient instances detected in the same browser context. It is not an error, but this should be avoided as it may produce undefined behavior when used concurrently under the same storage key.`\n console.warn(message)\n if (this.logDebugMessages) {\n console.trace(message)\n }\n }\n\n this.persistSession = settings.persistSession\n this.autoRefreshToken = settings.autoRefreshToken\n this.admin = new GoTrueAdminApi({\n url: settings.url,\n headers: settings.headers,\n fetch: settings.fetch,\n })\n\n this.url = settings.url\n this.headers = settings.headers\n this.fetch = resolveFetch(settings.fetch)\n this.lock = settings.lock || lockNoOp\n this.detectSessionInUrl = settings.detectSessionInUrl\n this.flowType = settings.flowType\n this.hasCustomAuthorizationHeader = settings.hasCustomAuthorizationHeader\n this.throwOnError = settings.throwOnError\n this.lockAcquireTimeout = settings.lockAcquireTimeout\n\n if (settings.lock) {\n this.lock = settings.lock\n } else if (this.persistSession && isBrowser() && globalThis?.navigator?.locks) {\n this.lock = navigatorLock\n } else {\n this.lock = lockNoOp\n }\n\n if (!this.jwks) {\n this.jwks = { keys: [] }\n this.jwks_cached_at = Number.MIN_SAFE_INTEGER\n }\n\n this.mfa = {\n verify: this._verify.bind(this),\n enroll: this._enroll.bind(this),\n unenroll: this._unenroll.bind(this),\n challenge: this._challenge.bind(this),\n listFactors: this._listFactors.bind(this),\n challengeAndVerify: this._challengeAndVerify.bind(this),\n getAuthenticatorAssuranceLevel: this._getAuthenticatorAssuranceLevel.bind(this),\n webauthn: new WebAuthnApi(this),\n }\n\n this.oauth = {\n getAuthorizationDetails: this._getAuthorizationDetails.bind(this),\n approveAuthorization: this._approveAuthorization.bind(this),\n denyAuthorization: this._denyAuthorization.bind(this),\n listGrants: this._listOAuthGrants.bind(this),\n revokeGrant: this._revokeOAuthGrant.bind(this),\n }\n\n if (this.persistSession) {\n if (settings.storage) {\n this.storage = settings.storage\n } else {\n if (supportsLocalStorage()) {\n this.storage = globalThis.localStorage\n } else {\n this.memoryStorage = {}\n this.storage = memoryLocalStorageAdapter(this.memoryStorage)\n }\n }\n\n if (settings.userStorage) {\n this.userStorage = settings.userStorage\n }\n } else {\n this.memoryStorage = {}\n this.storage = memoryLocalStorageAdapter(this.memoryStorage)\n }\n\n if (isBrowser() && globalThis.BroadcastChannel && this.persistSession && this.storageKey) {\n try {\n this.broadcastChannel = new globalThis.BroadcastChannel(this.storageKey)\n } catch (e: any) {\n console.error(\n 'Failed to create a new BroadcastChannel, multi-tab state changes will not be available',\n e\n )\n }\n\n this.broadcastChannel?.addEventListener('message', async (event) => {\n this._debug('received broadcast notification from other tab or client', event)\n\n await this._notifyAllSubscribers(event.data.event, event.data.session, false) // broadcast = false so we don't get an endless loop of messages\n })\n }\n\n this.initialize()\n }\n\n /**\n * Returns whether error throwing mode is enabled for this client.\n */\n public isThrowOnErrorEnabled(): boolean {\n return this.throwOnError\n }\n\n /**\n * Centralizes return handling with optional error throwing. When `throwOnError` is enabled\n * and the provided result contains a non-nullish error, the error is thrown instead of\n * being returned. This ensures consistent behavior across all public API methods.\n */\n private _returnResult<T extends { error: any }>(result: T): T {\n if (this.throwOnError && result && result.error) {\n throw result.error\n }\n return result\n }\n\n private _logPrefix(): string {\n return (\n 'GoTrueClient@' +\n `${this.storageKey}:${this.instanceID} (${version}) ${new Date().toISOString()}`\n )\n }\n\n private _debug(...args: any[]): GoTrueClient {\n if (this.logDebugMessages) {\n this.logger(this._logPrefix(), ...args)\n }\n\n return this\n }\n\n /**\n * Initializes the client session either from the url or from storage.\n * This method is automatically called when instantiating the client, but should also be called\n * manually when checking for an error from an auth redirect (oauth, magiclink, password recovery, etc).\n */\n async initialize(): Promise<InitializeResult> {\n if (this.initializePromise) {\n return await this.initializePromise\n }\n\n this.initializePromise = (async () => {\n return await this._acquireLock(this.lockAcquireTimeout, async () => {\n return await this._initialize()\n })\n })()\n\n return await this.initializePromise\n }\n\n /**\n * IMPORTANT:\n * 1. Never throw in this method, as it is called from the constructor\n * 2. Never return a session from this method as it would be cached over\n * the whole lifetime of the client\n */\n private async _initialize(): Promise<InitializeResult> {\n try {\n let params: { [parameter: string]: string } = {}\n let callbackUrlType = 'none'\n\n if (isBrowser()) {\n params = parseParametersFromURL(window.location.href)\n if (this._isImplicitGrantCallback(params)) {\n callbackUrlType = 'implicit'\n } else if (await this._isPKCECallback(params)) {\n callbackUrlType = 'pkce'\n }\n }\n\n /**\n * Attempt to get the session from the URL only if these conditions are fulfilled\n *\n * Note: If the URL isn't one of the callback url types (implicit or pkce),\n * then there could be an existing session so we don't want to prematurely remove it\n */\n if (isBrowser() && this.detectSessionInUrl && callbackUrlType !== 'none') {\n const { data, error } = await this._getSessionFromURL(params, callbackUrlType)\n if (error) {\n this._debug('#_initialize()', 'error detecting session from URL', error)\n\n if (isAuthImplicitGrantRedirectError(error)) {\n const errorCode = error.details?.code\n if (\n errorCode === 'identity_already_exists' ||\n errorCode === 'identity_not_found' ||\n errorCode === 'single_identity_not_deletable'\n ) {\n return { error }\n }\n }\n\n // Don't remove existing session on URL login failure.\n // A failed attempt (e.g. reused magic link) shouldn't invalidate a valid session.\n\n return { error }\n }\n\n const { session, redirectType } = data\n\n this._debug(\n '#_initialize()',\n 'detected session in URL',\n session,\n 'redirect type',\n redirectType\n )\n\n await this._saveSession(session)\n\n setTimeout(async () => {\n if (redirectType === 'recovery') {\n await this._notifyAllSubscribers('PASSWORD_RECOVERY', session)\n } else {\n await this._notifyAllSubscribers('SIGNED_IN', session)\n }\n }, 0)\n\n return { error: null }\n }\n // no login attempt via callback url try to recover session from storage\n await this._recoverAndRefresh()\n return { error: null }\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ error })\n }\n\n return this._returnResult({\n error: new AuthUnknownError('Unexpected error during initialization', error),\n })\n } finally {\n await this._handleVisibilityChange()\n this._debug('#_initialize()', 'end')\n }\n }\n\n /**\n * Creates a new anonymous user.\n *\n * @returns A session where the is_anonymous claim in the access token JWT set to true\n */\n async signInAnonymously(credentials?: SignInAnonymouslyCredentials): Promise<AuthResponse> {\n try {\n const res = await _request(this.fetch, 'POST', `${this.url}/signup`, {\n headers: this.headers,\n body: {\n data: credentials?.options?.data ?? {},\n gotrue_meta_security: { captcha_token: credentials?.options?.captchaToken },\n },\n xform: _sessionResponse,\n })\n const { data, error } = res\n\n if (error || !data) {\n return this._returnResult({ data: { user: null, session: null }, error: error })\n }\n const session: Session | null = data.session\n const user: User | null = data.user\n\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('SIGNED_IN', session)\n }\n\n return this._returnResult({ data: { user, session }, error: null })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Creates a new user.\n *\n * Be aware that if a user account exists in the system you may get back an\n * error message that attempts to hide this information from the user.\n * This method has support for PKCE via email signups. The PKCE flow cannot be used when autoconfirm is enabled.\n *\n * @returns A logged-in session if the server has \"autoconfirm\" ON\n * @returns A user if the server has \"autoconfirm\" OFF\n */\n async signUp(credentials: SignUpWithPasswordCredentials): Promise<AuthResponse> {\n try {\n let res: AuthResponse\n if ('email' in credentials) {\n const { email, password, options } = credentials\n let codeChallenge: string | null = null\n let codeChallengeMethod: string | null = null\n if (this.flowType === 'pkce') {\n ;[codeChallenge, codeChallengeMethod] = await getCodeChallengeAndMethod(\n this.storage,\n this.storageKey\n )\n }\n res = await _request(this.fetch, 'POST', `${this.url}/signup`, {\n headers: this.headers,\n redirectTo: options?.emailRedirectTo,\n body: {\n email,\n password,\n data: options?.data ?? {},\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n code_challenge: codeChallenge,\n code_challenge_method: codeChallengeMethod,\n },\n xform: _sessionResponse,\n })\n } else if ('phone' in credentials) {\n const { phone, password, options } = credentials\n res = await _request(this.fetch, 'POST', `${this.url}/signup`, {\n headers: this.headers,\n body: {\n phone,\n password,\n data: options?.data ?? {},\n channel: options?.channel ?? 'sms',\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n },\n xform: _sessionResponse,\n })\n } else {\n throw new AuthInvalidCredentialsError(\n 'You must provide either an email or phone number and a password'\n )\n }\n\n const { data, error } = res\n\n if (error || !data) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n return this._returnResult({ data: { user: null, session: null }, error: error })\n }\n\n const session: Session | null = data.session\n const user: User | null = data.user\n\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('SIGNED_IN', session)\n }\n\n return this._returnResult({ data: { user, session }, error: null })\n } catch (error) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Log in an existing user with an email and password or phone and password.\n *\n * Be aware that you may get back an error message that will not distinguish\n * between the cases where the account does not exist or that the\n * email/phone and password combination is wrong or that the account can only\n * be accessed via social login.\n */\n async signInWithPassword(\n credentials: SignInWithPasswordCredentials\n ): Promise<AuthTokenResponsePassword> {\n try {\n let res: AuthResponsePassword\n if ('email' in credentials) {\n const { email, password, options } = credentials\n res = await _request(this.fetch, 'POST', `${this.url}/token?grant_type=password`, {\n headers: this.headers,\n body: {\n email,\n password,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n },\n xform: _sessionResponsePassword,\n })\n } else if ('phone' in credentials) {\n const { phone, password, options } = credentials\n res = await _request(this.fetch, 'POST', `${this.url}/token?grant_type=password`, {\n headers: this.headers,\n body: {\n phone,\n password,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n },\n xform: _sessionResponsePassword,\n })\n } else {\n throw new AuthInvalidCredentialsError(\n 'You must provide either an email or phone number and a password'\n )\n }\n const { data, error } = res\n\n if (error) {\n return this._returnResult({ data: { user: null, session: null }, error })\n } else if (!data || !data.session || !data.user) {\n const invalidTokenError = new AuthInvalidTokenResponseError()\n return this._returnResult({ data: { user: null, session: null }, error: invalidTokenError })\n }\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('SIGNED_IN', data.session)\n }\n return this._returnResult({\n data: {\n user: data.user,\n session: data.session,\n ...(data.weak_password ? { weakPassword: data.weak_password } : null),\n },\n error,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n throw error\n }\n }\n\n /**\n * Log in an existing user via a third-party provider.\n * This method supports the PKCE flow.\n */\n async signInWithOAuth(credentials: SignInWithOAuthCredentials): Promise<OAuthResponse> {\n return await this._handleProviderSignIn(credentials.provider, {\n redirectTo: credentials.options?.redirectTo,\n scopes: credentials.options?.scopes,\n queryParams: credentials.options?.queryParams,\n skipBrowserRedirect: credentials.options?.skipBrowserRedirect,\n })\n }\n\n /**\n * Log in an existing user by exchanging an Auth Code issued during the PKCE flow.\n */\n async exchangeCodeForSession(authCode: string): Promise<AuthTokenResponse> {\n await this.initializePromise\n\n return this._acquireLock(this.lockAcquireTimeout, async () => {\n return this._exchangeCodeForSession(authCode)\n })\n }\n\n /**\n * Signs in a user by verifying a message signed by the user's private key.\n * Supports Ethereum (via Sign-In-With-Ethereum) & Solana (Sign-In-With-Solana) standards,\n * both of which derive from the EIP-4361 standard\n * With slight variation on Solana's side.\n * @reference https://eips.ethereum.org/EIPS/eip-4361\n */\n async signInWithWeb3(credentials: Web3Credentials): Promise<\n | {\n data: { session: Session; user: User }\n error: null\n }\n | { data: { session: null; user: null }; error: AuthError }\n > {\n const { chain } = credentials\n\n switch (chain) {\n case 'ethereum':\n return await this.signInWithEthereum(credentials)\n case 'solana':\n return await this.signInWithSolana(credentials)\n default:\n throw new Error(`@supabase/auth-js: Unsupported chain \"${chain}\"`)\n }\n }\n\n private async signInWithEthereum(\n credentials: EthereumWeb3Credentials\n ): Promise<\n | { data: { session: Session; user: User }; error: null }\n | { data: { session: null; user: null }; error: AuthError }\n > {\n // TODO: flatten type\n let message: string\n let signature: Hex\n\n if ('message' in credentials) {\n message = credentials.message\n signature = credentials.signature\n } else {\n const { chain, wallet, statement, options } = credentials\n\n let resolvedWallet: EthereumWallet\n\n if (!isBrowser()) {\n if (typeof wallet !== 'object' || !options?.url) {\n throw new Error(\n '@supabase/auth-js: Both wallet and url must be specified in non-browser environments.'\n )\n }\n\n resolvedWallet = wallet\n } else if (typeof wallet === 'object') {\n resolvedWallet = wallet\n } else {\n const windowAny = window as any\n\n if (\n 'ethereum' in windowAny &&\n typeof windowAny.ethereum === 'object' &&\n 'request' in windowAny.ethereum &&\n typeof windowAny.ethereum.request === 'function'\n ) {\n resolvedWallet = windowAny.ethereum\n } else {\n throw new Error(\n `@supabase/auth-js: No compatible Ethereum wallet interface on the window object (window.ethereum) detected. Make sure the user already has a wallet installed and connected for this app. Prefer passing the wallet interface object directly to signInWithWeb3({ chain: 'ethereum', wallet: resolvedUserWallet }) instead.`\n )\n }\n }\n\n const url = new URL(options?.url ?? window.location.href)\n\n const accounts = await resolvedWallet\n .request({\n method: 'eth_requestAccounts',\n })\n .then((accs) => accs as string[])\n .catch(() => {\n throw new Error(\n `@supabase/auth-js: Wallet method eth_requestAccounts is missing or invalid`\n )\n })\n\n if (!accounts || accounts.length === 0) {\n throw new Error(\n `@supabase/auth-js: No accounts available. Please ensure the wallet is connected.`\n )\n }\n\n const address = getAddress(accounts[0])\n\n let chainId = options?.signInWithEthereum?.chainId\n if (!chainId) {\n const chainIdHex = await resolvedWallet.request({\n method: 'eth_chainId',\n })\n chainId = fromHex(chainIdHex as Hex)\n }\n\n const siweMessage: SiweMessage = {\n domain: url.host,\n address: address,\n statement: statement,\n uri: url.href,\n version: '1',\n chainId: chainId,\n nonce: options?.signInWithEthereum?.nonce,\n issuedAt: options?.signInWithEthereum?.issuedAt ?? new Date(),\n expirationTime: options?.signInWithEthereum?.expirationTime,\n notBefore: options?.signInWithEthereum?.notBefore,\n requestId: options?.signInWithEthereum?.requestId,\n resources: options?.signInWithEthereum?.resources,\n }\n\n message = createSiweMessage(siweMessage)\n\n // Sign message\n signature = (await resolvedWallet.request({\n method: 'personal_sign',\n params: [toHex(message), address],\n })) as Hex\n }\n\n try {\n const { data, error } = await _request(\n this.fetch,\n 'POST',\n `${this.url}/token?grant_type=web3`,\n {\n headers: this.headers,\n body: {\n chain: 'ethereum',\n message,\n signature,\n ...(credentials.options?.captchaToken\n ? { gotrue_meta_security: { captcha_token: credentials.options?.captchaToken } }\n : null),\n },\n xform: _sessionResponse,\n }\n )\n if (error) {\n throw error\n }\n if (!data || !data.session || !data.user) {\n const invalidTokenError = new AuthInvalidTokenResponseError()\n return this._returnResult({ data: { user: null, session: null }, error: invalidTokenError })\n }\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('SIGNED_IN', data.session)\n }\n return this._returnResult({ data: { ...data }, error })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n\n throw error\n }\n }\n\n private async signInWithSolana(credentials: SolanaWeb3Credentials) {\n let message: string\n let signature: Uint8Array\n\n if ('message' in credentials) {\n message = credentials.message\n signature = credentials.signature\n } else {\n const { chain, wallet, statement, options } = credentials\n\n let resolvedWallet: SolanaWallet\n\n if (!isBrowser()) {\n if (typeof wallet !== 'object' || !options?.url) {\n throw new Error(\n '@supabase/auth-js: Both wallet and url must be specified in non-browser environments.'\n )\n }\n\n resolvedWallet = wallet\n } else if (typeof wallet === 'object') {\n resolvedWallet = wallet\n } else {\n const windowAny = window as any\n\n if (\n 'solana' in windowAny &&\n typeof windowAny.solana === 'object' &&\n (('signIn' in windowAny.solana && typeof windowAny.solana.signIn === 'function') ||\n ('signMessage' in windowAny.solana &&\n typeof windowAny.solana.signMessage === 'function'))\n ) {\n resolvedWallet = windowAny.solana\n } else {\n throw new Error(\n `@supabase/auth-js: No compatible Solana wallet interface on the window object (window.solana) detected. Make sure the user already has a wallet installed and connected for this app. Prefer passing the wallet interface object directly to signInWithWeb3({ chain: 'solana', wallet: resolvedUserWallet }) instead.`\n )\n }\n }\n\n const url = new URL(options?.url ?? window.location.href)\n\n if ('signIn' in resolvedWallet && resolvedWallet.signIn) {\n const output = await resolvedWallet.signIn({\n issuedAt: new Date().toISOString(),\n\n ...options?.signInWithSolana,\n\n // non-overridable properties\n version: '1',\n domain: url.host,\n uri: url.href,\n\n ...(statement ? { statement } : null),\n })\n\n let outputToProcess: any\n\n if (Array.isArray(output) && output[0] && typeof output[0] === 'object') {\n outputToProcess = output[0]\n } else if (\n output &&\n typeof output === 'object' &&\n 'signedMessage' in output &&\n 'signature' in output\n ) {\n outputToProcess = output\n } else {\n throw new Error('@supabase/auth-js: Wallet method signIn() returned unrecognized value')\n }\n\n if (\n 'signedMessage' in outputToProcess &&\n 'signature' in outputToProcess &&\n (typeof outputToProcess.signedMessage === 'string' ||\n outputToProcess.signedMessage instanceof Uint8Array) &&\n outputToProcess.signature instanceof Uint8Array\n ) {\n message =\n typeof outputToProcess.signedMessage === 'string'\n ? outputToProcess.signedMessage\n : new TextDecoder().decode(outputToProcess.signedMessage)\n signature = outputToProcess.signature\n } else {\n throw new Error(\n '@supabase/auth-js: Wallet method signIn() API returned object without signedMessage and signature fields'\n )\n }\n } else {\n if (\n !('signMessage' in resolvedWallet) ||\n typeof resolvedWallet.signMessage !== 'function' ||\n !('publicKey' in resolvedWallet) ||\n typeof resolvedWallet !== 'object' ||\n !resolvedWallet.publicKey ||\n !('toBase58' in resolvedWallet.publicKey) ||\n typeof resolvedWallet.publicKey.toBase58 !== 'function'\n ) {\n throw new Error(\n '@supabase/auth-js: Wallet does not have a compatible signMessage() and publicKey.toBase58() API'\n )\n }\n\n message = [\n `${url.host} wants you to sign in with your Solana account:`,\n resolvedWallet.publicKey.toBase58(),\n ...(statement ? ['', statement, ''] : ['']),\n 'Version: 1',\n `URI: ${url.href}`,\n `Issued At: ${options?.signInWithSolana?.issuedAt ?? new Date().toISOString()}`,\n ...(options?.signInWithSolana?.notBefore\n ? [`Not Before: ${options.signInWithSolana.notBefore}`]\n : []),\n ...(options?.signInWithSolana?.expirationTime\n ? [`Expiration Time: ${options.signInWithSolana.expirationTime}`]\n : []),\n ...(options?.signInWithSolana?.chainId\n ? [`Chain ID: ${options.signInWithSolana.chainId}`]\n : []),\n ...(options?.signInWithSolana?.nonce ? [`Nonce: ${options.signInWithSolana.nonce}`] : []),\n ...(options?.signInWithSolana?.requestId\n ? [`Request ID: ${options.signInWithSolana.requestId}`]\n : []),\n ...(options?.signInWithSolana?.resources?.length\n ? [\n 'Resources',\n ...options.signInWithSolana.resources.map((resource) => `- ${resource}`),\n ]\n : []),\n ].join('\\n')\n\n const maybeSignature = await resolvedWallet.signMessage(\n new TextEncoder().encode(message),\n 'utf8'\n )\n\n if (!maybeSignature || !(maybeSignature instanceof Uint8Array)) {\n throw new Error(\n '@supabase/auth-js: Wallet signMessage() API returned an recognized value'\n )\n }\n\n signature = maybeSignature\n }\n }\n\n try {\n const { data, error } = await _request(\n this.fetch,\n 'POST',\n `${this.url}/token?grant_type=web3`,\n {\n headers: this.headers,\n body: {\n chain: 'solana',\n message,\n signature: bytesToBase64URL(signature),\n\n ...(credentials.options?.captchaToken\n ? { gotrue_meta_security: { captcha_token: credentials.options?.captchaToken } }\n : null),\n },\n xform: _sessionResponse,\n }\n )\n if (error) {\n throw error\n }\n if (!data || !data.session || !data.user) {\n const invalidTokenError = new AuthInvalidTokenResponseError()\n return this._returnResult({ data: { user: null, session: null }, error: invalidTokenError })\n }\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('SIGNED_IN', data.session)\n }\n return this._returnResult({ data: { ...data }, error })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n\n throw error\n }\n }\n\n private async _exchangeCodeForSession(authCode: string): Promise<\n | {\n data: { session: Session; user: User; redirectType: string | null }\n error: null\n }\n | { data: { session: null; user: null; redirectType: null }; error: AuthError }\n > {\n const storageItem = await getItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n const [codeVerifier, redirectType] = ((storageItem ?? '') as string).split('/')\n\n try {\n if (!codeVerifier && this.flowType === 'pkce') {\n throw new AuthPKCECodeVerifierMissingError()\n }\n\n const { data, error } = await _request(\n this.fetch,\n 'POST',\n `${this.url}/token?grant_type=pkce`,\n {\n headers: this.headers,\n body: {\n auth_code: authCode,\n code_verifier: codeVerifier,\n },\n xform: _sessionResponse,\n }\n )\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (error) {\n throw error\n }\n if (!data || !data.session || !data.user) {\n const invalidTokenError = new AuthInvalidTokenResponseError()\n return this._returnResult({\n data: { user: null, session: null, redirectType: null },\n error: invalidTokenError,\n })\n }\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('SIGNED_IN', data.session)\n }\n return this._returnResult({ data: { ...data, redirectType: redirectType ?? null }, error })\n } catch (error) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (isAuthError(error)) {\n return this._returnResult({\n data: { user: null, session: null, redirectType: null },\n error,\n })\n }\n throw error\n }\n }\n\n /**\n * Allows signing in with an OIDC ID token. The authentication provider used\n * should be enabled and configured.\n */\n async signInWithIdToken(credentials: SignInWithIdTokenCredentials): Promise<AuthTokenResponse> {\n try {\n const { options, provider, token, access_token, nonce } = credentials\n\n const res = await _request(this.fetch, 'POST', `${this.url}/token?grant_type=id_token`, {\n headers: this.headers,\n body: {\n provider,\n id_token: token,\n access_token,\n nonce,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n },\n xform: _sessionResponse,\n })\n\n const { data, error } = res\n if (error) {\n return this._returnResult({ data: { user: null, session: null }, error })\n } else if (!data || !data.session || !data.user) {\n const invalidTokenError = new AuthInvalidTokenResponseError()\n return this._returnResult({ data: { user: null, session: null }, error: invalidTokenError })\n }\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('SIGNED_IN', data.session)\n }\n return this._returnResult({ data, error })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n throw error\n }\n }\n\n /**\n * Log in a user using magiclink or a one-time password (OTP).\n *\n * If the `{{ .ConfirmationURL }}` variable is specified in the email template, a magiclink will be sent.\n * If the `{{ .Token }}` variable is specified in the email template, an OTP will be sent.\n * If you're using phone sign-ins, only an OTP will be sent. You won't be able to send a magiclink for phone sign-ins.\n *\n * Be aware that you may get back an error message that will not distinguish\n * between the cases where the account does not exist or, that the account\n * can only be accessed via social login.\n *\n * Do note that you will need to configure a Whatsapp sender on Twilio\n * if you are using phone sign in with the 'whatsapp' channel. The whatsapp\n * channel is not supported on other providers\n * at this time.\n * This method supports PKCE when an email is passed.\n */\n async signInWithOtp(credentials: SignInWithPasswordlessCredentials): Promise<AuthOtpResponse> {\n try {\n if ('email' in credentials) {\n const { email, options } = credentials\n let codeChallenge: string | null = null\n let codeChallengeMethod: string | null = null\n if (this.flowType === 'pkce') {\n ;[codeChallenge, codeChallengeMethod] = await getCodeChallengeAndMethod(\n this.storage,\n this.storageKey\n )\n }\n const { error } = await _request(this.fetch, 'POST', `${this.url}/otp`, {\n headers: this.headers,\n body: {\n email,\n data: options?.data ?? {},\n create_user: options?.shouldCreateUser ?? true,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n code_challenge: codeChallenge,\n code_challenge_method: codeChallengeMethod,\n },\n redirectTo: options?.emailRedirectTo,\n })\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n if ('phone' in credentials) {\n const { phone, options } = credentials\n const { data, error } = await _request(this.fetch, 'POST', `${this.url}/otp`, {\n headers: this.headers,\n body: {\n phone,\n data: options?.data ?? {},\n create_user: options?.shouldCreateUser ?? true,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n channel: options?.channel ?? 'sms',\n },\n })\n return this._returnResult({\n data: { user: null, session: null, messageId: data?.message_id },\n error,\n })\n }\n throw new AuthInvalidCredentialsError('You must provide either an email or phone number.')\n } catch (error) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Log in a user given a User supplied OTP or TokenHash received through mobile or email.\n */\n async verifyOtp(params: VerifyOtpParams): Promise<AuthResponse> {\n try {\n let redirectTo: string | undefined = undefined\n let captchaToken: string | undefined = undefined\n if ('options' in params) {\n redirectTo = params.options?.redirectTo\n captchaToken = params.options?.captchaToken\n }\n const { data, error } = await _request(this.fetch, 'POST', `${this.url}/verify`, {\n headers: this.headers,\n body: {\n ...params,\n gotrue_meta_security: { captcha_token: captchaToken },\n },\n redirectTo,\n xform: _sessionResponse,\n })\n\n if (error) {\n throw error\n }\n if (!data) {\n const tokenVerificationError = new Error('An error occurred on token verification.')\n throw tokenVerificationError\n }\n\n const session: Session | null = data.session\n const user: User = data.user\n\n if (session?.access_token) {\n await this._saveSession(session as Session)\n await this._notifyAllSubscribers(\n params.type == 'recovery' ? 'PASSWORD_RECOVERY' : 'SIGNED_IN',\n session\n )\n }\n\n return this._returnResult({ data: { user, session }, error: null })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Attempts a single-sign on using an enterprise Identity Provider. A\n * successful SSO attempt will redirect the current page to the identity\n * provider authorization page. The redirect URL is implementation and SSO\n * protocol specific.\n *\n * You can use it by providing a SSO domain. Typically you can extract this\n * domain by asking users for their email address. If this domain is\n * registered on the Auth instance the redirect will use that organization's\n * currently active SSO Identity Provider for the login.\n *\n * If you have built an organization-specific login page, you can use the\n * organization's SSO Identity Provider UUID directly instead.\n */\n async signInWithSSO(params: SignInWithSSO): Promise<SSOResponse> {\n try {\n let codeChallenge: string | null = null\n let codeChallengeMethod: string | null = null\n if (this.flowType === 'pkce') {\n ;[codeChallenge, codeChallengeMethod] = await getCodeChallengeAndMethod(\n this.storage,\n this.storageKey\n )\n }\n\n const result = await _request(this.fetch, 'POST', `${this.url}/sso`, {\n body: {\n ...('providerId' in params ? { provider_id: params.providerId } : null),\n ...('domain' in params ? { domain: params.domain } : null),\n redirect_to: params.options?.redirectTo ?? undefined,\n ...(params?.options?.captchaToken\n ? { gotrue_meta_security: { captcha_token: params.options.captchaToken } }\n : null),\n skip_http_redirect: true, // fetch does not handle redirects\n code_challenge: codeChallenge,\n code_challenge_method: codeChallengeMethod,\n },\n headers: this.headers,\n xform: _ssoResponse,\n })\n\n // Automatically redirect in browser unless skipBrowserRedirect is true\n if (result.data?.url && isBrowser() && !params.options?.skipBrowserRedirect) {\n window.location.assign(result.data.url)\n }\n\n return this._returnResult(result)\n } catch (error) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n }\n\n /**\n * Sends a reauthentication OTP to the user's email or phone number.\n * Requires the user to be signed-in.\n */\n async reauthenticate(): Promise<AuthResponse> {\n await this.initializePromise\n\n return await this._acquireLock(this.lockAcquireTimeout, async () => {\n return await this._reauthenticate()\n })\n }\n\n private async _reauthenticate(): Promise<AuthResponse> {\n try {\n return await this._useSession(async (result) => {\n const {\n data: { session },\n error: sessionError,\n } = result\n if (sessionError) throw sessionError\n if (!session) throw new AuthSessionMissingError()\n\n const { error } = await _request(this.fetch, 'GET', `${this.url}/reauthenticate`, {\n headers: this.headers,\n jwt: session.access_token,\n })\n return this._returnResult({ data: { user: null, session: null }, error })\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n throw error\n }\n }\n\n /**\n * Resends an existing signup confirmation email, email change email, SMS OTP or phone change OTP.\n */\n async resend(credentials: ResendParams): Promise<AuthOtpResponse> {\n try {\n const endpoint = `${this.url}/resend`\n if ('email' in credentials) {\n const { email, type, options } = credentials\n const { error } = await _request(this.fetch, 'POST', endpoint, {\n headers: this.headers,\n body: {\n email,\n type,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n },\n redirectTo: options?.emailRedirectTo,\n })\n return this._returnResult({ data: { user: null, session: null }, error })\n } else if ('phone' in credentials) {\n const { phone, type, options } = credentials\n const { data, error } = await _request(this.fetch, 'POST', endpoint, {\n headers: this.headers,\n body: {\n phone,\n type,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n },\n })\n return this._returnResult({\n data: { user: null, session: null, messageId: data?.message_id },\n error,\n })\n }\n throw new AuthInvalidCredentialsError(\n 'You must provide either an email or phone number and a type'\n )\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n throw error\n }\n }\n\n /**\n * Returns the session, refreshing it if necessary.\n *\n * The session returned can be null if the session is not detected which can happen in the event a user is not signed-in or has logged out.\n *\n * **IMPORTANT:** This method loads values directly from the storage attached\n * to the client. If that storage is based on request cookies for example,\n * the values in it may not be authentic and therefore it's strongly advised\n * against using this method and its results in such circumstances. A warning\n * will be emitted if this is detected. Use {@link #getUser()} instead.\n */\n async getSession() {\n await this.initializePromise\n\n const result = await this._acquireLock(this.lockAcquireTimeout, async () => {\n return this._useSession(async (result) => {\n return result\n })\n })\n\n return result\n }\n\n /**\n * Acquires a global lock based on the storage key.\n */\n private async _acquireLock<R>(acquireTimeout: number, fn: () => Promise<R>): Promise<R> {\n this._debug('#_acquireLock', 'begin', acquireTimeout)\n\n try {\n if (this.lockAcquired) {\n const last = this.pendingInLock.length\n ? this.pendingInLock[this.pendingInLock.length - 1]\n : Promise.resolve()\n\n const result = (async () => {\n await last\n return await fn()\n })()\n\n this.pendingInLock.push(\n (async () => {\n try {\n await result\n } catch (e: any) {\n // we just care if it finished\n }\n })()\n )\n\n return result\n }\n\n return await this.lock(`lock:${this.storageKey}`, acquireTimeout, async () => {\n this._debug('#_acquireLock', 'lock acquired for storage key', this.storageKey)\n\n try {\n this.lockAcquired = true\n\n const result = fn()\n\n this.pendingInLock.push(\n (async () => {\n try {\n await result\n } catch (e: any) {\n // we just care if it finished\n }\n })()\n )\n\n await result\n\n // keep draining the queue until there's nothing to wait on\n while (this.pendingInLock.length) {\n const waitOn = [...this.pendingInLock]\n\n await Promise.all(waitOn)\n\n this.pendingInLock.splice(0, waitOn.length)\n }\n\n return await result\n } finally {\n this._debug('#_acquireLock', 'lock released for storage key', this.storageKey)\n\n this.lockAcquired = false\n }\n })\n } finally {\n this._debug('#_acquireLock', 'end')\n }\n }\n\n /**\n * Use instead of {@link #getSession} inside the library. It is\n * semantically usually what you want, as getting a session involves some\n * processing afterwards that requires only one client operating on the\n * session at once across multiple tabs or processes.\n */\n private async _useSession<R>(\n fn: (\n result:\n | {\n data: {\n session: Session\n }\n error: null\n }\n | {\n data: {\n session: null\n }\n error: AuthError\n }\n | {\n data: {\n session: null\n }\n error: null\n }\n ) => Promise<R>\n ): Promise<R> {\n this._debug('#_useSession', 'begin')\n\n try {\n // the use of __loadSession here is the only correct use of the function!\n const result = await this.__loadSession()\n\n return await fn(result)\n } finally {\n this._debug('#_useSession', 'end')\n }\n }\n\n /**\n * NEVER USE DIRECTLY!\n *\n * Always use {@link #_useSession}.\n */\n private async __loadSession(): Promise<\n | {\n data: {\n session: Session\n }\n error: null\n }\n | {\n data: {\n session: null\n }\n error: AuthError\n }\n | {\n data: {\n session: null\n }\n error: null\n }\n > {\n this._debug('#__loadSession()', 'begin')\n\n if (!this.lockAcquired) {\n this._debug('#__loadSession()', 'used outside of an acquired lock!', new Error().stack)\n }\n\n try {\n let currentSession: Session | null = null\n\n const maybeSession = await getItemAsync(this.storage, this.storageKey)\n\n this._debug('#getSession()', 'session from storage', maybeSession)\n\n if (maybeSession !== null) {\n if (this._isValidSession(maybeSession)) {\n currentSession = maybeSession\n } else {\n this._debug('#getSession()', 'session from storage is not valid')\n await this._removeSession()\n }\n }\n\n if (!currentSession) {\n return { data: { session: null }, error: null }\n }\n\n // A session is considered expired before the access token _actually_\n // expires. When the autoRefreshToken option is off (or when the tab is\n // in the background), very eager users of getSession() -- like\n // realtime-js -- might send a valid JWT which will expire by the time it\n // reaches the server.\n const hasExpired = currentSession.expires_at\n ? currentSession.expires_at * 1000 - Date.now() < EXPIRY_MARGIN_MS\n : false\n\n this._debug(\n '#__loadSession()',\n `session has${hasExpired ? '' : ' not'} expired`,\n 'expires_at',\n currentSession.expires_at\n )\n\n if (!hasExpired) {\n if (this.userStorage) {\n const maybeUser: { user?: User | null } | null = (await getItemAsync(\n this.userStorage,\n this.storageKey + '-user'\n )) as any\n\n if (maybeUser?.user) {\n currentSession.user = maybeUser.user\n } else {\n currentSession.user = userNotAvailableProxy()\n }\n }\n\n // Wrap the user object with a warning proxy on the server\n // This warns when properties of the user are accessed, not when session.user itself is accessed\n if (\n this.storage.isServer &&\n currentSession.user &&\n !(currentSession.user as any).__isUserNotAvailableProxy\n ) {\n const suppressWarningRef = { value: this.suppressGetSessionWarning }\n currentSession.user = insecureUserWarningProxy(currentSession.user, suppressWarningRef)\n\n // Update the client-level suppression flag when the proxy suppresses the warning\n if (suppressWarningRef.value) {\n this.suppressGetSessionWarning = true\n }\n }\n\n return { data: { session: currentSession }, error: null }\n }\n\n const { data: session, error } = await this._callRefreshToken(currentSession.refresh_token)\n if (error) {\n return this._returnResult({ data: { session: null }, error })\n }\n\n return this._returnResult({ data: { session }, error: null })\n } finally {\n this._debug('#__loadSession()', 'end')\n }\n }\n\n /**\n * Gets the current user details if there is an existing session. This method\n * performs a network request to the Supabase Auth server, so the returned\n * value is authentic and can be used to base authorization rules on.\n *\n * @param jwt Takes in an optional access token JWT. If no JWT is provided, the JWT from the current session is used.\n */\n async getUser(jwt?: string): Promise<UserResponse> {\n if (jwt) {\n return await this._getUser(jwt)\n }\n\n await this.initializePromise\n\n const result = await this._acquireLock(this.lockAcquireTimeout, async () => {\n return await this._getUser()\n })\n\n if (result.data.user) {\n this.suppressGetSessionWarning = true\n }\n\n return result\n }\n\n private async _getUser(jwt?: string): Promise<UserResponse> {\n try {\n if (jwt) {\n return await _request(this.fetch, 'GET', `${this.url}/user`, {\n headers: this.headers,\n jwt: jwt,\n xform: _userResponse,\n })\n }\n\n return await this._useSession(async (result) => {\n const { data, error } = result\n if (error) {\n throw error\n }\n\n // returns an error if there is no access_token or custom authorization header\n if (!data.session?.access_token && !this.hasCustomAuthorizationHeader) {\n return { data: { user: null }, error: new AuthSessionMissingError() }\n }\n\n return await _request(this.fetch, 'GET', `${this.url}/user`, {\n headers: this.headers,\n jwt: data.session?.access_token ?? undefined,\n xform: _userResponse,\n })\n })\n } catch (error) {\n if (isAuthError(error)) {\n if (isAuthSessionMissingError(error)) {\n // JWT contains a `session_id` which does not correspond to an active\n // session in the database, indicating the user is signed out.\n\n await this._removeSession()\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n }\n\n return this._returnResult({ data: { user: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Updates user data for a logged in user.\n */\n async updateUser(\n attributes: UserAttributes,\n options: {\n emailRedirectTo?: string | undefined\n } = {}\n ): Promise<UserResponse> {\n await this.initializePromise\n\n return await this._acquireLock(this.lockAcquireTimeout, async () => {\n return await this._updateUser(attributes, options)\n })\n }\n\n protected async _updateUser(\n attributes: UserAttributes,\n options: {\n emailRedirectTo?: string | undefined\n } = {}\n ): Promise<UserResponse> {\n try {\n return await this._useSession(async (result) => {\n const { data: sessionData, error: sessionError } = result\n if (sessionError) {\n throw sessionError\n }\n if (!sessionData.session) {\n throw new AuthSessionMissingError()\n }\n const session: Session = sessionData.session\n let codeChallenge: string | null = null\n let codeChallengeMethod: string | null = null\n if (this.flowType === 'pkce' && attributes.email != null) {\n ;[codeChallenge, codeChallengeMethod] = await getCodeChallengeAndMethod(\n this.storage,\n this.storageKey\n )\n }\n\n const { data, error: userError } = await _request(this.fetch, 'PUT', `${this.url}/user`, {\n headers: this.headers,\n redirectTo: options?.emailRedirectTo,\n body: {\n ...attributes,\n code_challenge: codeChallenge,\n code_challenge_method: codeChallengeMethod,\n },\n jwt: session.access_token,\n xform: _userResponse,\n })\n if (userError) {\n throw userError\n }\n session.user = data.user as User\n await this._saveSession(session)\n await this._notifyAllSubscribers('USER_UPDATED', session)\n return this._returnResult({ data: { user: session.user }, error: null })\n })\n } catch (error) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Sets the session data from the current session. If the current session is expired, setSession will take care of refreshing it to obtain a new session.\n * If the refresh token or access token in the current session is invalid, an error will be thrown.\n * @param currentSession The current session that minimally contains an access token and refresh token.\n */\n async setSession(currentSession: {\n access_token: string\n refresh_token: string\n }): Promise<AuthResponse> {\n await this.initializePromise\n\n return await this._acquireLock(this.lockAcquireTimeout, async () => {\n return await this._setSession(currentSession)\n })\n }\n\n protected async _setSession(currentSession: {\n access_token: string\n refresh_token: string\n }): Promise<AuthResponse> {\n try {\n if (!currentSession.access_token || !currentSession.refresh_token) {\n throw new AuthSessionMissingError()\n }\n\n const timeNow = Date.now() / 1000\n let expiresAt = timeNow\n let hasExpired = true\n let session: Session | null = null\n const { payload } = decodeJWT(currentSession.access_token)\n if (payload.exp) {\n expiresAt = payload.exp\n hasExpired = expiresAt <= timeNow\n }\n\n if (hasExpired) {\n const { data: refreshedSession, error } = await this._callRefreshToken(\n currentSession.refresh_token\n )\n if (error) {\n return this._returnResult({ data: { user: null, session: null }, error: error })\n }\n\n if (!refreshedSession) {\n return { data: { user: null, session: null }, error: null }\n }\n session = refreshedSession\n } else {\n const { data, error } = await this._getUser(currentSession.access_token)\n if (error) {\n throw error\n }\n session = {\n access_token: currentSession.access_token,\n refresh_token: currentSession.refresh_token,\n user: data.user,\n token_type: 'bearer',\n expires_in: expiresAt - timeNow,\n expires_at: expiresAt,\n }\n await this._saveSession(session)\n await this._notifyAllSubscribers('SIGNED_IN', session)\n }\n\n return this._returnResult({ data: { user: session.user, session }, error: null })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { session: null, user: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Returns a new session, regardless of expiry status.\n * Takes in an optional current session. If not passed in, then refreshSession() will attempt to retrieve it from getSession().\n * If the current session's refresh token is invalid, an error will be thrown.\n * @param currentSession The current session. If passed in, it must contain a refresh token.\n */\n async refreshSession(currentSession?: { refresh_token: string }): Promise<AuthResponse> {\n await this.initializePromise\n\n return await this._acquireLock(this.lockAcquireTimeout, async () => {\n return await this._refreshSession(currentSession)\n })\n }\n\n protected async _refreshSession(currentSession?: {\n refresh_token: string\n }): Promise<AuthResponse> {\n try {\n return await this._useSession(async (result) => {\n if (!currentSession) {\n const { data, error } = result\n if (error) {\n throw error\n }\n\n currentSession = data.session ?? undefined\n }\n\n if (!currentSession?.refresh_token) {\n throw new AuthSessionMissingError()\n }\n\n const { data: session, error } = await this._callRefreshToken(currentSession.refresh_token)\n if (error) {\n return this._returnResult({ data: { user: null, session: null }, error: error })\n }\n\n if (!session) {\n return this._returnResult({ data: { user: null, session: null }, error: null })\n }\n\n return this._returnResult({ data: { user: session.user, session }, error: null })\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Gets the session data from a URL string\n */\n private async _getSessionFromURL(\n params: { [parameter: string]: string },\n callbackUrlType: string\n ): Promise<\n | {\n data: { session: Session; redirectType: string | null }\n error: null\n }\n | { data: { session: null; redirectType: null }; error: AuthError }\n > {\n try {\n if (!isBrowser()) throw new AuthImplicitGrantRedirectError('No browser detected.')\n\n // If there's an error in the URL, it doesn't matter what flow it is, we just return the error.\n if (params.error || params.error_description || params.error_code) {\n // The error class returned implies that the redirect is from an implicit grant flow\n // but it could also be from a redirect error from a PKCE flow.\n throw new AuthImplicitGrantRedirectError(\n params.error_description || 'Error in URL with unspecified error_description',\n {\n error: params.error || 'unspecified_error',\n code: params.error_code || 'unspecified_code',\n }\n )\n }\n\n // Checks for mismatches between the flowType initialised in the client and the URL parameters\n switch (callbackUrlType) {\n case 'implicit':\n if (this.flowType === 'pkce') {\n throw new AuthPKCEGrantCodeExchangeError('Not a valid PKCE flow url.')\n }\n break\n case 'pkce':\n if (this.flowType === 'implicit') {\n throw new AuthImplicitGrantRedirectError('Not a valid implicit grant flow url.')\n }\n break\n default:\n // there's no mismatch so we continue\n }\n\n // Since this is a redirect for PKCE, we attempt to retrieve the code from the URL for the code exchange\n if (callbackUrlType === 'pkce') {\n this._debug('#_initialize()', 'begin', 'is PKCE flow', true)\n if (!params.code) throw new AuthPKCEGrantCodeExchangeError('No code detected.')\n const { data, error } = await this._exchangeCodeForSession(params.code)\n if (error) throw error\n\n const url = new URL(window.location.href)\n url.searchParams.delete('code')\n\n window.history.replaceState(window.history.state, '', url.toString())\n\n return { data: { session: data.session, redirectType: null }, error: null }\n }\n\n const {\n provider_token,\n provider_refresh_token,\n access_token,\n refresh_token,\n expires_in,\n expires_at,\n token_type,\n } = params\n\n if (!access_token || !expires_in || !refresh_token || !token_type) {\n throw new AuthImplicitGrantRedirectError('No session defined in URL')\n }\n\n const timeNow = Math.round(Date.now() / 1000)\n const expiresIn = parseInt(expires_in)\n let expiresAt = timeNow + expiresIn\n\n if (expires_at) {\n expiresAt = parseInt(expires_at)\n }\n\n const actuallyExpiresIn = expiresAt - timeNow\n if (actuallyExpiresIn * 1000 <= AUTO_REFRESH_TICK_DURATION_MS) {\n console.warn(\n `@supabase/gotrue-js: Session as retrieved from URL expires in ${actuallyExpiresIn}s, should have been closer to ${expiresIn}s`\n )\n }\n\n const issuedAt = expiresAt - expiresIn\n if (timeNow - issuedAt >= 120) {\n console.warn(\n '@supabase/gotrue-js: Session as retrieved from URL was issued over 120s ago, URL could be stale',\n issuedAt,\n expiresAt,\n timeNow\n )\n } else if (timeNow - issuedAt < 0) {\n console.warn(\n '@supabase/gotrue-js: Session as retrieved from URL was issued in the future? Check the device clock for skew',\n issuedAt,\n expiresAt,\n timeNow\n )\n }\n\n const { data, error } = await this._getUser(access_token)\n if (error) throw error\n\n const session: Session = {\n provider_token,\n provider_refresh_token,\n access_token,\n expires_in: expiresIn,\n expires_at: expiresAt,\n refresh_token,\n token_type: token_type as 'bearer',\n user: data.user,\n }\n\n // Remove tokens from URL\n window.location.hash = ''\n this._debug('#_getSessionFromURL()', 'clearing window.location.hash')\n\n return this._returnResult({ data: { session, redirectType: params.type }, error: null })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { session: null, redirectType: null }, error })\n }\n\n throw error\n }\n }\n\n /**\n * Checks if the current URL contains parameters given by an implicit oauth grant flow (https://www.rfc-editor.org/rfc/rfc6749.html#section-4.2)\n *\n * If `detectSessionInUrl` is a function, it will be called with the URL and params to determine\n * if the URL should be processed as a Supabase auth callback. This allows users to exclude\n * URLs from other OAuth providers (e.g., Facebook Login) that also return access_token in the fragment.\n */\n private _isImplicitGrantCallback(params: { [parameter: string]: string }): boolean {\n if (typeof this.detectSessionInUrl === 'function') {\n return this.detectSessionInUrl(new URL(window.location.href), params)\n }\n return Boolean(params.access_token || params.error_description)\n }\n\n /**\n * Checks if the current URL and backing storage contain parameters given by a PKCE flow\n */\n private async _isPKCECallback(params: { [parameter: string]: string }): Promise<boolean> {\n const currentStorageContent = await getItemAsync(\n this.storage,\n `${this.storageKey}-code-verifier`\n )\n\n return !!(params.code && currentStorageContent)\n }\n\n /**\n * Inside a browser context, `signOut()` will remove the logged in user from the browser session and log them out - removing all items from localstorage and then trigger a `\"SIGNED_OUT\"` event.\n *\n * For server-side management, you can revoke all refresh tokens for a user by passing a user's JWT through to `auth.api.signOut(JWT: string)`.\n * There is no way to revoke a user's access token jwt until it expires. It is recommended to set a shorter expiry on the jwt for this reason.\n *\n * If using `others` scope, no `SIGNED_OUT` event is fired!\n */\n async signOut(options: SignOut = { scope: 'global' }): Promise<{ error: AuthError | null }> {\n await this.initializePromise\n\n return await this._acquireLock(this.lockAcquireTimeout, async () => {\n return await this._signOut(options)\n })\n }\n\n protected async _signOut(\n { scope }: SignOut = { scope: 'global' }\n ): Promise<{ error: AuthError | null }> {\n return await this._useSession(async (result) => {\n const { data, error: sessionError } = result\n if (sessionError) {\n return this._returnResult({ error: sessionError })\n }\n const accessToken = data.session?.access_token\n if (accessToken) {\n const { error } = await this.admin.signOut(accessToken, scope)\n if (error) {\n // ignore 404s since user might not exist anymore\n // ignore 401s since an invalid or expired JWT should sign out the current session\n if (\n !(\n isAuthApiError(error) &&\n (error.status === 404 || error.status === 401 || error.status === 403)\n )\n ) {\n return this._returnResult({ error })\n }\n }\n }\n if (scope !== 'others') {\n await this._removeSession()\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n }\n return this._returnResult({ error: null })\n })\n }\n\n /**\n * Receive a notification every time an auth event happens.\n * Safe to use without an async function as callback.\n *\n * @param callback A callback function to be invoked when an auth event happens.\n */\n onAuthStateChange(callback: (event: AuthChangeEvent, session: Session | null) => void): {\n data: { subscription: Subscription }\n }\n\n /**\n * Avoid using an async function inside `onAuthStateChange` as you might end\n * up with a deadlock. The callback function runs inside an exclusive lock,\n * so calling other Supabase Client APIs that also try to acquire the\n * exclusive lock, might cause a deadlock. This behavior is observable across\n * tabs. In the next major library version, this behavior will not be supported.\n *\n * Receive a notification every time an auth event happens.\n *\n * @param callback A callback function to be invoked when an auth event happens.\n * @deprecated Due to the possibility of deadlocks with async functions as callbacks, use the version without an async function.\n */\n onAuthStateChange(callback: (event: AuthChangeEvent, session: Session | null) => Promise<void>): {\n data: { subscription: Subscription }\n }\n\n onAuthStateChange(\n callback: (event: AuthChangeEvent, session: Session | null) => void | Promise<void>\n ): {\n data: { subscription: Subscription }\n } {\n const id: string | symbol = generateCallbackId()\n const subscription: Subscription = {\n id,\n callback,\n unsubscribe: () => {\n this._debug('#unsubscribe()', 'state change callback with id removed', id)\n\n this.stateChangeEmitters.delete(id)\n },\n }\n\n this._debug('#onAuthStateChange()', 'registered callback with id', id)\n\n this.stateChangeEmitters.set(id, subscription)\n ;(async () => {\n await this.initializePromise\n\n await this._acquireLock(this.lockAcquireTimeout, async () => {\n this._emitInitialSession(id)\n })\n })()\n\n return { data: { subscription } }\n }\n\n private async _emitInitialSession(id: string | symbol): Promise<void> {\n return await this._useSession(async (result) => {\n try {\n const {\n data: { session },\n error,\n } = result\n if (error) throw error\n\n await this.stateChangeEmitters.get(id)?.callback('INITIAL_SESSION', session)\n this._debug('INITIAL_SESSION', 'callback id', id, 'session', session)\n } catch (err) {\n await this.stateChangeEmitters.get(id)?.callback('INITIAL_SESSION', null)\n this._debug('INITIAL_SESSION', 'callback id', id, 'error', err)\n console.error(err)\n }\n })\n }\n\n /**\n * Sends a password reset request to an email address. This method supports the PKCE flow.\n *\n * @param email The email address of the user.\n * @param options.redirectTo The URL to send the user to after they click the password reset link.\n * @param options.captchaToken Verification token received when the user completes the captcha on the site.\n */\n async resetPasswordForEmail(\n email: string,\n options: {\n redirectTo?: string\n captchaToken?: string\n } = {}\n ): Promise<\n | {\n data: {}\n error: null\n }\n | { data: null; error: AuthError }\n > {\n let codeChallenge: string | null = null\n let codeChallengeMethod: string | null = null\n\n if (this.flowType === 'pkce') {\n ;[codeChallenge, codeChallengeMethod] = await getCodeChallengeAndMethod(\n this.storage,\n this.storageKey,\n true // isPasswordRecovery\n )\n }\n try {\n return await _request(this.fetch, 'POST', `${this.url}/recover`, {\n body: {\n email,\n code_challenge: codeChallenge,\n code_challenge_method: codeChallengeMethod,\n gotrue_meta_security: { captcha_token: options.captchaToken },\n },\n headers: this.headers,\n redirectTo: options.redirectTo,\n })\n } catch (error) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n\n throw error\n }\n }\n\n /**\n * Gets all the identities linked to a user.\n */\n async getUserIdentities(): Promise<\n | {\n data: {\n identities: UserIdentity[]\n }\n error: null\n }\n | { data: null; error: AuthError }\n > {\n try {\n const { data, error } = await this.getUser()\n if (error) throw error\n return this._returnResult({ data: { identities: data.user.identities ?? [] }, error: null })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n }\n\n /**\n * Links an oauth identity to an existing user.\n * This method supports the PKCE flow.\n */\n async linkIdentity(credentials: SignInWithOAuthCredentials): Promise<OAuthResponse>\n\n /**\n * Links an OIDC identity to an existing user.\n */\n async linkIdentity(credentials: SignInWithIdTokenCredentials): Promise<AuthTokenResponse>\n\n async linkIdentity(credentials: any): Promise<any> {\n if ('token' in credentials) {\n return this.linkIdentityIdToken(credentials)\n }\n\n return this.linkIdentityOAuth(credentials)\n }\n\n private async linkIdentityOAuth(credentials: SignInWithOAuthCredentials): Promise<OAuthResponse> {\n try {\n const { data, error } = await this._useSession(async (result) => {\n const { data, error } = result\n if (error) throw error\n const url: string = await this._getUrlForProvider(\n `${this.url}/user/identities/authorize`,\n credentials.provider,\n {\n redirectTo: credentials.options?.redirectTo,\n scopes: credentials.options?.scopes,\n queryParams: credentials.options?.queryParams,\n skipBrowserRedirect: true,\n }\n )\n return await _request(this.fetch, 'GET', url, {\n headers: this.headers,\n jwt: data.session?.access_token ?? undefined,\n })\n })\n if (error) throw error\n if (isBrowser() && !credentials.options?.skipBrowserRedirect) {\n window.location.assign(data?.url)\n }\n return this._returnResult({\n data: { provider: credentials.provider, url: data?.url },\n error: null,\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: { provider: credentials.provider, url: null }, error })\n }\n throw error\n }\n }\n\n private async linkIdentityIdToken(\n credentials: SignInWithIdTokenCredentials\n ): Promise<AuthTokenResponse> {\n return await this._useSession(async (result) => {\n try {\n const {\n error: sessionError,\n data: { session },\n } = result\n if (sessionError) throw sessionError\n\n const { options, provider, token, access_token, nonce } = credentials\n\n const res = await _request(this.fetch, 'POST', `${this.url}/token?grant_type=id_token`, {\n headers: this.headers,\n jwt: session?.access_token ?? undefined,\n body: {\n provider,\n id_token: token,\n access_token,\n nonce,\n link_identity: true,\n gotrue_meta_security: { captcha_token: options?.captchaToken },\n },\n xform: _sessionResponse,\n })\n\n const { data, error } = res\n if (error) {\n return this._returnResult({ data: { user: null, session: null }, error })\n } else if (!data || !data.session || !data.user) {\n return this._returnResult({\n data: { user: null, session: null },\n error: new AuthInvalidTokenResponseError(),\n })\n }\n if (data.session) {\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('USER_UPDATED', data.session)\n }\n return this._returnResult({ data, error })\n } catch (error) {\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n if (isAuthError(error)) {\n return this._returnResult({ data: { user: null, session: null }, error })\n }\n throw error\n }\n })\n }\n\n /**\n * Unlinks an identity from a user by deleting it. The user will no longer be able to sign in with that identity once it's unlinked.\n */\n async unlinkIdentity(identity: UserIdentity): Promise<\n | {\n data: {}\n error: null\n }\n | { data: null; error: AuthError }\n > {\n try {\n return await this._useSession(async (result) => {\n const { data, error } = result\n if (error) {\n throw error\n }\n return await _request(\n this.fetch,\n 'DELETE',\n `${this.url}/user/identities/${identity.identity_id}`,\n {\n headers: this.headers,\n jwt: data.session?.access_token ?? undefined,\n }\n )\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n }\n\n /**\n * Generates a new JWT.\n * @param refreshToken A valid refresh token that was returned on login.\n */\n private async _refreshAccessToken(refreshToken: string): Promise<AuthResponse> {\n const debugName = `#_refreshAccessToken(${refreshToken.substring(0, 5)}...)`\n this._debug(debugName, 'begin')\n\n try {\n const startedAt = Date.now()\n\n // will attempt to refresh the token with exponential backoff\n return await retryable(\n async (attempt) => {\n if (attempt > 0) {\n await sleep(200 * Math.pow(2, attempt - 1)) // 200, 400, 800, ...\n }\n\n this._debug(debugName, 'refreshing attempt', attempt)\n\n return await _request(this.fetch, 'POST', `${this.url}/token?grant_type=refresh_token`, {\n body: { refresh_token: refreshToken },\n headers: this.headers,\n xform: _sessionResponse,\n })\n },\n (attempt, error) => {\n const nextBackOffInterval = 200 * Math.pow(2, attempt)\n return (\n error &&\n isAuthRetryableFetchError(error) &&\n // retryable only if the request can be sent before the backoff overflows the tick duration\n Date.now() + nextBackOffInterval - startedAt < AUTO_REFRESH_TICK_DURATION_MS\n )\n }\n )\n } catch (error) {\n this._debug(debugName, 'error', error)\n\n if (isAuthError(error)) {\n return this._returnResult({ data: { session: null, user: null }, error })\n }\n throw error\n } finally {\n this._debug(debugName, 'end')\n }\n }\n\n private _isValidSession(maybeSession: unknown): maybeSession is Session {\n const isValidSession =\n typeof maybeSession === 'object' &&\n maybeSession !== null &&\n 'access_token' in maybeSession &&\n 'refresh_token' in maybeSession &&\n 'expires_at' in maybeSession\n\n return isValidSession\n }\n\n private async _handleProviderSignIn(\n provider: Provider,\n options: {\n redirectTo?: string\n scopes?: string\n queryParams?: { [key: string]: string }\n skipBrowserRedirect?: boolean\n }\n ) {\n const url: string = await this._getUrlForProvider(`${this.url}/authorize`, provider, {\n redirectTo: options.redirectTo,\n scopes: options.scopes,\n queryParams: options.queryParams,\n })\n\n this._debug('#_handleProviderSignIn()', 'provider', provider, 'options', options, 'url', url)\n\n // try to open on the browser\n if (isBrowser() && !options.skipBrowserRedirect) {\n window.location.assign(url)\n }\n\n return { data: { provider, url }, error: null }\n }\n\n /**\n * Recovers the session from LocalStorage and refreshes the token\n * Note: this method is async to accommodate for AsyncStorage e.g. in React native.\n */\n private async _recoverAndRefresh() {\n const debugName = '#_recoverAndRefresh()'\n this._debug(debugName, 'begin')\n\n try {\n const currentSession = (await getItemAsync(this.storage, this.storageKey)) as Session | null\n\n if (currentSession && this.userStorage) {\n let maybeUser: { user: User | null } | null = (await getItemAsync(\n this.userStorage,\n this.storageKey + '-user'\n )) as any\n\n if (!this.storage.isServer && Object.is(this.storage, this.userStorage) && !maybeUser) {\n // storage and userStorage are the same storage medium, for example\n // window.localStorage if userStorage does not have the user from\n // storage stored, store it first thereby migrating the user object\n // from storage -> userStorage\n\n maybeUser = { user: currentSession.user }\n await setItemAsync(this.userStorage, this.storageKey + '-user', maybeUser)\n }\n\n currentSession.user = maybeUser?.user ?? userNotAvailableProxy()\n } else if (currentSession && !currentSession.user) {\n // user storage is not set, let's check if it was previously enabled so\n // we bring back the storage as it should be\n\n if (!currentSession.user) {\n // test if userStorage was previously enabled and the storage medium was the same, to move the user back under the same key\n const separateUser: { user: User | null } | null = (await getItemAsync(\n this.storage,\n this.storageKey + '-user'\n )) as any\n\n if (separateUser && separateUser?.user) {\n currentSession.user = separateUser.user\n\n await removeItemAsync(this.storage, this.storageKey + '-user')\n await setItemAsync(this.storage, this.storageKey, currentSession)\n } else {\n currentSession.user = userNotAvailableProxy()\n }\n }\n }\n\n this._debug(debugName, 'session from storage', currentSession)\n\n if (!this._isValidSession(currentSession)) {\n this._debug(debugName, 'session is not valid')\n if (currentSession !== null) {\n await this._removeSession()\n }\n\n return\n }\n\n const expiresWithMargin =\n (currentSession.expires_at ?? Infinity) * 1000 - Date.now() < EXPIRY_MARGIN_MS\n\n this._debug(\n debugName,\n `session has${expiresWithMargin ? '' : ' not'} expired with margin of ${EXPIRY_MARGIN_MS}s`\n )\n\n if (expiresWithMargin) {\n if (this.autoRefreshToken && currentSession.refresh_token) {\n const { error } = await this._callRefreshToken(currentSession.refresh_token)\n\n if (error) {\n console.error(error)\n\n if (!isAuthRetryableFetchError(error)) {\n this._debug(\n debugName,\n 'refresh failed with a non-retryable error, removing the session',\n error\n )\n await this._removeSession()\n }\n }\n }\n } else if (\n currentSession.user &&\n (currentSession.user as any).__isUserNotAvailableProxy === true\n ) {\n // If we have a proxy user, try to get the real user data\n try {\n const { data, error: userError } = await this._getUser(currentSession.access_token)\n\n if (!userError && data?.user) {\n currentSession.user = data.user\n await this._saveSession(currentSession)\n await this._notifyAllSubscribers('SIGNED_IN', currentSession)\n } else {\n this._debug(debugName, 'could not get user data, skipping SIGNED_IN notification')\n }\n } catch (getUserError) {\n console.error('Error getting user data:', getUserError)\n this._debug(\n debugName,\n 'error getting user data, skipping SIGNED_IN notification',\n getUserError\n )\n }\n } else {\n // no need to persist currentSession again, as we just loaded it from\n // local storage; persisting it again may overwrite a value saved by\n // another client with access to the same local storage\n await this._notifyAllSubscribers('SIGNED_IN', currentSession)\n }\n } catch (err) {\n this._debug(debugName, 'error', err)\n\n console.error(err)\n return\n } finally {\n this._debug(debugName, 'end')\n }\n }\n\n private async _callRefreshToken(refreshToken: string): Promise<CallRefreshTokenResult> {\n if (!refreshToken) {\n throw new AuthSessionMissingError()\n }\n\n // refreshing is already in progress\n if (this.refreshingDeferred) {\n return this.refreshingDeferred.promise\n }\n\n const debugName = `#_callRefreshToken(${refreshToken.substring(0, 5)}...)`\n\n this._debug(debugName, 'begin')\n\n try {\n this.refreshingDeferred = new Deferred<CallRefreshTokenResult>()\n\n const { data, error } = await this._refreshAccessToken(refreshToken)\n if (error) throw error\n if (!data.session) throw new AuthSessionMissingError()\n\n await this._saveSession(data.session)\n await this._notifyAllSubscribers('TOKEN_REFRESHED', data.session)\n\n const result = { data: data.session, error: null }\n\n this.refreshingDeferred.resolve(result)\n\n return result\n } catch (error) {\n this._debug(debugName, 'error', error)\n\n if (isAuthError(error)) {\n const result = { data: null, error }\n\n if (!isAuthRetryableFetchError(error)) {\n await this._removeSession()\n }\n\n this.refreshingDeferred?.resolve(result)\n\n return result\n }\n\n this.refreshingDeferred?.reject(error)\n throw error\n } finally {\n this.refreshingDeferred = null\n this._debug(debugName, 'end')\n }\n }\n\n private async _notifyAllSubscribers(\n event: AuthChangeEvent,\n session: Session | null,\n broadcast = true\n ) {\n const debugName = `#_notifyAllSubscribers(${event})`\n this._debug(debugName, 'begin', session, `broadcast = ${broadcast}`)\n\n try {\n if (this.broadcastChannel && broadcast) {\n this.broadcastChannel.postMessage({ event, session })\n }\n\n const errors: any[] = []\n const promises = Array.from(this.stateChangeEmitters.values()).map(async (x) => {\n try {\n await x.callback(event, session)\n } catch (e: any) {\n errors.push(e)\n }\n })\n\n await Promise.all(promises)\n\n if (errors.length > 0) {\n for (let i = 0; i < errors.length; i += 1) {\n console.error(errors[i])\n }\n\n throw errors[0]\n }\n } finally {\n this._debug(debugName, 'end')\n }\n }\n\n /**\n * set currentSession and currentUser\n * process to _startAutoRefreshToken if possible\n */\n private async _saveSession(session: Session) {\n this._debug('#_saveSession()', session)\n // _saveSession is always called whenever a new session has been acquired\n // so we can safely suppress the warning returned by future getSession calls\n this.suppressGetSessionWarning = true\n await removeItemAsync(this.storage, `${this.storageKey}-code-verifier`)\n // Create a shallow copy to work with, to avoid mutating the original session object if it's used elsewhere\n const sessionToProcess = { ...session }\n\n const userIsProxy =\n sessionToProcess.user && (sessionToProcess.user as any).__isUserNotAvailableProxy === true\n if (this.userStorage) {\n if (!userIsProxy && sessionToProcess.user) {\n // If it's a real user object, save it to userStorage.\n await setItemAsync(this.userStorage, this.storageKey + '-user', {\n user: sessionToProcess.user,\n })\n } else if (userIsProxy) {\n // If it's the proxy, it means user was not found in userStorage.\n // We should ensure no stale user data for this key exists in userStorage if we were to save null,\n // or simply not save the proxy. For now, we don't save the proxy here.\n // If there's a need to clear userStorage if user becomes proxy, that logic would go here.\n }\n\n // Prepare the main session data for primary storage: remove the user property before cloning\n // This is important because the original session.user might be the proxy\n const mainSessionData: Omit<Session, 'user'> & { user?: User } = { ...sessionToProcess }\n delete mainSessionData.user // Remove user (real or proxy) before cloning for main storage\n\n const clonedMainSessionData = deepClone(mainSessionData)\n await setItemAsync(this.storage, this.storageKey, clonedMainSessionData)\n } else {\n // No userStorage is configured.\n // In this case, session.user should ideally not be a proxy.\n // If it were, structuredClone would fail. This implies an issue elsewhere if user is a proxy here\n const clonedSession = deepClone(sessionToProcess) // sessionToProcess still has its original user property\n await setItemAsync(this.storage, this.storageKey, clonedSession)\n }\n }\n\n private async _removeSession() {\n this._debug('#_removeSession()')\n\n this.suppressGetSessionWarning = false\n\n await removeItemAsync(this.storage, this.storageKey)\n await removeItemAsync(this.storage, this.storageKey + '-code-verifier')\n await removeItemAsync(this.storage, this.storageKey + '-user')\n\n if (this.userStorage) {\n await removeItemAsync(this.userStorage, this.storageKey + '-user')\n }\n\n await this._notifyAllSubscribers('SIGNED_OUT', null)\n }\n\n /**\n * Removes any registered visibilitychange callback.\n *\n * {@see #startAutoRefresh}\n * {@see #stopAutoRefresh}\n */\n private _removeVisibilityChangedCallback() {\n this._debug('#_removeVisibilityChangedCallback()')\n\n const callback = this.visibilityChangedCallback\n this.visibilityChangedCallback = null\n\n try {\n if (callback && isBrowser() && window?.removeEventListener) {\n window.removeEventListener('visibilitychange', callback)\n }\n } catch (e) {\n console.error('removing visibilitychange callback failed', e)\n }\n }\n\n /**\n * This is the private implementation of {@link #startAutoRefresh}. Use this\n * within the library.\n */\n private async _startAutoRefresh() {\n await this._stopAutoRefresh()\n\n this._debug('#_startAutoRefresh()')\n\n const ticker = setInterval(() => this._autoRefreshTokenTick(), AUTO_REFRESH_TICK_DURATION_MS)\n this.autoRefreshTicker = ticker\n\n if (ticker && typeof ticker === 'object' && typeof ticker.unref === 'function') {\n // ticker is a NodeJS Timeout object that has an `unref` method\n // https://nodejs.org/api/timers.html#timeoutunref\n // When auto refresh is used in NodeJS (like for testing) the\n // `setInterval` is preventing the process from being marked as\n // finished and tests run endlessly. This can be prevented by calling\n // `unref()` on the returned object.\n ticker.unref()\n // @ts-expect-error TS has no context of Deno\n } else if (typeof Deno !== 'undefined' && typeof Deno.unrefTimer === 'function') {\n // similar like for NodeJS, but with the Deno API\n // https://deno.land/api@latest?unstable&s=Deno.unrefTimer\n // @ts-expect-error TS has no context of Deno\n Deno.unrefTimer(ticker)\n }\n\n // run the tick immediately, but in the next pass of the event loop so that\n // #_initialize can be allowed to complete without recursively waiting on\n // itself\n const timeout = setTimeout(async () => {\n await this.initializePromise\n await this._autoRefreshTokenTick()\n }, 0)\n this.autoRefreshTickTimeout = timeout\n\n if (timeout && typeof timeout === 'object' && typeof timeout.unref === 'function') {\n timeout.unref()\n // @ts-expect-error TS has no context of Deno\n } else if (typeof Deno !== 'undefined' && typeof Deno.unrefTimer === 'function') {\n // @ts-expect-error TS has no context of Deno\n Deno.unrefTimer(timeout)\n }\n }\n\n /**\n * This is the private implementation of {@link #stopAutoRefresh}. Use this\n * within the library.\n */\n private async _stopAutoRefresh() {\n this._debug('#_stopAutoRefresh()')\n\n const ticker = this.autoRefreshTicker\n this.autoRefreshTicker = null\n\n if (ticker) {\n clearInterval(ticker)\n }\n\n const timeout = this.autoRefreshTickTimeout\n this.autoRefreshTickTimeout = null\n\n if (timeout) {\n clearTimeout(timeout)\n }\n }\n\n /**\n * Starts an auto-refresh process in the background. The session is checked\n * every few seconds. Close to the time of expiration a process is started to\n * refresh the session. If refreshing fails it will be retried for as long as\n * necessary.\n *\n * If you set the {@link GoTrueClientOptions#autoRefreshToken} you don't need\n * to call this function, it will be called for you.\n *\n * On browsers the refresh process works only when the tab/window is in the\n * foreground to conserve resources as well as prevent race conditions and\n * flooding auth with requests. If you call this method any managed\n * visibility change callback will be removed and you must manage visibility\n * changes on your own.\n *\n * On non-browser platforms the refresh process works *continuously* in the\n * background, which may not be desirable. You should hook into your\n * platform's foreground indication mechanism and call these methods\n * appropriately to conserve resources.\n *\n * {@see #stopAutoRefresh}\n */\n async startAutoRefresh() {\n this._removeVisibilityChangedCallback()\n await this._startAutoRefresh()\n }\n\n /**\n * Stops an active auto refresh process running in the background (if any).\n *\n * If you call this method any managed visibility change callback will be\n * removed and you must manage visibility changes on your own.\n *\n * See {@link #startAutoRefresh} for more details.\n */\n async stopAutoRefresh() {\n this._removeVisibilityChangedCallback()\n await this._stopAutoRefresh()\n }\n\n /**\n * Runs the auto refresh token tick.\n */\n private async _autoRefreshTokenTick() {\n this._debug('#_autoRefreshTokenTick()', 'begin')\n\n try {\n await this._acquireLock(0, async () => {\n try {\n const now = Date.now()\n\n try {\n return await this._useSession(async (result) => {\n const {\n data: { session },\n } = result\n\n if (!session || !session.refresh_token || !session.expires_at) {\n this._debug('#_autoRefreshTokenTick()', 'no session')\n return\n }\n\n // session will expire in this many ticks (or has already expired if <= 0)\n const expiresInTicks = Math.floor(\n (session.expires_at * 1000 - now) / AUTO_REFRESH_TICK_DURATION_MS\n )\n\n this._debug(\n '#_autoRefreshTokenTick()',\n `access token expires in ${expiresInTicks} ticks, a tick lasts ${AUTO_REFRESH_TICK_DURATION_MS}ms, refresh threshold is ${AUTO_REFRESH_TICK_THRESHOLD} ticks`\n )\n\n if (expiresInTicks <= AUTO_REFRESH_TICK_THRESHOLD) {\n await this._callRefreshToken(session.refresh_token)\n }\n })\n } catch (e: any) {\n console.error(\n 'Auto refresh tick failed with error. This is likely a transient error.',\n e\n )\n }\n } finally {\n this._debug('#_autoRefreshTokenTick()', 'end')\n }\n })\n } catch (e: any) {\n if (e.isAcquireTimeout || e instanceof LockAcquireTimeoutError) {\n this._debug('auto refresh token tick lock not available')\n } else {\n throw e\n }\n }\n }\n\n /**\n * Registers callbacks on the browser / platform, which in-turn run\n * algorithms when the browser window/tab are in foreground. On non-browser\n * platforms it assumes always foreground.\n */\n private async _handleVisibilityChange() {\n this._debug('#_handleVisibilityChange()')\n\n if (!isBrowser() || !window?.addEventListener) {\n if (this.autoRefreshToken) {\n // in non-browser environments the refresh token ticker runs always\n this.startAutoRefresh()\n }\n\n return false\n }\n\n try {\n this.visibilityChangedCallback = async () => await this._onVisibilityChanged(false)\n\n window?.addEventListener('visibilitychange', this.visibilityChangedCallback)\n\n // now immediately call the visbility changed callback to setup with the\n // current visbility state\n await this._onVisibilityChanged(true) // initial call\n } catch (error) {\n console.error('_handleVisibilityChange', error)\n }\n }\n\n /**\n * Callback registered with `window.addEventListener('visibilitychange')`.\n */\n private async _onVisibilityChanged(calledFromInitialize: boolean) {\n const methodName = `#_onVisibilityChanged(${calledFromInitialize})`\n this._debug(methodName, 'visibilityState', document.visibilityState)\n\n if (document.visibilityState === 'visible') {\n if (this.autoRefreshToken) {\n // in browser environments the refresh token ticker runs only on focused tabs\n // which prevents race conditions\n this._startAutoRefresh()\n }\n\n if (!calledFromInitialize) {\n // called when the visibility has changed, i.e. the browser\n // transitioned from hidden -> visible so we need to see if the session\n // should be recovered immediately... but to do that we need to acquire\n // the lock first asynchronously\n await this.initializePromise\n\n await this._acquireLock(this.lockAcquireTimeout, async () => {\n if (document.visibilityState !== 'visible') {\n this._debug(\n methodName,\n 'acquired the lock to recover the session, but the browser visibilityState is no longer visible, aborting'\n )\n\n // visibility has changed while waiting for the lock, abort\n return\n }\n\n // recover the session\n await this._recoverAndRefresh()\n })\n }\n } else if (document.visibilityState === 'hidden') {\n if (this.autoRefreshToken) {\n this._stopAutoRefresh()\n }\n }\n }\n\n /**\n * Generates the relevant login URL for a third-party provider.\n * @param options.redirectTo A URL or mobile address to send the user to after they are confirmed.\n * @param options.scopes A space-separated list of scopes granted to the OAuth application.\n * @param options.queryParams An object of key-value pairs containing query parameters granted to the OAuth application.\n */\n private async _getUrlForProvider(\n url: string,\n provider: Provider,\n options: {\n redirectTo?: string\n scopes?: string\n queryParams?: { [key: string]: string }\n skipBrowserRedirect?: boolean\n }\n ) {\n const urlParams: string[] = [`provider=${encodeURIComponent(provider)}`]\n if (options?.redirectTo) {\n urlParams.push(`redirect_to=${encodeURIComponent(options.redirectTo)}`)\n }\n if (options?.scopes) {\n urlParams.push(`scopes=${encodeURIComponent(options.scopes)}`)\n }\n if (this.flowType === 'pkce') {\n const [codeChallenge, codeChallengeMethod] = await getCodeChallengeAndMethod(\n this.storage,\n this.storageKey\n )\n\n const flowParams = new URLSearchParams({\n code_challenge: `${encodeURIComponent(codeChallenge)}`,\n code_challenge_method: `${encodeURIComponent(codeChallengeMethod)}`,\n })\n urlParams.push(flowParams.toString())\n }\n if (options?.queryParams) {\n const query = new URLSearchParams(options.queryParams)\n urlParams.push(query.toString())\n }\n if (options?.skipBrowserRedirect) {\n urlParams.push(`skip_http_redirect=${options.skipBrowserRedirect}`)\n }\n\n return `${url}?${urlParams.join('&')}`\n }\n\n private async _unenroll(params: MFAUnenrollParams): Promise<AuthMFAUnenrollResponse> {\n try {\n return await this._useSession(async (result) => {\n const { data: sessionData, error: sessionError } = result\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n return await _request(this.fetch, 'DELETE', `${this.url}/factors/${params.factorId}`, {\n headers: this.headers,\n jwt: sessionData?.session?.access_token,\n })\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n }\n\n /**\n * {@see GoTrueMFAApi#enroll}\n */\n private async _enroll(params: MFAEnrollTOTPParams): Promise<AuthMFAEnrollTOTPResponse>\n private async _enroll(params: MFAEnrollPhoneParams): Promise<AuthMFAEnrollPhoneResponse>\n private async _enroll(params: MFAEnrollWebauthnParams): Promise<AuthMFAEnrollWebauthnResponse>\n private async _enroll(params: MFAEnrollParams): Promise<AuthMFAEnrollResponse> {\n try {\n return await this._useSession(async (result) => {\n const { data: sessionData, error: sessionError } = result\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n const body = {\n friendly_name: params.friendlyName,\n factor_type: params.factorType,\n ...(params.factorType === 'phone'\n ? { phone: params.phone }\n : params.factorType === 'totp'\n ? { issuer: params.issuer }\n : {}),\n }\n\n const { data, error } = (await _request(this.fetch, 'POST', `${this.url}/factors`, {\n body,\n headers: this.headers,\n jwt: sessionData?.session?.access_token,\n })) as AuthMFAEnrollResponse\n if (error) {\n return this._returnResult({ data: null, error })\n }\n\n if (params.factorType === 'totp' && data.type === 'totp' && data?.totp?.qr_code) {\n data.totp.qr_code = `data:image/svg+xml;utf-8,${data.totp.qr_code}`\n }\n\n return this._returnResult({ data, error: null })\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n }\n\n /**\n * {@see GoTrueMFAApi#verify}\n */\n private async _verify(params: MFAVerifyTOTPParams): Promise<AuthMFAVerifyResponse>\n private async _verify(params: MFAVerifyPhoneParams): Promise<AuthMFAVerifyResponse>\n private async _verify<T extends 'create' | 'request'>(\n params: MFAVerifyWebauthnParams<T>\n ): Promise<AuthMFAVerifyResponse>\n private async _verify(params: MFAVerifyParams): Promise<AuthMFAVerifyResponse> {\n return this._acquireLock(this.lockAcquireTimeout, async () => {\n try {\n return await this._useSession(async (result) => {\n const { data: sessionData, error: sessionError } = result\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n const body: StrictOmit<\n | Exclude<MFAVerifyParams, MFAVerifyWebauthnParams>\n /** Exclude out the webauthn params from here because we're going to need to serialize them in the response */\n | Prettify<\n StrictOmit<MFAVerifyWebauthnParams, 'webauthn'> & {\n webauthn: Prettify<\n StrictOmit<MFAVerifyWebauthnParamFields['webauthn'], 'credential_response'> & {\n credential_response: PublicKeyCredentialJSON\n }\n >\n }\n >,\n /* Exclude challengeId because the backend expects snake_case, and exclude factorId since it's passed in the path params */\n 'challengeId' | 'factorId'\n > & {\n challenge_id: string\n } = {\n challenge_id: params.challengeId,\n ...('webauthn' in params\n ? {\n webauthn: {\n ...params.webauthn,\n credential_response:\n params.webauthn.type === 'create'\n ? serializeCredentialCreationResponse(\n params.webauthn.credential_response as RegistrationCredential\n )\n : serializeCredentialRequestResponse(\n params.webauthn.credential_response as AuthenticationCredential\n ),\n },\n }\n : { code: params.code }),\n }\n\n const { data, error } = await _request(\n this.fetch,\n 'POST',\n `${this.url}/factors/${params.factorId}/verify`,\n {\n body,\n headers: this.headers,\n jwt: sessionData?.session?.access_token,\n }\n )\n if (error) {\n return this._returnResult({ data: null, error })\n }\n\n await this._saveSession({\n expires_at: Math.round(Date.now() / 1000) + data.expires_in,\n ...data,\n })\n await this._notifyAllSubscribers('MFA_CHALLENGE_VERIFIED', data)\n\n return this._returnResult({ data, error })\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n })\n }\n\n /**\n * {@see GoTrueMFAApi#challenge}\n */\n private async _challenge(\n params: MFAChallengeTOTPParams\n ): Promise<Prettify<AuthMFAChallengeTOTPResponse>>\n private async _challenge(\n params: MFAChallengePhoneParams\n ): Promise<Prettify<AuthMFAChallengePhoneResponse>>\n private async _challenge(\n params: MFAChallengeWebauthnParams\n ): Promise<Prettify<AuthMFAChallengeWebauthnResponse>>\n private async _challenge(params: MFAChallengeParams): Promise<AuthMFAChallengeResponse> {\n return this._acquireLock(this.lockAcquireTimeout, async () => {\n try {\n return await this._useSession(async (result) => {\n const { data: sessionData, error: sessionError } = result\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n const response = (await _request(\n this.fetch,\n 'POST',\n `${this.url}/factors/${params.factorId}/challenge`,\n {\n body: params,\n headers: this.headers,\n jwt: sessionData?.session?.access_token,\n }\n )) as\n | Exclude<AuthMFAChallengeResponse, AuthMFAChallengeWebauthnResponse>\n /** The server will send `serialized` data, so we assert the serialized response */\n | AuthMFAChallengeWebauthnServerResponse\n\n if (response.error) {\n return response\n }\n\n const { data } = response\n\n if (data.type !== 'webauthn') {\n return { data, error: null }\n }\n\n switch (data.webauthn.type) {\n case 'create':\n return {\n data: {\n ...data,\n webauthn: {\n ...data.webauthn,\n credential_options: {\n ...data.webauthn.credential_options,\n publicKey: deserializeCredentialCreationOptions(\n data.webauthn.credential_options.publicKey\n ),\n },\n },\n },\n error: null,\n }\n case 'request':\n return {\n data: {\n ...data,\n webauthn: {\n ...data.webauthn,\n credential_options: {\n ...data.webauthn.credential_options,\n publicKey: deserializeCredentialRequestOptions(\n data.webauthn.credential_options.publicKey\n ),\n },\n },\n },\n error: null,\n }\n }\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n })\n }\n\n /**\n * {@see GoTrueMFAApi#challengeAndVerify}\n */\n private async _challengeAndVerify(\n params: MFAChallengeAndVerifyParams\n ): Promise<AuthMFAVerifyResponse> {\n // both _challenge and _verify independently acquire the lock, so no need\n // to acquire it here\n\n const { data: challengeData, error: challengeError } = await this._challenge({\n factorId: params.factorId,\n })\n if (challengeError) {\n return this._returnResult({ data: null, error: challengeError })\n }\n\n return await this._verify({\n factorId: params.factorId,\n challengeId: challengeData.id,\n code: params.code,\n })\n }\n\n /**\n * {@see GoTrueMFAApi#listFactors}\n */\n private async _listFactors(): Promise<AuthMFAListFactorsResponse> {\n // use #getUser instead of #_getUser as the former acquires a lock\n const {\n data: { user },\n error: userError,\n } = await this.getUser()\n if (userError) {\n return { data: null, error: userError }\n }\n\n const data: AuthMFAListFactorsResponse['data'] = {\n all: [],\n phone: [],\n totp: [],\n webauthn: [],\n }\n\n // loop over the factors ONCE\n for (const factor of user?.factors ?? []) {\n data.all.push(factor)\n if (factor.status === 'verified') {\n ;(data[factor.factor_type] as (typeof factor)[]).push(factor)\n }\n }\n\n return {\n data,\n error: null,\n }\n }\n\n /**\n * {@see GoTrueMFAApi#getAuthenticatorAssuranceLevel}\n */\n private async _getAuthenticatorAssuranceLevel(): Promise<AuthMFAGetAuthenticatorAssuranceLevelResponse> {\n const {\n data: { session },\n error: sessionError,\n } = await this.getSession()\n\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n if (!session) {\n return {\n data: { currentLevel: null, nextLevel: null, currentAuthenticationMethods: [] },\n error: null,\n }\n }\n\n const { payload } = decodeJWT(session.access_token)\n\n let currentLevel: AuthenticatorAssuranceLevels | null = null\n\n if (payload.aal) {\n currentLevel = payload.aal\n }\n\n let nextLevel: AuthenticatorAssuranceLevels | null = currentLevel\n\n const verifiedFactors =\n session.user.factors?.filter((factor: Factor) => factor.status === 'verified') ?? []\n\n if (verifiedFactors.length > 0) {\n nextLevel = 'aal2'\n }\n\n const currentAuthenticationMethods = payload.amr || []\n\n return { data: { currentLevel, nextLevel, currentAuthenticationMethods }, error: null }\n }\n\n /**\n * Retrieves details about an OAuth authorization request.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n *\n * Returns authorization details including client info, scopes, and user information.\n * If the API returns a redirect_uri, it means consent was already given - the caller\n * should handle the redirect manually if needed.\n */\n private async _getAuthorizationDetails(\n authorizationId: string\n ): Promise<AuthOAuthAuthorizationDetailsResponse> {\n try {\n return await this._useSession(async (result) => {\n const {\n data: { session },\n error: sessionError,\n } = result\n\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n if (!session) {\n return this._returnResult({ data: null, error: new AuthSessionMissingError() })\n }\n\n return await _request(\n this.fetch,\n 'GET',\n `${this.url}/oauth/authorizations/${authorizationId}`,\n {\n headers: this.headers,\n jwt: session.access_token,\n xform: (data: any) => ({ data, error: null }),\n }\n )\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n\n throw error\n }\n }\n\n /**\n * Approves an OAuth authorization request.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\n private async _approveAuthorization(\n authorizationId: string,\n options?: { skipBrowserRedirect?: boolean }\n ): Promise<AuthOAuthConsentResponse> {\n try {\n return await this._useSession(async (result) => {\n const {\n data: { session },\n error: sessionError,\n } = result\n\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n if (!session) {\n return this._returnResult({ data: null, error: new AuthSessionMissingError() })\n }\n\n const response = await _request(\n this.fetch,\n 'POST',\n `${this.url}/oauth/authorizations/${authorizationId}/consent`,\n {\n headers: this.headers,\n jwt: session.access_token,\n body: { action: 'approve' },\n xform: (data: any) => ({ data, error: null }),\n }\n )\n\n if (response.data && response.data.redirect_url) {\n // Automatically redirect in browser unless skipBrowserRedirect is true\n if (isBrowser() && !options?.skipBrowserRedirect) {\n window.location.assign(response.data.redirect_url)\n }\n }\n\n return response\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n\n throw error\n }\n }\n\n /**\n * Denies an OAuth authorization request.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\n private async _denyAuthorization(\n authorizationId: string,\n options?: { skipBrowserRedirect?: boolean }\n ): Promise<AuthOAuthConsentResponse> {\n try {\n return await this._useSession(async (result) => {\n const {\n data: { session },\n error: sessionError,\n } = result\n\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n if (!session) {\n return this._returnResult({ data: null, error: new AuthSessionMissingError() })\n }\n\n const response = await _request(\n this.fetch,\n 'POST',\n `${this.url}/oauth/authorizations/${authorizationId}/consent`,\n {\n headers: this.headers,\n jwt: session.access_token,\n body: { action: 'deny' },\n xform: (data: any) => ({ data, error: null }),\n }\n )\n\n if (response.data && response.data.redirect_url) {\n // Automatically redirect in browser unless skipBrowserRedirect is true\n if (isBrowser() && !options?.skipBrowserRedirect) {\n window.location.assign(response.data.redirect_url)\n }\n }\n\n return response\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n\n throw error\n }\n }\n\n /**\n * Lists all OAuth grants that the authenticated user has authorized.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\n private async _listOAuthGrants(): Promise<AuthOAuthGrantsResponse> {\n try {\n return await this._useSession(async (result) => {\n const {\n data: { session },\n error: sessionError,\n } = result\n\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n if (!session) {\n return this._returnResult({ data: null, error: new AuthSessionMissingError() })\n }\n\n return await _request(this.fetch, 'GET', `${this.url}/user/oauth/grants`, {\n headers: this.headers,\n jwt: session.access_token,\n xform: (data: any) => ({ data, error: null }),\n })\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n\n throw error\n }\n }\n\n /**\n * Revokes a user's OAuth grant for a specific client.\n * Only relevant when the OAuth 2.1 server is enabled in Supabase Auth.\n */\n private async _revokeOAuthGrant(options: {\n clientId: string\n }): Promise<AuthOAuthRevokeGrantResponse> {\n try {\n return await this._useSession(async (result) => {\n const {\n data: { session },\n error: sessionError,\n } = result\n\n if (sessionError) {\n return this._returnResult({ data: null, error: sessionError })\n }\n\n if (!session) {\n return this._returnResult({ data: null, error: new AuthSessionMissingError() })\n }\n\n await _request(this.fetch, 'DELETE', `${this.url}/user/oauth/grants`, {\n headers: this.headers,\n jwt: session.access_token,\n query: { client_id: options.clientId },\n noResolveJson: true,\n })\n return { data: {}, error: null }\n })\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n\n throw error\n }\n }\n\n private async fetchJwk(kid: string, jwks: { keys: JWK[] } = { keys: [] }): Promise<JWK | null> {\n // try fetching from the supplied jwks\n let jwk = jwks.keys.find((key) => key.kid === kid)\n if (jwk) {\n return jwk\n }\n\n const now = Date.now()\n\n // try fetching from cache\n jwk = this.jwks.keys.find((key) => key.kid === kid)\n\n // jwk exists and jwks isn't stale\n if (jwk && this.jwks_cached_at + JWKS_TTL > now) {\n return jwk\n }\n // jwk isn't cached in memory so we need to fetch it from the well-known endpoint\n const { data, error } = await _request(this.fetch, 'GET', `${this.url}/.well-known/jwks.json`, {\n headers: this.headers,\n })\n if (error) {\n throw error\n }\n if (!data.keys || data.keys.length === 0) {\n return null\n }\n\n this.jwks = data\n this.jwks_cached_at = now\n\n // Find the signing key\n jwk = data.keys.find((key: any) => key.kid === kid)\n if (!jwk) {\n return null\n }\n return jwk\n }\n\n /**\n * Extracts the JWT claims present in the access token by first verifying the\n * JWT against the server's JSON Web Key Set endpoint\n * `/.well-known/jwks.json` which is often cached, resulting in significantly\n * faster responses. Prefer this method over {@link #getUser} which always\n * sends a request to the Auth server for each JWT.\n *\n * If the project is not using an asymmetric JWT signing key (like ECC or\n * RSA) it always sends a request to the Auth server (similar to {@link\n * #getUser}) to verify the JWT.\n *\n * @param jwt An optional specific JWT you wish to verify, not the one you\n * can obtain from {@link #getSession}.\n * @param options Various additional options that allow you to customize the\n * behavior of this method.\n */\n async getClaims(\n jwt?: string,\n options: {\n /**\n * @deprecated Please use options.jwks instead.\n */\n keys?: JWK[]\n\n /** If set to `true` the `exp` claim will not be validated against the current time. */\n allowExpired?: boolean\n\n /** If set, this JSON Web Key Set is going to have precedence over the cached value available on the server. */\n jwks?: { keys: JWK[] }\n } = {}\n ): Promise<\n | {\n data: { claims: JwtPayload; header: JwtHeader; signature: Uint8Array }\n error: null\n }\n | { data: null; error: AuthError }\n | { data: null; error: null }\n > {\n try {\n let token = jwt\n if (!token) {\n const { data, error } = await this.getSession()\n if (error || !data.session) {\n return this._returnResult({ data: null, error })\n }\n token = data.session.access_token\n }\n\n const {\n header,\n payload,\n signature,\n raw: { header: rawHeader, payload: rawPayload },\n } = decodeJWT(token)\n\n if (!options?.allowExpired) {\n // Reject expired JWTs should only happen if jwt argument was passed\n validateExp(payload.exp)\n }\n\n const signingKey =\n !header.alg ||\n header.alg.startsWith('HS') ||\n !header.kid ||\n !('crypto' in globalThis && 'subtle' in globalThis.crypto)\n ? null\n : await this.fetchJwk(header.kid, options?.keys ? { keys: options.keys } : options?.jwks)\n\n // If symmetric algorithm or WebCrypto API is unavailable, fallback to getUser()\n if (!signingKey) {\n const { error } = await this.getUser(token)\n if (error) {\n throw error\n }\n // getUser succeeds so the claims in the JWT can be trusted\n return {\n data: {\n claims: payload,\n header,\n signature,\n },\n error: null,\n }\n }\n\n const algorithm = getAlgorithm(header.alg)\n\n // Convert JWK to CryptoKey\n const publicKey = await crypto.subtle.importKey('jwk', signingKey, algorithm, true, [\n 'verify',\n ])\n\n // Verify the signature\n const isValid = await crypto.subtle.verify(\n algorithm,\n publicKey,\n signature,\n stringToUint8Array(`${rawHeader}.${rawPayload}`)\n )\n\n if (!isValid) {\n throw new AuthInvalidJwtError('Invalid JWT signature')\n }\n\n // If verification succeeds, decode and return claims\n return {\n data: {\n claims: payload,\n header,\n signature,\n },\n error: null,\n }\n } catch (error) {\n if (isAuthError(error)) {\n return this._returnResult({ data: null, error })\n }\n throw error\n }\n }\n}\n","import GoTrueClient from './GoTrueClient'\n\nconst AuthClient = GoTrueClient\n\nexport default AuthClient\n","// Generated automatically during releases by scripts/update-version-files.ts\n// This file provides runtime access to the package version for:\n// - HTTP request headers (e.g., X-Client-Info header for API requests)\n// - Debugging and support (identifying which version is running)\n// - Telemetry and logging (version reporting in errors/analytics)\n// - Ensuring build artifacts match the published package version\nexport const version = '2.90.1'\n","// constants.ts\nimport { RealtimeClientOptions } from '@supabase/realtime-js'\nimport { SupabaseAuthClientOptions } from './types'\nimport { version } from './version'\n\nlet JS_ENV = ''\n// @ts-ignore\nif (typeof Deno !== 'undefined') {\n JS_ENV = 'deno'\n} else if (typeof document !== 'undefined') {\n JS_ENV = 'web'\n} else if (typeof navigator !== 'undefined' && navigator.product === 'ReactNative') {\n JS_ENV = 'react-native'\n} else {\n JS_ENV = 'node'\n}\n\nexport const DEFAULT_HEADERS = { 'X-Client-Info': `supabase-js-${JS_ENV}/${version}` }\n\nexport const DEFAULT_GLOBAL_OPTIONS = {\n headers: DEFAULT_HEADERS,\n}\n\nexport const DEFAULT_DB_OPTIONS = {\n schema: 'public',\n}\n\nexport const DEFAULT_AUTH_OPTIONS: SupabaseAuthClientOptions = {\n autoRefreshToken: true,\n persistSession: true,\n detectSessionInUrl: true,\n flowType: 'implicit',\n}\n\nexport const DEFAULT_REALTIME_OPTIONS: RealtimeClientOptions = {}\n","type Fetch = typeof fetch\n\nexport const resolveFetch = (customFetch?: Fetch): Fetch => {\n if (customFetch) {\n return (...args: Parameters<Fetch>) => customFetch(...args)\n }\n return (...args: Parameters<Fetch>) => fetch(...args)\n}\n\nexport const resolveHeadersConstructor = () => {\n return Headers\n}\n\nexport const fetchWithAuth = (\n supabaseKey: string,\n getAccessToken: () => Promise<string | null>,\n customFetch?: Fetch\n): Fetch => {\n const fetch = resolveFetch(customFetch)\n const HeadersConstructor = resolveHeadersConstructor()\n\n return async (input, init) => {\n const accessToken = (await getAccessToken()) ?? supabaseKey\n let headers = new HeadersConstructor(init?.headers)\n\n if (!headers.has('apikey')) {\n headers.set('apikey', supabaseKey)\n }\n\n if (!headers.has('Authorization')) {\n headers.set('Authorization', `Bearer ${accessToken}`)\n }\n\n return fetch(input, { ...init, headers })\n }\n}\n","// helpers.ts\nimport { SupabaseClientOptions } from './types'\n\nexport function uuid() {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n var r = (Math.random() * 16) | 0,\n v = c == 'x' ? r : (r & 0x3) | 0x8\n return v.toString(16)\n })\n}\n\nexport function ensureTrailingSlash(url: string): string {\n return url.endsWith('/') ? url : url + '/'\n}\n\nexport const isBrowser = () => typeof window !== 'undefined'\n\nexport function applySettingDefaults<\n Database = any,\n SchemaName extends string & keyof Database = 'public' extends keyof Database\n ? 'public'\n : string & keyof Database,\n>(\n options: SupabaseClientOptions<SchemaName>,\n defaults: SupabaseClientOptions<any>\n): Required<SupabaseClientOptions<SchemaName>> {\n const {\n db: dbOptions,\n auth: authOptions,\n realtime: realtimeOptions,\n global: globalOptions,\n } = options\n const {\n db: DEFAULT_DB_OPTIONS,\n auth: DEFAULT_AUTH_OPTIONS,\n realtime: DEFAULT_REALTIME_OPTIONS,\n global: DEFAULT_GLOBAL_OPTIONS,\n } = defaults\n\n const result: Required<SupabaseClientOptions<SchemaName>> = {\n db: {\n ...DEFAULT_DB_OPTIONS,\n ...dbOptions,\n },\n auth: {\n ...DEFAULT_AUTH_OPTIONS,\n ...authOptions,\n },\n realtime: {\n ...DEFAULT_REALTIME_OPTIONS,\n ...realtimeOptions,\n },\n storage: {},\n global: {\n ...DEFAULT_GLOBAL_OPTIONS,\n ...globalOptions,\n headers: {\n ...(DEFAULT_GLOBAL_OPTIONS?.headers ?? {}),\n ...(globalOptions?.headers ?? {}),\n },\n },\n accessToken: async () => '',\n }\n\n if (options.accessToken) {\n result.accessToken = options.accessToken\n } else {\n // hack around Required<>\n delete (result as any).accessToken\n }\n\n return result\n}\n\n/**\n * Validates a Supabase client URL\n *\n * @param {string} supabaseUrl - The Supabase client URL string.\n * @returns {URL} - The validated base URL.\n * @throws {Error}\n */\nexport function validateSupabaseUrl(supabaseUrl: string): URL {\n const trimmedUrl = supabaseUrl?.trim()\n\n if (!trimmedUrl) {\n throw new Error('supabaseUrl is required.')\n }\n\n if (!trimmedUrl.match(/^https?:\\/\\//i)) {\n throw new Error('Invalid supabaseUrl: Must be a valid HTTP or HTTPS URL.')\n }\n\n try {\n return new URL(ensureTrailingSlash(trimmedUrl))\n } catch {\n throw Error('Invalid supabaseUrl: Provided URL is malformed.')\n }\n}\n","import { AuthClient } from '@supabase/auth-js'\nimport { SupabaseAuthClientOptions } from './types'\n\nexport class SupabaseAuthClient extends AuthClient {\n constructor(options: SupabaseAuthClientOptions) {\n super(options)\n }\n}\n","import type { AuthChangeEvent } from '@supabase/auth-js'\nimport { FunctionsClient } from '@supabase/functions-js'\nimport {\n PostgrestClient,\n type PostgrestFilterBuilder,\n type PostgrestQueryBuilder,\n} from '@supabase/postgrest-js'\nimport {\n type RealtimeChannel,\n type RealtimeChannelOptions,\n RealtimeClient,\n type RealtimeClientOptions,\n} from '@supabase/realtime-js'\nimport { StorageClient as SupabaseStorageClient } from '@supabase/storage-js'\nimport {\n DEFAULT_AUTH_OPTIONS,\n DEFAULT_DB_OPTIONS,\n DEFAULT_GLOBAL_OPTIONS,\n DEFAULT_REALTIME_OPTIONS,\n} from './lib/constants'\nimport { fetchWithAuth } from './lib/fetch'\nimport { applySettingDefaults, validateSupabaseUrl } from './lib/helpers'\nimport { SupabaseAuthClient } from './lib/SupabaseAuthClient'\nimport type {\n Fetch,\n GenericSchema,\n SupabaseAuthClientOptions,\n SupabaseClientOptions,\n} from './lib/types'\nimport { GetRpcFunctionFilterBuilderByArgs } from './lib/rest/types/common/rpc'\n\n/**\n * Supabase Client.\n *\n * An isomorphic Javascript client for interacting with Postgres.\n */\nexport default class SupabaseClient<\n Database = any,\n // The second type parameter is also used for specifying db_schema, so we\n // support both cases.\n // TODO: Allow setting db_schema from ClientOptions.\n SchemaNameOrClientOptions extends\n | (string & keyof Omit<Database, '__InternalSupabase'>)\n | { PostgrestVersion: string } = 'public' extends keyof Omit<Database, '__InternalSupabase'>\n ? 'public'\n : string & keyof Omit<Database, '__InternalSupabase'>,\n SchemaName extends string &\n keyof Omit<Database, '__InternalSupabase'> = SchemaNameOrClientOptions extends string &\n keyof Omit<Database, '__InternalSupabase'>\n ? SchemaNameOrClientOptions\n : 'public' extends keyof Omit<Database, '__InternalSupabase'>\n ? 'public'\n : string & keyof Omit<Omit<Database, '__InternalSupabase'>, '__InternalSupabase'>,\n Schema extends Omit<Database, '__InternalSupabase'>[SchemaName] extends GenericSchema\n ? Omit<Database, '__InternalSupabase'>[SchemaName]\n : never = Omit<Database, '__InternalSupabase'>[SchemaName] extends GenericSchema\n ? Omit<Database, '__InternalSupabase'>[SchemaName]\n : never,\n ClientOptions extends { PostgrestVersion: string } = SchemaNameOrClientOptions extends string &\n keyof Omit<Database, '__InternalSupabase'>\n ? // If the version isn't explicitly set, look for it in the __InternalSupabase object to infer the right version\n Database extends { __InternalSupabase: { PostgrestVersion: string } }\n ? Database['__InternalSupabase']\n : // otherwise default to 12\n { PostgrestVersion: '12' }\n : SchemaNameOrClientOptions extends { PostgrestVersion: string }\n ? SchemaNameOrClientOptions\n : never,\n> {\n /**\n * Supabase Auth allows you to create and manage user sessions for access to data that is secured by access policies.\n */\n auth: SupabaseAuthClient\n realtime: RealtimeClient\n /**\n * Supabase Storage allows you to manage user-generated content, such as photos or videos.\n */\n storage: SupabaseStorageClient\n\n protected realtimeUrl: URL\n protected authUrl: URL\n protected storageUrl: URL\n protected functionsUrl: URL\n protected rest: PostgrestClient<Database, ClientOptions, SchemaName>\n protected storageKey: string\n protected fetch?: Fetch\n protected changedAccessToken?: string\n protected accessToken?: () => Promise<string | null>\n\n protected headers: Record<string, string>\n\n /**\n * Create a new client for use in the browser.\n * @param supabaseUrl The unique Supabase URL which is supplied when you create a new project in your project dashboard.\n * @param supabaseKey The unique Supabase Key which is supplied when you create a new project in your project dashboard.\n * @param options.db.schema You can switch in between schemas. The schema needs to be on the list of exposed schemas inside Supabase.\n * @param options.auth.autoRefreshToken Set to \"true\" if you want to automatically refresh the token before expiring.\n * @param options.auth.persistSession Set to \"true\" if you want to automatically save the user session into local storage.\n * @param options.auth.detectSessionInUrl Set to \"true\" if you want to automatically detects OAuth grants in the URL and signs in the user.\n * @param options.realtime Options passed along to realtime-js constructor.\n * @param options.storage Options passed along to the storage-js constructor.\n * @param options.global.fetch A custom fetch implementation.\n * @param options.global.headers Any additional headers to send with each network request.\n * @example\n * ```ts\n * import { createClient } from '@supabase/supabase-js'\n *\n * const supabase = createClient('https://xyzcompany.supabase.co', 'public-anon-key')\n * const { data } = await supabase.from('profiles').select('*')\n * ```\n */\n constructor(\n protected supabaseUrl: string,\n protected supabaseKey: string,\n options?: SupabaseClientOptions<SchemaName>\n ) {\n const baseUrl = validateSupabaseUrl(supabaseUrl)\n if (!supabaseKey) throw new Error('supabaseKey is required.')\n\n this.realtimeUrl = new URL('realtime/v1', baseUrl)\n this.realtimeUrl.protocol = this.realtimeUrl.protocol.replace('http', 'ws')\n this.authUrl = new URL('auth/v1', baseUrl)\n this.storageUrl = new URL('storage/v1', baseUrl)\n this.functionsUrl = new URL('functions/v1', baseUrl)\n\n // default storage key uses the supabase project ref as a namespace\n const defaultStorageKey = `sb-${baseUrl.hostname.split('.')[0]}-auth-token`\n const DEFAULTS = {\n db: DEFAULT_DB_OPTIONS,\n realtime: DEFAULT_REALTIME_OPTIONS,\n auth: { ...DEFAULT_AUTH_OPTIONS, storageKey: defaultStorageKey },\n global: DEFAULT_GLOBAL_OPTIONS,\n }\n\n const settings = applySettingDefaults(options ?? {}, DEFAULTS)\n\n this.storageKey = settings.auth.storageKey ?? ''\n this.headers = settings.global.headers ?? {}\n\n if (!settings.accessToken) {\n this.auth = this._initSupabaseAuthClient(\n settings.auth ?? {},\n this.headers,\n settings.global.fetch\n )\n } else {\n this.accessToken = settings.accessToken\n\n this.auth = new Proxy<SupabaseAuthClient>({} as any, {\n get: (_, prop) => {\n throw new Error(\n `@supabase/supabase-js: Supabase Client is configured with the accessToken option, accessing supabase.auth.${String(\n prop\n )} is not possible`\n )\n },\n })\n }\n\n this.fetch = fetchWithAuth(supabaseKey, this._getAccessToken.bind(this), settings.global.fetch)\n this.realtime = this._initRealtimeClient({\n headers: this.headers,\n accessToken: this._getAccessToken.bind(this),\n ...settings.realtime,\n })\n if (this.accessToken) {\n // Start auth immediately to avoid race condition with channel subscriptions\n this.accessToken()\n .then((token) => this.realtime.setAuth(token))\n .catch((e) => console.warn('Failed to set initial Realtime auth token:', e))\n }\n\n this.rest = new PostgrestClient(new URL('rest/v1', baseUrl).href, {\n headers: this.headers,\n schema: settings.db.schema,\n fetch: this.fetch,\n })\n\n this.storage = new SupabaseStorageClient(\n this.storageUrl.href,\n this.headers,\n this.fetch,\n options?.storage\n )\n\n if (!settings.accessToken) {\n this._listenForAuthEvents()\n }\n }\n\n /**\n * Supabase Functions allows you to deploy and invoke edge functions.\n */\n get functions(): FunctionsClient {\n return new FunctionsClient(this.functionsUrl.href, {\n headers: this.headers,\n customFetch: this.fetch,\n })\n }\n\n // NOTE: signatures must be kept in sync with PostgrestClient.from\n from<\n TableName extends string & keyof Schema['Tables'],\n Table extends Schema['Tables'][TableName],\n >(relation: TableName): PostgrestQueryBuilder<ClientOptions, Schema, Table, TableName>\n from<ViewName extends string & keyof Schema['Views'], View extends Schema['Views'][ViewName]>(\n relation: ViewName\n ): PostgrestQueryBuilder<ClientOptions, Schema, View, ViewName>\n /**\n * Perform a query on a table or a view.\n *\n * @param relation - The table or view name to query\n */\n from(relation: string): PostgrestQueryBuilder<ClientOptions, Schema, any> {\n return this.rest.from(relation)\n }\n\n // NOTE: signatures must be kept in sync with PostgrestClient.schema\n /**\n * Select a schema to query or perform an function (rpc) call.\n *\n * The schema needs to be on the list of exposed schemas inside Supabase.\n *\n * @param schema - The schema to query\n */\n schema<DynamicSchema extends string & keyof Omit<Database, '__InternalSupabase'>>(\n schema: DynamicSchema\n ): PostgrestClient<\n Database,\n ClientOptions,\n DynamicSchema,\n Database[DynamicSchema] extends GenericSchema ? Database[DynamicSchema] : any\n > {\n return this.rest.schema<DynamicSchema>(schema)\n }\n\n // NOTE: signatures must be kept in sync with PostgrestClient.rpc\n /**\n * Perform a function call.\n *\n * @param fn - The function name to call\n * @param args - The arguments to pass to the function call\n * @param options - Named parameters\n * @param options.head - When set to `true`, `data` will not be returned.\n * Useful if you only need the count.\n * @param options.get - When set to `true`, the function will be called with\n * read-only access mode.\n * @param options.count - Count algorithm to use to count rows returned by the\n * function. Only applicable for [set-returning\n * functions](https://www.postgresql.org/docs/current/functions-srf.html).\n *\n * `\"exact\"`: Exact but slow count algorithm. Performs a `COUNT(*)` under the\n * hood.\n *\n * `\"planned\"`: Approximated but fast count algorithm. Uses the Postgres\n * statistics under the hood.\n *\n * `\"estimated\"`: Uses exact count for low numbers and planned count for high\n * numbers.\n */\n rpc<\n FnName extends string & keyof Schema['Functions'],\n Args extends Schema['Functions'][FnName]['Args'] = never,\n FilterBuilder extends GetRpcFunctionFilterBuilderByArgs<\n Schema,\n FnName,\n Args\n > = GetRpcFunctionFilterBuilderByArgs<Schema, FnName, Args>,\n >(\n fn: FnName,\n args: Args = {} as Args,\n options: {\n head?: boolean\n get?: boolean\n count?: 'exact' | 'planned' | 'estimated'\n } = {\n head: false,\n get: false,\n count: undefined,\n }\n ): PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n FilterBuilder['Row'],\n FilterBuilder['Result'],\n FilterBuilder['RelationName'],\n FilterBuilder['Relationships'],\n 'RPC'\n > {\n return this.rest.rpc(fn, args, options) as unknown as PostgrestFilterBuilder<\n ClientOptions,\n Schema,\n FilterBuilder['Row'],\n FilterBuilder['Result'],\n FilterBuilder['RelationName'],\n FilterBuilder['Relationships'],\n 'RPC'\n >\n }\n\n /**\n * Creates a Realtime channel with Broadcast, Presence, and Postgres Changes.\n *\n * @param {string} name - The name of the Realtime channel.\n * @param {Object} opts - The options to pass to the Realtime channel.\n *\n */\n channel(name: string, opts: RealtimeChannelOptions = { config: {} }): RealtimeChannel {\n return this.realtime.channel(name, opts)\n }\n\n /**\n * Returns all Realtime channels.\n */\n getChannels(): RealtimeChannel[] {\n return this.realtime.getChannels()\n }\n\n /**\n * Unsubscribes and removes Realtime channel from Realtime client.\n *\n * @param {RealtimeChannel} channel - The name of the Realtime channel.\n *\n */\n removeChannel(channel: RealtimeChannel): Promise<'ok' | 'timed out' | 'error'> {\n return this.realtime.removeChannel(channel)\n }\n\n /**\n * Unsubscribes and removes all Realtime channels from Realtime client.\n */\n removeAllChannels(): Promise<('ok' | 'timed out' | 'error')[]> {\n return this.realtime.removeAllChannels()\n }\n\n private async _getAccessToken() {\n if (this.accessToken) {\n return await this.accessToken()\n }\n\n const { data } = await this.auth.getSession()\n\n return data.session?.access_token ?? this.supabaseKey\n }\n\n private _initSupabaseAuthClient(\n {\n autoRefreshToken,\n persistSession,\n detectSessionInUrl,\n storage,\n userStorage,\n storageKey,\n flowType,\n lock,\n debug,\n throwOnError,\n }: SupabaseAuthClientOptions,\n headers?: Record<string, string>,\n fetch?: Fetch\n ) {\n const authHeaders = {\n Authorization: `Bearer ${this.supabaseKey}`,\n apikey: `${this.supabaseKey}`,\n }\n return new SupabaseAuthClient({\n url: this.authUrl.href,\n headers: { ...authHeaders, ...headers },\n storageKey: storageKey,\n autoRefreshToken,\n persistSession,\n detectSessionInUrl,\n storage,\n userStorage,\n flowType,\n lock,\n debug,\n throwOnError,\n fetch,\n // auth checks if there is a custom authorizaiton header using this flag\n // so it knows whether to return an error when getUser is called with no session\n hasCustomAuthorizationHeader: Object.keys(this.headers).some(\n (key) => key.toLowerCase() === 'authorization'\n ),\n })\n }\n\n private _initRealtimeClient(options: RealtimeClientOptions) {\n return new RealtimeClient(this.realtimeUrl.href, {\n ...options,\n params: { ...{ apikey: this.supabaseKey }, ...options?.params },\n })\n }\n\n private _listenForAuthEvents() {\n const data = this.auth.onAuthStateChange((event, session) => {\n this._handleTokenChanged(event, 'CLIENT', session?.access_token)\n })\n return data\n }\n\n private _handleTokenChanged(\n event: AuthChangeEvent,\n source: 'CLIENT' | 'STORAGE',\n token?: string\n ) {\n if (\n (event === 'TOKEN_REFRESHED' || event === 'SIGNED_IN') &&\n this.changedAccessToken !== token\n ) {\n this.changedAccessToken = token\n this.realtime.setAuth(token)\n } else if (event === 'SIGNED_OUT') {\n this.realtime.setAuth()\n if (source == 'STORAGE') this.auth.signOut()\n this.changedAccessToken = undefined\n }\n }\n}\n","import SupabaseClient from './SupabaseClient'\nimport type { SupabaseClientOptions } from './lib/types'\n\nexport * from '@supabase/auth-js'\nexport type { User as AuthUser, Session as AuthSession } from '@supabase/auth-js'\nexport type {\n PostgrestResponse,\n PostgrestSingleResponse,\n PostgrestMaybeSingleResponse,\n} from '@supabase/postgrest-js'\nexport { PostgrestError } from '@supabase/postgrest-js'\nexport type { FunctionInvokeOptions } from '@supabase/functions-js'\nexport {\n FunctionsHttpError,\n FunctionsFetchError,\n FunctionsRelayError,\n FunctionsError,\n FunctionRegion,\n} from '@supabase/functions-js'\nexport * from '@supabase/realtime-js'\nexport { default as SupabaseClient } from './SupabaseClient'\nexport type {\n SupabaseClientOptions,\n QueryResult,\n QueryData,\n QueryError,\n DatabaseWithoutInternals,\n} from './lib/types'\n\n/**\n * Creates a new Supabase Client.\n *\n * @example\n * ```ts\n * import { createClient } from '@supabase/supabase-js'\n *\n * const supabase = createClient('https://xyzcompany.supabase.co', 'public-anon-key')\n * const { data, error } = await supabase.from('profiles').select('*')\n * ```\n */\nexport const createClient = <\n Database = any,\n SchemaNameOrClientOptions extends\n | (string & keyof Omit<Database, '__InternalSupabase'>)\n | { PostgrestVersion: string } = 'public' extends keyof Omit<Database, '__InternalSupabase'>\n ? 'public'\n : string & keyof Omit<Database, '__InternalSupabase'>,\n SchemaName extends string &\n keyof Omit<Database, '__InternalSupabase'> = SchemaNameOrClientOptions extends string &\n keyof Omit<Database, '__InternalSupabase'>\n ? SchemaNameOrClientOptions\n : 'public' extends keyof Omit<Database, '__InternalSupabase'>\n ? 'public'\n : string & keyof Omit<Omit<Database, '__InternalSupabase'>, '__InternalSupabase'>,\n>(\n supabaseUrl: string,\n supabaseKey: string,\n options?: SupabaseClientOptions<SchemaName>\n): SupabaseClient<Database, SchemaNameOrClientOptions, SchemaName> => {\n return new SupabaseClient<Database, SchemaNameOrClientOptions, SchemaName>(\n supabaseUrl,\n supabaseKey,\n options\n )\n}\n\n// Check for Node.js <= 18 deprecation\nfunction shouldShowDeprecationWarning(): boolean {\n // Skip in browser environments\n if (typeof window !== 'undefined') {\n return false\n }\n\n // Skip if process is not available (e.g., Edge Runtime)\n // Use dynamic property access to avoid Next.js Edge Runtime static analysis warnings\n const _process = (globalThis as any)['process']\n if (!_process) {\n return false\n }\n\n const processVersion = _process['version']\n if (processVersion === undefined || processVersion === null) {\n return false\n }\n\n const versionMatch = processVersion.match(/^v(\\d+)\\./)\n if (!versionMatch) {\n return false\n }\n\n const majorVersion = parseInt(versionMatch[1], 10)\n return majorVersion <= 18\n}\n\nif (shouldShowDeprecationWarning()) {\n console.warn(\n `⚠️ Node.js 18 and below are deprecated and will no longer be supported in future versions of @supabase/supabase-js. ` +\n `Please upgrade to Node.js 20 or later. ` +\n `For more information, visit: https://github.com/orgs/supabase/discussions/37217`\n )\n}\n","import { createClient, SupabaseClient } from '@supabase/supabase-js';\n\nexport function createSupabaseClient(url: string, key: string): SupabaseClient {\n return createClient(url, key);\n}\n","import { Facilitator, type PaymentRequirements, CronosNetwork } from '@crypto.com/facilitator-client';\n\nexport class FacilitatorClient {\n private facilitator: Facilitator;\n\n constructor(network: CronosNetwork = 'cronos-testnet', privateKey?: string) {\n // If privateKey is provided, set it in process.env for the Facilitator SDK to pick up\n // Note: The Facilitator SDK currently relies on process.env.WALLET_PRIVATE_KEY\n if (privateKey) {\n process.env.WALLET_PRIVATE_KEY = privateKey;\n }\n\n this.facilitator = new Facilitator({ network });\n }\n\n async settlePayment(params: {\n paymentHeader: string;\n paymentRequirements: PaymentRequirements;\n }) {\n try {\n // Build the verify request\n const verifyRequest = this.facilitator.buildVerifyRequest(\n params.paymentHeader,\n params.paymentRequirements\n );\n\n // Step 1: Verify the EIP-3009 authorization\n const verifyResult = await this.facilitator.verifyPayment(verifyRequest);\n\n if (!verifyResult.isValid) {\n throw new Error('Payment verification failed: Invalid signature or parameters');\n }\n\n // Step 2: Settle the payment on-chain\n const settleResult = await this.facilitator.settlePayment(verifyRequest);\n\n return {\n success: true,\n txHash: settleResult.txHash,\n timestamp: Date.now(),\n };\n } catch (error) {\n console.error('Payment settlement error', error);\n throw error;\n }\n }\n\n generatePaymentRequirements(params: {\n merchantAddress: string;\n amount: string;\n resourceUrl: string;\n description?: string;\n }): PaymentRequirements {\n return this.facilitator.generatePaymentRequirements({\n payTo: params.merchantAddress,\n maxAmountRequired: params.amount,\n resource: params.resourceUrl,\n description: params.description || 'Protected resource access',\n });\n }\n\n getFacilitator(): Facilitator {\n return this.facilitator;\n }\n}\n","/**\n * IPFS Metadata Service (SDK Version)\n */\n\nexport interface AgentMetadata {\n name: string;\n description: string;\n image?: string;\n external_url?: string;\n attributes: {\n trait_type: string;\n value: string | number;\n }[];\n service_type: string;\n endpoint: string;\n price_per_request: string;\n version: string;\n created_at: string;\n}\n\nexport async function uploadAgentMetadataToIPFS(\n metadata: AgentMetadata,\n apiBaseUrl: string\n): Promise<string> {\n try {\n const response = await fetch(`${apiBaseUrl}/api/ipfs/upload-metadata`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(metadata),\n });\n\n if (!response.ok) {\n const error = await response.json();\n throw new Error(error.error || 'IPFS upload failed');\n }\n\n const result = await response.json();\n return result.ipfsUri;\n } catch (error: unknown) {\n const message = error instanceof Error ? error.message : 'Unknown error';\n throw new Error(`Failed to upload to IPFS: ${message}`);\n }\n}\n\nexport function buildAgentMetadata(params: {\n name: string;\n description: string;\n serviceType: string;\n endpoint: string;\n pricePerRequest: string;\n imageUri?: string;\n}): AgentMetadata {\n return {\n name: params.name,\n description: params.description,\n image: params.imageUri,\n external_url: 'https://relaycore.xyz',\n attributes: [\n { trait_type: 'Service Type', value: params.serviceType },\n { trait_type: 'Network', value: 'Cronos Testnet' },\n { trait_type: 'Protocol', value: 'x402' },\n ],\n service_type: params.serviceType,\n endpoint: params.endpoint,\n price_per_request: params.pricePerRequest,\n version: '1.0.0',\n created_at: new Date().toISOString(),\n };\n}\n","import { ethers } from 'ethers';\n\nconst IDENTITY_REGISTRY_ABI = [\n 'function registerAgent(string memory agentURI, address walletAddress) external returns (uint256)',\n 'event AgentRegistered(uint256 indexed agentId, address indexed owner, string agentURI, address walletAddress)',\n];\n\nexport async function registerAgent(\n agentURI: string,\n walletAddress: string,\n signer: ethers.Signer,\n contractAddress: string\n): Promise<{ agentId: number; txHash: string }> {\n try {\n if (!contractAddress) {\n throw new Error('Identity Registry address not configured');\n }\n\n const identityRegistry = new ethers.Contract(\n contractAddress,\n IDENTITY_REGISTRY_ABI,\n signer\n );\n\n const tx = await identityRegistry.registerAgent(agentURI, walletAddress);\n const receipt = await tx.wait();\n\n // Extract agentId from event\n const event = receipt.logs.find((log: any) => {\n try {\n const parsed = identityRegistry.interface.parseLog(log);\n return parsed?.name === 'AgentRegistered';\n } catch {\n return false;\n }\n });\n\n if (event) {\n const parsed = identityRegistry.interface.parseLog(event);\n return {\n agentId: Number(parsed?.args.agentId),\n txHash: receipt.hash,\n };\n }\n\n throw new Error('AgentRegistered event not found');\n } catch (error: any) {\n console.error('Failed to register agent:', error);\n throw new Error(`Agent registration failed: ${error.message}`);\n }\n}\n","/**\n * Relay Core Agent SDK\n * \n * Enables AI agents to interact with Relay Core:\n * - Register services (on-chain + off-chain)\n * - Discover other agents\n * - Pay for services (x402)\n * - Submit feedback\n */\n\nimport { createSupabaseClient } from './lib/supabase';\nimport { FacilitatorClient } from './lib/facilitator';\nimport type { PaymentRequirements, CronosNetwork } from '@crypto.com/facilitator-client';\nimport { uploadAgentMetadataToIPFS, buildAgentMetadata } from './lib/ipfs';\nimport { registerAgent as registerAgentOnChain } from './lib/erc8004';\nimport { ethers } from 'ethers';\nimport { SupabaseClient } from '@supabase/supabase-js';\n\n// SDK Configuration\nexport interface SDKConfig {\n apiKey?: string; // API key for authenticated access\n walletAddress: string; // Agent's wallet address\n rpcUrl?: string; // Cronos RPC URL\n baseUrl?: string; // Relay Core API URL (default: localhost:4000)\n supabaseUrl?: string;\n supabaseKey?: string;\n contracts?: {\n identityRegistry?: string;\n };\n}\n\nexport interface AgentService {\n serviceId?: string;\n name: string;\n description: string;\n serviceType: string;\n pricePerRequest: string; // in USDC\n endpoint: string;\n agentAddress?: string;\n}\n\nexport interface AgentProfile {\n address: string;\n agentId?: number; // On-chain agent ID\n name?: string;\n services: AgentService[];\n reputationScore: number;\n successRate: number;\n}\n\nexport interface RegisterAgentResult {\n agentId: number;\n txHash: string;\n ipfsUri: string;\n}\n\n/**\n * Relay Core Agent SDK\n */\nexport class AgentSDK {\n private config: SDKConfig;\n private headers: Record<string, string>;\n private supabase: SupabaseClient | null = null;\n private facilitator: FacilitatorClient;\n\n constructor(config: SDKConfig) {\n this.config = {\n rpcUrl: 'https://evm-t3.cronos.org',\n baseUrl: 'http://localhost:4000',\n ...config,\n };\n\n // Set up headers with API key if provided\n this.headers = {\n 'Content-Type': 'application/json',\n };\n\n if (config.apiKey) {\n this.headers['x-api-key'] = config.apiKey;\n }\n\n // Initialize Supabase if config provided\n if (config.supabaseUrl && config.supabaseKey) {\n this.supabase = createSupabaseClient(config.supabaseUrl, config.supabaseKey);\n }\n\n // Initialize Facilitator\n // Determining network from RPC URL is heuristics, might be better to explicitly ask for network\n // For now defaulting to testnet\n this.facilitator = new FacilitatorClient('cronos-testnet' as CronosNetwork);\n }\n\n /**\n * Register an agent on-chain with IPFS metadata\n * \n * Requires a signer (wallet) to submit the transaction.\n */\n async registerAgentOnChain(\n service: Omit<AgentService, 'agentAddress' | 'serviceId'>,\n signer: ethers.Signer\n ): Promise<RegisterAgentResult> {\n // Build and upload metadata to IPFS\n const metadata = buildAgentMetadata({\n name: service.name,\n description: service.description,\n serviceType: service.serviceType,\n endpoint: service.endpoint,\n pricePerRequest: service.pricePerRequest,\n });\n\n // Use base URL for IPFS upload proxy\n const ipfsUri = await uploadAgentMetadataToIPFS(metadata, this.config.baseUrl || 'http://localhost:4000');\n\n // Register on-chain\n const { agentId, txHash } = await registerAgentOnChain(\n ipfsUri,\n this.config.walletAddress,\n signer,\n this.config.contracts?.identityRegistry || '0x4b697D8ABC0e3dA0086011222755d9029DBB9C43'\n );\n\n // Also save to Supabase for discoverability\n await this.registerServiceOffChain({\n ...service,\n serviceId: `agent-${agentId}`,\n });\n\n return { agentId, txHash, ipfsUri };\n }\n\n /**\n * Register a service (off-chain only, for discovery)\n */\n async registerServiceOffChain(service: Omit<AgentService, 'agentAddress'>): Promise<void> {\n // Use API if available\n if (this.config.apiKey) {\n const response = await fetch(`${this.config.baseUrl}/api/services`, {\n method: 'POST',\n headers: this.headers,\n body: JSON.stringify({\n ...service,\n agentAddress: this.config.walletAddress,\n }),\n });\n\n if (!response.ok) {\n const error = await response.json();\n throw new Error(`Failed to register service: ${error.error}`);\n }\n\n console.log(`Service registered: ${service.name}`);\n return;\n }\n\n // Fallback to direct Supabase\n if (!this.supabase) {\n console.warn('Supabase not configured. Off-chain service registration skiped.');\n return;\n }\n\n const { error } = await this.supabase.from('agent_activity').insert({\n agent_address: this.config.walletAddress,\n activity_type: 'service_registered',\n metadata: {\n serviceId: service.serviceId,\n name: service.name,\n description: service.description,\n serviceType: service.serviceType,\n pricePerRequest: service.pricePerRequest,\n endpoint: service.endpoint,\n },\n timestamp: new Date().toISOString(),\n });\n\n if (error) throw new Error(`Failed to register service: ${error.message}`);\n\n console.log(`Service registered: ${service.name}`);\n }\n\n /**\n * Discover agents by service type\n */\n async discoverAgents(serviceType: string, minReputation: number = 0): Promise<AgentProfile[]> {\n // Use API for discovery\n if (this.config.apiKey) {\n const response = await fetch(\n `${this.config.baseUrl}/api/agents?serviceType=${serviceType}&minReputation=${minReputation}`,\n { headers: this.headers }\n );\n\n if (!response.ok) {\n throw new Error('Failed to discover agents');\n }\n\n return response.json();\n }\n\n // Fallback to direct Supabase query\n if (!this.supabase) {\n throw new Error('Supabase not configured. Cannot discover agents without API Key or Supabase credentials.');\n }\n\n const { data: activities, error: actError } = await this.supabase\n .from('agent_activity')\n .select('agent_address, metadata')\n .eq('activity_type', 'service_registered')\n .contains('metadata', { serviceType });\n\n if (actError) throw new Error(`Failed to discover agents: ${actError.message}`);\n\n if (!activities || activities.length === 0) return [];\n\n const agentAddresses = [...new Set(activities.map((a: any) => a.agent_address))];\n\n const { data: reputations, error: repError } = await this.supabase\n .from('agent_reputation')\n .select('*')\n .in('agent_address', agentAddresses)\n .gte('reputation_score', minReputation);\n\n if (repError) throw new Error(`Failed to get reputations: ${repError.message}`);\n\n const profiles: AgentProfile[] = [];\n\n for (const address of agentAddresses) {\n const agentActivities = activities.filter((a: any) => a.agent_address === address);\n const reputation = reputations?.find((r: any) => r.agent_address === address);\n\n const services: AgentService[] = agentActivities.map((a: any) => ({\n serviceId: a.metadata.serviceId,\n name: a.metadata.name,\n description: a.metadata.description,\n serviceType: a.metadata.serviceType,\n pricePerRequest: a.metadata.pricePerRequest,\n endpoint: a.metadata.endpoint,\n agentAddress: address as string,\n }));\n\n const total = (reputation?.successful_transactions || 0) + (reputation?.failed_transactions || 0);\n const successRate = total > 0 ? (reputation?.successful_transactions || 0) / total : 0;\n\n profiles.push({\n address: address as string,\n services,\n reputationScore: reputation?.reputation_score || 0,\n successRate,\n });\n }\n\n return profiles.sort((a, b) => b.reputationScore - a.reputationScore);\n }\n\n /**\n * Get agent reputation\n */\n async getReputation(address: string): Promise<number> {\n if (!this.supabase) {\n return 0; // Or throw error\n }\n\n const { data, error } = await this.supabase\n .from('agent_reputation')\n .select('reputation_score')\n .eq('agent_address', address)\n .single();\n\n if (error) {\n if (error.code === 'PGRST116') return 0;\n throw new Error(`Failed to get reputation: ${error.message}`);\n }\n\n return data.reputation_score;\n }\n\n /**\n * Pay for a service using x402\n */\n async payForService(params: {\n serviceId: string;\n agentAddress: string;\n amount: string;\n signer: any;\n }): Promise<{ paymentId: string; txHash: string }> {\n const paymentRequirements = this.facilitator.generatePaymentRequirements({\n merchantAddress: params.agentAddress,\n amount: params.amount,\n resourceUrl: `https://relaycore.xyz/api/services/${params.serviceId}`,\n description: `Payment for service ${params.serviceId}`,\n });\n\n const facilitator = this.facilitator.getFacilitator();\n const now = Math.floor(Date.now() / 1000);\n const paymentHeader = await facilitator.generatePaymentHeader({\n to: params.agentAddress,\n value: paymentRequirements.maxAmountRequired,\n asset: paymentRequirements.asset,\n signer: params.signer,\n validAfter: now - 60,\n validBefore: now + 300,\n });\n\n const result = await this.facilitator.settlePayment({\n paymentHeader,\n paymentRequirements,\n });\n\n const txHash = result.txHash || '';\n const paymentId = `pay_${txHash.slice(2, 18)}`;\n\n console.log(`Payment settled: ${txHash}`);\n\n return { paymentId, txHash };\n }\n\n /**\n * Call a protected service endpoint with automatic payment\n */\n async callService(params: {\n endpoint: string;\n paymentRequirements: PaymentRequirements;\n signer: any;\n }): Promise<any> {\n let response = await fetch(params.endpoint, { headers: this.headers });\n\n if (response.status === 402) {\n await response.json();\n\n const facilitator = this.facilitator.getFacilitator();\n const now = Math.floor(Date.now() / 1000);\n const paymentHeader = await facilitator.generatePaymentHeader({\n to: params.paymentRequirements.payTo,\n value: params.paymentRequirements.maxAmountRequired,\n asset: params.paymentRequirements.asset,\n signer: params.signer,\n validAfter: now - 60,\n validBefore: now + (params.paymentRequirements.maxTimeoutSeconds || 300),\n });\n\n const result = await this.facilitator.settlePayment({\n paymentHeader,\n paymentRequirements: params.paymentRequirements,\n });\n\n const txHash = result.txHash || '';\n const paymentId = `pay_${txHash.slice(2, 18)}`;\n\n response = await fetch(params.endpoint, {\n headers: {\n ...this.headers,\n 'x-payment-id': paymentId,\n },\n });\n }\n\n if (!response.ok) {\n throw new Error(`Service call failed: ${response.statusText}`);\n }\n\n return response.json();\n }\n\n /**\n * Validate the API key\n */\n async validateApiKey(): Promise<boolean> {\n if (!this.config.apiKey) return false;\n\n try {\n const response = await fetch(`${this.config.baseUrl}/api/auth/validate`, {\n headers: this.headers,\n });\n return response.ok;\n } catch {\n return false;\n }\n }\n}\n\n/**\n * Create an Agent SDK instance\n * \n * @example\n * ```typescript\n * const sdk = createAgentSDK({\n * apiKey: 'rc_xxxxx',\n * walletAddress: '0x1234...',\n * });\n * ```\n */\nexport function createAgentSDK(config: SDKConfig): AgentSDK {\n return new AgentSDK(config);\n}\n","/**\n * X402 Payment Middleware - Cronos Standard Implementation\n * \n * Based on x402-examples reference from Cronos Labs.\n * Provides middleware for protecting routes with x402 payment requirements.\n */\n\nimport crypto from 'crypto';\nimport type { Request, Response, NextFunction } from 'express';\nimport type { Facilitator, VerifyRequest } from '@crypto.com/facilitator-client';\nimport type {\n X402Accepts,\n X402Response,\n X402PaidRecord,\n X402PayResult,\n X402ProtectionOptions,\n} from '../types/x402.types';\n\n/**\n * In-memory entitlement store keyed by payment ID.\n * \n * @remarks\n * For production, replace with persistent storage (Redis, Supabase, etc.)\n */\nconst paidEntitlements = new Map<string, X402PaidRecord>();\n\n/**\n * Generates a unique payment identifier per Cronos standard.\n * @returns Payment ID in format `pay_<uuid>`\n */\nexport const generatePaymentId = (): string => `pay_${crypto.randomUUID()}`;\n\n/**\n * Check if a payment ID has been settled.\n */\nexport function isEntitled(paymentId: string): boolean {\n return paidEntitlements.get(paymentId)?.settled === true;\n}\n\n/**\n * Get entitlement record for a payment ID.\n */\nexport function getEntitlement(paymentId: string): X402PaidRecord | undefined {\n return paidEntitlements.get(paymentId);\n}\n\n/**\n * Store an entitlement record after successful payment.\n */\nexport function recordEntitlement(paymentId: string, record: X402PaidRecord): void {\n paidEntitlements.set(paymentId, record);\n}\n\n/**\n * Creates Express middleware that enforces x402 payment.\n * \n * If the request is already entitled (has valid x-payment-id), calls next().\n * Otherwise, responds with HTTP 402 and x402 challenge.\n * \n * @example\n * ```ts\n * router.get('/protected', requireX402({\n * network: 'cronos-testnet',\n * payTo: '0x...',\n * asset: '0x...',\n * maxAmountRequired: '1000000',\n * description: 'Access to premium data',\n * resource: '/api/protected',\n * }), handler);\n * ```\n */\nexport function requireX402(options: X402ProtectionOptions) {\n const {\n network,\n payTo,\n asset,\n maxAmountRequired,\n maxTimeoutSeconds = 300,\n description,\n mimeType = 'application/json',\n resource,\n outputSchema,\n getEntitlementKey,\n } = options;\n\n return (req: Request, res: Response, next: NextFunction): void => {\n // Check for existing entitlement\n const entitlementKey = (\n getEntitlementKey?.(req) ??\n req.header('x-payment-id') ??\n ''\n ).trim();\n\n if (entitlementKey && isEntitled(entitlementKey)) {\n next();\n return;\n }\n\n // Generate new payment ID for challenge\n const paymentId = generatePaymentId();\n\n const accepts: X402Accepts = {\n scheme: 'exact',\n network,\n asset,\n payTo,\n maxAmountRequired,\n maxTimeoutSeconds,\n description,\n mimeType,\n resource,\n outputSchema,\n extra: { paymentId },\n };\n\n const response: X402Response = {\n x402Version: 1,\n error: 'payment_required',\n accepts: [accepts],\n };\n\n res.status(402).json(response);\n };\n}\n\n/**\n * Verifies and settles an x402 payment using the Facilitator SDK.\n * Records entitlement on success.\n * \n * @example\n * ```ts\n * const result = await handleX402Settlement({\n * facilitator,\n * paymentId: 'pay_...',\n * paymentHeader: '...',\n * paymentRequirements: {...},\n * });\n * ```\n */\nexport async function handleX402Settlement(params: {\n facilitator: Facilitator;\n paymentId: string;\n paymentHeader: string;\n paymentRequirements: VerifyRequest['paymentRequirements'];\n}): Promise<X402PayResult> {\n const { facilitator, paymentId, paymentHeader, paymentRequirements } = params;\n\n const body: VerifyRequest = {\n x402Version: 1,\n paymentHeader,\n paymentRequirements,\n };\n\n // Step 1: Verify\n const verify = await facilitator.verifyPayment(body);\n if (!verify.isValid) {\n return {\n ok: false,\n error: 'verify_failed',\n details: verify,\n };\n }\n\n // Step 2: Settle\n const settle = await facilitator.settlePayment(body);\n if (settle.event !== 'payment.settled') {\n return {\n ok: false,\n error: 'settle_failed',\n details: settle,\n };\n }\n\n // Step 3: Record entitlement\n recordEntitlement(paymentId, {\n settled: true,\n txHash: settle.txHash,\n at: Date.now(),\n });\n\n return {\n ok: true,\n txHash: settle.txHash,\n };\n}\n\n/**\n * Helper to create payment requirements for a resource.\n */\nexport function createPaymentRequirements(options: {\n network: string;\n payTo: string;\n asset: string;\n maxAmountRequired: string;\n resource: string;\n description: string;\n}): X402Accepts {\n return {\n scheme: 'exact',\n network: options.network as X402Accepts['network'],\n payTo: options.payTo,\n asset: options.asset,\n maxAmountRequired: options.maxAmountRequired,\n maxTimeoutSeconds: 300,\n description: options.description,\n mimeType: 'application/json',\n resource: options.resource,\n extra: { paymentId: generatePaymentId() },\n };\n}\n\nexport default {\n requireX402,\n handleX402Settlement,\n generatePaymentId,\n isEntitled,\n getEntitlement,\n recordEntitlement,\n createPaymentRequirements,\n};\n","/**\n * Chat Service Types\n * \n * Defines the chat API contract per the In-App Chat Architecture specification.\n * Chat is a control plane + explainer + orchestrator, NOT an executor.\n */\n\nexport type ChatMode = 'explain' | 'simulate' | 'plan' | 'observe';\n\nexport type ChatResponseType = 'explanation' | 'simulation' | 'plan' | 'observation' | 'error';\n\n/**\n * Chat request structure\n */\nexport interface ChatRequest {\n /** User's query */\n query: string;\n /** Operating mode */\n mode: ChatMode;\n /** Context for the request */\n context?: {\n sessionId?: string;\n agentId?: string;\n taskId?: string;\n walletAddress?: string;\n };\n /** Conversation history */\n history?: Array<{\n role: 'user' | 'assistant';\n content: string;\n }>;\n}\n\n/**\n * Proposed action that requires user approval\n */\nexport interface ChatAction {\n /** Human-readable label */\n label: string;\n /** API endpoint to call */\n endpoint: string;\n /** HTTP method */\n method: 'GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH';\n /** Request body */\n body: Record<string, unknown>;\n /** Whether this action requires explicit user approval */\n requiresApproval: boolean;\n /** Estimated cost if applicable */\n estimatedCost?: {\n amount: string;\n currency: string;\n };\n /** Risk level */\n riskLevel?: 'low' | 'medium' | 'high';\n}\n\n/**\n * Simulation result for dry-run operations\n */\nexport interface SimulationResult {\n /** What would happen */\n description: string;\n /** Expected outcome */\n expectedOutcome: {\n success: boolean;\n estimatedResult?: Record<string, unknown>;\n };\n /** Potential risks */\n risks?: string[];\n /** Required confirmations */\n confirmations?: string[];\n /** Gas/fee estimate */\n estimatedFees?: {\n gas?: string;\n payment?: string;\n total?: string;\n };\n}\n\n/**\n * Chat response structure\n */\nexport interface ChatResponse {\n /** Response type */\n type: ChatResponseType;\n /** Main content (human-readable) */\n content: string;\n /** Structured data */\n data?: Record<string, unknown>;\n /** Actions user can take (require approval) */\n actions?: ChatAction[];\n /** Simulation results (for simulate mode) */\n simulation?: SimulationResult;\n /** Data sources used */\n sources?: Array<{\n name: string;\n type: 'indexer' | 'api' | 'contract' | 'database';\n latencyMs?: number;\n }>;\n /** Processing metadata */\n meta?: {\n processingTimeMs: number;\n tokensUsed?: number;\n mode: ChatMode;\n };\n}\n\n/**\n * Chat capabilities per mode\n */\nexport const CHAT_CAPABILITIES = {\n explain: {\n description: 'Explain agent decisions, transactions, and system state',\n canExecute: false,\n canModify: false,\n },\n simulate: {\n description: 'Dry-run operations before committing',\n canExecute: false,\n canModify: false,\n },\n plan: {\n description: 'Create execution plans for user approval',\n canExecute: false,\n canModify: false,\n },\n observe: {\n description: 'Summarize trends, anomalies, and system health',\n canExecute: false,\n canModify: false,\n },\n} as const;\n\n/**\n * Prohibited chat operations\n * Chat should NEVER do these directly - they require SDK/MCP\n */\nexport const PROHIBITED_OPERATIONS = [\n 'send_transaction',\n 'sign_message',\n 'approve_token',\n 'execute_trade',\n 'release_payment',\n 'create_session',\n 'fund_session',\n] as const;\n","import { ethers } from 'ethers';\nimport { Facilitator } from '@crypto.com/facilitator-client';\n\nexport interface RWAConfig {\n apiUrl: string;\n facilitatorAddress?: string;\n provider?: ethers.BrowserProvider | ethers.JsonRpcProvider;\n}\n\nexport interface RWAStateMachine {\n id: string;\n rwaId: string;\n currentState: string;\n previousState: string | null;\n metadata: Record<string, unknown>;\n createdAt: string;\n updatedAt: string;\n}\n\nexport interface TransitionParams {\n rwaId: string;\n toState: string;\n agentAddress: string;\n agentRole: string;\n signer: ethers.Signer;\n}\n\nexport interface TransitionResult {\n success: boolean;\n txHash?: string;\n newState?: string;\n error?: string;\n}\n\n/**\n * RelayRWASDK - SDK for managing Real-World Asset (RWA) state machines\n * with x402 payment enforcement and agent coordination.\n */\nexport class RelayRWASDK {\n private config: RWAConfig;\n\n constructor(config: RWAConfig) {\n this.config = config;\n }\n\n /**\n * Create a new RWA state machine\n */\n async create(rwaId: string, metadata: Record<string, unknown> = {}): Promise<RWAStateMachine> {\n const response = await fetch(`${this.config.apiUrl}/api/rwa/state-machine/create`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ rwaId, metadata })\n });\n\n if (!response.ok) {\n throw new Error(`Failed to create RWA: ${response.statusText}`);\n }\n\n return await response.json();\n }\n\n /**\n * Get RWA state by ID\n */\n async getState(rwaId: string): Promise<RWAStateMachine> {\n const response = await fetch(`${this.config.apiUrl}/api/rwa/state-machine/${rwaId}/state`);\n\n if (!response.ok) {\n throw new Error(`Failed to get RWA state: ${response.statusText}`);\n }\n\n return await response.json();\n }\n\n /**\n * Transition RWA state with x402 payment enforcement\n */\n async transition(params: TransitionParams): Promise<TransitionResult> {\n const { rwaId, toState, agentAddress, agentRole, signer } = params;\n\n // Step 1: Request transition (expecting 402)\n const initResponse = await fetch(`${this.config.apiUrl}/api/rwa/state-machine/${rwaId}/transition`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ rwaId, toState, agentAddress, agentRole })\n });\n\n if (initResponse.status !== 402) {\n const data = await initResponse.json();\n return { success: true, newState: data.newState, txHash: data.txHash };\n }\n\n // Step 2: Handle x402 Payment\n const paymentRequirements = initResponse.headers.get('XXX-Payment-Config');\n if (!paymentRequirements) {\n throw new Error('No payment requirements received');\n }\n\n const requirements = JSON.parse(paymentRequirements);\n\n // Generate EIP-3009 signature using Facilitator Client logic\n // Note: In a real SDK bundle, this would use a properly instantiated Facilitator\n // For now, we simulate the client-side signing flow\n\n const signerAddress = await signer.getAddress();\n const facilitator = new Facilitator(requirements.payTo); // simplified\n\n // This is a placeholder for the actual SDK signing logic which might vary\n // depending on the environment (browser vs node)\n // In a real implementation, we'd reuse the logic from verify-payment.ts\n\n // For production use, we assume the user provides a payment header\n // generated by the Facilitator client separately if needed,\n // or we implement the full signing here.\n\n // TO DO: Full client-side signing implementation\n // For now, we return specific instructions\n throw new Error('SDK requires a fully initialized Facilitator instance for automatic payment signing. Please use the UI or CLI.');\n }\n}\n\n/**\n * Create a new RWA SDK instance\n */\nexport function createRWASDK(config: RWAConfig): RelayRWASDK {\n return new RelayRWASDK(config);\n}\n"],"mappings":"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","names":["retryable","NETWORK_CONFIG","retryable","import_ethers","DEFAULT_API_URL","FACILITATOR_URL","FunctionRegion","count: number | null","res","this","fetch","head","PostgrestClient","get","method: 'HEAD' | 'GET' | 'POST'","body: unknown | undefined","SOCKET_STATES","CHANNEL_STATES","CHANNEL_EVENTS","TRANSPORTS","CONNECTION_STATE","PostgresTypes","REALTIME_PRESENCE_LISTEN_EVENTS","REALTIME_POSTGRES_CHANGES_LISTEN_EVENT","REALTIME_LISTEN_TYPES","REALTIME_SUBSCRIBE_STATES","postgres_changes","_a","_b","type","noop","_a","namespaceToPath","resolveFetch","resolveResponse","result: Record<string, any>","isPlainObject","_getErrorMessage","handleError","_getRequestParams","params: { [k: string]: any }","_handleRequest","post","downloadFn: () => Promise<Response>","shouldThrowOnError: boolean","this","DEFAULT_FILE_OPTIONS: FileOptions","fetch","headers: Record<string, string>","_queryString: string[]","params: string[]","version","DEFAULT_HEADERS","params: Record<string, string>","resolveFetch","params: { [k: string]: any }","resolveFetch","fetch","this","version","DEFAULT_HEADERS","version","resolveFetch","_getErrorMessage","handleError","_getRequestParams","_handleRequest","fetch","resolveFetch","version","factor","DEFAULT_HEADERS","resolveFetch","version","result","expiresAt","error","data","_a","version","DEFAULT_HEADERS","DEFAULT_AUTH_OPTIONS: SupabaseAuthClientOptions","DEFAULT_REALTIME_OPTIONS: RealtimeClientOptions","resolveFetch","fetch","_objectSpread2","DEFAULT_DB_OPTIONS","DEFAULT_AUTH_OPTIONS","DEFAULT_REALTIME_OPTIONS","DEFAULT_GLOBAL_OPTIONS","result: Required<SupabaseClientOptions<SchemaName>>","supabaseUrl: string","supabaseKey: string","SupabaseStorageClient","this","import_ethers","error","crypto","import_facilitator_client"]}