UNPKG

@supabase/auth-js

Version:
107 lines 3.83 kB
/** * @experimental */ export declare const internals: { /** * @experimental */ debug: boolean; }; /** * An error thrown when a lock cannot be acquired after some amount of time. * * Use the {@link #isAcquireTimeout} property instead of checking with `instanceof`. * * @example * ```ts * import { LockAcquireTimeoutError } from '@supabase/auth-js' * * class CustomLockError extends LockAcquireTimeoutError { * constructor() { * super('Lock timed out') * } * } * ``` */ export declare abstract class LockAcquireTimeoutError extends Error { readonly isAcquireTimeout = true; constructor(message: string); } /** * Error thrown when the browser Navigator Lock API fails to acquire a lock. * * @example * ```ts * import { NavigatorLockAcquireTimeoutError } from '@supabase/auth-js' * * throw new NavigatorLockAcquireTimeoutError('Lock timed out') * ``` */ export declare class NavigatorLockAcquireTimeoutError extends LockAcquireTimeoutError { } /** * Error thrown when the process-level lock helper cannot acquire a lock. * * @example * ```ts * import { ProcessLockAcquireTimeoutError } from '@supabase/auth-js' * * throw new ProcessLockAcquireTimeoutError('Lock timed out') * ``` */ export declare class ProcessLockAcquireTimeoutError extends LockAcquireTimeoutError { } /** * Implements a global exclusive lock using the Navigator LockManager API. It * is available on all browsers released after 2022-03-15 with Safari being the * last one to release support. If the API is not available, this function will * throw. Make sure you check availablility before configuring {@link * GoTrueClient}. * * You can turn on debugging by setting the `supabase.gotrue-js.locks.debug` * local storage item to `true`. * * Internals: * * Since the LockManager API does not preserve stack traces for the async * function passed in the `request` method, a trick is used where acquiring the * lock releases a previously started promise to run the operation in the `fn` * function. The lock waits for that promise to finish (with or without error), * while the function will finally wait for the result anyway. * * @param name Name of the lock to be acquired. * @param acquireTimeout If negative, no timeout. If 0 an error is thrown if * the lock can't be acquired without waiting. If positive, the lock acquire * will time out after so many milliseconds. An error is * a timeout if it has `isAcquireTimeout` set to true. * @param fn The operation to run once the lock is acquired. * @example * ```ts * await navigatorLock('sync-user', 1000, async () => { * await refreshSession() * }) * ``` */ export declare function navigatorLock<R>(name: string, acquireTimeout: number, fn: () => Promise<R>): Promise<R>; /** * Implements a global exclusive lock that works only in the current process. * Useful for environments like React Native or other non-browser * single-process (i.e. no concept of "tabs") environments. * * Use {@link #navigatorLock} in browser environments. * * @param name Name of the lock to be acquired. * @param acquireTimeout If negative, no timeout. If 0 an error is thrown if * the lock can't be acquired without waiting. If positive, the lock acquire * will time out after so many milliseconds. An error is * a timeout if it has `isAcquireTimeout` set to true. * @param fn The operation to run once the lock is acquired. * @example * ```ts * await processLock('migrate', 5000, async () => { * await runMigration() * }) * ``` */ export declare function processLock<R>(name: string, acquireTimeout: number, fn: () => Promise<R>): Promise<R>; //# sourceMappingURL=locks.d.ts.map