@clerk/chrome-extension 2.7.4-canary.v20251007110408 → 2.7.4-canary.v20251007151725
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.
- package/dist/cjs/background/index.js +1 -1
- package/dist/cjs/index.js +2 -2
- package/dist/cjs/react/index.js +2 -2
- package/dist/esm/background/index.js +1 -1
- package/dist/esm/{chunk-3I2XDGHO.js → chunk-CGI3LCPZ.js} +5 -5
- package/dist/esm/{chunk-3I2XDGHO.js.map → chunk-CGI3LCPZ.js.map} +1 -1
- package/dist/esm/{chunk-ZOYCCU2I.js → chunk-ODI55SF5.js} +3 -3
- package/dist/esm/{chunk-ZOYCCU2I.js.map → chunk-ODI55SF5.js.map} +1 -1
- package/dist/esm/index.js +3 -3
- package/dist/esm/react/index.js +2 -2
- package/package.json +4 -4
@@ -448,7 +448,7 @@ var BrowserStorageCache = createBrowserStorageCache();
|
|
448
448
|
var clerk;
|
449
449
|
Clerk.sdkMetadata = {
|
450
450
|
name: "@clerk/chrome-extension",
|
451
|
-
version: "2.7.4-canary.
|
451
|
+
version: "2.7.4-canary.v20251007151725"
|
452
452
|
};
|
453
453
|
async function createClerkClient({
|
454
454
|
__experimental_syncHostListener = false,
|
@@ -500,5 +500,5 @@ async function createClerkClient({
|
|
500
500
|
}
|
501
501
|
|
502
502
|
export { ClerkRuntimeError, SCOPE, __export, __export2, __reExport, buildErrorThrower, createClerkClient, createDevOrStagingUrlCache, isClerkAPIResponseError, isPublishableKey };
|
503
|
-
//# sourceMappingURL=chunk-
|
504
|
-
//# sourceMappingURL=chunk-
|
503
|
+
//# sourceMappingURL=chunk-ODI55SF5.js.map
|
504
|
+
//# sourceMappingURL=chunk-ODI55SF5.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../shared/src/errors/errorThrower.ts","../../../shared/src/errors/runtimeError.ts","../../../shared/src/errors/helpers.ts","../../../shared/dist/chunk-IEP6GGEX.mjs","../../../shared/src/isomorphicAtob.ts","../../../shared/src/constants.ts","../../../shared/src/keys.ts","../../src/types.ts","../../../shared/src/devBrowser.ts","../../src/internal/constants.ts","../../src/internal/utils/errors.ts","../../src/internal/utils/cookies.ts","../../src/internal/utils/jwt-handler.ts","../../src/internal/utils/manifest.ts","../../src/internal/utils/request-handler.ts","../../src/internal/utils/response-handler.ts","../../src/internal/utils/storage.ts","../../src/internal/clerk.ts"],"names":["packageName","customMessages","__defProp","__export","prodHandler","devHandler","browser"],"mappings":"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","file":"chunk-ZOYCCU2I.js","sourcesContent":["const DefaultMessages = Object.freeze({\n InvalidProxyUrlErrorMessage: `The proxyUrl passed to Clerk is invalid. The expected value for proxyUrl is an absolute URL or a relative path with a leading '/'. (key={{url}})`,\n InvalidPublishableKeyErrorMessage: `The publishableKey passed to Clerk is invalid. You can get your Publishable key at https://dashboard.clerk.com/last-active?path=api-keys. (key={{key}})`,\n MissingPublishableKeyErrorMessage: `Missing publishableKey. You can get your key at https://dashboard.clerk.com/last-active?path=api-keys.`,\n MissingSecretKeyErrorMessage: `Missing secretKey. You can get your key at https://dashboard.clerk.com/last-active?path=api-keys.`,\n MissingClerkProvider: `{{source}} can only be used within the <ClerkProvider /> component. Learn more: https://clerk.com/docs/components/clerk-provider`,\n});\n\ntype MessageKeys = keyof typeof DefaultMessages;\n\ntype Messages = Record<MessageKeys, string>;\n\ntype CustomMessages = Partial<Messages>;\n\nexport type ErrorThrowerOptions = {\n packageName: string;\n customMessages?: CustomMessages;\n};\n\nexport interface ErrorThrower {\n setPackageName(options: ErrorThrowerOptions): ErrorThrower;\n\n setMessages(options: ErrorThrowerOptions): ErrorThrower;\n\n throwInvalidPublishableKeyError(params: { key?: string }): never;\n\n throwInvalidProxyUrl(params: { url?: string }): never;\n\n throwMissingPublishableKeyError(): never;\n\n throwMissingSecretKeyError(): never;\n\n throwMissingClerkProviderError(params: { source?: string }): never;\n\n throw(message: string): never;\n}\n\n/**\n * Builds an error thrower.\n *\n * @internal\n */\nexport function buildErrorThrower({ packageName, customMessages }: ErrorThrowerOptions): ErrorThrower {\n let pkg = packageName;\n\n /**\n * Builds a message from a raw message and replacements.\n *\n * @internal\n */\n function buildMessage(rawMessage: string, replacements?: Record<string, string | number>) {\n if (!replacements) {\n return `${pkg}: ${rawMessage}`;\n }\n\n let msg = rawMessage;\n const matches = rawMessage.matchAll(/{{([a-zA-Z0-9-_]+)}}/g);\n\n for (const match of matches) {\n const replacement = (replacements[match[1]] || '').toString();\n msg = msg.replace(`{{${match[1]}}}`, replacement);\n }\n\n return `${pkg}: ${msg}`;\n }\n\n const messages = {\n ...DefaultMessages,\n ...customMessages,\n };\n\n return {\n setPackageName({ packageName }: ErrorThrowerOptions): ErrorThrower {\n if (typeof packageName === 'string') {\n pkg = packageName;\n }\n return this;\n },\n\n setMessages({ customMessages }: ErrorThrowerOptions): ErrorThrower {\n Object.assign(messages, customMessages || {});\n return this;\n },\n\n throwInvalidPublishableKeyError(params: { key?: string }): never {\n throw new Error(buildMessage(messages.InvalidPublishableKeyErrorMessage, params));\n },\n\n throwInvalidProxyUrl(params: { url?: string }): never {\n throw new Error(buildMessage(messages.InvalidProxyUrlErrorMessage, params));\n },\n\n throwMissingPublishableKeyError(): never {\n throw new Error(buildMessage(messages.MissingPublishableKeyErrorMessage));\n },\n\n throwMissingSecretKeyError(): never {\n throw new Error(buildMessage(messages.MissingSecretKeyErrorMessage));\n },\n\n throwMissingClerkProviderError(params: { source?: string }): never {\n throw new Error(buildMessage(messages.MissingClerkProvider, params));\n },\n\n throw(message: string): never {\n throw new Error(buildMessage(message));\n },\n };\n}\n","/**\n * Custom error class for representing Clerk runtime errors.\n *\n * @class ClerkRuntimeError\n *\n * @example\n * throw new ClerkRuntimeError('An error occurred', { code: 'password_invalid' });\n */\nexport class ClerkRuntimeError extends Error {\n clerkRuntimeError: true;\n /**\n * The error message in english, it contains a detailed description of the error.\n */\n message: string;\n\n /**\n * A unique code identifying the error, can be used for localization.\n */\n code: string;\n\n /**\n * The original error that was caught to throw an instance of ClerkRuntimeError.\n */\n cause?: Error;\n\n constructor(message: string, { code, cause }: { code: string; cause?: Error }) {\n const prefix = '🔒 Clerk:';\n const regex = new RegExp(prefix.replace(' ', '\\\\s*'), 'i');\n const sanitized = message.replace(regex, '');\n const _message = `${prefix} ${sanitized.trim()}\\n\\n(code=\"${code}\")\\n`;\n super(_message);\n\n Object.setPrototypeOf(this, ClerkRuntimeError.prototype);\n\n this.cause = cause;\n this.code = code;\n this.message = _message;\n this.clerkRuntimeError = true;\n this.name = 'ClerkRuntimeError';\n }\n\n /**\n * Returns a string representation of the error.\n *\n * @returns A formatted string with the error name and message.\n */\n public toString = () => {\n return `[${this.name}]\\nMessage:${this.message}`;\n };\n}\n","import type { ClerkAPIResponseError } from './apiResponseError';\nimport type { EmailLinkError } from './emailLinkError';\nimport type { MetamaskError } from './metamaskError';\nimport type { ClerkRuntimeError } from './runtimeError';\n\n/**\n * Checks if the provided error object is an unauthorized error.\n *\n * @internal\n *\n * @deprecated This is no longer used, and will be removed in the next major version.\n */\nexport function isUnauthorizedError(e: any): boolean {\n const status = e?.status;\n const code = e?.errors?.[0]?.code;\n return code === 'authentication_invalid' && status === 401;\n}\n\n/**\n * Checks if the provided error object is a captcha error.\n *\n * @internal\n */\nexport function isCaptchaError(e: ClerkAPIResponseError): boolean {\n return ['captcha_invalid', 'captcha_not_enabled', 'captcha_missing_token'].includes(e.errors[0].code);\n}\n\n/**\n * Checks if the provided error is a 4xx error.\n *\n * @internal\n */\nexport function is4xxError(e: any): boolean {\n const status = e?.status;\n return !!status && status >= 400 && status < 500;\n}\n\n/**\n * Checks if the provided error is a network error.\n *\n * @internal\n */\nexport function isNetworkError(e: any): boolean {\n // TODO: revise during error handling epic\n const message = (`${e.message}${e.name}` || '').toLowerCase().replace(/\\s+/g, '');\n return message.includes('networkerror');\n}\n\n/**\n * Checks if the provided error is either a ClerkAPIResponseError, a ClerkRuntimeError, or a MetamaskError.\n *\n * @internal\n */\nexport function isKnownError(error: any): error is ClerkAPIResponseError | ClerkRuntimeError | MetamaskError {\n return isClerkAPIResponseError(error) || isMetamaskError(error) || isClerkRuntimeError(error);\n}\n\n/**\n * Checks if the provided error is a ClerkAPIResponseError.\n *\n * @internal\n */\nexport function isClerkAPIResponseError(err: any): err is ClerkAPIResponseError {\n return err && 'clerkError' in err;\n}\n\n/**\n * Checks if the provided error object is an instance of ClerkRuntimeError.\n *\n * @param err - The error object to check.\n * @returns True if the error is a ClerkRuntimeError, false otherwise.\n *\n * @example\n * const error = new ClerkRuntimeError('An error occurred');\n * if (isClerkRuntimeError(error)) {\n * // Handle ClerkRuntimeError\n * console.error('ClerkRuntimeError:', error.message);\n * } else {\n * // Handle other errors\n * console.error('Other error:', error.message);\n * }\n */\nexport function isClerkRuntimeError(err: any): err is ClerkRuntimeError {\n return 'clerkRuntimeError' in err;\n}\n\n/**\n * Checks if the provided error is a Clerk runtime error indicating a reverification was cancelled.\n *\n * @internal\n */\nexport function isReverificationCancelledError(err: any) {\n return isClerkRuntimeError(err) && err.code === 'reverification_cancelled';\n}\n\n/**\n * Checks if the provided error is a Metamask error.\n *\n * @internal\n */\nexport function isMetamaskError(err: any): err is MetamaskError {\n return 'code' in err && [4001, 32602, 32603].includes(err.code) && 'message' in err;\n}\n\n/**\n * Checks if the provided error is clerk api response error indicating a user is locked.\n *\n * @internal\n */\nexport function isUserLockedError(err: any) {\n return isClerkAPIResponseError(err) && err.errors?.[0]?.code === 'user_locked';\n}\n\n/**\n * Checks if the provided error is a clerk api response error indicating a password was pwned.\n *\n * @internal\n */\nexport function isPasswordPwnedError(err: any) {\n return isClerkAPIResponseError(err) && err.errors?.[0]?.code === 'form_password_pwned';\n}\n\n/**\n * Checks if the provided error is an EmailLinkError.\n *\n * @internal\n */\nexport function isEmailLinkError(err: Error): err is EmailLinkError {\n return err.name === 'EmailLinkError';\n}\n","var __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, \"default\"), secondTarget && __copyProps(secondTarget, mod, \"default\"));\n\nexport {\n __export,\n __reExport\n};\n//# sourceMappingURL=chunk-IEP6GGEX.mjs.map","/**\n * A function that decodes a string of data which has been encoded using base-64 encoding.\n * Uses `atob` if available, otherwise uses `Buffer` from `global`. If neither are available, returns the data as-is.\n */\nexport const isomorphicAtob = (data: string) => {\n if (typeof atob !== 'undefined' && typeof atob === 'function') {\n return atob(data);\n } else if (typeof global !== 'undefined' && global.Buffer) {\n return new global.Buffer(data, 'base64').toString();\n }\n return data;\n};\n","export const LEGACY_DEV_INSTANCE_SUFFIXES = ['.lcl.dev', '.lclstage.dev', '.lclclerk.com'];\nexport const CURRENT_DEV_INSTANCE_SUFFIXES = ['.accounts.dev', '.accountsstage.dev', '.accounts.lclclerk.com'];\nexport const DEV_OR_STAGING_SUFFIXES = [\n '.lcl.dev',\n '.stg.dev',\n '.lclstage.dev',\n '.stgstage.dev',\n '.dev.lclclerk.com',\n '.stg.lclclerk.com',\n '.accounts.lclclerk.com',\n 'accountsstage.dev',\n 'accounts.dev',\n];\nexport const LOCAL_ENV_SUFFIXES = ['.lcl.dev', 'lclstage.dev', '.lclclerk.com', '.accounts.lclclerk.com'];\nexport const STAGING_ENV_SUFFIXES = ['.accountsstage.dev'];\nexport const LOCAL_API_URL = 'https://api.lclclerk.com';\nexport const STAGING_API_URL = 'https://api.clerkstage.dev';\nexport const PROD_API_URL = 'https://api.clerk.com';\n\n/**\n * Returns the URL for a static image\n * using the new img.clerk.com service\n */\nexport function iconImageUrl(id: string, format: 'svg' | 'jpeg' = 'svg'): string {\n return `https://img.clerk.com/static/${id}.${format}`;\n}\n","import type { PublishableKey } from '@clerk/types';\n\nimport { DEV_OR_STAGING_SUFFIXES, LEGACY_DEV_INSTANCE_SUFFIXES } from './constants';\nimport { isomorphicAtob } from './isomorphicAtob';\nimport { isomorphicBtoa } from './isomorphicBtoa';\n\n/**\n * Configuration options for parsing publishable keys.\n */\ntype ParsePublishableKeyOptions = {\n /** Whether to throw an error if parsing fails */\n fatal?: boolean;\n /** Custom domain to use for satellite instances */\n domain?: string;\n /** Proxy URL to use instead of the decoded frontend API */\n proxyUrl?: string;\n /** Whether this is a satellite instance */\n isSatellite?: boolean;\n};\n\n/** Prefix used for production publishable keys */\nconst PUBLISHABLE_KEY_LIVE_PREFIX = 'pk_live_';\n\n/** Prefix used for development publishable keys */\nconst PUBLISHABLE_KEY_TEST_PREFIX = 'pk_test_';\n\n/**\n * Regular expression that matches development frontend API keys.\n * Matches patterns like: foo-bar-13.clerk.accounts.dev.\n */\nconst PUBLISHABLE_FRONTEND_API_DEV_REGEX = /^(([a-z]+)-){2}([0-9]{1,2})\\.clerk\\.accounts([a-z.]*)(dev|com)$/i;\n\n/**\n * Converts a frontend API URL into a base64-encoded publishable key.\n *\n * @param frontendApi - The frontend API URL (e.g., 'clerk.example.com').\n * @returns A base64-encoded publishable key with appropriate prefix (pk_live_ or pk_test_).\n */\nexport function buildPublishableKey(frontendApi: string): string {\n const isDevKey =\n PUBLISHABLE_FRONTEND_API_DEV_REGEX.test(frontendApi) ||\n (frontendApi.startsWith('clerk.') && LEGACY_DEV_INSTANCE_SUFFIXES.some(s => frontendApi.endsWith(s)));\n const keyPrefix = isDevKey ? PUBLISHABLE_KEY_TEST_PREFIX : PUBLISHABLE_KEY_LIVE_PREFIX;\n return `${keyPrefix}${isomorphicBtoa(`${frontendApi}$`)}`;\n}\n\n/**\n * Validates that a decoded publishable key has the correct format.\n * The decoded value should be a frontend API followed by exactly one '$' at the end.\n *\n * @param decoded - The decoded publishable key string to validate.\n * @returns `true` if the decoded key has valid format, `false` otherwise.\n */\nfunction isValidDecodedPublishableKey(decoded: string): boolean {\n if (!decoded.endsWith('$')) {\n return false;\n }\n\n const withoutTrailing = decoded.slice(0, -1);\n if (withoutTrailing.includes('$')) {\n return false;\n }\n\n return withoutTrailing.includes('.');\n}\n\nexport function parsePublishableKey(\n key: string | undefined,\n options: ParsePublishableKeyOptions & { fatal: true },\n): PublishableKey;\nexport function parsePublishableKey(\n key: string | undefined,\n options?: ParsePublishableKeyOptions,\n): PublishableKey | null;\n/**\n * Parses and validates a publishable key, extracting the frontend API and instance type.\n *\n * @param key - The publishable key to parse.\n * @param options - Configuration options for parsing.\n * @param options.fatal\n * @param options.domain\n * @param options.proxyUrl\n * @param options.isSatellite\n * @returns Parsed publishable key object with instanceType and frontendApi, or null if invalid.\n *\n * @throws {Error} When options.fatal is true and key is missing or invalid.\n */\nexport function parsePublishableKey(\n key: string | undefined,\n options: { fatal?: boolean; domain?: string; proxyUrl?: string; isSatellite?: boolean } = {},\n): PublishableKey | null {\n key = key || '';\n\n if (!key || !isPublishableKey(key)) {\n if (options.fatal && !key) {\n throw new Error(\n 'Publishable key is missing. Ensure that your publishable key is correctly configured. Double-check your environment configuration for your keys, or access them here: https://dashboard.clerk.com/last-active?path=api-keys',\n );\n }\n if (options.fatal && !isPublishableKey(key)) {\n throw new Error('Publishable key not valid.');\n }\n return null;\n }\n\n const instanceType = key.startsWith(PUBLISHABLE_KEY_LIVE_PREFIX) ? 'production' : 'development';\n\n let decodedFrontendApi: string;\n try {\n decodedFrontendApi = isomorphicAtob(key.split('_')[2]);\n } catch {\n if (options.fatal) {\n throw new Error('Publishable key not valid: Failed to decode key.');\n }\n return null;\n }\n\n if (!isValidDecodedPublishableKey(decodedFrontendApi)) {\n if (options.fatal) {\n throw new Error('Publishable key not valid: Decoded key has invalid format.');\n }\n return null;\n }\n\n let frontendApi = decodedFrontendApi.slice(0, -1);\n\n if (options.proxyUrl) {\n frontendApi = options.proxyUrl;\n } else if (instanceType !== 'development' && options.domain && options.isSatellite) {\n frontendApi = `clerk.${options.domain}`;\n }\n\n return {\n instanceType,\n frontendApi,\n };\n}\n\n/**\n * Checks if the provided key is a valid publishable key.\n *\n * @param key - The key to be checked. Defaults to an empty string if not provided.\n * @returns `true` if 'key' is a valid publishable key, `false` otherwise.\n */\nexport function isPublishableKey(key: string = '') {\n try {\n const hasValidPrefix = key.startsWith(PUBLISHABLE_KEY_LIVE_PREFIX) || key.startsWith(PUBLISHABLE_KEY_TEST_PREFIX);\n\n if (!hasValidPrefix) {\n return false;\n }\n\n const parts = key.split('_');\n if (parts.length !== 3) {\n return false;\n }\n\n const encodedPart = parts[2];\n if (!encodedPart) {\n return false;\n }\n\n const decoded = isomorphicAtob(encodedPart);\n return isValidDecodedPublishableKey(decoded);\n } catch {\n return false;\n }\n}\n\n/**\n * Creates a memoized cache for checking if URLs are development or staging environments.\n * Uses a Map to cache results for better performance on repeated checks.\n *\n * @returns An object with an isDevOrStagingUrl method that checks if a URL is dev/staging.\n */\nexport function createDevOrStagingUrlCache() {\n const devOrStagingUrlCache = new Map<string, boolean>();\n\n return {\n /**\n * Checks if a URL is a development or staging environment.\n *\n * @param url - The URL to check (string or URL object).\n * @returns `true` if the URL is a development or staging environment, `false` otherwise.\n */\n isDevOrStagingUrl: (url: string | URL): boolean => {\n if (!url) {\n return false;\n }\n\n const hostname = typeof url === 'string' ? url : url.hostname;\n let res = devOrStagingUrlCache.get(hostname);\n if (res === undefined) {\n res = DEV_OR_STAGING_SUFFIXES.some(s => hostname.endsWith(s));\n devOrStagingUrlCache.set(hostname, res);\n }\n return res;\n },\n };\n}\n\n/**\n * Checks if a publishable key is for a development environment.\n * Supports both legacy format (test_) and new format (pk_test_).\n *\n * @param apiKey - The API key to check.\n * @returns `true` if the key is for development, `false` otherwise.\n */\nexport function isDevelopmentFromPublishableKey(apiKey: string): boolean {\n return apiKey.startsWith('test_') || apiKey.startsWith('pk_test_');\n}\n\n/**\n * Checks if a publishable key is for a production environment.\n * Supports both legacy format (live_) and new format (pk_live_).\n *\n * @param apiKey - The API key to check.\n * @returns `true` if the key is for production, `false` otherwise.\n */\nexport function isProductionFromPublishableKey(apiKey: string): boolean {\n return apiKey.startsWith('live_') || apiKey.startsWith('pk_live_');\n}\n\n/**\n * Checks if a secret key is for a development environment.\n * Supports both legacy format (test_) and new format (sk_test_).\n *\n * @param apiKey - The secret key to check.\n * @returns `true` if the key is for development, `false` otherwise.\n */\nexport function isDevelopmentFromSecretKey(apiKey: string): boolean {\n return apiKey.startsWith('test_') || apiKey.startsWith('sk_test_');\n}\n\n/**\n * Checks if a secret key is for a production environment.\n * Supports both legacy format (live_) and new format (sk_live_).\n *\n * @param apiKey - The secret key to check.\n * @returns `true` if the key is for production, `false` otherwise.\n */\nexport function isProductionFromSecretKey(apiKey: string): boolean {\n return apiKey.startsWith('live_') || apiKey.startsWith('sk_live_');\n}\n\n/**\n * Generates a unique cookie suffix based on the publishable key using SHA-1 hashing.\n * The suffix is base64-encoded and URL-safe (+ and / characters are replaced).\n *\n * @param publishableKey - The publishable key to generate suffix from.\n * @param subtle - The SubtleCrypto interface to use for hashing (defaults to globalThis.crypto.subtle).\n * @returns A promise that resolves to an 8-character URL-safe base64 string.\n */\nexport async function getCookieSuffix(\n publishableKey: string,\n subtle: SubtleCrypto = globalThis.crypto.subtle,\n): Promise<string> {\n const data = new TextEncoder().encode(publishableKey);\n const digest = await subtle.digest('sha-1', data);\n const stringDigest = String.fromCharCode(...new Uint8Array(digest));\n // Base 64 Encoding with URL and Filename Safe Alphabet: https://datatracker.ietf.org/doc/html/rfc4648#section-5\n return isomorphicBtoa(stringDigest).replace(/\\+/gi, '-').replace(/\\//gi, '_').substring(0, 8);\n}\n\n/**\n * Creates a suffixed cookie name by appending the cookie suffix to the base name.\n * Used to create unique cookie names based on the publishable key.\n *\n * @param cookieName - The base cookie name.\n * @param cookieSuffix - The suffix to append (typically generated by getCookieSuffix).\n * @returns The suffixed cookie name in format: `${cookieName}_${cookieSuffix}`.\n */\nexport const getSuffixedCookieName = (cookieName: string, cookieSuffix: string): string => {\n return `${cookieName}_${cookieSuffix}`;\n};\n","export const SCOPE = {\n BACKGROUND: 'background',\n} as const;\n\nexport type Scope = (typeof SCOPE)[keyof typeof SCOPE];\n\nexport interface ClerkClientExtensionFeatures {\n background?: boolean;\n sync?: boolean;\n}\n","export const DEV_BROWSER_JWT_KEY = '__clerk_db_jwt';\nexport const DEV_BROWSER_JWT_HEADER = 'Clerk-Db-Jwt';\n\n// Sets the dev_browser JWT in the hash or the search\nexport function setDevBrowserJWTInURL(url: URL, jwt: string): URL {\n const resultURL = new URL(url);\n\n // extract & strip existing jwt from search\n const jwtFromSearch = resultURL.searchParams.get(DEV_BROWSER_JWT_KEY);\n resultURL.searchParams.delete(DEV_BROWSER_JWT_KEY);\n\n // Existing jwt takes precedence\n const jwtToSet = jwtFromSearch || jwt;\n\n if (jwtToSet) {\n resultURL.searchParams.set(DEV_BROWSER_JWT_KEY, jwtToSet);\n }\n\n return resultURL;\n}\n\n/**\n * Gets the __clerk_db_jwt JWT from either the hash or the search\n * Side effect:\n * Removes __clerk_db_jwt JWT from the URL (hash and searchParams) and updates the browser history\n */\nexport function extractDevBrowserJWTFromURL(url: URL): string {\n const jwt = readDevBrowserJwtFromSearchParams(url);\n const cleanUrl = removeDevBrowserJwt(url);\n if (cleanUrl.href !== url.href && typeof globalThis.history !== 'undefined') {\n globalThis.history.replaceState(null, '', removeDevBrowserJwt(url));\n }\n return jwt;\n}\n\nconst readDevBrowserJwtFromSearchParams = (url: URL) => {\n return url.searchParams.get(DEV_BROWSER_JWT_KEY) || '';\n};\n\nconst removeDevBrowserJwt = (url: URL) => {\n return removeDevBrowserJwtFromURLSearchParams(removeLegacyDevBrowserJwt(url));\n};\n\nconst removeDevBrowserJwtFromURLSearchParams = (_url: URL) => {\n const url = new URL(_url);\n url.searchParams.delete(DEV_BROWSER_JWT_KEY);\n return url;\n};\n\n/**\n * Removes the __clerk_db_jwt JWT from the URL hash, as well as\n * the legacy __dev_session JWT from the URL searchParams\n * We no longer need to use this value, however, we should remove it from the URL\n * Existing v4 apps will write the JWT to the hash and the search params in order to ensure\n * backwards compatibility with older v4 apps.\n * The only use case where this is needed now is when a user upgrades to clerk@5 locally\n * without changing the component's version on their dashboard.\n * In this scenario, the AP@4 -> localhost@5 redirect will still have the JWT in the hash,\n * in which case we need to remove it.\n */\nconst removeLegacyDevBrowserJwt = (_url: URL) => {\n const DEV_BROWSER_JWT_MARKER_REGEXP = /__clerk_db_jwt\\[(.*)\\]/;\n const DEV_BROWSER_JWT_LEGACY_KEY = '__dev_session';\n const url = new URL(_url);\n url.searchParams.delete(DEV_BROWSER_JWT_LEGACY_KEY);\n url.hash = decodeURI(url.hash).replace(DEV_BROWSER_JWT_MARKER_REGEXP, '');\n if (url.href.endsWith('#')) {\n url.hash = '';\n }\n return url;\n};\n","export const AUTH_HEADER = {\n PRODUCTION: 'Authorization',\n DEVELOPMENT: 'Clerk-Db-Jwt',\n};\n\nexport const CLIENT_JWT_KEY = '__client';\nexport const CLIENT_UAT_KEY = '__clerk_uat';\nexport const DEFAULT_LOCAL_HOST_PERMISSION = 'http://localhost';\nexport const STORAGE_KEY_CLIENT_JWT = '__clerk_client_jwt';\n","import { buildErrorThrower } from '@clerk/shared/error';\n\nexport type HostPermissionHintOpts = {\n hostHint: string;\n};\n\nexport const errorLogger = (err: Error) => console.error(err, err.stack);\nexport const errorThrower = buildErrorThrower({ packageName: '@clerk/chrome-extension' });\n\nexport const missingManifestKeyError = (key: string) => `Missing \\`${key}\\` entry in manifest.json`;\n\nexport function assertPublishableKey(publishableKey: unknown): asserts publishableKey {\n if (!publishableKey) {\n errorThrower.throwMissingPublishableKeyError();\n }\n}\n","import browser from 'webextension-polyfill';\n\nexport type FormattedUrl = `http${string}`;\n\nexport type GetClientCookieParams = {\n name: string;\n url: string;\n callback: (changeInfo: ChangeInfo) => Promise<void>;\n onListenerCallback?: () => void;\n};\n\nexport type ChangeInfo = {\n cookie: browser.Cookies.Cookie;\n cause: browser.Cookies.OnChangedCause;\n removed: boolean;\n};\n\nfunction ensureFormattedUrl(url: string): FormattedUrl {\n return url.startsWith('http') ? (url as FormattedUrl) : `https://${url}`;\n}\n\nexport async function getClientCookie({ url, name }: GetClientCookieParams) {\n return await browser.cookies.get({ name, url: ensureFormattedUrl(url) });\n}\n\nexport function createClientCookieListener({ url, name, callback }: GetClientCookieParams) {\n const domain = new URL(url).hostname;\n const cookieDomain = domain.startsWith('www.') ? domain.slice(4) : domain;\n\n const listener = (changeInfo: ChangeInfo) => {\n if (changeInfo.cookie.domain === cookieDomain && changeInfo.cookie.name === name) {\n void callback(changeInfo);\n }\n };\n\n return {\n add: () => browser.cookies.onChanged.addListener(listener),\n has: () => browser.cookies.onChanged.hasListener(listener),\n remove: () => browser.cookies.onChanged.removeListener(listener),\n };\n}\n","import { CLIENT_UAT_KEY, STORAGE_KEY_CLIENT_JWT } from '../constants';\nimport type { ChangeInfo, GetClientCookieParams } from './cookies';\nimport { createClientCookieListener, getClientCookie } from './cookies';\nimport { errorLogger } from './errors';\nimport type { StorageCache } from './storage';\n\nexport type JWTHandlerParams = { frontendApi: string } & (\n | {\n sync?: false;\n }\n | ({ sync: true } & GetClientCookieParams)\n);\n\nexport type JWTHandler = ReturnType<typeof JWTHandler>;\n\nfunction shouldSync(sync: boolean | undefined, _params: unknown): _params is GetClientCookieParams {\n return Boolean(sync);\n}\n\nexport function JWTHandler(store: StorageCache, params: JWTHandlerParams) {\n const { sync, frontendApi, ...cookieParams } = params;\n\n const CACHE_KEY = store.createKey(frontendApi, STORAGE_KEY_CLIENT_JWT, 'v2');\n\n /**\n * Sets the JWT value to the active\n * @param value: JWT generally from the cookie or authorization header\n */\n const set = async (value: string): Promise<void> => {\n return await store.set(CACHE_KEY, value).catch(errorLogger);\n };\n\n /**\n * Remove the JWT value\n */\n const remove = async (): Promise<void> => {\n return await store.remove(CACHE_KEY).catch(errorLogger);\n };\n\n /**\n * Gets the JWT value to the active store.\n * If not set, attempt to get it from the synced session and save for later use.\n */\n const get = async () => {\n if (shouldSync(sync, cookieParams)) {\n // Get client cookie from browser\n const syncedJWT = await getClientCookie(cookieParams).catch(errorLogger);\n\n if (syncedJWT) {\n // Set client cookie in StorageCache\n await set(syncedJWT.value);\n return syncedJWT.value;\n }\n }\n\n // Get current JWT from StorageCache\n return await store.get<string>(CACHE_KEY);\n };\n\n const listener = () => {\n if (!shouldSync(sync, cookieParams)) {\n return;\n }\n\n const { onListenerCallback, ...restCookieParams } = cookieParams;\n\n return createClientCookieListener({\n ...restCookieParams,\n callback: async (changeInfo: ChangeInfo) => {\n const existingJWT = await get();\n\n if (existingJWT === changeInfo.cookie.value) {\n const syncedUAT = await getClientCookie({ ...restCookieParams, name: CLIENT_UAT_KEY }).catch(errorLogger);\n\n if (!syncedUAT || syncedUAT?.value === '0') {\n onListenerCallback?.();\n }\n\n return;\n }\n\n await set(changeInfo.cookie.value);\n onListenerCallback?.();\n },\n });\n };\n\n return { get, listener, set, remove };\n}\n","import type { SetRequired } from 'type-fest';\nimport type { Manifest } from 'webextension-polyfill';\n\nimport type { ClerkClientExtensionFeatures } from '../../types';\nimport { errorThrower, missingManifestKeyError } from './errors';\n\nexport type ValidatedManifest = SetRequired<Manifest.WebExtensionManifest, 'permissions' | 'host_permissions'>;\nexport type ManifestKeys = keyof Manifest.WebExtensionManifest;\n\nfunction validateRootManifestKey(manifest: Manifest.WebExtensionManifest, key: ManifestKeys): void {\n if (!manifest[key]) {\n errorThrower.throw(missingManifestKeyError(key));\n }\n}\n\nfunction validateManifestPermission(manifest: Manifest.WebExtensionManifest, key: Manifest.Permission): void {\n if (!manifest.permissions?.includes(key)) {\n errorThrower.throw(missingManifestKeyError(`permissions.${key}`));\n }\n}\n\nfunction hasAdditionalFeatures(features: ClerkClientExtensionFeatures): boolean {\n return Boolean(features) && Object.keys(features).length > 0;\n}\n\nexport function validateManifest(\n manifest: Manifest.WebExtensionManifest,\n features: ClerkClientExtensionFeatures,\n): asserts manifest is ValidatedManifest {\n validateRootManifestKey(manifest, 'permissions');\n validateManifestPermission(manifest, 'storage');\n\n // If no additional features are provided, we can return success early\n if (!hasAdditionalFeatures(features)) {\n return;\n }\n\n if (features.background) {\n validateRootManifestKey(manifest, 'background');\n }\n\n if (features.sync) {\n validateManifestPermission(manifest, 'cookies');\n validateRootManifestKey(manifest, 'host_permissions');\n }\n}\n","import type { Clerk } from '@clerk/clerk-js';\n\nimport { AUTH_HEADER } from '../constants';\nimport type { JWTHandler } from './jwt-handler';\n\ntype Handler = Parameters<Clerk['__unstable__onBeforeRequest']>[0];\ntype Req = Parameters<Handler>[0];\n\n/** Append the JWT to the FAPI request */\nexport function requestHandler(jwtHandler: JWTHandler, { isProd }: { isProd: boolean }) {\n const handler: Handler = async requestInit => {\n requestInit.credentials = 'omit';\n\n const currentJWT = await jwtHandler.get();\n\n if (!currentJWT) {\n return;\n }\n\n if (isProd) {\n prodHandler(requestInit, currentJWT);\n } else {\n devHandler(requestInit, currentJWT);\n }\n };\n\n return handler;\n}\n\n/** Append the JWT to the FAPI request, per development instances */\nfunction devHandler(requestInit: Req, jwt: string) {\n requestInit.url?.searchParams.append('__clerk_db_jwt', jwt);\n}\n\n/** Append the JWT to the FAPI request, per production instances */\nfunction prodHandler(requestInit: Req, jwt: string) {\n requestInit.url?.searchParams.append('_is_native', '1');\n (requestInit.headers as Headers).set(AUTH_HEADER.PRODUCTION, `Bearer ${jwt}`);\n}\n","import type { Clerk } from '@clerk/clerk-js';\n\nimport { AUTH_HEADER } from '../constants';\nimport type { JWTHandler } from './jwt-handler';\n\ntype Handler = Parameters<Clerk['__unstable__onAfterResponse']>[0];\ntype Res = Parameters<Handler>[1];\n\n/** Retrieve the JWT to the FAPI response */\nexport function responseHandler(jwtHandler: JWTHandler, { isProd }: { isProd: boolean }) {\n const handler: Handler = async (_, response) => {\n if (isProd) {\n await prodHandler(response, jwtHandler);\n } else {\n await devHandler(response, jwtHandler);\n }\n };\n return handler;\n}\n\n/** Retrieve the JWT to the FAPI response, per development instances */\nasync function devHandler(response: Res, jwtHandler: JWTHandler) {\n const header = response?.headers.get(AUTH_HEADER.DEVELOPMENT);\n\n if (header) {\n await jwtHandler.set(header);\n } else {\n await jwtHandler.remove();\n }\n}\n\n/** Retrieve the JWT to the FAPI response, per production instances */\nasync function prodHandler(response: Res, jwtHandler: JWTHandler) {\n const header = response?.headers.get(AUTH_HEADER.PRODUCTION);\n\n if (header?.startsWith('Bearer')) {\n const jwt = header.split(' ')[1] || undefined;\n\n if (jwt) {\n await jwtHandler.set(jwt);\n } else {\n await jwtHandler.remove();\n }\n } else if (header) {\n await jwtHandler.set(header);\n }\n}\n","import browser from 'webextension-polyfill';\n\ntype StorageCacheOptions = {\n storageArea?: 'local' | 'sync';\n};\n\nexport type StorageCache = {\n createKey: (...keys: string[]) => string;\n get: <T = any>(key: string) => Promise<T | undefined>;\n remove: (key: string) => Promise<void>;\n set: (key: string, value: string) => Promise<void>;\n};\n\nconst createKey: StorageCache['createKey'] = (...keys: string[]) => keys.filter(Boolean).join('|');\n\n// Use browser.storage (local or sync) to persist Clerk client JWT.\n// More information at https://developer.chrome.com/docs/extensions/reference/storage\nconst createBrowserStorageCache = (opts: StorageCacheOptions = {}): StorageCache => {\n const __storageArea = opts.storageArea || 'local';\n\n return {\n createKey,\n get: <T>(key: string) => browser.storage[__storageArea].get(key).then(result => (result[key] as T) || undefined),\n remove: (key: string) => browser.storage[__storageArea].remove(key),\n set: (key: string, value: string) => browser.storage[__storageArea].set({ [key]: value }),\n };\n};\n\nconst createMemoryStorageCache = (): StorageCache => {\n const cache: Map<string, any> = new Map();\n\n return {\n createKey,\n get: (key: string) => Promise.resolve(cache.get(key)),\n remove: (key: string) => {\n cache.delete(key);\n return Promise.resolve();\n },\n set: (key: string, value: string) => {\n cache.set(key, value);\n return Promise.resolve();\n },\n };\n};\n\nexport const BrowserStorageCache = createBrowserStorageCache();\nexport const MemoryStorageCache = createMemoryStorageCache();\n","import { Clerk } from '@clerk/clerk-js/no-rhc';\nimport { DEV_BROWSER_JWT_KEY } from '@clerk/shared/devBrowser';\nimport { parsePublishableKey } from '@clerk/shared/keys';\nimport browser from 'webextension-polyfill';\n\nimport { SCOPE, type Scope } from '../types';\nimport { CLIENT_JWT_KEY, DEFAULT_LOCAL_HOST_PERMISSION } from './constants';\nimport { assertPublishableKey } from './utils/errors';\nimport type { JWTHandlerParams } from './utils/jwt-handler';\nimport { JWTHandler } from './utils/jwt-handler';\nimport { validateManifest } from './utils/manifest';\nimport { requestHandler } from './utils/request-handler';\nimport { responseHandler } from './utils/response-handler';\nimport { BrowserStorageCache, type StorageCache } from './utils/storage';\n\nexport let clerk: Clerk;\n\nClerk.sdkMetadata = {\n name: PACKAGE_NAME,\n version: PACKAGE_VERSION,\n};\n\nexport type CreateClerkClientOptions = {\n __experimental_syncHostListener?: boolean;\n publishableKey: string;\n scope?: Scope;\n storageCache?: StorageCache;\n syncHost?: string;\n};\n\nexport async function createClerkClient({\n __experimental_syncHostListener = false,\n publishableKey,\n scope,\n storageCache = BrowserStorageCache,\n syncHost,\n}: CreateClerkClientOptions): Promise<Clerk> {\n if (scope === SCOPE.BACKGROUND) {\n Clerk.mountComponentRenderer = undefined;\n }\n\n // Don't cache background scripts as it can result in out-of-sync client information.\n if (clerk && scope !== SCOPE.BACKGROUND) {\n return clerk;\n }\n\n // Sync is enabled if a `syncHost` is provided\n const sync = Boolean(syncHost);\n\n // Parse publishableKey and assert it's present/valid, throw if not\n const key = parsePublishableKey(publishableKey);\n assertPublishableKey(key);\n\n const isProd = key.instanceType === 'production';\n const manifest = browser.runtime.getManifest();\n\n // Will throw if manifest is invalid\n validateManifest(manifest, {\n background: scope === SCOPE.BACKGROUND,\n sync,\n });\n\n // Set up JWT handler and attempt to get JWT from storage on initialization\n const url = syncHost ? syncHost : DEFAULT_LOCAL_HOST_PERMISSION;\n\n // Create Clerk instance\n clerk = new Clerk(publishableKey);\n\n // @ts-expect-error - TODO: sync is evaluating to true vs boolean\n const jwtOptions: JWTHandlerParams = {\n frontendApi: key.frontendApi,\n name: isProd ? CLIENT_JWT_KEY : DEV_BROWSER_JWT_KEY,\n url,\n sync: sync,\n };\n\n if (jwtOptions.sync && __experimental_syncHostListener) {\n jwtOptions.onListenerCallback = () => {\n if (clerk.user) {\n clerk.user.reload();\n } else {\n window.location.reload();\n }\n };\n }\n\n const jwt = JWTHandler(storageCache, jwtOptions);\n\n // Add listener to sync host cookies if enabled\n if (jwtOptions.sync && __experimental_syncHostListener) {\n const listener = jwt.listener();\n listener?.add();\n }\n\n clerk.__unstable__onAfterResponse(responseHandler(jwt, { isProd }));\n clerk.__unstable__onBeforeRequest(requestHandler(jwt, { isProd }));\n\n return clerk;\n}\n"]}
|
1
|
+
{"version":3,"sources":["../../../shared/src/errors/errorThrower.ts","../../../shared/src/errors/runtimeError.ts","../../../shared/src/errors/helpers.ts","../../../shared/dist/chunk-IEP6GGEX.mjs","../../../shared/src/isomorphicAtob.ts","../../../shared/src/constants.ts","../../../shared/src/keys.ts","../../src/types.ts","../../../shared/src/devBrowser.ts","../../src/internal/constants.ts","../../src/internal/utils/errors.ts","../../src/internal/utils/cookies.ts","../../src/internal/utils/jwt-handler.ts","../../src/internal/utils/manifest.ts","../../src/internal/utils/request-handler.ts","../../src/internal/utils/response-handler.ts","../../src/internal/utils/storage.ts","../../src/internal/clerk.ts"],"names":["packageName","customMessages","__defProp","__export","prodHandler","devHandler","browser"],"mappings":"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","file":"chunk-ODI55SF5.js","sourcesContent":["const DefaultMessages = Object.freeze({\n InvalidProxyUrlErrorMessage: `The proxyUrl passed to Clerk is invalid. The expected value for proxyUrl is an absolute URL or a relative path with a leading '/'. (key={{url}})`,\n InvalidPublishableKeyErrorMessage: `The publishableKey passed to Clerk is invalid. You can get your Publishable key at https://dashboard.clerk.com/last-active?path=api-keys. (key={{key}})`,\n MissingPublishableKeyErrorMessage: `Missing publishableKey. You can get your key at https://dashboard.clerk.com/last-active?path=api-keys.`,\n MissingSecretKeyErrorMessage: `Missing secretKey. You can get your key at https://dashboard.clerk.com/last-active?path=api-keys.`,\n MissingClerkProvider: `{{source}} can only be used within the <ClerkProvider /> component. Learn more: https://clerk.com/docs/components/clerk-provider`,\n});\n\ntype MessageKeys = keyof typeof DefaultMessages;\n\ntype Messages = Record<MessageKeys, string>;\n\ntype CustomMessages = Partial<Messages>;\n\nexport type ErrorThrowerOptions = {\n packageName: string;\n customMessages?: CustomMessages;\n};\n\nexport interface ErrorThrower {\n setPackageName(options: ErrorThrowerOptions): ErrorThrower;\n\n setMessages(options: ErrorThrowerOptions): ErrorThrower;\n\n throwInvalidPublishableKeyError(params: { key?: string }): never;\n\n throwInvalidProxyUrl(params: { url?: string }): never;\n\n throwMissingPublishableKeyError(): never;\n\n throwMissingSecretKeyError(): never;\n\n throwMissingClerkProviderError(params: { source?: string }): never;\n\n throw(message: string): never;\n}\n\n/**\n * Builds an error thrower.\n *\n * @internal\n */\nexport function buildErrorThrower({ packageName, customMessages }: ErrorThrowerOptions): ErrorThrower {\n let pkg = packageName;\n\n /**\n * Builds a message from a raw message and replacements.\n *\n * @internal\n */\n function buildMessage(rawMessage: string, replacements?: Record<string, string | number>) {\n if (!replacements) {\n return `${pkg}: ${rawMessage}`;\n }\n\n let msg = rawMessage;\n const matches = rawMessage.matchAll(/{{([a-zA-Z0-9-_]+)}}/g);\n\n for (const match of matches) {\n const replacement = (replacements[match[1]] || '').toString();\n msg = msg.replace(`{{${match[1]}}}`, replacement);\n }\n\n return `${pkg}: ${msg}`;\n }\n\n const messages = {\n ...DefaultMessages,\n ...customMessages,\n };\n\n return {\n setPackageName({ packageName }: ErrorThrowerOptions): ErrorThrower {\n if (typeof packageName === 'string') {\n pkg = packageName;\n }\n return this;\n },\n\n setMessages({ customMessages }: ErrorThrowerOptions): ErrorThrower {\n Object.assign(messages, customMessages || {});\n return this;\n },\n\n throwInvalidPublishableKeyError(params: { key?: string }): never {\n throw new Error(buildMessage(messages.InvalidPublishableKeyErrorMessage, params));\n },\n\n throwInvalidProxyUrl(params: { url?: string }): never {\n throw new Error(buildMessage(messages.InvalidProxyUrlErrorMessage, params));\n },\n\n throwMissingPublishableKeyError(): never {\n throw new Error(buildMessage(messages.MissingPublishableKeyErrorMessage));\n },\n\n throwMissingSecretKeyError(): never {\n throw new Error(buildMessage(messages.MissingSecretKeyErrorMessage));\n },\n\n throwMissingClerkProviderError(params: { source?: string }): never {\n throw new Error(buildMessage(messages.MissingClerkProvider, params));\n },\n\n throw(message: string): never {\n throw new Error(buildMessage(message));\n },\n };\n}\n","/**\n * Custom error class for representing Clerk runtime errors.\n *\n * @class ClerkRuntimeError\n *\n * @example\n * throw new ClerkRuntimeError('An error occurred', { code: 'password_invalid' });\n */\nexport class ClerkRuntimeError extends Error {\n clerkRuntimeError: true;\n /**\n * The error message in english, it contains a detailed description of the error.\n */\n message: string;\n\n /**\n * A unique code identifying the error, can be used for localization.\n */\n code: string;\n\n /**\n * The original error that was caught to throw an instance of ClerkRuntimeError.\n */\n cause?: Error;\n\n constructor(message: string, { code, cause }: { code: string; cause?: Error }) {\n const prefix = '🔒 Clerk:';\n const regex = new RegExp(prefix.replace(' ', '\\\\s*'), 'i');\n const sanitized = message.replace(regex, '');\n const _message = `${prefix} ${sanitized.trim()}\\n\\n(code=\"${code}\")\\n`;\n super(_message);\n\n Object.setPrototypeOf(this, ClerkRuntimeError.prototype);\n\n this.cause = cause;\n this.code = code;\n this.message = _message;\n this.clerkRuntimeError = true;\n this.name = 'ClerkRuntimeError';\n }\n\n /**\n * Returns a string representation of the error.\n *\n * @returns A formatted string with the error name and message.\n */\n public toString = () => {\n return `[${this.name}]\\nMessage:${this.message}`;\n };\n}\n","import type { ClerkAPIResponseError } from './apiResponseError';\nimport type { EmailLinkError } from './emailLinkError';\nimport type { MetamaskError } from './metamaskError';\nimport type { ClerkRuntimeError } from './runtimeError';\n\n/**\n * Checks if the provided error object is an unauthorized error.\n *\n * @internal\n *\n * @deprecated This is no longer used, and will be removed in the next major version.\n */\nexport function isUnauthorizedError(e: any): boolean {\n const status = e?.status;\n const code = e?.errors?.[0]?.code;\n return code === 'authentication_invalid' && status === 401;\n}\n\n/**\n * Checks if the provided error object is a captcha error.\n *\n * @internal\n */\nexport function isCaptchaError(e: ClerkAPIResponseError): boolean {\n return ['captcha_invalid', 'captcha_not_enabled', 'captcha_missing_token'].includes(e.errors[0].code);\n}\n\n/**\n * Checks if the provided error is a 4xx error.\n *\n * @internal\n */\nexport function is4xxError(e: any): boolean {\n const status = e?.status;\n return !!status && status >= 400 && status < 500;\n}\n\n/**\n * Checks if the provided error is a network error.\n *\n * @internal\n */\nexport function isNetworkError(e: any): boolean {\n // TODO: revise during error handling epic\n const message = (`${e.message}${e.name}` || '').toLowerCase().replace(/\\s+/g, '');\n return message.includes('networkerror');\n}\n\n/**\n * Checks if the provided error is either a ClerkAPIResponseError, a ClerkRuntimeError, or a MetamaskError.\n *\n * @internal\n */\nexport function isKnownError(error: any): error is ClerkAPIResponseError | ClerkRuntimeError | MetamaskError {\n return isClerkAPIResponseError(error) || isMetamaskError(error) || isClerkRuntimeError(error);\n}\n\n/**\n * Checks if the provided error is a ClerkAPIResponseError.\n *\n * @internal\n */\nexport function isClerkAPIResponseError(err: any): err is ClerkAPIResponseError {\n return err && 'clerkError' in err;\n}\n\n/**\n * Checks if the provided error object is an instance of ClerkRuntimeError.\n *\n * @param err - The error object to check.\n * @returns True if the error is a ClerkRuntimeError, false otherwise.\n *\n * @example\n * const error = new ClerkRuntimeError('An error occurred');\n * if (isClerkRuntimeError(error)) {\n * // Handle ClerkRuntimeError\n * console.error('ClerkRuntimeError:', error.message);\n * } else {\n * // Handle other errors\n * console.error('Other error:', error.message);\n * }\n */\nexport function isClerkRuntimeError(err: any): err is ClerkRuntimeError {\n return 'clerkRuntimeError' in err;\n}\n\n/**\n * Checks if the provided error is a Clerk runtime error indicating a reverification was cancelled.\n *\n * @internal\n */\nexport function isReverificationCancelledError(err: any) {\n return isClerkRuntimeError(err) && err.code === 'reverification_cancelled';\n}\n\n/**\n * Checks if the provided error is a Metamask error.\n *\n * @internal\n */\nexport function isMetamaskError(err: any): err is MetamaskError {\n return 'code' in err && [4001, 32602, 32603].includes(err.code) && 'message' in err;\n}\n\n/**\n * Checks if the provided error is clerk api response error indicating a user is locked.\n *\n * @internal\n */\nexport function isUserLockedError(err: any) {\n return isClerkAPIResponseError(err) && err.errors?.[0]?.code === 'user_locked';\n}\n\n/**\n * Checks if the provided error is a clerk api response error indicating a password was pwned.\n *\n * @internal\n */\nexport function isPasswordPwnedError(err: any) {\n return isClerkAPIResponseError(err) && err.errors?.[0]?.code === 'form_password_pwned';\n}\n\n/**\n * Checks if the provided error is an EmailLinkError.\n *\n * @internal\n */\nexport function isEmailLinkError(err: Error): err is EmailLinkError {\n return err.name === 'EmailLinkError';\n}\n","var __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, \"default\"), secondTarget && __copyProps(secondTarget, mod, \"default\"));\n\nexport {\n __export,\n __reExport\n};\n//# sourceMappingURL=chunk-IEP6GGEX.mjs.map","/**\n * A function that decodes a string of data which has been encoded using base-64 encoding.\n * Uses `atob` if available, otherwise uses `Buffer` from `global`. If neither are available, returns the data as-is.\n */\nexport const isomorphicAtob = (data: string) => {\n if (typeof atob !== 'undefined' && typeof atob === 'function') {\n return atob(data);\n } else if (typeof global !== 'undefined' && global.Buffer) {\n return new global.Buffer(data, 'base64').toString();\n }\n return data;\n};\n","export const LEGACY_DEV_INSTANCE_SUFFIXES = ['.lcl.dev', '.lclstage.dev', '.lclclerk.com'];\nexport const CURRENT_DEV_INSTANCE_SUFFIXES = ['.accounts.dev', '.accountsstage.dev', '.accounts.lclclerk.com'];\nexport const DEV_OR_STAGING_SUFFIXES = [\n '.lcl.dev',\n '.stg.dev',\n '.lclstage.dev',\n '.stgstage.dev',\n '.dev.lclclerk.com',\n '.stg.lclclerk.com',\n '.accounts.lclclerk.com',\n 'accountsstage.dev',\n 'accounts.dev',\n];\nexport const LOCAL_ENV_SUFFIXES = ['.lcl.dev', 'lclstage.dev', '.lclclerk.com', '.accounts.lclclerk.com'];\nexport const STAGING_ENV_SUFFIXES = ['.accountsstage.dev'];\nexport const LOCAL_API_URL = 'https://api.lclclerk.com';\nexport const STAGING_API_URL = 'https://api.clerkstage.dev';\nexport const PROD_API_URL = 'https://api.clerk.com';\n\n/**\n * Returns the URL for a static image\n * using the new img.clerk.com service\n */\nexport function iconImageUrl(id: string, format: 'svg' | 'jpeg' = 'svg'): string {\n return `https://img.clerk.com/static/${id}.${format}`;\n}\n","import type { PublishableKey } from '@clerk/types';\n\nimport { DEV_OR_STAGING_SUFFIXES, LEGACY_DEV_INSTANCE_SUFFIXES } from './constants';\nimport { isomorphicAtob } from './isomorphicAtob';\nimport { isomorphicBtoa } from './isomorphicBtoa';\n\n/**\n * Configuration options for parsing publishable keys.\n */\ntype ParsePublishableKeyOptions = {\n /** Whether to throw an error if parsing fails */\n fatal?: boolean;\n /** Custom domain to use for satellite instances */\n domain?: string;\n /** Proxy URL to use instead of the decoded frontend API */\n proxyUrl?: string;\n /** Whether this is a satellite instance */\n isSatellite?: boolean;\n};\n\n/** Prefix used for production publishable keys */\nconst PUBLISHABLE_KEY_LIVE_PREFIX = 'pk_live_';\n\n/** Prefix used for development publishable keys */\nconst PUBLISHABLE_KEY_TEST_PREFIX = 'pk_test_';\n\n/**\n * Regular expression that matches development frontend API keys.\n * Matches patterns like: foo-bar-13.clerk.accounts.dev.\n */\nconst PUBLISHABLE_FRONTEND_API_DEV_REGEX = /^(([a-z]+)-){2}([0-9]{1,2})\\.clerk\\.accounts([a-z.]*)(dev|com)$/i;\n\n/**\n * Converts a frontend API URL into a base64-encoded publishable key.\n *\n * @param frontendApi - The frontend API URL (e.g., 'clerk.example.com').\n * @returns A base64-encoded publishable key with appropriate prefix (pk_live_ or pk_test_).\n */\nexport function buildPublishableKey(frontendApi: string): string {\n const isDevKey =\n PUBLISHABLE_FRONTEND_API_DEV_REGEX.test(frontendApi) ||\n (frontendApi.startsWith('clerk.') && LEGACY_DEV_INSTANCE_SUFFIXES.some(s => frontendApi.endsWith(s)));\n const keyPrefix = isDevKey ? PUBLISHABLE_KEY_TEST_PREFIX : PUBLISHABLE_KEY_LIVE_PREFIX;\n return `${keyPrefix}${isomorphicBtoa(`${frontendApi}$`)}`;\n}\n\n/**\n * Validates that a decoded publishable key has the correct format.\n * The decoded value should be a frontend API followed by exactly one '$' at the end.\n *\n * @param decoded - The decoded publishable key string to validate.\n * @returns `true` if the decoded key has valid format, `false` otherwise.\n */\nfunction isValidDecodedPublishableKey(decoded: string): boolean {\n if (!decoded.endsWith('$')) {\n return false;\n }\n\n const withoutTrailing = decoded.slice(0, -1);\n if (withoutTrailing.includes('$')) {\n return false;\n }\n\n return withoutTrailing.includes('.');\n}\n\nexport function parsePublishableKey(\n key: string | undefined,\n options: ParsePublishableKeyOptions & { fatal: true },\n): PublishableKey;\nexport function parsePublishableKey(\n key: string | undefined,\n options?: ParsePublishableKeyOptions,\n): PublishableKey | null;\n/**\n * Parses and validates a publishable key, extracting the frontend API and instance type.\n *\n * @param key - The publishable key to parse.\n * @param options - Configuration options for parsing.\n * @param options.fatal\n * @param options.domain\n * @param options.proxyUrl\n * @param options.isSatellite\n * @returns Parsed publishable key object with instanceType and frontendApi, or null if invalid.\n *\n * @throws {Error} When options.fatal is true and key is missing or invalid.\n */\nexport function parsePublishableKey(\n key: string | undefined,\n options: { fatal?: boolean; domain?: string; proxyUrl?: string; isSatellite?: boolean } = {},\n): PublishableKey | null {\n key = key || '';\n\n if (!key || !isPublishableKey(key)) {\n if (options.fatal && !key) {\n throw new Error(\n 'Publishable key is missing. Ensure that your publishable key is correctly configured. Double-check your environment configuration for your keys, or access them here: https://dashboard.clerk.com/last-active?path=api-keys',\n );\n }\n if (options.fatal && !isPublishableKey(key)) {\n throw new Error('Publishable key not valid.');\n }\n return null;\n }\n\n const instanceType = key.startsWith(PUBLISHABLE_KEY_LIVE_PREFIX) ? 'production' : 'development';\n\n let decodedFrontendApi: string;\n try {\n decodedFrontendApi = isomorphicAtob(key.split('_')[2]);\n } catch {\n if (options.fatal) {\n throw new Error('Publishable key not valid: Failed to decode key.');\n }\n return null;\n }\n\n if (!isValidDecodedPublishableKey(decodedFrontendApi)) {\n if (options.fatal) {\n throw new Error('Publishable key not valid: Decoded key has invalid format.');\n }\n return null;\n }\n\n let frontendApi = decodedFrontendApi.slice(0, -1);\n\n if (options.proxyUrl) {\n frontendApi = options.proxyUrl;\n } else if (instanceType !== 'development' && options.domain && options.isSatellite) {\n frontendApi = `clerk.${options.domain}`;\n }\n\n return {\n instanceType,\n frontendApi,\n };\n}\n\n/**\n * Checks if the provided key is a valid publishable key.\n *\n * @param key - The key to be checked. Defaults to an empty string if not provided.\n * @returns `true` if 'key' is a valid publishable key, `false` otherwise.\n */\nexport function isPublishableKey(key: string = '') {\n try {\n const hasValidPrefix = key.startsWith(PUBLISHABLE_KEY_LIVE_PREFIX) || key.startsWith(PUBLISHABLE_KEY_TEST_PREFIX);\n\n if (!hasValidPrefix) {\n return false;\n }\n\n const parts = key.split('_');\n if (parts.length !== 3) {\n return false;\n }\n\n const encodedPart = parts[2];\n if (!encodedPart) {\n return false;\n }\n\n const decoded = isomorphicAtob(encodedPart);\n return isValidDecodedPublishableKey(decoded);\n } catch {\n return false;\n }\n}\n\n/**\n * Creates a memoized cache for checking if URLs are development or staging environments.\n * Uses a Map to cache results for better performance on repeated checks.\n *\n * @returns An object with an isDevOrStagingUrl method that checks if a URL is dev/staging.\n */\nexport function createDevOrStagingUrlCache() {\n const devOrStagingUrlCache = new Map<string, boolean>();\n\n return {\n /**\n * Checks if a URL is a development or staging environment.\n *\n * @param url - The URL to check (string or URL object).\n * @returns `true` if the URL is a development or staging environment, `false` otherwise.\n */\n isDevOrStagingUrl: (url: string | URL): boolean => {\n if (!url) {\n return false;\n }\n\n const hostname = typeof url === 'string' ? url : url.hostname;\n let res = devOrStagingUrlCache.get(hostname);\n if (res === undefined) {\n res = DEV_OR_STAGING_SUFFIXES.some(s => hostname.endsWith(s));\n devOrStagingUrlCache.set(hostname, res);\n }\n return res;\n },\n };\n}\n\n/**\n * Checks if a publishable key is for a development environment.\n * Supports both legacy format (test_) and new format (pk_test_).\n *\n * @param apiKey - The API key to check.\n * @returns `true` if the key is for development, `false` otherwise.\n */\nexport function isDevelopmentFromPublishableKey(apiKey: string): boolean {\n return apiKey.startsWith('test_') || apiKey.startsWith('pk_test_');\n}\n\n/**\n * Checks if a publishable key is for a production environment.\n * Supports both legacy format (live_) and new format (pk_live_).\n *\n * @param apiKey - The API key to check.\n * @returns `true` if the key is for production, `false` otherwise.\n */\nexport function isProductionFromPublishableKey(apiKey: string): boolean {\n return apiKey.startsWith('live_') || apiKey.startsWith('pk_live_');\n}\n\n/**\n * Checks if a secret key is for a development environment.\n * Supports both legacy format (test_) and new format (sk_test_).\n *\n * @param apiKey - The secret key to check.\n * @returns `true` if the key is for development, `false` otherwise.\n */\nexport function isDevelopmentFromSecretKey(apiKey: string): boolean {\n return apiKey.startsWith('test_') || apiKey.startsWith('sk_test_');\n}\n\n/**\n * Checks if a secret key is for a production environment.\n * Supports both legacy format (live_) and new format (sk_live_).\n *\n * @param apiKey - The secret key to check.\n * @returns `true` if the key is for production, `false` otherwise.\n */\nexport function isProductionFromSecretKey(apiKey: string): boolean {\n return apiKey.startsWith('live_') || apiKey.startsWith('sk_live_');\n}\n\n/**\n * Generates a unique cookie suffix based on the publishable key using SHA-1 hashing.\n * The suffix is base64-encoded and URL-safe (+ and / characters are replaced).\n *\n * @param publishableKey - The publishable key to generate suffix from.\n * @param subtle - The SubtleCrypto interface to use for hashing (defaults to globalThis.crypto.subtle).\n * @returns A promise that resolves to an 8-character URL-safe base64 string.\n */\nexport async function getCookieSuffix(\n publishableKey: string,\n subtle: SubtleCrypto = globalThis.crypto.subtle,\n): Promise<string> {\n const data = new TextEncoder().encode(publishableKey);\n const digest = await subtle.digest('sha-1', data);\n const stringDigest = String.fromCharCode(...new Uint8Array(digest));\n // Base 64 Encoding with URL and Filename Safe Alphabet: https://datatracker.ietf.org/doc/html/rfc4648#section-5\n return isomorphicBtoa(stringDigest).replace(/\\+/gi, '-').replace(/\\//gi, '_').substring(0, 8);\n}\n\n/**\n * Creates a suffixed cookie name by appending the cookie suffix to the base name.\n * Used to create unique cookie names based on the publishable key.\n *\n * @param cookieName - The base cookie name.\n * @param cookieSuffix - The suffix to append (typically generated by getCookieSuffix).\n * @returns The suffixed cookie name in format: `${cookieName}_${cookieSuffix}`.\n */\nexport const getSuffixedCookieName = (cookieName: string, cookieSuffix: string): string => {\n return `${cookieName}_${cookieSuffix}`;\n};\n","export const SCOPE = {\n BACKGROUND: 'background',\n} as const;\n\nexport type Scope = (typeof SCOPE)[keyof typeof SCOPE];\n\nexport interface ClerkClientExtensionFeatures {\n background?: boolean;\n sync?: boolean;\n}\n","export const DEV_BROWSER_JWT_KEY = '__clerk_db_jwt';\nexport const DEV_BROWSER_JWT_HEADER = 'Clerk-Db-Jwt';\n\n// Sets the dev_browser JWT in the hash or the search\nexport function setDevBrowserJWTInURL(url: URL, jwt: string): URL {\n const resultURL = new URL(url);\n\n // extract & strip existing jwt from search\n const jwtFromSearch = resultURL.searchParams.get(DEV_BROWSER_JWT_KEY);\n resultURL.searchParams.delete(DEV_BROWSER_JWT_KEY);\n\n // Existing jwt takes precedence\n const jwtToSet = jwtFromSearch || jwt;\n\n if (jwtToSet) {\n resultURL.searchParams.set(DEV_BROWSER_JWT_KEY, jwtToSet);\n }\n\n return resultURL;\n}\n\n/**\n * Gets the __clerk_db_jwt JWT from either the hash or the search\n * Side effect:\n * Removes __clerk_db_jwt JWT from the URL (hash and searchParams) and updates the browser history\n */\nexport function extractDevBrowserJWTFromURL(url: URL): string {\n const jwt = readDevBrowserJwtFromSearchParams(url);\n const cleanUrl = removeDevBrowserJwt(url);\n if (cleanUrl.href !== url.href && typeof globalThis.history !== 'undefined') {\n globalThis.history.replaceState(null, '', removeDevBrowserJwt(url));\n }\n return jwt;\n}\n\nconst readDevBrowserJwtFromSearchParams = (url: URL) => {\n return url.searchParams.get(DEV_BROWSER_JWT_KEY) || '';\n};\n\nconst removeDevBrowserJwt = (url: URL) => {\n return removeDevBrowserJwtFromURLSearchParams(removeLegacyDevBrowserJwt(url));\n};\n\nconst removeDevBrowserJwtFromURLSearchParams = (_url: URL) => {\n const url = new URL(_url);\n url.searchParams.delete(DEV_BROWSER_JWT_KEY);\n return url;\n};\n\n/**\n * Removes the __clerk_db_jwt JWT from the URL hash, as well as\n * the legacy __dev_session JWT from the URL searchParams\n * We no longer need to use this value, however, we should remove it from the URL\n * Existing v4 apps will write the JWT to the hash and the search params in order to ensure\n * backwards compatibility with older v4 apps.\n * The only use case where this is needed now is when a user upgrades to clerk@5 locally\n * without changing the component's version on their dashboard.\n * In this scenario, the AP@4 -> localhost@5 redirect will still have the JWT in the hash,\n * in which case we need to remove it.\n */\nconst removeLegacyDevBrowserJwt = (_url: URL) => {\n const DEV_BROWSER_JWT_MARKER_REGEXP = /__clerk_db_jwt\\[(.*)\\]/;\n const DEV_BROWSER_JWT_LEGACY_KEY = '__dev_session';\n const url = new URL(_url);\n url.searchParams.delete(DEV_BROWSER_JWT_LEGACY_KEY);\n url.hash = decodeURI(url.hash).replace(DEV_BROWSER_JWT_MARKER_REGEXP, '');\n if (url.href.endsWith('#')) {\n url.hash = '';\n }\n return url;\n};\n","export const AUTH_HEADER = {\n PRODUCTION: 'Authorization',\n DEVELOPMENT: 'Clerk-Db-Jwt',\n};\n\nexport const CLIENT_JWT_KEY = '__client';\nexport const CLIENT_UAT_KEY = '__clerk_uat';\nexport const DEFAULT_LOCAL_HOST_PERMISSION = 'http://localhost';\nexport const STORAGE_KEY_CLIENT_JWT = '__clerk_client_jwt';\n","import { buildErrorThrower } from '@clerk/shared/error';\n\nexport type HostPermissionHintOpts = {\n hostHint: string;\n};\n\nexport const errorLogger = (err: Error) => console.error(err, err.stack);\nexport const errorThrower = buildErrorThrower({ packageName: '@clerk/chrome-extension' });\n\nexport const missingManifestKeyError = (key: string) => `Missing \\`${key}\\` entry in manifest.json`;\n\nexport function assertPublishableKey(publishableKey: unknown): asserts publishableKey {\n if (!publishableKey) {\n errorThrower.throwMissingPublishableKeyError();\n }\n}\n","import browser from 'webextension-polyfill';\n\nexport type FormattedUrl = `http${string}`;\n\nexport type GetClientCookieParams = {\n name: string;\n url: string;\n callback: (changeInfo: ChangeInfo) => Promise<void>;\n onListenerCallback?: () => void;\n};\n\nexport type ChangeInfo = {\n cookie: browser.Cookies.Cookie;\n cause: browser.Cookies.OnChangedCause;\n removed: boolean;\n};\n\nfunction ensureFormattedUrl(url: string): FormattedUrl {\n return url.startsWith('http') ? (url as FormattedUrl) : `https://${url}`;\n}\n\nexport async function getClientCookie({ url, name }: GetClientCookieParams) {\n return await browser.cookies.get({ name, url: ensureFormattedUrl(url) });\n}\n\nexport function createClientCookieListener({ url, name, callback }: GetClientCookieParams) {\n const domain = new URL(url).hostname;\n const cookieDomain = domain.startsWith('www.') ? domain.slice(4) : domain;\n\n const listener = (changeInfo: ChangeInfo) => {\n if (changeInfo.cookie.domain === cookieDomain && changeInfo.cookie.name === name) {\n void callback(changeInfo);\n }\n };\n\n return {\n add: () => browser.cookies.onChanged.addListener(listener),\n has: () => browser.cookies.onChanged.hasListener(listener),\n remove: () => browser.cookies.onChanged.removeListener(listener),\n };\n}\n","import { CLIENT_UAT_KEY, STORAGE_KEY_CLIENT_JWT } from '../constants';\nimport type { ChangeInfo, GetClientCookieParams } from './cookies';\nimport { createClientCookieListener, getClientCookie } from './cookies';\nimport { errorLogger } from './errors';\nimport type { StorageCache } from './storage';\n\nexport type JWTHandlerParams = { frontendApi: string } & (\n | {\n sync?: false;\n }\n | ({ sync: true } & GetClientCookieParams)\n);\n\nexport type JWTHandler = ReturnType<typeof JWTHandler>;\n\nfunction shouldSync(sync: boolean | undefined, _params: unknown): _params is GetClientCookieParams {\n return Boolean(sync);\n}\n\nexport function JWTHandler(store: StorageCache, params: JWTHandlerParams) {\n const { sync, frontendApi, ...cookieParams } = params;\n\n const CACHE_KEY = store.createKey(frontendApi, STORAGE_KEY_CLIENT_JWT, 'v2');\n\n /**\n * Sets the JWT value to the active\n * @param value: JWT generally from the cookie or authorization header\n */\n const set = async (value: string): Promise<void> => {\n return await store.set(CACHE_KEY, value).catch(errorLogger);\n };\n\n /**\n * Remove the JWT value\n */\n const remove = async (): Promise<void> => {\n return await store.remove(CACHE_KEY).catch(errorLogger);\n };\n\n /**\n * Gets the JWT value to the active store.\n * If not set, attempt to get it from the synced session and save for later use.\n */\n const get = async () => {\n if (shouldSync(sync, cookieParams)) {\n // Get client cookie from browser\n const syncedJWT = await getClientCookie(cookieParams).catch(errorLogger);\n\n if (syncedJWT) {\n // Set client cookie in StorageCache\n await set(syncedJWT.value);\n return syncedJWT.value;\n }\n }\n\n // Get current JWT from StorageCache\n return await store.get<string>(CACHE_KEY);\n };\n\n const listener = () => {\n if (!shouldSync(sync, cookieParams)) {\n return;\n }\n\n const { onListenerCallback, ...restCookieParams } = cookieParams;\n\n return createClientCookieListener({\n ...restCookieParams,\n callback: async (changeInfo: ChangeInfo) => {\n const existingJWT = await get();\n\n if (existingJWT === changeInfo.cookie.value) {\n const syncedUAT = await getClientCookie({ ...restCookieParams, name: CLIENT_UAT_KEY }).catch(errorLogger);\n\n if (!syncedUAT || syncedUAT?.value === '0') {\n onListenerCallback?.();\n }\n\n return;\n }\n\n await set(changeInfo.cookie.value);\n onListenerCallback?.();\n },\n });\n };\n\n return { get, listener, set, remove };\n}\n","import type { SetRequired } from 'type-fest';\nimport type { Manifest } from 'webextension-polyfill';\n\nimport type { ClerkClientExtensionFeatures } from '../../types';\nimport { errorThrower, missingManifestKeyError } from './errors';\n\nexport type ValidatedManifest = SetRequired<Manifest.WebExtensionManifest, 'permissions' | 'host_permissions'>;\nexport type ManifestKeys = keyof Manifest.WebExtensionManifest;\n\nfunction validateRootManifestKey(manifest: Manifest.WebExtensionManifest, key: ManifestKeys): void {\n if (!manifest[key]) {\n errorThrower.throw(missingManifestKeyError(key));\n }\n}\n\nfunction validateManifestPermission(manifest: Manifest.WebExtensionManifest, key: Manifest.Permission): void {\n if (!manifest.permissions?.includes(key)) {\n errorThrower.throw(missingManifestKeyError(`permissions.${key}`));\n }\n}\n\nfunction hasAdditionalFeatures(features: ClerkClientExtensionFeatures): boolean {\n return Boolean(features) && Object.keys(features).length > 0;\n}\n\nexport function validateManifest(\n manifest: Manifest.WebExtensionManifest,\n features: ClerkClientExtensionFeatures,\n): asserts manifest is ValidatedManifest {\n validateRootManifestKey(manifest, 'permissions');\n validateManifestPermission(manifest, 'storage');\n\n // If no additional features are provided, we can return success early\n if (!hasAdditionalFeatures(features)) {\n return;\n }\n\n if (features.background) {\n validateRootManifestKey(manifest, 'background');\n }\n\n if (features.sync) {\n validateManifestPermission(manifest, 'cookies');\n validateRootManifestKey(manifest, 'host_permissions');\n }\n}\n","import type { Clerk } from '@clerk/clerk-js';\n\nimport { AUTH_HEADER } from '../constants';\nimport type { JWTHandler } from './jwt-handler';\n\ntype Handler = Parameters<Clerk['__unstable__onBeforeRequest']>[0];\ntype Req = Parameters<Handler>[0];\n\n/** Append the JWT to the FAPI request */\nexport function requestHandler(jwtHandler: JWTHandler, { isProd }: { isProd: boolean }) {\n const handler: Handler = async requestInit => {\n requestInit.credentials = 'omit';\n\n const currentJWT = await jwtHandler.get();\n\n if (!currentJWT) {\n return;\n }\n\n if (isProd) {\n prodHandler(requestInit, currentJWT);\n } else {\n devHandler(requestInit, currentJWT);\n }\n };\n\n return handler;\n}\n\n/** Append the JWT to the FAPI request, per development instances */\nfunction devHandler(requestInit: Req, jwt: string) {\n requestInit.url?.searchParams.append('__clerk_db_jwt', jwt);\n}\n\n/** Append the JWT to the FAPI request, per production instances */\nfunction prodHandler(requestInit: Req, jwt: string) {\n requestInit.url?.searchParams.append('_is_native', '1');\n (requestInit.headers as Headers).set(AUTH_HEADER.PRODUCTION, `Bearer ${jwt}`);\n}\n","import type { Clerk } from '@clerk/clerk-js';\n\nimport { AUTH_HEADER } from '../constants';\nimport type { JWTHandler } from './jwt-handler';\n\ntype Handler = Parameters<Clerk['__unstable__onAfterResponse']>[0];\ntype Res = Parameters<Handler>[1];\n\n/** Retrieve the JWT to the FAPI response */\nexport function responseHandler(jwtHandler: JWTHandler, { isProd }: { isProd: boolean }) {\n const handler: Handler = async (_, response) => {\n if (isProd) {\n await prodHandler(response, jwtHandler);\n } else {\n await devHandler(response, jwtHandler);\n }\n };\n return handler;\n}\n\n/** Retrieve the JWT to the FAPI response, per development instances */\nasync function devHandler(response: Res, jwtHandler: JWTHandler) {\n const header = response?.headers.get(AUTH_HEADER.DEVELOPMENT);\n\n if (header) {\n await jwtHandler.set(header);\n } else {\n await jwtHandler.remove();\n }\n}\n\n/** Retrieve the JWT to the FAPI response, per production instances */\nasync function prodHandler(response: Res, jwtHandler: JWTHandler) {\n const header = response?.headers.get(AUTH_HEADER.PRODUCTION);\n\n if (header?.startsWith('Bearer')) {\n const jwt = header.split(' ')[1] || undefined;\n\n if (jwt) {\n await jwtHandler.set(jwt);\n } else {\n await jwtHandler.remove();\n }\n } else if (header) {\n await jwtHandler.set(header);\n }\n}\n","import browser from 'webextension-polyfill';\n\ntype StorageCacheOptions = {\n storageArea?: 'local' | 'sync';\n};\n\nexport type StorageCache = {\n createKey: (...keys: string[]) => string;\n get: <T = any>(key: string) => Promise<T | undefined>;\n remove: (key: string) => Promise<void>;\n set: (key: string, value: string) => Promise<void>;\n};\n\nconst createKey: StorageCache['createKey'] = (...keys: string[]) => keys.filter(Boolean).join('|');\n\n// Use browser.storage (local or sync) to persist Clerk client JWT.\n// More information at https://developer.chrome.com/docs/extensions/reference/storage\nconst createBrowserStorageCache = (opts: StorageCacheOptions = {}): StorageCache => {\n const __storageArea = opts.storageArea || 'local';\n\n return {\n createKey,\n get: <T>(key: string) => browser.storage[__storageArea].get(key).then(result => (result[key] as T) || undefined),\n remove: (key: string) => browser.storage[__storageArea].remove(key),\n set: (key: string, value: string) => browser.storage[__storageArea].set({ [key]: value }),\n };\n};\n\nconst createMemoryStorageCache = (): StorageCache => {\n const cache: Map<string, any> = new Map();\n\n return {\n createKey,\n get: (key: string) => Promise.resolve(cache.get(key)),\n remove: (key: string) => {\n cache.delete(key);\n return Promise.resolve();\n },\n set: (key: string, value: string) => {\n cache.set(key, value);\n return Promise.resolve();\n },\n };\n};\n\nexport const BrowserStorageCache = createBrowserStorageCache();\nexport const MemoryStorageCache = createMemoryStorageCache();\n","import { Clerk } from '@clerk/clerk-js/no-rhc';\nimport { DEV_BROWSER_JWT_KEY } from '@clerk/shared/devBrowser';\nimport { parsePublishableKey } from '@clerk/shared/keys';\nimport browser from 'webextension-polyfill';\n\nimport { SCOPE, type Scope } from '../types';\nimport { CLIENT_JWT_KEY, DEFAULT_LOCAL_HOST_PERMISSION } from './constants';\nimport { assertPublishableKey } from './utils/errors';\nimport type { JWTHandlerParams } from './utils/jwt-handler';\nimport { JWTHandler } from './utils/jwt-handler';\nimport { validateManifest } from './utils/manifest';\nimport { requestHandler } from './utils/request-handler';\nimport { responseHandler } from './utils/response-handler';\nimport { BrowserStorageCache, type StorageCache } from './utils/storage';\n\nexport let clerk: Clerk;\n\nClerk.sdkMetadata = {\n name: PACKAGE_NAME,\n version: PACKAGE_VERSION,\n};\n\nexport type CreateClerkClientOptions = {\n __experimental_syncHostListener?: boolean;\n publishableKey: string;\n scope?: Scope;\n storageCache?: StorageCache;\n syncHost?: string;\n};\n\nexport async function createClerkClient({\n __experimental_syncHostListener = false,\n publishableKey,\n scope,\n storageCache = BrowserStorageCache,\n syncHost,\n}: CreateClerkClientOptions): Promise<Clerk> {\n if (scope === SCOPE.BACKGROUND) {\n Clerk.mountComponentRenderer = undefined;\n }\n\n // Don't cache background scripts as it can result in out-of-sync client information.\n if (clerk && scope !== SCOPE.BACKGROUND) {\n return clerk;\n }\n\n // Sync is enabled if a `syncHost` is provided\n const sync = Boolean(syncHost);\n\n // Parse publishableKey and assert it's present/valid, throw if not\n const key = parsePublishableKey(publishableKey);\n assertPublishableKey(key);\n\n const isProd = key.instanceType === 'production';\n const manifest = browser.runtime.getManifest();\n\n // Will throw if manifest is invalid\n validateManifest(manifest, {\n background: scope === SCOPE.BACKGROUND,\n sync,\n });\n\n // Set up JWT handler and attempt to get JWT from storage on initialization\n const url = syncHost ? syncHost : DEFAULT_LOCAL_HOST_PERMISSION;\n\n // Create Clerk instance\n clerk = new Clerk(publishableKey);\n\n // @ts-expect-error - TODO: sync is evaluating to true vs boolean\n const jwtOptions: JWTHandlerParams = {\n frontendApi: key.frontendApi,\n name: isProd ? CLIENT_JWT_KEY : DEV_BROWSER_JWT_KEY,\n url,\n sync: sync,\n };\n\n if (jwtOptions.sync && __experimental_syncHostListener) {\n jwtOptions.onListenerCallback = () => {\n if (clerk.user) {\n clerk.user.reload();\n } else {\n window.location.reload();\n }\n };\n }\n\n const jwt = JWTHandler(storageCache, jwtOptions);\n\n // Add listener to sync host cookies if enabled\n if (jwtOptions.sync && __experimental_syncHostListener) {\n const listener = jwt.listener();\n listener?.add();\n }\n\n clerk.__unstable__onAfterResponse(responseHandler(jwt, { isProd }));\n clerk.__unstable__onBeforeRequest(requestHandler(jwt, { isProd }));\n\n return clerk;\n}\n"]}
|
package/dist/esm/index.js
CHANGED
@@ -1,6 +1,6 @@
|
|
1
|
-
import { setErrorThrowerOptions } from './chunk-
|
2
|
-
export { APIKeys, AuthenticateWithRedirectCallback, ClerkDegraded, ClerkFailed, ClerkLoaded, ClerkLoading, ClerkProvider, CreateOrganization, GoogleOneTap, OrganizationList, OrganizationProfile, OrganizationSwitcher, PricingTable, Protect, RedirectToCreateOrganization, RedirectToOrganizationProfile, RedirectToSignIn, RedirectToSignUp, RedirectToUserProfile, SignIn, SignInButton, SignInWithMetamaskButton, SignOutButton, SignUp, SignUpButton, SignedIn, SignedOut, UserAvatar, UserButton, UserProfile, Waitlist, useAuth, useClerk, useEmailLink, useOrganization, useOrganizationList, useReverification, useSession, useSessionList, useSignIn, useSignUp, useUser } from './chunk-
|
3
|
-
import './chunk-
|
1
|
+
import { setErrorThrowerOptions } from './chunk-CGI3LCPZ.js';
|
2
|
+
export { APIKeys, AuthenticateWithRedirectCallback, ClerkDegraded, ClerkFailed, ClerkLoaded, ClerkLoading, ClerkProvider, CreateOrganization, GoogleOneTap, OrganizationList, OrganizationProfile, OrganizationSwitcher, PricingTable, Protect, RedirectToCreateOrganization, RedirectToOrganizationProfile, RedirectToSignIn, RedirectToSignUp, RedirectToUserProfile, SignIn, SignInButton, SignInWithMetamaskButton, SignOutButton, SignUp, SignUpButton, SignedIn, SignedOut, UserAvatar, UserButton, UserProfile, Waitlist, useAuth, useClerk, useEmailLink, useOrganization, useOrganizationList, useReverification, useSession, useSessionList, useSignIn, useSignUp, useUser } from './chunk-CGI3LCPZ.js';
|
3
|
+
import './chunk-ODI55SF5.js';
|
4
4
|
|
5
5
|
// src/index.ts
|
6
6
|
setErrorThrowerOptions({ packageName: "@clerk/chrome-extension" });
|
package/dist/esm/react/index.js
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
export { ClerkProvider, GoogleOneTap } from '../chunk-
|
2
|
-
import '../chunk-
|
1
|
+
export { ClerkProvider, GoogleOneTap } from '../chunk-CGI3LCPZ.js';
|
2
|
+
import '../chunk-ODI55SF5.js';
|
3
3
|
//# sourceMappingURL=index.js.map
|
4
4
|
//# sourceMappingURL=index.js.map
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@clerk/chrome-extension",
|
3
|
-
"version": "2.7.4-canary.
|
3
|
+
"version": "2.7.4-canary.v20251007151725",
|
4
4
|
"description": "Clerk SDK for Chrome extensions",
|
5
5
|
"keywords": [
|
6
6
|
"auth",
|
@@ -33,9 +33,9 @@
|
|
33
33
|
],
|
34
34
|
"dependencies": {
|
35
35
|
"webextension-polyfill": "~0.12.0",
|
36
|
-
"@clerk/clerk-js": "^5.100.0-canary.
|
37
|
-
"@clerk/clerk-react": "^5.51.1-canary.
|
38
|
-
"@clerk/shared": "^3.27.4-canary.
|
36
|
+
"@clerk/clerk-js": "^5.100.0-canary.v20251007151725",
|
37
|
+
"@clerk/clerk-react": "^5.51.1-canary.v20251007151725",
|
38
|
+
"@clerk/shared": "^3.27.4-canary.v20251007151725"
|
39
39
|
},
|
40
40
|
"devDependencies": {
|
41
41
|
"@types/chrome": "^0.1.12",
|