@djangocfg/monitor 2.1.359 → 2.1.361

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/client/index.ts","../src/client/capture/fingerprint.ts","../src/client/capture/session.ts","../src/client/store/index.ts","../src/_api/generated/helpers/auth.ts","../src/_api/generated/helpers/logger.ts","../src/_api/generated/core/bodySerializer.gen.ts","../src/_api/generated/core/params.gen.ts","../src/_api/generated/core/serverSentEvents.gen.ts","../src/_api/generated/core/pathSerializer.gen.ts","../src/_api/generated/core/utils.gen.ts","../src/_api/generated/core/auth.gen.ts","../src/_api/generated/client/utils.gen.ts","../src/_api/generated/client/client.gen.ts","../src/_api/generated/client.gen.ts","../src/_api/generated/sdk.gen.ts","../src/_api/generated/_cfg_monitor/api.ts","../src/_api/BaseClient.ts","../src/_api/generated/types.gen.ts","../src/_api/index.ts","../src/client/transport/ingest.ts","../src/client/utils/env.ts","../src/client/constants.ts","../src/client/capture/js-errors.ts","../src/client/capture/console.ts","../src/client/capture/validation.ts","../src/client/capture/network.ts","../src/client/MonitorProvider.tsx","../src/client/window.ts","../src/client/hooks/useDebugMode.ts"],"sourcesContent":["/**\n * @djangocfg/monitor/client\n *\n * Browser-side monitor. Use in 'use client' components only.\n *\n * @example\n * ```tsx\n * 'use client'\n * import { useEffect } from 'react'\n * import { FrontendMonitor } from '@djangocfg/monitor/client'\n *\n * export function MonitorProvider() {\n * useEffect(() => {\n * FrontendMonitor.init({ project: 'my-app', environment: process.env.NODE_ENV })\n * return () => FrontendMonitor.destroy()\n * }, [])\n * return null\n * }\n * ```\n */\n\nimport { installJsErrorCapture } from './capture/js-errors'\nimport { installConsoleCapture } from './capture/console'\nimport { installValidationCapture } from './capture/validation'\nimport { ensureSessionCookie } from './capture/session'\nimport { monitorStore } from './store'\nimport { configureMonitorApi } from '../_api'\nimport type { MonitorConfig, MonitorEvent } from '../types'\n\nexport type { MonitorConfig, MonitorEvent } from '../types'\nexport { EventType, EventLevel } from '../types'\nexport { monitoredFetch } from './capture/network'\nexport { getSessionId } from './capture/session'\nexport { MonitorProvider } from './MonitorProvider'\nexport type { MonitorProviderProps } from './MonitorProvider'\nexport { initWindowMonitor } from './window'\nexport type { WindowMonitorAPI } from './window'\nexport { monitorStore } from './store'\nexport { useDebugMode } from './hooks/useDebugMode'\nexport { isDevelopment, isProduction, MONITOR_VERSION } from './utils/env'\n\nlet flushInterval: ReturnType<typeof setInterval> | null = null\nconst cleanupFns: Array<() => void> = []\n\nexport const FrontendMonitor = {\n init(config: MonitorConfig = {}): void {\n if (typeof window === 'undefined') return\n\n const baseUrl = config.baseUrl ?? process.env.NEXT_PUBLIC_API_URL ?? ''\n if (baseUrl) configureMonitorApi(baseUrl)\n monitorStore.getState().setConfig(config)\n ensureSessionCookie()\n\n if (config.captureJsErrors !== false) cleanupFns.push(installJsErrorCapture())\n if (config.captureConsole !== false) cleanupFns.push(installConsoleCapture())\n cleanupFns.push(installValidationCapture())\n\n const interval = config.flushInterval ?? 5000\n flushInterval = setInterval(() => monitorStore.getState().flush(), interval)\n\n const onHide = () => { if (document.visibilityState === 'hidden') monitorStore.getState().flush(true) }\n window.addEventListener('visibilitychange', onHide)\n window.addEventListener('beforeunload', () => monitorStore.getState().flush(true))\n\n if (config.debug) console.info('[FrontendMonitor] initialized', config)\n },\n\n capture(event: MonitorEvent): void {\n monitorStore.getState().push(event)\n },\n\n flush(): void {\n monitorStore.getState().flush()\n },\n\n destroy(): void {\n if (flushInterval !== null) { clearInterval(flushInterval); flushInterval = null }\n cleanupFns.forEach((fn) => fn())\n cleanupFns.length = 0\n },\n}\n","function simpleHash(str: string): string {\n let hash = 0\n for (let i = 0; i < str.length; i++) {\n hash = (hash << 5) - hash + str.charCodeAt(i)\n hash = hash & hash\n }\n return Math.abs(hash).toString(16).padStart(8, '0')\n}\n\nexport async function computeFingerprint(\n message: string,\n stack: string,\n url: string,\n): Promise<string> {\n const raw = `${message}|${stack}|${url}`\n if (typeof crypto !== 'undefined' && crypto.subtle) {\n try {\n const data = new TextEncoder().encode(raw)\n const buf = await crypto.subtle.digest('SHA-256', data)\n return Array.from(new Uint8Array(buf))\n .map((b) => b.toString(16).padStart(2, '0'))\n .join('')\n .slice(0, 64)\n } catch { /* fall through */ }\n }\n return simpleHash(raw)\n}\n","const SESSION_KEY = 'fm_session_id'\nconst COOKIE_MAX_AGE = 60 * 60 * 24 * 365\n\nfunction generateUUID(): string {\n if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n return crypto.randomUUID()\n }\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = (Math.random() * 16) | 0\n return (c === 'x' ? r : (r & 0x3) | 0x8).toString(16)\n })\n}\n\nfunction setCookie(name: string, value: string): void {\n if (typeof document === 'undefined') return\n document.cookie = `${name}=${value}; path=/; SameSite=Lax; max-age=${COOKIE_MAX_AGE}`\n}\n\nexport function getSessionId(): string {\n if (typeof localStorage === 'undefined') return ''\n let id = localStorage.getItem(SESSION_KEY)\n if (!id) {\n id = generateUUID()\n localStorage.setItem(SESSION_KEY, id)\n setCookie(SESSION_KEY, id)\n }\n return id\n}\n\nexport function ensureSessionCookie(): void {\n const id = getSessionId()\n if (id) setCookie(SESSION_KEY, id)\n}\n","import { createStore } from 'zustand/vanilla'\nimport type { MonitorEvent, MonitorConfig } from '../../types'\nimport { sendBatch } from '../transport/ingest'\nimport { MONITOR_VERSION } from '../utils/env'\nimport { DEFAULT_DEDUPE_STORE_TTL } from '../constants'\n\n// Circuit breaker: pause flushing after N consecutive transport failures\nconst CIRCUIT_BREAKER_THRESHOLD = 3\nconst CIRCUIT_BREAKER_COOLDOWN_MS = 60_000 // 1 minute\n\n// Global deduplication: skip pushing identical events within this window.\n// Protects against multiple capture sources (js-errors, console, ErrorTrackingProvider)\n// all firing for the same underlying error.\nconst STORE_DEDUP_MAX = 200\nconst _recentPushKeys = new Map<string, number>()\n\nfunction _pushDedupeKey(event: MonitorEvent): string {\n const msg = (event.message ?? '').slice(0, 100)\n return `${event.event_type}:${event.level}:${msg}:${event.http_url ?? event.url ?? ''}`\n}\n\nfunction _isRecentPush(key: string, ttl: number): boolean {\n const now = Date.now()\n const last = _recentPushKeys.get(key)\n if (last !== undefined && now - last < ttl) return true\n _recentPushKeys.set(key, now)\n if (_recentPushKeys.size > STORE_DEDUP_MAX) {\n for (const [k, ts] of _recentPushKeys) {\n if (now - ts > ttl) _recentPushKeys.delete(k)\n }\n }\n return false\n}\n\ninterface MonitorState {\n config: MonitorConfig\n buffer: MonitorEvent[]\n initialized: boolean\n _consecutiveFailures: number\n _pausedUntil: number\n push: (event: MonitorEvent) => void\n flush: (useBeacon?: boolean) => void\n setConfig: (config: MonitorConfig) => void\n}\n\nexport const monitorStore = createStore<MonitorState>((set, get) => ({\n config: {},\n buffer: [],\n initialized: false,\n _consecutiveFailures: 0,\n _pausedUntil: 0,\n\n push(event) {\n // Global dedup: skip if an identical event was pushed recently\n const { config, buffer } = get()\n const storeTtl = config.dedupeStoreTtl ?? DEFAULT_DEDUPE_STORE_TTL\n const dedupeKey = _pushDedupeKey(event)\n if (_isRecentPush(dedupeKey, storeTtl)) return\n const maxSize = config.maxBufferSize ?? 20\n const sanitized: MonitorEvent = {\n build_id: event.build_id ?? config.buildId ?? `sdk:${MONITOR_VERSION}`,\n ...event,\n // Enforce field size limits before buffering (last-resort backstop)\n message: event.message && event.message.length > 4997\n ? event.message.slice(0, 4997) + '...'\n : event.message,\n stack_trace: event.stack_trace && event.stack_trace.length > 10000\n ? event.stack_trace.slice(0, 9997) + '...'\n : event.stack_trace,\n // Cap extra payload — drop entirely if serialized size exceeds 32KB\n extra: (() => {\n if (!event.extra) return event.extra\n try {\n return JSON.stringify(event.extra).length > 32768 ? {} : event.extra\n } catch { return {} }\n })(),\n }\n const next = [...buffer, sanitized]\n set({ buffer: next })\n\n if (next.length >= maxSize || event.level === 'error') {\n get().flush()\n }\n },\n\n flush(useBeacon = false) {\n const { buffer, _pausedUntil } = get()\n if (buffer.length === 0) return\n\n // Circuit breaker: skip sending while paused\n if (Date.now() < _pausedUntil) return\n\n const batch = buffer.slice(0, 25)\n set({ buffer: buffer.slice(25) })\n\n sendBatch({ events: batch }, useBeacon).then(\n () => {\n // Success: reset failure counter\n set({ _consecutiveFailures: 0, _pausedUntil: 0 })\n },\n () => {\n // Failure: increment counter and maybe open circuit\n const failures = get()._consecutiveFailures + 1\n const pausedUntil = failures >= CIRCUIT_BREAKER_THRESHOLD\n ? Date.now() + CIRCUIT_BREAKER_COOLDOWN_MS\n : get()._pausedUntil\n set({ _consecutiveFailures: failures, _pausedUntil: pausedUntil })\n }\n )\n },\n\n setConfig(config) {\n set({ config, initialized: true })\n },\n}))\n","// AUTO-GENERATED by django_generator / ts_extras.wrapper\n// Global auth store. Wired into the shared `client` from `client.gen.ts`\n// via `installAuthOnClient(client)` — called synchronously by the\n// post-processed bottom of client.gen.ts. No circular import here.\n// DO NOT EDIT — re-run `make gen`.\n\nconst ACCESS_KEY = 'cfg.access_token';\nconst REFRESH_KEY = 'cfg.refresh_token';\nconst API_KEY_KEY = 'cfg.api_key';\n\nconst isBrowser = typeof window !== 'undefined';\n\nexport type StorageMode = 'localStorage' | 'cookie';\n\n// ── Storage backends (browser-only; server-side reads return null) ─────────\n\ninterface KVStore {\n get(key: string): string | null;\n set(key: string, value: string | null): void;\n}\n\nconst localStorageBackend: KVStore = {\n get(key) {\n if (!isBrowser) return null;\n try { return window.localStorage.getItem(key); } catch { return null; }\n },\n set(key, value) {\n if (!isBrowser) return;\n try {\n if (value === null) window.localStorage.removeItem(key);\n else window.localStorage.setItem(key, value);\n } catch {}\n },\n};\n\n/** 30 days, matches typical refresh-token lifetime. */\nconst COOKIE_MAX_AGE = 60 * 60 * 24 * 30;\n\nconst cookieBackend: KVStore = {\n get(key) {\n if (!isBrowser) return null;\n try {\n const re = new RegExp(`(?:^|;\\\\s*)${encodeURIComponent(key)}=([^;]*)`);\n const m = document.cookie.match(re);\n return m ? decodeURIComponent(m[1]) : null;\n } catch { return null; }\n },\n set(key, value) {\n if (!isBrowser) return;\n try {\n const k = encodeURIComponent(key);\n const secure = window.location.protocol === 'https:' ? '; Secure' : '';\n if (value === null) {\n document.cookie = `${k}=; Path=/; Max-Age=0; SameSite=Lax${secure}`;\n } else {\n const v = encodeURIComponent(value);\n document.cookie = `${k}=${v}; Path=/; Max-Age=${COOKIE_MAX_AGE}; SameSite=Lax${secure}`;\n }\n } catch {}\n },\n};\n\nlet _storage: KVStore = localStorageBackend;\nlet _storageMode: StorageMode = 'localStorage';\n\n/** Detect locale from `NEXT_LOCALE` cookie or `navigator.language`. */\nfunction detectLocale(): string | null {\n try {\n if (typeof document !== 'undefined') {\n const m = document.cookie.match(/(?:^|;\\s*)NEXT_LOCALE=([^;]*)/);\n if (m) return decodeURIComponent(m[1]);\n }\n if (typeof navigator !== 'undefined' && navigator.language) {\n return navigator.language;\n }\n } catch {}\n return null;\n}\n\n/** Default baseUrl from `NEXT_PUBLIC_API_URL` (empty for static builds). */\nfunction defaultBaseUrl(): string {\n try {\n if (typeof process !== 'undefined' && process.env) {\n if (process.env.NEXT_PUBLIC_STATIC_BUILD === 'true') return '';\n return process.env.NEXT_PUBLIC_API_URL || '';\n }\n } catch {}\n return '';\n}\n\n/** Default API key fallback from `NEXT_PUBLIC_API_KEY`. */\nfunction defaultApiKey(): string | null {\n try {\n if (typeof process !== 'undefined' && process.env?.NEXT_PUBLIC_API_KEY) {\n return process.env.NEXT_PUBLIC_API_KEY;\n }\n } catch {}\n return null;\n}\n\n// ── In-memory overrides (win over storage / env) ───────────────────────────\nlet _localeOverride: string | null = null;\nlet _apiKeyOverride: string | null = null;\nlet _baseUrlOverride: string | null = null;\nlet _withCredentials = true;\nlet _onUnauthorized: ((response: Response) => void) | null = null;\n\n/**\n * User-supplied refresh handler. Receives the current refresh token,\n * must return a fresh access (and optional refresh) pair or null on failure.\n * Set once at app bootstrap via `auth.setRefreshHandler(...)`.\n */\ntype RefreshResult = { access: string; refresh?: string } | null;\ntype RefreshHandler = (refreshToken: string) => Promise<RefreshResult>;\nlet _refreshHandler: RefreshHandler | null = null;\n\n/** Single-flight: every concurrent 401 awaits the same refresh. */\nlet _refreshInflight: Promise<string | null> | null = null;\n\n/** Marker header — set on retried requests so we never loop on 401. */\nconst RETRY_MARKER = 'X-Auth-Retry';\n\n/**\n * Captured reference to the shared Hey API client. Set exactly once by\n * `installAuthOnClient(client)` (called from client.gen.ts). All `auth.set*`\n * methods that mutate transport config (baseUrl / credentials) push through\n * this reference. Until installed, those mutations are silently buffered as\n * in-memory state — the next request after install will pick them up.\n */\ntype HeyClient = {\n setConfig(opts: Record<string, unknown>): void;\n interceptors: {\n request: { use(fn: (req: Request) => Request | Promise<Request>): void };\n response: { use(fn: (res: Response, req: Request) => Response | Promise<Response>): void };\n };\n};\nlet _client: HeyClient | null = null;\n\nfunction pushClientConfig(): void {\n if (!_client) return;\n _client.setConfig({\n baseUrl: auth.getBaseUrl(),\n credentials: _withCredentials ? 'include' : 'same-origin',\n });\n}\n\n/**\n * Global auth/config store. All getters read live state every call —\n * the interceptor below uses these to attach headers per-request.\n *\n * Default storage backend is `localStorage`. Switch to cookies (e.g.\n * for Next.js SSR cookie access) via `auth.setStorageMode('cookie')`\n * early in the app bootstrap.\n *\n * @example\n * import { auth } from '@your/api';\n * auth.setToken(jwt);\n * auth.clearTokens();\n * auth.setStorageMode('cookie');\n */\nexport const auth = {\n // ── Storage mode ──────────────────────────────────────────────────\n getStorageMode(): StorageMode { return _storageMode; },\n setStorageMode(mode: StorageMode): void {\n _storageMode = mode;\n _storage = mode === 'cookie' ? cookieBackend : localStorageBackend;\n },\n\n // ── Bearer token ──────────────────────────────────────────────────\n getToken(): string | null { return _storage.get(ACCESS_KEY); },\n setToken(token: string | null): void { _storage.set(ACCESS_KEY, token); },\n getRefreshToken(): string | null { return _storage.get(REFRESH_KEY); },\n setRefreshToken(token: string | null): void { _storage.set(REFRESH_KEY, token); },\n clearTokens(): void { _storage.set(ACCESS_KEY, null); _storage.set(REFRESH_KEY, null); },\n isAuthenticated(): boolean { return _storage.get(ACCESS_KEY) !== null; },\n\n // ── API key ───────────────────────────────────────────────────────\n getApiKey(): string | null {\n return _apiKeyOverride ?? _storage.get(API_KEY_KEY) ?? defaultApiKey();\n },\n setApiKey(key: string | null): void { _apiKeyOverride = key; },\n setApiKeyPersist(key: string | null): void {\n _apiKeyOverride = key;\n _storage.set(API_KEY_KEY, key);\n },\n clearApiKey(): void { _apiKeyOverride = null; _storage.set(API_KEY_KEY, null); },\n\n // ── Locale ────────────────────────────────────────────────────────\n getLocale(): string | null { return _localeOverride ?? detectLocale(); },\n setLocale(locale: string | null): void { _localeOverride = locale; },\n\n // ── Base URL ──────────────────────────────────────────────────────\n getBaseUrl(): string {\n const url = (_baseUrlOverride ?? defaultBaseUrl());\n return url.replace(/\\/$/, '');\n },\n setBaseUrl(url: string | null): void {\n _baseUrlOverride = url ? url.replace(/\\/$/, '') : null;\n pushClientConfig();\n },\n\n // ── Credentials toggle ────────────────────────────────────────────\n getWithCredentials(): boolean { return _withCredentials; },\n setWithCredentials(value: boolean): void {\n _withCredentials = value;\n pushClientConfig();\n },\n\n // ── 401 handler ───────────────────────────────────────────────────\n /**\n * Fired when the server returns 401 AND no refresh path recovers it\n * (no refresh token, no refresh handler, refresh failed, or retry\n * still 401). The app should clear local state and redirect to login.\n *\n * NOT fired for 401 that gets transparently recovered by the refresh\n * handler — those are invisible to callers.\n */\n onUnauthorized(cb: ((response: Response) => void) | null): void {\n _onUnauthorized = cb;\n },\n\n /**\n * Register the refresh strategy. The handler receives the current\n * refresh token and must call your refresh endpoint, returning\n * `{ access, refresh? }` on success or `null` on failure.\n *\n * @example\n * auth.setRefreshHandler(async (refresh) => {\n * const { data } = await Auth.tokenRefreshCreate({ body: { refresh } });\n * return data ? { access: data.access, refresh: data.refresh } : null;\n * });\n */\n setRefreshHandler(fn: RefreshHandler | null): void {\n _refreshHandler = fn;\n },\n};\n\n/**\n * Run the user-supplied refresh handler under single-flight, persist\n * the new tokens, and return the fresh access token (or null on any\n * failure path). All concurrent 401s share the same in-flight promise.\n */\nasync function tryRefresh(): Promise<string | null> {\n if (_refreshInflight) return _refreshInflight;\n if (!_refreshHandler) return null;\n const refresh = auth.getRefreshToken();\n if (!refresh) return null;\n\n _refreshInflight = (async () => {\n try {\n const result = await _refreshHandler!(refresh);\n if (!result?.access) return null;\n auth.setToken(result.access);\n if (result.refresh) auth.setRefreshToken(result.refresh);\n return result.access;\n } catch {\n return null;\n } finally {\n _refreshInflight = null;\n }\n })();\n\n return _refreshInflight;\n}\n\n/**\n * Wire the shared client to the global auth store. Called exactly\n * once from `client.gen.ts` (post-processed) right after\n * `createClient()`. Synchronous — no microtask, no TDZ races.\n *\n * Safe to call from server / SSR: storage backends short-circuit on\n * non-browser environments, so headers populated by the interceptor\n * are simply absent server-side (which is the correct behaviour\n * unless the caller explicitly sets a server-side token).\n */\nexport function installAuthOnClient(client: HeyClient): void {\n if (_client) return; // idempotent\n _client = client;\n\n client.setConfig({\n baseUrl: auth.getBaseUrl(),\n credentials: _withCredentials ? 'include' : 'same-origin',\n });\n\n client.interceptors.request.use((request) => {\n const token = auth.getToken();\n if (token) request.headers.set('Authorization', `Bearer ${token}`);\n\n const locale = auth.getLocale();\n if (locale) request.headers.set('Accept-Language', locale);\n\n const apiKey = auth.getApiKey();\n if (apiKey) request.headers.set('X-API-Key', apiKey);\n\n try {\n const tz = Intl.DateTimeFormat().resolvedOptions().timeZone;\n if (tz) request.headers.set('X-Timezone', tz);\n } catch {}\n request.headers.set('X-Client-Time', new Date().toISOString());\n\n return request;\n });\n\n client.interceptors.response.use(async (response, request) => {\n if (response.status !== 401) return response;\n\n // Already retried once — give up to avoid loops.\n if (request.headers.get(RETRY_MARKER)) {\n if (_onUnauthorized) {\n try { _onUnauthorized(response); } catch {}\n }\n return response;\n }\n\n const newToken = await tryRefresh();\n if (!newToken) {\n if (_onUnauthorized) {\n try { _onUnauthorized(response); } catch {}\n }\n return response;\n }\n\n // Retry the original request once with the new token. We mutate a\n // clone so the original Request body (already consumed by the\n // failed call) doesn't trip \"body already used\".\n const retry = request.clone();\n retry.headers.set('Authorization', `Bearer ${newToken}`);\n retry.headers.set(RETRY_MARKER, '1');\n try {\n const retried = await fetch(retry);\n if (retried.status === 401 && _onUnauthorized) {\n try { _onUnauthorized(retried); } catch {}\n }\n return retried;\n } catch {\n // Network error on retry — surface the original 401.\n if (_onUnauthorized) {\n try { _onUnauthorized(response); } catch {}\n }\n return response;\n }\n });\n}\n\nexport type Auth = typeof auth;\n","// AUTO-GENERATED by django_generator / ts_extras.wrapper\n// API logger built on consola. Optional dependency — install if you enable logging:\n// npm install consola\n// DO NOT EDIT — re-run `make gen`.\n\nimport { type ConsolaInstance, createConsola } from \"consola\";\n\nexport interface RequestLog {\n method: string;\n url: string;\n headers?: Record<string, string>;\n body?: any;\n timestamp: number;\n}\n\nexport interface ResponseLog {\n status: number;\n statusText: string;\n data?: any;\n duration: number;\n timestamp: number;\n}\n\nexport interface ErrorLog {\n message: string;\n statusCode?: number;\n fieldErrors?: Record<string, string[]>;\n duration: number;\n timestamp: number;\n}\n\nexport interface LoggerConfig {\n enabled: boolean;\n logRequests: boolean;\n logResponses: boolean;\n logErrors: boolean;\n logBodies: boolean;\n logHeaders: boolean;\n consola?: ConsolaInstance;\n}\n\nconst DEFAULT_CONFIG: LoggerConfig = {\n enabled: typeof process !== \"undefined\" && process.env?.NODE_ENV !== \"production\",\n logRequests: true,\n logResponses: true,\n logErrors: true,\n logBodies: true,\n logHeaders: false,\n};\n\nconst SENSITIVE_HEADERS = [\n \"authorization\",\n \"cookie\",\n \"set-cookie\",\n \"x-api-key\",\n \"x-csrf-token\",\n];\n\nexport class APILogger {\n private config: LoggerConfig;\n private consola: ConsolaInstance;\n\n constructor(config: Partial<LoggerConfig> = {}) {\n this.config = { ...DEFAULT_CONFIG, ...config };\n this.consola = config.consola || createConsola({\n level: this.config.enabled ? 4 : 0,\n });\n }\n\n enable(): void { this.config.enabled = true; }\n disable(): void { this.config.enabled = false; }\n setConfig(config: Partial<LoggerConfig>): void {\n this.config = { ...this.config, ...config };\n }\n\n private filterHeaders(headers?: Record<string, string>): Record<string, string> {\n if (!headers) return {};\n const filtered: Record<string, string> = {};\n Object.keys(headers).forEach((key) => {\n filtered[key] = SENSITIVE_HEADERS.includes(key.toLowerCase()) ? \"***\" : (headers[key] || \"\");\n });\n return filtered;\n }\n\n logRequest(request: RequestLog): void {\n if (!this.config.enabled || !this.config.logRequests) return;\n const { method, url, headers, body } = request;\n this.consola.start(`${method} ${url}`);\n if (this.config.logHeaders && headers) this.consola.debug(\"Headers:\", this.filterHeaders(headers));\n if (this.config.logBodies && body) this.consola.debug(\"Body:\", body);\n }\n\n logResponse(request: RequestLog, response: ResponseLog): void {\n if (!this.config.enabled || !this.config.logResponses) return;\n const { method, url } = request;\n const { status, statusText, data, duration } = response;\n this.consola.success(`${method} ${url} ${status} ${statusText} (${duration}ms)`);\n if (this.config.logBodies && data) this.consola.debug(\"Response:\", data);\n }\n\n logError(request: RequestLog, error: ErrorLog): void {\n if (!this.config.enabled || !this.config.logErrors) return;\n const { method, url } = request;\n const { message, statusCode, fieldErrors, duration } = error;\n this.consola.error(`${method} ${url} ${statusCode || \"Network\"} Error (${duration}ms)`);\n this.consola.error(\"Message:\", message);\n if (fieldErrors && Object.keys(fieldErrors).length > 0) {\n this.consola.error(\"Field Errors:\");\n Object.entries(fieldErrors).forEach(([field, errors]) => {\n errors.forEach((err) => this.consola.error(` • ${field}: ${err}`));\n });\n }\n }\n\n info(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.info(message, ...args); }\n warn(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.warn(message, ...args); }\n error(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.error(message, ...args); }\n debug(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.debug(message, ...args); }\n success(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.success(message, ...args); }\n withTag(tag: string): ConsolaInstance { return this.consola.withTag(tag); }\n}\n\nexport const defaultLogger = new APILogger();\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { ArrayStyle, ObjectStyle, SerializerOptions } from './pathSerializer.gen';\n\nexport type QuerySerializer = (query: Record<string, unknown>) => string;\n\nexport type BodySerializer = (body: unknown) => unknown;\n\ntype QuerySerializerOptionsObject = {\n allowReserved?: boolean;\n array?: Partial<SerializerOptions<ArrayStyle>>;\n object?: Partial<SerializerOptions<ObjectStyle>>;\n};\n\nexport type QuerySerializerOptions = QuerySerializerOptionsObject & {\n /**\n * Per-parameter serialization overrides. When provided, these settings\n * override the global array/object settings for specific parameter names.\n */\n parameters?: Record<string, QuerySerializerOptionsObject>;\n};\n\nconst serializeFormDataPair = (data: FormData, key: string, value: unknown): void => {\n if (typeof value === 'string' || value instanceof Blob) {\n data.append(key, value);\n } else if (value instanceof Date) {\n data.append(key, value.toISOString());\n } else {\n data.append(key, JSON.stringify(value));\n }\n};\n\nconst serializeUrlSearchParamsPair = (data: URLSearchParams, key: string, value: unknown): void => {\n if (typeof value === 'string') {\n data.append(key, value);\n } else {\n data.append(key, JSON.stringify(value));\n }\n};\n\nexport const formDataBodySerializer = {\n bodySerializer: (body: unknown): FormData => {\n const data = new FormData();\n\n Object.entries(body as Record<string, unknown>).forEach(([key, value]) => {\n if (value === undefined || value === null) {\n return;\n }\n if (Array.isArray(value)) {\n value.forEach((v) => serializeFormDataPair(data, key, v));\n } else {\n serializeFormDataPair(data, key, value);\n }\n });\n\n return data;\n },\n};\n\nexport const jsonBodySerializer = {\n bodySerializer: (body: unknown): string =>\n JSON.stringify(body, (_key, value) => (typeof value === 'bigint' ? value.toString() : value)),\n};\n\nexport const urlSearchParamsBodySerializer = {\n bodySerializer: (body: unknown): string => {\n const data = new URLSearchParams();\n\n Object.entries(body as Record<string, unknown>).forEach(([key, value]) => {\n if (value === undefined || value === null) {\n return;\n }\n if (Array.isArray(value)) {\n value.forEach((v) => serializeUrlSearchParamsPair(data, key, v));\n } else {\n serializeUrlSearchParamsPair(data, key, value);\n }\n });\n\n return data.toString();\n },\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\ntype Slot = 'body' | 'headers' | 'path' | 'query';\n\nexport type Field =\n | {\n in: Exclude<Slot, 'body'>;\n /**\n * Field name. This is the name we want the user to see and use.\n */\n key: string;\n /**\n * Field mapped name. This is the name we want to use in the request.\n * If omitted, we use the same value as `key`.\n */\n map?: string;\n }\n | {\n in: Extract<Slot, 'body'>;\n /**\n * Key isn't required for bodies.\n */\n key?: string;\n map?: string;\n }\n | {\n /**\n * Field name. This is the name we want the user to see and use.\n */\n key: string;\n /**\n * Field mapped name. This is the name we want to use in the request.\n * If `in` is omitted, `map` aliases `key` to the transport layer.\n */\n map: Slot;\n };\n\nexport interface Fields {\n allowExtra?: Partial<Record<Slot, boolean>>;\n args?: ReadonlyArray<Field>;\n}\n\nexport type FieldsConfig = ReadonlyArray<Field | Fields>;\n\nconst extraPrefixesMap: Record<string, Slot> = {\n $body_: 'body',\n $headers_: 'headers',\n $path_: 'path',\n $query_: 'query',\n};\nconst extraPrefixes = Object.entries(extraPrefixesMap);\n\ntype KeyMap = Map<\n string,\n | {\n in: Slot;\n map?: string;\n }\n | {\n in?: never;\n map: Slot;\n }\n>;\n\nconst buildKeyMap = (fields: FieldsConfig, map?: KeyMap): KeyMap => {\n if (!map) {\n map = new Map();\n }\n\n for (const config of fields) {\n if ('in' in config) {\n if (config.key) {\n map.set(config.key, {\n in: config.in,\n map: config.map,\n });\n }\n } else if ('key' in config) {\n map.set(config.key, {\n map: config.map,\n });\n } else if (config.args) {\n buildKeyMap(config.args, map);\n }\n }\n\n return map;\n};\n\ninterface Params {\n body: unknown;\n headers: Record<string, unknown>;\n path: Record<string, unknown>;\n query: Record<string, unknown>;\n}\n\nconst stripEmptySlots = (params: Params) => {\n for (const [slot, value] of Object.entries(params)) {\n if (value && typeof value === 'object' && !Array.isArray(value) && !Object.keys(value).length) {\n delete params[slot as Slot];\n }\n }\n};\n\nexport const buildClientParams = (args: ReadonlyArray<unknown>, fields: FieldsConfig) => {\n const params: Params = {\n body: {},\n headers: {},\n path: {},\n query: {},\n };\n\n const map = buildKeyMap(fields);\n\n let config: FieldsConfig[number] | undefined;\n\n for (const [index, arg] of args.entries()) {\n if (fields[index]) {\n config = fields[index];\n }\n\n if (!config) {\n continue;\n }\n\n if ('in' in config) {\n if (config.key) {\n const field = map.get(config.key)!;\n const name = field.map || config.key;\n if (field.in) {\n (params[field.in] as Record<string, unknown>)[name] = arg;\n }\n } else {\n params.body = arg;\n }\n } else {\n for (const [key, value] of Object.entries(arg ?? {})) {\n const field = map.get(key);\n\n if (field) {\n if (field.in) {\n const name = field.map || key;\n (params[field.in] as Record<string, unknown>)[name] = value;\n } else {\n params[field.map] = value;\n }\n } else {\n const extra = extraPrefixes.find(([prefix]) => key.startsWith(prefix));\n\n if (extra) {\n const [prefix, slot] = extra;\n (params[slot] as Record<string, unknown>)[key.slice(prefix.length)] = value;\n } else if ('allowExtra' in config && config.allowExtra) {\n for (const [slot, allowed] of Object.entries(config.allowExtra)) {\n if (allowed) {\n (params[slot as Slot] as Record<string, unknown>)[key] = value;\n break;\n }\n }\n }\n }\n }\n }\n }\n\n stripEmptySlots(params);\n\n return params;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { Config } from './types.gen';\n\nexport type ServerSentEventsOptions<TData = unknown> = Omit<RequestInit, 'method'> &\n Pick<Config, 'method' | 'responseTransformer' | 'responseValidator'> & {\n /**\n * Fetch API implementation. You can use this option to provide a custom\n * fetch instance.\n *\n * @default globalThis.fetch\n */\n fetch?: typeof fetch;\n /**\n * Implementing clients can call request interceptors inside this hook.\n */\n onRequest?: (url: string, init: RequestInit) => Promise<Request>;\n /**\n * Callback invoked when a network or parsing error occurs during streaming.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @param error The error that occurred.\n */\n onSseError?: (error: unknown) => void;\n /**\n * Callback invoked when an event is streamed from the server.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @param event Event streamed from the server.\n * @returns Nothing (void).\n */\n onSseEvent?: (event: StreamEvent<TData>) => void;\n serializedBody?: RequestInit['body'];\n /**\n * Default retry delay in milliseconds.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @default 3000\n */\n sseDefaultRetryDelay?: number;\n /**\n * Maximum number of retry attempts before giving up.\n */\n sseMaxRetryAttempts?: number;\n /**\n * Maximum retry delay in milliseconds.\n *\n * Applies only when exponential backoff is used.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @default 30000\n */\n sseMaxRetryDelay?: number;\n /**\n * Optional sleep function for retry backoff.\n *\n * Defaults to using `setTimeout`.\n */\n sseSleepFn?: (ms: number) => Promise<void>;\n url: string;\n };\n\nexport interface StreamEvent<TData = unknown> {\n data: TData;\n event?: string;\n id?: string;\n retry?: number;\n}\n\nexport type ServerSentEventsResult<TData = unknown, TReturn = void, TNext = unknown> = {\n stream: AsyncGenerator<\n TData extends Record<string, unknown> ? TData[keyof TData] : TData,\n TReturn,\n TNext\n >;\n};\n\nexport function createSseClient<TData = unknown>({\n onRequest,\n onSseError,\n onSseEvent,\n responseTransformer,\n responseValidator,\n sseDefaultRetryDelay,\n sseMaxRetryAttempts,\n sseMaxRetryDelay,\n sseSleepFn,\n url,\n ...options\n}: ServerSentEventsOptions): ServerSentEventsResult<TData> {\n let lastEventId: string | undefined;\n\n const sleep = sseSleepFn ?? ((ms: number) => new Promise((resolve) => setTimeout(resolve, ms)));\n\n const createStream = async function* () {\n let retryDelay: number = sseDefaultRetryDelay ?? 3000;\n let attempt = 0;\n const signal = options.signal ?? new AbortController().signal;\n\n while (true) {\n if (signal.aborted) break;\n\n attempt++;\n\n const headers =\n options.headers instanceof Headers\n ? options.headers\n : new Headers(options.headers as Record<string, string> | undefined);\n\n if (lastEventId !== undefined) {\n headers.set('Last-Event-ID', lastEventId);\n }\n\n try {\n const requestInit: RequestInit = {\n redirect: 'follow',\n ...options,\n body: options.serializedBody,\n headers,\n signal,\n };\n let request = new Request(url, requestInit);\n if (onRequest) {\n request = await onRequest(url, requestInit);\n }\n // fetch must be assigned here, otherwise it would throw the error:\n // TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation\n const _fetch = options.fetch ?? globalThis.fetch;\n const response = await _fetch(request);\n\n if (!response.ok) throw new Error(`SSE failed: ${response.status} ${response.statusText}`);\n\n if (!response.body) throw new Error('No body in SSE response');\n\n const reader = response.body.pipeThrough(new TextDecoderStream()).getReader();\n\n let buffer = '';\n\n const abortHandler = () => {\n try {\n reader.cancel();\n } catch {\n // noop\n }\n };\n\n signal.addEventListener('abort', abortHandler);\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n buffer += value;\n buffer = buffer.replace(/\\r\\n?/g, '\\n'); // normalize line endings\n\n const chunks = buffer.split('\\n\\n');\n buffer = chunks.pop() ?? '';\n\n for (const chunk of chunks) {\n const lines = chunk.split('\\n');\n const dataLines: Array<string> = [];\n let eventName: string | undefined;\n\n for (const line of lines) {\n if (line.startsWith('data:')) {\n dataLines.push(line.replace(/^data:\\s*/, ''));\n } else if (line.startsWith('event:')) {\n eventName = line.replace(/^event:\\s*/, '');\n } else if (line.startsWith('id:')) {\n lastEventId = line.replace(/^id:\\s*/, '');\n } else if (line.startsWith('retry:')) {\n const parsed = Number.parseInt(line.replace(/^retry:\\s*/, ''), 10);\n if (!Number.isNaN(parsed)) {\n retryDelay = parsed;\n }\n }\n }\n\n let data: unknown;\n let parsedJson = false;\n\n if (dataLines.length) {\n const rawData = dataLines.join('\\n');\n try {\n data = JSON.parse(rawData);\n parsedJson = true;\n } catch {\n data = rawData;\n }\n }\n\n if (parsedJson) {\n if (responseValidator) {\n await responseValidator(data);\n }\n\n if (responseTransformer) {\n data = await responseTransformer(data);\n }\n }\n\n onSseEvent?.({\n data,\n event: eventName,\n id: lastEventId,\n retry: retryDelay,\n });\n\n if (dataLines.length) {\n yield data as any;\n }\n }\n }\n } finally {\n signal.removeEventListener('abort', abortHandler);\n reader.releaseLock();\n }\n\n break; // exit loop on normal completion\n } catch (error) {\n // connection failed or aborted; retry after delay\n onSseError?.(error);\n\n if (sseMaxRetryAttempts !== undefined && attempt >= sseMaxRetryAttempts) {\n break; // stop after firing error\n }\n\n // exponential backoff: double retry each attempt, cap at 30s\n const backoff = Math.min(retryDelay * 2 ** (attempt - 1), sseMaxRetryDelay ?? 30000);\n await sleep(backoff);\n }\n }\n };\n\n const stream = createStream();\n\n return { stream };\n}\n","// This file is auto-generated by @hey-api/openapi-ts\n\ninterface SerializeOptions<T> extends SerializePrimitiveOptions, SerializerOptions<T> {}\n\ninterface SerializePrimitiveOptions {\n allowReserved?: boolean;\n name: string;\n}\n\nexport interface SerializerOptions<T> {\n /**\n * @default true\n */\n explode: boolean;\n style: T;\n}\n\nexport type ArrayStyle = 'form' | 'spaceDelimited' | 'pipeDelimited';\nexport type ArraySeparatorStyle = ArrayStyle | MatrixStyle;\ntype MatrixStyle = 'label' | 'matrix' | 'simple';\nexport type ObjectStyle = 'form' | 'deepObject';\ntype ObjectSeparatorStyle = ObjectStyle | MatrixStyle;\n\ninterface SerializePrimitiveParam extends SerializePrimitiveOptions {\n value: string;\n}\n\nexport const separatorArrayExplode = (style: ArraySeparatorStyle) => {\n switch (style) {\n case 'label':\n return '.';\n case 'matrix':\n return ';';\n case 'simple':\n return ',';\n default:\n return '&';\n }\n};\n\nexport const separatorArrayNoExplode = (style: ArraySeparatorStyle) => {\n switch (style) {\n case 'form':\n return ',';\n case 'pipeDelimited':\n return '|';\n case 'spaceDelimited':\n return '%20';\n default:\n return ',';\n }\n};\n\nexport const separatorObjectExplode = (style: ObjectSeparatorStyle) => {\n switch (style) {\n case 'label':\n return '.';\n case 'matrix':\n return ';';\n case 'simple':\n return ',';\n default:\n return '&';\n }\n};\n\nexport const serializeArrayParam = ({\n allowReserved,\n explode,\n name,\n style,\n value,\n}: SerializeOptions<ArraySeparatorStyle> & {\n value: unknown[];\n}) => {\n if (!explode) {\n const joinedValues = (\n allowReserved ? value : value.map((v) => encodeURIComponent(v as string))\n ).join(separatorArrayNoExplode(style));\n switch (style) {\n case 'label':\n return `.${joinedValues}`;\n case 'matrix':\n return `;${name}=${joinedValues}`;\n case 'simple':\n return joinedValues;\n default:\n return `${name}=${joinedValues}`;\n }\n }\n\n const separator = separatorArrayExplode(style);\n const joinedValues = value\n .map((v) => {\n if (style === 'label' || style === 'simple') {\n return allowReserved ? v : encodeURIComponent(v as string);\n }\n\n return serializePrimitiveParam({\n allowReserved,\n name,\n value: v as string,\n });\n })\n .join(separator);\n return style === 'label' || style === 'matrix' ? separator + joinedValues : joinedValues;\n};\n\nexport const serializePrimitiveParam = ({\n allowReserved,\n name,\n value,\n}: SerializePrimitiveParam) => {\n if (value === undefined || value === null) {\n return '';\n }\n\n if (typeof value === 'object') {\n throw new Error(\n 'Deeply-nested arrays/objects aren’t supported. Provide your own `querySerializer()` to handle these.',\n );\n }\n\n return `${name}=${allowReserved ? value : encodeURIComponent(value)}`;\n};\n\nexport const serializeObjectParam = ({\n allowReserved,\n explode,\n name,\n style,\n value,\n valueOnly,\n}: SerializeOptions<ObjectSeparatorStyle> & {\n value: Record<string, unknown> | Date;\n valueOnly?: boolean;\n}) => {\n if (value instanceof Date) {\n return valueOnly ? value.toISOString() : `${name}=${value.toISOString()}`;\n }\n\n if (style !== 'deepObject' && !explode) {\n let values: string[] = [];\n Object.entries(value).forEach(([key, v]) => {\n values = [...values, key, allowReserved ? (v as string) : encodeURIComponent(v as string)];\n });\n const joinedValues = values.join(',');\n switch (style) {\n case 'form':\n return `${name}=${joinedValues}`;\n case 'label':\n return `.${joinedValues}`;\n case 'matrix':\n return `;${name}=${joinedValues}`;\n default:\n return joinedValues;\n }\n }\n\n const separator = separatorObjectExplode(style);\n const joinedValues = Object.entries(value)\n .map(([key, v]) =>\n serializePrimitiveParam({\n allowReserved,\n name: style === 'deepObject' ? `${name}[${key}]` : key,\n value: v as string,\n }),\n )\n .join(separator);\n return style === 'label' || style === 'matrix' ? separator + joinedValues : joinedValues;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { BodySerializer, QuerySerializer } from './bodySerializer.gen';\nimport {\n type ArraySeparatorStyle,\n serializeArrayParam,\n serializeObjectParam,\n serializePrimitiveParam,\n} from './pathSerializer.gen';\n\nexport interface PathSerializer {\n path: Record<string, unknown>;\n url: string;\n}\n\nexport const PATH_PARAM_RE = /\\{[^{}]+\\}/g;\n\nexport const defaultPathSerializer = ({ path, url: _url }: PathSerializer) => {\n let url = _url;\n const matches = _url.match(PATH_PARAM_RE);\n if (matches) {\n for (const match of matches) {\n let explode = false;\n let name = match.substring(1, match.length - 1);\n let style: ArraySeparatorStyle = 'simple';\n\n if (name.endsWith('*')) {\n explode = true;\n name = name.substring(0, name.length - 1);\n }\n\n if (name.startsWith('.')) {\n name = name.substring(1);\n style = 'label';\n } else if (name.startsWith(';')) {\n name = name.substring(1);\n style = 'matrix';\n }\n\n const value = path[name];\n\n if (value === undefined || value === null) {\n continue;\n }\n\n if (Array.isArray(value)) {\n url = url.replace(match, serializeArrayParam({ explode, name, style, value }));\n continue;\n }\n\n if (typeof value === 'object') {\n url = url.replace(\n match,\n serializeObjectParam({\n explode,\n name,\n style,\n value: value as Record<string, unknown>,\n valueOnly: true,\n }),\n );\n continue;\n }\n\n if (style === 'matrix') {\n url = url.replace(\n match,\n `;${serializePrimitiveParam({\n name,\n value: value as string,\n })}`,\n );\n continue;\n }\n\n const replaceValue = encodeURIComponent(\n style === 'label' ? `.${value as string}` : (value as string),\n );\n url = url.replace(match, replaceValue);\n }\n }\n return url;\n};\n\nexport const getUrl = ({\n baseUrl,\n path,\n query,\n querySerializer,\n url: _url,\n}: {\n baseUrl?: string;\n path?: Record<string, unknown>;\n query?: Record<string, unknown>;\n querySerializer: QuerySerializer;\n url: string;\n}) => {\n const pathUrl = _url.startsWith('/') ? _url : `/${_url}`;\n let url = (baseUrl ?? '') + pathUrl;\n if (path) {\n url = defaultPathSerializer({ path, url });\n }\n let search = query ? querySerializer(query) : '';\n if (search.startsWith('?')) {\n search = search.substring(1);\n }\n if (search) {\n url += `?${search}`;\n }\n return url;\n};\n\nexport function getValidRequestBody(options: {\n body?: unknown;\n bodySerializer?: BodySerializer | null;\n serializedBody?: unknown;\n}) {\n const hasBody = options.body !== undefined;\n const isSerializedBody = hasBody && options.bodySerializer;\n\n if (isSerializedBody) {\n if ('serializedBody' in options) {\n const hasSerializedBody =\n options.serializedBody !== undefined && options.serializedBody !== '';\n\n return hasSerializedBody ? options.serializedBody : null;\n }\n\n // not all clients implement a serializedBody property (i.e., client-axios)\n return options.body !== '' ? options.body : null;\n }\n\n // plain/text body\n if (hasBody) {\n return options.body;\n }\n\n // no body was provided\n return undefined;\n}\n","// This file is auto-generated by @hey-api/openapi-ts\n\nexport type AuthToken = string | undefined;\n\nexport interface Auth {\n /**\n * Which part of the request do we use to send the auth?\n *\n * @default 'header'\n */\n in?: 'header' | 'query' | 'cookie';\n /**\n * Header or query parameter name.\n *\n * @default 'Authorization'\n */\n name?: string;\n scheme?: 'basic' | 'bearer';\n type: 'apiKey' | 'http';\n}\n\nexport const getAuthToken = async (\n auth: Auth,\n callback: ((auth: Auth) => Promise<AuthToken> | AuthToken) | AuthToken,\n): Promise<string | undefined> => {\n const token = typeof callback === 'function' ? await callback(auth) : callback;\n\n if (!token) {\n return;\n }\n\n if (auth.scheme === 'bearer') {\n return `Bearer ${token}`;\n }\n\n if (auth.scheme === 'basic') {\n return `Basic ${btoa(token)}`;\n }\n\n return token;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport { getAuthToken } from '../core/auth.gen';\nimport type { QuerySerializerOptions } from '../core/bodySerializer.gen';\nimport { jsonBodySerializer } from '../core/bodySerializer.gen';\nimport {\n serializeArrayParam,\n serializeObjectParam,\n serializePrimitiveParam,\n} from '../core/pathSerializer.gen';\nimport { getUrl } from '../core/utils.gen';\nimport type { Client, ClientOptions, Config, RequestOptions } from './types.gen';\n\nexport const createQuerySerializer = <T = unknown>({\n parameters = {},\n ...args\n}: QuerySerializerOptions = {}) => {\n const querySerializer = (queryParams: T) => {\n const search: string[] = [];\n if (queryParams && typeof queryParams === 'object') {\n for (const name in queryParams) {\n const value = queryParams[name];\n\n if (value === undefined || value === null) {\n continue;\n }\n\n const options = parameters[name] || args;\n\n if (Array.isArray(value)) {\n const serializedArray = serializeArrayParam({\n allowReserved: options.allowReserved,\n explode: true,\n name,\n style: 'form',\n value,\n ...options.array,\n });\n if (serializedArray) search.push(serializedArray);\n } else if (typeof value === 'object') {\n const serializedObject = serializeObjectParam({\n allowReserved: options.allowReserved,\n explode: true,\n name,\n style: 'deepObject',\n value: value as Record<string, unknown>,\n ...options.object,\n });\n if (serializedObject) search.push(serializedObject);\n } else {\n const serializedPrimitive = serializePrimitiveParam({\n allowReserved: options.allowReserved,\n name,\n value: value as string,\n });\n if (serializedPrimitive) search.push(serializedPrimitive);\n }\n }\n }\n return search.join('&');\n };\n return querySerializer;\n};\n\n/**\n * Infers parseAs value from provided Content-Type header.\n */\nexport const getParseAs = (contentType: string | null): Exclude<Config['parseAs'], 'auto'> => {\n if (!contentType) {\n // If no Content-Type header is provided, the best we can do is return the raw response body,\n // which is effectively the same as the 'stream' option.\n return 'stream';\n }\n\n const cleanContent = contentType.split(';')[0]?.trim();\n\n if (!cleanContent) {\n return;\n }\n\n if (cleanContent.startsWith('application/json') || cleanContent.endsWith('+json')) {\n return 'json';\n }\n\n if (cleanContent === 'multipart/form-data') {\n return 'formData';\n }\n\n if (\n ['application/', 'audio/', 'image/', 'video/'].some((type) => cleanContent.startsWith(type))\n ) {\n return 'blob';\n }\n\n if (cleanContent.startsWith('text/')) {\n return 'text';\n }\n\n return;\n};\n\nconst checkForExistence = (\n options: Pick<RequestOptions, 'auth' | 'query'> & {\n headers: Headers;\n },\n name?: string,\n): boolean => {\n if (!name) {\n return false;\n }\n if (\n options.headers.has(name) ||\n options.query?.[name] ||\n options.headers.get('Cookie')?.includes(`${name}=`)\n ) {\n return true;\n }\n return false;\n};\n\nexport const setAuthParams = async ({\n security,\n ...options\n}: Pick<Required<RequestOptions>, 'security'> &\n Pick<RequestOptions, 'auth' | 'query'> & {\n headers: Headers;\n }) => {\n for (const auth of security) {\n if (checkForExistence(options, auth.name)) {\n continue;\n }\n\n const token = await getAuthToken(auth, options.auth);\n\n if (!token) {\n continue;\n }\n\n const name = auth.name ?? 'Authorization';\n\n switch (auth.in) {\n case 'query':\n if (!options.query) {\n options.query = {};\n }\n options.query[name] = token;\n break;\n case 'cookie':\n options.headers.append('Cookie', `${name}=${token}`);\n break;\n case 'header':\n default:\n options.headers.set(name, token);\n break;\n }\n }\n};\n\nexport const buildUrl: Client['buildUrl'] = (options) =>\n getUrl({\n baseUrl: options.baseUrl as string,\n path: options.path,\n query: options.query,\n querySerializer:\n typeof options.querySerializer === 'function'\n ? options.querySerializer\n : createQuerySerializer(options.querySerializer),\n url: options.url,\n });\n\nexport const mergeConfigs = (a: Config, b: Config): Config => {\n const config = { ...a, ...b };\n if (config.baseUrl?.endsWith('/')) {\n config.baseUrl = config.baseUrl.substring(0, config.baseUrl.length - 1);\n }\n config.headers = mergeHeaders(a.headers, b.headers);\n return config;\n};\n\nconst headersEntries = (headers: Headers): Array<[string, string]> => {\n const entries: Array<[string, string]> = [];\n headers.forEach((value, key) => {\n entries.push([key, value]);\n });\n return entries;\n};\n\nexport const mergeHeaders = (\n ...headers: Array<Required<Config>['headers'] | undefined>\n): Headers => {\n const mergedHeaders = new Headers();\n for (const header of headers) {\n if (!header) {\n continue;\n }\n\n const iterator = header instanceof Headers ? headersEntries(header) : Object.entries(header);\n\n for (const [key, value] of iterator) {\n if (value === null) {\n mergedHeaders.delete(key);\n } else if (Array.isArray(value)) {\n for (const v of value) {\n mergedHeaders.append(key, v as string);\n }\n } else if (value !== undefined) {\n // assume object headers are meant to be JSON stringified, i.e., their\n // content value in OpenAPI specification is 'application/json'\n mergedHeaders.set(\n key,\n typeof value === 'object' ? JSON.stringify(value) : (value as string),\n );\n }\n }\n }\n return mergedHeaders;\n};\n\ntype ErrInterceptor<Err, Res, Req, Options> = (\n error: Err,\n /** response may be undefined due to a network error where no response object is produced */\n response: Res | undefined,\n /** request may be undefined, because error may be from building the request object itself */\n request: Req | undefined,\n options: Options,\n) => Err | Promise<Err>;\n\ntype ReqInterceptor<Req, Options> = (request: Req, options: Options) => Req | Promise<Req>;\n\ntype ResInterceptor<Res, Req, Options> = (\n response: Res,\n request: Req,\n options: Options,\n) => Res | Promise<Res>;\n\nclass Interceptors<Interceptor> {\n fns: Array<Interceptor | null> = [];\n\n clear(): void {\n this.fns = [];\n }\n\n eject(id: number | Interceptor): void {\n const index = this.getInterceptorIndex(id);\n if (this.fns[index]) {\n this.fns[index] = null;\n }\n }\n\n exists(id: number | Interceptor): boolean {\n const index = this.getInterceptorIndex(id);\n return Boolean(this.fns[index]);\n }\n\n getInterceptorIndex(id: number | Interceptor): number {\n if (typeof id === 'number') {\n return this.fns[id] ? id : -1;\n }\n return this.fns.indexOf(id);\n }\n\n update(id: number | Interceptor, fn: Interceptor): number | Interceptor | false {\n const index = this.getInterceptorIndex(id);\n if (this.fns[index]) {\n this.fns[index] = fn;\n return id;\n }\n return false;\n }\n\n use(fn: Interceptor): number {\n this.fns.push(fn);\n return this.fns.length - 1;\n }\n}\n\nexport interface Middleware<Req, Res, Err, Options> {\n error: Interceptors<ErrInterceptor<Err, Res, Req, Options>>;\n request: Interceptors<ReqInterceptor<Req, Options>>;\n response: Interceptors<ResInterceptor<Res, Req, Options>>;\n}\n\nexport const createInterceptors = <Req, Res, Err, Options>(): Middleware<\n Req,\n Res,\n Err,\n Options\n> => ({\n error: new Interceptors<ErrInterceptor<Err, Res, Req, Options>>(),\n request: new Interceptors<ReqInterceptor<Req, Options>>(),\n response: new Interceptors<ResInterceptor<Res, Req, Options>>(),\n});\n\nconst defaultQuerySerializer = createQuerySerializer({\n allowReserved: false,\n array: {\n explode: true,\n style: 'form',\n },\n object: {\n explode: true,\n style: 'deepObject',\n },\n});\n\nconst defaultHeaders = {\n 'Content-Type': 'application/json',\n};\n\nexport const createConfig = <T extends ClientOptions = ClientOptions>(\n override: Config<Omit<ClientOptions, keyof T> & T> = {},\n): Config<Omit<ClientOptions, keyof T> & T> => ({\n ...jsonBodySerializer,\n headers: defaultHeaders,\n parseAs: 'auto',\n querySerializer: defaultQuerySerializer,\n ...override,\n});\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport { createSseClient } from '../core/serverSentEvents.gen';\nimport type { HttpMethod } from '../core/types.gen';\nimport { getValidRequestBody } from '../core/utils.gen';\nimport type { Client, Config, RequestOptions, ResolvedRequestOptions } from './types.gen';\nimport {\n buildUrl,\n createConfig,\n createInterceptors,\n getParseAs,\n mergeConfigs,\n mergeHeaders,\n setAuthParams,\n} from './utils.gen';\n\ntype ReqInit = Omit<RequestInit, 'body' | 'headers'> & {\n body?: any;\n headers: ReturnType<typeof mergeHeaders>;\n};\n\nexport const createClient = (config: Config = {}): Client => {\n let _config = mergeConfigs(createConfig(), config);\n\n const getConfig = (): Config => ({ ..._config });\n\n const setConfig = (config: Config): Config => {\n _config = mergeConfigs(_config, config);\n return getConfig();\n };\n\n const interceptors = createInterceptors<Request, Response, unknown, ResolvedRequestOptions>();\n\n const beforeRequest = async <\n TData = unknown,\n TResponseStyle extends 'data' | 'fields' = 'fields',\n ThrowOnError extends boolean = boolean,\n Url extends string = string,\n >(\n options: RequestOptions<TData, TResponseStyle, ThrowOnError, Url>,\n ) => {\n const opts = {\n ..._config,\n ...options,\n fetch: options.fetch ?? _config.fetch ?? globalThis.fetch,\n headers: mergeHeaders(_config.headers, options.headers),\n serializedBody: undefined as string | undefined,\n };\n\n if (opts.security) {\n await setAuthParams({\n ...opts,\n security: opts.security,\n });\n }\n\n if (opts.requestValidator) {\n await opts.requestValidator(opts);\n }\n\n if (opts.body !== undefined && opts.bodySerializer) {\n opts.serializedBody = opts.bodySerializer(opts.body) as string | undefined;\n }\n\n // remove Content-Type header if body is empty to avoid sending invalid requests\n if (opts.body === undefined || opts.serializedBody === '') {\n opts.headers.delete('Content-Type');\n }\n\n const resolvedOpts = opts as typeof opts &\n ResolvedRequestOptions<TResponseStyle, ThrowOnError, Url>;\n const url = buildUrl(resolvedOpts);\n\n return { opts: resolvedOpts, url };\n };\n\n const request: Client['request'] = async (options) => {\n const throwOnError = options.throwOnError ?? _config.throwOnError;\n const responseStyle = options.responseStyle ?? _config.responseStyle;\n\n let request: Request | undefined;\n let response: Response | undefined;\n\n try {\n const { opts, url } = await beforeRequest(options);\n const requestInit: ReqInit = {\n redirect: 'follow',\n ...opts,\n body: getValidRequestBody(opts),\n };\n\n request = new Request(url, requestInit);\n\n for (const fn of interceptors.request.fns) {\n if (fn) {\n request = await fn(request, opts);\n }\n }\n\n // fetch must be assigned here, otherwise it would throw the error:\n // TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation\n const _fetch = opts.fetch!;\n\n response = await _fetch(request);\n\n for (const fn of interceptors.response.fns) {\n if (fn) {\n response = await fn(response, request, opts);\n }\n }\n\n const result = {\n request,\n response,\n };\n\n if (response.ok) {\n const parseAs =\n (opts.parseAs === 'auto'\n ? getParseAs(response.headers.get('Content-Type'))\n : opts.parseAs) ?? 'json';\n\n if (response.status === 204 || response.headers.get('Content-Length') === '0') {\n let emptyData: any;\n switch (parseAs) {\n case 'arrayBuffer':\n case 'blob':\n case 'text':\n emptyData = await response[parseAs]();\n break;\n case 'formData':\n emptyData = new FormData();\n break;\n case 'stream':\n emptyData = response.body;\n break;\n case 'json':\n default:\n emptyData = {};\n break;\n }\n return opts.responseStyle === 'data'\n ? emptyData\n : {\n data: emptyData,\n ...result,\n };\n }\n\n let data: any;\n switch (parseAs) {\n case 'arrayBuffer':\n case 'blob':\n case 'formData':\n case 'text':\n data = await response[parseAs]();\n break;\n case 'json': {\n // Some servers return 200 with no Content-Length and empty body.\n // response.json() would throw; read as text and parse if non-empty.\n const text = await response.text();\n data = text ? JSON.parse(text) : {};\n break;\n }\n case 'stream':\n return opts.responseStyle === 'data'\n ? response.body\n : {\n data: response.body,\n ...result,\n };\n }\n\n if (parseAs === 'json') {\n if (opts.responseValidator) {\n await opts.responseValidator(data);\n }\n\n if (opts.responseTransformer) {\n data = await opts.responseTransformer(data);\n }\n }\n\n return opts.responseStyle === 'data'\n ? data\n : {\n data,\n ...result,\n };\n }\n\n const textError = await response.text();\n let jsonError: unknown;\n\n try {\n jsonError = JSON.parse(textError);\n } catch {\n // noop\n }\n\n throw jsonError ?? textError;\n } catch (error) {\n let finalError = error;\n\n for (const fn of interceptors.error.fns) {\n if (fn) {\n finalError = await fn(finalError, response, request, options as ResolvedRequestOptions);\n }\n }\n\n finalError = finalError || {};\n\n if (throwOnError) {\n throw finalError;\n }\n\n // TODO: we probably want to return error and improve types\n return responseStyle === 'data'\n ? undefined\n : {\n error: finalError,\n request,\n response,\n };\n }\n };\n\n const makeMethodFn = (method: Uppercase<HttpMethod>) => (options: RequestOptions) =>\n request({ ...options, method });\n\n const makeSseFn = (method: Uppercase<HttpMethod>) => async (options: RequestOptions) => {\n const { opts, url } = await beforeRequest(options);\n return createSseClient({\n ...opts,\n body: opts.body as BodyInit | null | undefined,\n method,\n onRequest: async (url, init) => {\n let request = new Request(url, init);\n for (const fn of interceptors.request.fns) {\n if (fn) {\n request = await fn(request, opts);\n }\n }\n return request;\n },\n serializedBody: getValidRequestBody(opts) as BodyInit | null | undefined,\n url,\n });\n };\n\n const _buildUrl: Client['buildUrl'] = (options) => buildUrl({ ..._config, ...options });\n\n return {\n buildUrl: _buildUrl,\n connect: makeMethodFn('CONNECT'),\n delete: makeMethodFn('DELETE'),\n get: makeMethodFn('GET'),\n getConfig,\n head: makeMethodFn('HEAD'),\n interceptors,\n options: makeMethodFn('OPTIONS'),\n patch: makeMethodFn('PATCH'),\n post: makeMethodFn('POST'),\n put: makeMethodFn('PUT'),\n request,\n setConfig,\n sse: {\n connect: makeSseFn('CONNECT'),\n delete: makeSseFn('DELETE'),\n get: makeSseFn('GET'),\n head: makeSseFn('HEAD'),\n options: makeSseFn('OPTIONS'),\n patch: makeSseFn('PATCH'),\n post: makeSseFn('POST'),\n put: makeSseFn('PUT'),\n trace: makeSseFn('TRACE'),\n },\n trace: makeMethodFn('TRACE'),\n } as Client;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport { type ClientOptions, type Config, createClient, createConfig } from './client';\nimport type { ClientOptions as ClientOptions2 } from './types.gen';\n\n/**\n * The `createClientConfig()` function will be called on client initialization\n * and the returned object will become the client's initial configuration.\n *\n * You may want to initialize your client this way instead of calling\n * `setConfig()`. This is useful for example if you're using Next.js\n * to ensure your client always has the correct values.\n */\nexport type CreateClientConfig<T extends ClientOptions = ClientOptions2> = (override?: Config<ClientOptions & T>) => Config<Required<ClientOptions> & T>;\n\nexport const client = createClient(createConfig<ClientOptions2>({ baseUrl: 'http://localhost:8000' }));\n\n// auto-init: install auth on client\nimport { installAuthOnClient } from './helpers/auth';\ninstallAuthOnClient(client);\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { Client, Options as Options2, TDataShape } from './client';\nimport { client } from './client.gen';\nimport type { CfgMonitorIngestCreateData, CfgMonitorIngestCreateResponses } from './types.gen';\n\nexport type Options<TData extends TDataShape = TDataShape, ThrowOnError extends boolean = boolean, TResponse = unknown> = Options2<TData, ThrowOnError, TResponse> & {\n /**\n * You can provide a client instance returned by `createClient()` instead of\n * individual options. This might be also useful if you want to implement a\n * custom client.\n */\n client?: Client;\n /**\n * You can pass arbitrary values through the `meta` object. This can be\n * used to access values that aren't defined as part of the SDK function.\n */\n meta?: Record<string, unknown>;\n};\n\nexport class CfgMonitor {\n /**\n * Ingest browser events\n *\n * Accepts a batch of up to 50 frontend events. No authentication required — anonymous visitors can send events.\n */\n public static cfgMonitorIngestCreate<ThrowOnError extends boolean = false>(options: Options<CfgMonitorIngestCreateData, ThrowOnError>) {\n return (options.client ?? client).post<CfgMonitorIngestCreateResponses, unknown, ThrowOnError>({\n url: '/cfg/monitor/ingest/',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n });\n }\n}\n","// AUTO-GENERATED by django_generator / ts_extras.wrapper\n// Thin per-group proxy over the global `auth` store. All actual auth\n// wiring lives in `helpers/auth.ts` (one interceptor, one source of\n// truth). DO NOT EDIT — re-run `make gen`.\n\nimport { auth } from '../helpers/auth';\nimport { APILogger, type LoggerConfig } from '../helpers/logger';\n\nimport { CfgMonitor } from '../sdk.gen';\n\n\n\nexport interface APIOptions {\n /** Logger config (defaults to dev-only). */\n logger?: Partial<LoggerConfig>;\n /** Locale for `Accept-Language`. If omitted, auto-detected from cookie/navigator. */\n locale?: string;\n /** API key sent as `X-API-Key`. Falls back to NEXT_PUBLIC_API_KEY. */\n apiKey?: string;\n /** Send Django session/CSRF cookies cross-origin. Defaults to true. */\n withCredentials?: boolean;\n}\n\n/**\n * Per-group ergonomic facade.\n *\n * Calling `setToken/setApiKey/setLocale/setBaseUrl` proxies to the\n * global `auth` store — the change applies to **every** group's API\n * instance because they share the same HTTP client and interceptor.\n *\n * Use the global `auth` object directly when you don't need a group\n * facade: `import { auth } from '@your/api'; auth.setToken(jwt);`\n */\nexport class API {\n readonly logger: APILogger;\n\n readonly cfgMonitor = CfgMonitor;\n\n constructor(_baseUrl?: string, opts: APIOptions = {}) {\n this.logger = new APILogger(opts.logger);\n if (_baseUrl) auth.setBaseUrl(_baseUrl);\n if (opts.locale !== undefined) auth.setLocale(opts.locale);\n if (opts.apiKey !== undefined) auth.setApiKey(opts.apiKey);\n if (opts.withCredentials !== undefined) auth.setWithCredentials(opts.withCredentials);\n }\n\n // ── Base URL ────────────────────────────────────────────────────────────\n getBaseUrl(): string { return auth.getBaseUrl(); }\n setBaseUrl(url: string): void { auth.setBaseUrl(url); }\n\n // ── Tokens ──────────────────────────────────────────────────────────────\n getToken(): string | null { return auth.getToken(); }\n setToken(token: string | null): void { auth.setToken(token); }\n getRefreshToken(): string | null { return auth.getRefreshToken(); }\n setRefreshToken(token: string | null): void { auth.setRefreshToken(token); }\n clearToken(): void { auth.clearTokens(); }\n isAuthenticated(): boolean { return auth.isAuthenticated(); }\n\n // ── Locale / API key ────────────────────────────────────────────────────\n getLocale(): string | null { return auth.getLocale(); }\n setLocale(locale: string | null): void { auth.setLocale(locale); }\n getApiKey(): string | null { return auth.getApiKey(); }\n setApiKey(key: string | null): void { auth.setApiKey(key); }\n\n // ── 401 handling ────────────────────────────────────────────────────────\n /** Fired only on terminal 401 (after refresh+retry path is exhausted). */\n onUnauthorized(cb: ((response: Response) => void) | null): void {\n auth.onUnauthorized(cb);\n }\n /** Provide a refresh strategy. See `auth.setRefreshHandler` for the contract. */\n setRefreshHandler(\n fn: ((refreshToken: string) => Promise<{ access: string; refresh?: string } | null>) | null,\n ): void {\n auth.setRefreshHandler(fn);\n }\n}\n\nexport { CfgMonitor };\nexport { auth };\n","/**\n * BaseClient for @djangocfg/monitor\n *\n * Singleton monitorApi instance for the frontend monitor ingest endpoint.\n * Uses MemoryStorageAdapter — ingest is public (no auth tokens needed).\n */\n\nimport { API } from './generated/_cfg_monitor'\n\nexport const monitorApi = new API('')\n\nexport function configureMonitorApi(baseUrl: string): void {\n monitorApi.setBaseUrl(baseUrl)\n}\n\nexport class BaseClient {\n protected static monitorApi = monitorApi\n}\n","// This file is auto-generated by @hey-api/openapi-ts\n\nexport type ClientOptions = {\n baseUrl: 'http://localhost:8000' | (string & {});\n};\n\n/**\n * Single browser event payload.\n */\nexport type FrontendEventIngestRequest = {\n event_type: FrontendEventTypeEnum;\n message: string;\n level?: FrontendEventLevelEnum;\n stack_trace?: string;\n url?: string;\n fingerprint?: string;\n http_status?: number | null;\n http_method?: string;\n http_url?: string;\n session_id?: string;\n user_agent?: string;\n build_id?: string;\n environment?: string;\n extra?: unknown;\n project_name?: string;\n};\n\n/**\n * * `error` - Error\n * * `warning` - Warning\n * * `info` - Info\n * * `debug` - Debug\n */\nexport enum FrontendEventLevelEnum {\n ERROR = 'error',\n WARNING = 'warning',\n INFO = 'info',\n DEBUG = 'debug'\n}\n\n/**\n * * `JS_ERROR` - Js Error\n * * `NETWORK_ERROR` - Network Error\n * * `ERROR` - Error\n * * `WARNING` - Warning\n * * `PAGE_VIEW` - Page View\n * * `PERFORMANCE` - Performance\n * * `CONSOLE` - Console\n */\nexport enum FrontendEventTypeEnum {\n JS_ERROR = 'JS_ERROR',\n NETWORK_ERROR = 'NETWORK_ERROR',\n ERROR = 'ERROR',\n WARNING = 'WARNING',\n PAGE_VIEW = 'PAGE_VIEW',\n PERFORMANCE = 'PERFORMANCE',\n CONSOLE = 'CONSOLE'\n}\n\n/**\n * Batch of up to 50 browser events.\n */\nexport type IngestBatchRequest = {\n events: Array<FrontendEventIngestRequest>;\n};\n\nexport type CfgMonitorIngestCreateData = {\n body: IngestBatchRequest;\n path?: never;\n query?: never;\n url: '/cfg/monitor/ingest/';\n};\n\nexport type CfgMonitorIngestCreateResponses = {\n /**\n * Accepted\n */\n 202: unknown;\n};\n","export { monitorApi, configureMonitorApi, BaseClient } from './BaseClient'\nexport type { FrontendEventIngestRequest, IngestBatchRequest } from './generated/_cfg_monitor/types.gen'\nexport { FrontendEventTypeEnum as EventType, FrontendEventLevelEnum as EventLevel } from './generated/_cfg_monitor/types.gen'\n\n/** Ingest path — matches the generated client. Single source of truth for sendBeacon fallback. */\nexport const INGEST_PATH = '/cfg/monitor/ingest/'\n","import { monitorApi, INGEST_PATH } from '../../_api'\nimport { CfgMonitor } from '../../_api/generated/sdk.gen'\nimport type { IngestBatchRequest } from '../../_api'\n\n/**\n * Send a batch of events to the ingest endpoint.\n *\n * `useBeacon=true` is for page-unload scenarios — `fetch` with `keepalive: true`\n * lets the request survive after the document goes away (browser-supported\n * replacement for navigator.sendBeacon when we need JSON + custom headers).\n */\nexport async function sendBatch(\n batch: IngestBatchRequest,\n useBeacon = false,\n): Promise<void> {\n if (batch.events.length === 0) return\n\n if (useBeacon && typeof fetch !== 'undefined') {\n const baseUrl = monitorApi.getBaseUrl()\n await fetch(`${baseUrl}${INGEST_PATH}`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(batch),\n keepalive: true,\n credentials: 'include',\n })\n return\n }\n\n await CfgMonitor.cfgMonitorIngestCreate({ body: batch, throwOnError: true })\n}\n","/**\n * Environment utilities.\n */\n\n/** True only in next dev / jest / vitest */\nexport const isDevelopment = process.env.NODE_ENV === 'development'\n\n/** True in any non-development environment */\nexport const isProduction = !isDevelopment\n\n/** Package version */\nexport const MONITOR_VERSION: string = (process.env.MONITOR_VERSION as string) ?? '2.1.230'\n","/**\n * Internal URL patterns for the monitor transport.\n * Used to filter out self-generated errors and prevent capture→flush feedback loops.\n */\n\n/** Matches any request to the monitor ingest endpoint */\nexport const MONITOR_INGEST_PATTERN = /cfg\\/monitor\\/ingest/\n\n/** Default deduplication TTL for per-capture-source filtering (ms) */\nexport const DEFAULT_DEDUPE_TTL = 5_000\n\n/** Default deduplication TTL for global store-level filtering (ms) */\nexport const DEFAULT_DEDUPE_STORE_TTL = 30_000\n","import { computeFingerprint } from './fingerprint'\nimport { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { MONITOR_INGEST_PATTERN, DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\nconst MSG_MAX = 2000\n\nfunction truncate(s: string, max = MSG_MAX): string {\n return s.length > max ? s.slice(0, max - 1) + '…' : s\n}\n\nfunction isMonitorOwnError(msg: string, stack?: string): boolean {\n return MONITOR_INGEST_PATTERN.test(msg) || MONITOR_INGEST_PATTERN.test(stack ?? '')\n}\n\n// Hydration mismatches caused by browser extensions (Grammarly, translators, etc.)\n// These are not application bugs — filtering them prevents alert noise.\nconst HYDRATION_NOISE: RegExp[] = [\n /hydration failed/i,\n /there was an error while hydrating/i,\n /minified react error #418/i,\n /minified react error #423/i,\n /minified react error #425/i,\n /text content does not match server-rendered html/i,\n]\n\nfunction isHydrationNoise(msg: string): boolean {\n return HYDRATION_NOISE.some((p) => p.test(msg))\n}\n\n// Client-side dedup: skip re-sending the same fingerprint within dedupeTtl.\n// Protects against crash-loop pages flooding the ingest endpoint.\nconst recentFingerprints = new Map<string, number>()\n\nfunction isRecentlySent(fingerprint: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentFingerprints.get(fingerprint)\n if (last !== undefined && now - last < ttl) return true\n recentFingerprints.set(fingerprint, now)\n if (recentFingerprints.size > 100) {\n const oldest = [...recentFingerprints.entries()].sort((a, b) => a[1] - b[1])[0]\n recentFingerprints.delete(oldest[0])\n }\n return false\n}\n\nexport function installJsErrorCapture(): () => void {\n if (typeof window === 'undefined') return () => {}\n\n const onError = async (\n message: string | Event,\n source?: string,\n lineno?: number,\n colno?: number,\n error?: Error,\n ) => {\n try {\n const msg = truncate(typeof message === 'string' ? message : String(message))\n if (isHydrationNoise(msg)) return\n const stack = error?.stack ?? `at ${source}:${lineno}:${colno}`\n if (isMonitorOwnError(msg, stack)) return\n const url = window.location.href\n const fingerprint = await computeFingerprint(msg, stack, url)\n if (isRecentlySent(fingerprint)) return\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.JS_ERROR,\n level: EventLevel.ERROR,\n message: msg,\n stack_trace: stack,\n url,\n fingerprint,\n session_id: getSessionId(),\n user_agent: navigator.userAgent,\n project_name: config.project,\n environment: config.environment,\n build_id: config.buildId ?? '',\n })\n } catch { /* never crash */ }\n }\n\n const onUnhandledRejection = async (e: PromiseRejectionEvent) => {\n try {\n const reason = e.reason\n const msg = truncate(reason instanceof Error ? reason.message\n : typeof reason === 'string' ? reason\n : 'Unhandled promise rejection')\n if (isHydrationNoise(msg)) return\n const stack = reason instanceof Error ? (reason.stack ?? '') : ''\n if (isMonitorOwnError(msg, stack)) return\n const url = window.location.href\n const fingerprint = await computeFingerprint(msg, stack, url)\n if (isRecentlySent(fingerprint)) return\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.JS_ERROR,\n level: EventLevel.ERROR,\n message: msg,\n stack_trace: stack,\n url,\n fingerprint,\n session_id: getSessionId(),\n user_agent: navigator.userAgent,\n project_name: config.project,\n environment: config.environment,\n build_id: config.buildId ?? '',\n })\n } catch { /* never crash */ }\n }\n\n const errHandler = (e: ErrorEvent) => onError(e.message, e.filename, e.lineno, e.colno, e.error)\n window.addEventListener('error', errHandler)\n window.addEventListener('unhandledrejection', onUnhandledRejection)\n\n return () => {\n window.removeEventListener('error', errHandler)\n window.removeEventListener('unhandledrejection', onUnhandledRejection)\n }\n}\n","import { computeFingerprint } from './fingerprint'\nimport { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { MONITOR_INGEST_PATTERN, DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\ntype ConsoleLevel = 'warn' | 'error'\n\nconst levelMap: Record<ConsoleLevel, EventLevel> = {\n warn: EventLevel.WARNING,\n error: EventLevel.ERROR,\n}\nconst typeMap: Record<ConsoleLevel, EventType> = {\n warn: EventType.WARNING,\n error: EventType.ERROR,\n}\n\nconst ARG_MAX = 500\n\n// Dedup: skip re-sending the same console message within TTL (read from config)\nconst recentConsoleFingerprints = new Map<string, number>()\n\nfunction isRecentConsole(fingerprint: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentConsoleFingerprints.get(fingerprint)\n if (last !== undefined && now - last < ttl) return true\n recentConsoleFingerprints.set(fingerprint, now)\n if (recentConsoleFingerprints.size > 100) {\n const oldest = [...recentConsoleFingerprints.entries()].sort((a, b) => a[1] - b[1])[0]\n recentConsoleFingerprints.delete(oldest[0])\n }\n return false\n}\n\nfunction stringifyArg(a: unknown): string {\n let s: string\n if (typeof a === 'string') s = a\n else if (a instanceof Error) s = a.message\n else { try { s = JSON.stringify(a) } catch { s = String(a) } }\n return s.length > ARG_MAX ? s.slice(0, ARG_MAX - 1) + '…' : s\n}\n\nfunction stringify(args: unknown[]): string {\n return args.map(stringifyArg).join(' ')\n}\n\nasync function captureConsoleEvent(level: ConsoleLevel, args: unknown[]) {\n try {\n const message = stringify(args)\n if (MONITOR_INGEST_PATTERN.test(message)) return\n const url = typeof window !== 'undefined' ? window.location.href : ''\n const fingerprint = await computeFingerprint(message, '', url)\n if (isRecentConsole(fingerprint)) return\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: typeMap[level],\n level: levelMap[level],\n message,\n url,\n fingerprint,\n session_id: getSessionId(),\n user_agent: typeof navigator !== 'undefined' ? navigator.userAgent : '',\n project_name: config.project,\n environment: config.environment,\n })\n } catch { /* never crash */ }\n}\n\nexport function installConsoleCapture(): () => void {\n if (typeof window === 'undefined') return () => {}\n\n try {\n const g = globalThis as Record<string, unknown>\n if (g.consola && typeof (g.consola as { addReporter?: unknown }).addReporter === 'function') {\n const consolaInst = g.consola as {\n addReporter: (r: unknown) => void\n removeReporter: (r: unknown) => void\n }\n const reporter = {\n log(logObj: { level: number; args: unknown[] }) {\n if (logObj.level === 1) captureConsoleEvent('error', logObj.args)\n else if (logObj.level === 2) captureConsoleEvent('warn', logObj.args)\n },\n }\n consolaInst.addReporter(reporter)\n return () => consolaInst.removeReporter(reporter)\n }\n } catch { /* consola not available */ }\n\n const origWarn = console.warn.bind(console)\n const origError = console.error.bind(console)\n console.warn = (...args: unknown[]) => { origWarn(...args); captureConsoleEvent('warn', args) }\n console.error = (...args: unknown[]) => { origError(...args); captureConsoleEvent('error', args) }\n return () => { console.warn = origWarn; console.error = origError }\n}\n","import { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\n// Dedup: skip re-sending the same validation error within TTL (read from config)\nconst recentValidations = new Map<string, number>()\n\nfunction isRecentValidation(key: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentValidations.get(key)\n if (last !== undefined && now - last < ttl) return true\n recentValidations.set(key, now)\n if (recentValidations.size > 50) {\n for (const [k, ts] of recentValidations) {\n if (now - ts > ttl) recentValidations.delete(k)\n }\n }\n return false\n}\n\ninterface ValidationErrorDetail {\n operation: string\n path: string\n method: string\n error: { message: string }\n}\n\nexport function installValidationCapture(): () => void {\n if (typeof window === 'undefined') return () => {}\n\n const handler = (event: Event) => {\n if (!(event instanceof CustomEvent)) return\n try {\n const detail = event.detail as ValidationErrorDetail\n const dedupeKey = `${detail.operation}:${detail.path}:${detail.method}`\n if (isRecentValidation(dedupeKey)) return\n const { config } = monitorStore.getState()\n const rawMsg = `Zod validation error in ${detail.operation}: ${detail.error?.message ?? 'unknown'}`\n monitorStore.getState().push({\n event_type: EventType.WARNING,\n level: EventLevel.WARNING,\n message: rawMsg.length > 500 ? rawMsg.slice(0, 499) + '…' : rawMsg,\n url: window.location.href,\n http_method: detail.method,\n http_url: detail.path,\n session_id: getSessionId(),\n user_agent: navigator.userAgent,\n project_name: config.project,\n environment: config.environment,\n extra: { operation: detail.operation, path: detail.path, method: detail.method },\n })\n } catch { /* never crash */ }\n }\n\n window.addEventListener('zod-validation-error', handler)\n return () => window.removeEventListener('zod-validation-error', handler)\n}\n","import { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\n// Dedup: skip re-sending the same network error within TTL (read from config)\nconst recentNetworkErrors = new Map<string, number>()\n\nfunction isRecentNetwork(key: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentNetworkErrors.get(key)\n if (last !== undefined && now - last < ttl) return true\n recentNetworkErrors.set(key, now)\n if (recentNetworkErrors.size > 100) {\n for (const [k, ts] of recentNetworkErrors) {\n if (now - ts > ttl) recentNetworkErrors.delete(k)\n }\n }\n return false\n}\n\nexport async function monitoredFetch(\n input: RequestInfo | URL,\n init?: RequestInit,\n): Promise<Response> {\n const url = typeof input === 'string' ? input : input instanceof URL ? input.href : input.url\n const method = (init?.method ?? 'GET').toUpperCase()\n\n try {\n const response = await fetch(input, init)\n if (!response.ok) {\n const netKey = `${response.status}:${method}:${url}`\n if (isRecentNetwork(netKey)) return response\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.NETWORK_ERROR,\n level: response.status >= 500 ? EventLevel.ERROR : EventLevel.WARNING,\n message: `HTTP ${response.status} ${response.statusText} — ${method} ${url}`,\n url: typeof window !== 'undefined' ? window.location.href : '',\n http_status: response.status,\n http_method: method,\n http_url: url,\n session_id: getSessionId(),\n user_agent: typeof navigator !== 'undefined' ? navigator.userAgent : '',\n project_name: config.project,\n environment: config.environment,\n })\n }\n return response\n } catch (err) {\n const errMsg = err instanceof Error ? err.message : 'network-error'\n const netKey = `err:${errMsg.slice(0, 50)}:${method}:${url}`\n if (!isRecentNetwork(netKey)) {\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.NETWORK_ERROR,\n level: EventLevel.ERROR,\n message: err instanceof Error ? err.message : `Network error — ${method} ${url}`,\n url: typeof window !== 'undefined' ? window.location.href : '',\n http_method: method,\n http_url: url,\n session_id: getSessionId(),\n user_agent: typeof navigator !== 'undefined' ? navigator.userAgent : '',\n project_name: config.project,\n environment: config.environment,\n })\n }\n throw err\n }\n}\n","'use client'\n\n/**\n * MonitorProvider\n *\n * Initialises FrontendMonitor on mount and tears it down on unmount.\n * Drop it once into your root layout — no other setup needed.\n *\n * @example\n * // app/layout.tsx\n * import { MonitorProvider } from '@djangocfg/monitor/client'\n *\n * export default function RootLayout({ children }) {\n * return (\n * <html>\n * <body>\n * <MonitorProvider project=\"my-app\" environment={process.env.NODE_ENV} />\n * {children}\n * </body>\n * </html>\n * )\n * }\n */\n\nimport { memo, useEffect } from 'react'\nimport { FrontendMonitor } from './index'\nimport { initWindowMonitor } from './window'\nimport type { MonitorConfig } from '../types'\n\nexport interface MonitorProviderProps extends MonitorConfig {\n /** Optional: render children inside the provider (or use as a standalone leaf) */\n children?: React.ReactNode\n}\n\n/**\n * MonitorProvider — initialises FrontendMonitor on mount.\n *\n * Memoised: re-renders only when `children` or config props change.\n * The init effect runs once on mount (config is captured in closure).\n */\nfunction MonitorProviderRaw({ children, ...config }: MonitorProviderProps) {\n useEffect(() => {\n FrontendMonitor.init(config)\n initWindowMonitor()\n return () => FrontendMonitor.destroy()\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n return children ?? null\n}\n\nexport const MonitorProvider = memo(MonitorProviderRaw)\n","/**\n * window.monitor — global debug API for browser console testing.\n *\n * Automatically installed by MonitorProvider after FrontendMonitor.init().\n * Allows manual event firing from DevTools without importing the module.\n *\n * @example\n * // In browser DevTools console:\n * window.monitor.error('Something broke')\n * window.monitor.warn('Low disk space', { extra: 'context' })\n * window.monitor.network(404, 'GET', '/api/users/')\n * window.monitor.flush()\n * window.monitor.status()\n */\n\nimport { monitorStore } from './store'\nimport { EventType, EventLevel } from '../_api'\nimport { getSessionId } from './capture/session'\nimport { MONITOR_VERSION } from './utils/env'\nimport type { MonitorEvent } from '../types'\n\nexport interface WindowMonitorAPI {\n /** Capture a custom error event */\n error(message: string, extra?: Record<string, unknown>): void\n /** Capture a custom warning event */\n warn(message: string, extra?: Record<string, unknown>): void\n /** Capture a custom info event */\n info(message: string, extra?: Record<string, unknown>): void\n /** Capture a network error event */\n network(status: number, method: string, url: string, extra?: Record<string, unknown>): void\n /** Capture a raw event (full control) */\n capture(event: MonitorEvent): void\n /** Force-flush the event buffer to backend */\n flush(): void\n /** Show current monitor state (config + buffer size) */\n status(): void\n}\n\ndeclare global {\n interface Window {\n monitor?: WindowMonitorAPI\n }\n}\n\nfunction makeEvent(\n type: MonitorEvent['event_type'],\n level: MonitorEvent['level'],\n message: string,\n extra?: Record<string, unknown>,\n): MonitorEvent {\n const state = monitorStore.getState()\n const cfg = state.config\n return {\n event_type: type,\n level,\n message,\n session_id: getSessionId(),\n url: window.location.href,\n user_agent: navigator.userAgent,\n project_name: cfg.project ?? '',\n environment: cfg.environment ?? '',\n ...(extra ? { extra } : {}),\n }\n}\n\nexport function initWindowMonitor(): void {\n if (typeof window === 'undefined') return\n\n const api: WindowMonitorAPI = {\n error(message, extra) {\n monitorStore.getState().push(makeEvent(EventType.JS_ERROR, EventLevel.ERROR, message, extra))\n console.log('[monitor] error captured →', message)\n },\n\n warn(message, extra) {\n monitorStore.getState().push(makeEvent(EventType.WARNING, EventLevel.WARNING, message, extra))\n console.log('[monitor] warn captured →', message)\n },\n\n info(message, extra) {\n monitorStore.getState().push(makeEvent(EventType.WARNING, EventLevel.INFO, message, extra))\n console.log('[monitor] info captured →', message)\n },\n\n network(status, method, url, extra) {\n const event = makeEvent(\n EventType.NETWORK_ERROR,\n status >= 500 ? EventLevel.ERROR : EventLevel.WARNING,\n `${method} ${url} → ${status}`,\n extra,\n )\n monitorStore.getState().push({ ...event, http_status: status, http_method: method, http_url: url })\n console.log('[monitor] network captured →', method, url, status)\n },\n\n capture(event) {\n monitorStore.getState().push(event)\n console.log('[monitor] event captured →', event)\n },\n\n flush() {\n monitorStore.getState().flush()\n console.log('[monitor] flushed')\n },\n\n status() {\n const state = monitorStore.getState()\n console.group('[monitor] status')\n console.log('sdk version:', MONITOR_VERSION)\n console.log('build_id:', state.config.buildId ?? `sdk:${MONITOR_VERSION}`)\n console.log('config:', state.config)\n console.log('buffer size:', state.buffer.length)\n console.log('initialized:', state.initialized)\n console.log('session_id:', getSessionId())\n console.groupEnd()\n },\n }\n\n window.monitor = api\n}\n","'use client'\n\n/**\n * useDebugMode — shared debug mode detection hook.\n *\n * Logic:\n * - development: always true (no localStorage needed)\n * - production:\n * - ?debug=1 in URL → persist to localStorage, remove param from URL\n * - ?debug=0 in URL → clear localStorage, disable debug mode\n * - localStorage.__debug_mode__ === '1' → true\n * - otherwise → false\n *\n * @example\n * const isDebug = useDebugMode()\n */\n\nimport { useEffect, useState } from 'react'\nimport { isDevelopment } from '../utils/env'\n\nconst LS_KEY = '__debug_mode__'\n\nfunction readFromStorage(): boolean {\n try {\n return localStorage.getItem(LS_KEY) === '1'\n } catch {\n return false\n }\n}\n\nfunction persistToStorage(): void {\n try {\n localStorage.setItem(LS_KEY, '1')\n } catch {\n // ignore — private browsing or quota exceeded\n }\n}\n\nfunction clearFromStorage(): void {\n try {\n localStorage.removeItem(LS_KEY)\n } catch {\n // ignore\n }\n}\n\nfunction consumeDebugParam(): boolean | null {\n if (typeof window === 'undefined') return null\n const params = new URLSearchParams(window.location.search)\n const value = params.get('debug')\n if (value === null) return null\n\n if (value === '1') {\n persistToStorage()\n } else {\n // ?debug=0 or any other value → explicitly disable and clear stored flag\n clearFromStorage()\n }\n\n params.delete('debug')\n const newUrl = `${window.location.pathname}${params.toString() ? `?${params.toString()}` : ''}${window.location.hash}`\n window.history.replaceState(null, '', newUrl)\n return value === '1'\n}\n\nexport function useDebugMode(): boolean {\n // In development, always true — no side effects needed\n if (isDevelopment) return true\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const [isDebug, setIsDebug] = useState(false)\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useEffect(() => {\n const fromUrl = consumeDebugParam()\n if (fromUrl !== null) {\n setIsDebug(fromUrl)\n return\n }\n setIsDebug(readFromStorage())\n }, [])\n\n return isDebug\n}\n"],"mappings":"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","names":["COOKIE_MAX_AGE","client","joinedValues","auth","auth","config","request","url","FrontendEventLevelEnum","FrontendEventTypeEnum","import_react"]}
1
+ {"version":3,"sources":["../src/client/index.ts","../src/client/capture/fingerprint.ts","../src/client/capture/session.ts","../src/client/store/index.ts","../src/_api/generated/helpers/errors.ts","../src/_api/generated/helpers/auth.ts","../src/_api/generated/helpers/logger.ts","../src/_api/generated/core/bodySerializer.gen.ts","../src/_api/generated/core/params.gen.ts","../src/_api/generated/core/serverSentEvents.gen.ts","../src/_api/generated/core/pathSerializer.gen.ts","../src/_api/generated/core/utils.gen.ts","../src/_api/generated/core/auth.gen.ts","../src/_api/generated/client/utils.gen.ts","../src/_api/generated/client/client.gen.ts","../src/_api/generated/client.gen.ts","../src/_api/generated/sdk.gen.ts","../src/_api/generated/_cfg_monitor/api.ts","../src/_api/BaseClient.ts","../src/_api/generated/types.gen.ts","../src/_api/index.ts","../src/client/transport/ingest.ts","../src/client/utils/env.ts","../src/client/constants.ts","../src/client/capture/js-errors.ts","../src/client/capture/console.ts","../src/client/capture/validation.ts","../src/client/capture/network.ts","../src/client/MonitorProvider.tsx","../src/client/window.ts","../src/client/hooks/useDebugMode.ts"],"sourcesContent":["/**\n * @djangocfg/monitor/client\n *\n * Browser-side monitor. Use in 'use client' components only.\n *\n * @example\n * ```tsx\n * 'use client'\n * import { useEffect } from 'react'\n * import { FrontendMonitor } from '@djangocfg/monitor/client'\n *\n * export function MonitorProvider() {\n * useEffect(() => {\n * FrontendMonitor.init({ project: 'my-app', environment: process.env.NODE_ENV })\n * return () => FrontendMonitor.destroy()\n * }, [])\n * return null\n * }\n * ```\n */\n\nimport { installJsErrorCapture } from './capture/js-errors'\nimport { installConsoleCapture } from './capture/console'\nimport { installValidationCapture } from './capture/validation'\nimport { ensureSessionCookie } from './capture/session'\nimport { monitorStore } from './store'\nimport { configureMonitorApi } from '../_api'\nimport type { MonitorConfig, MonitorEvent } from '../types'\n\nexport type { MonitorConfig, MonitorEvent } from '../types'\nexport { EventType, EventLevel } from '../types'\nexport { monitoredFetch } from './capture/network'\nexport { getSessionId } from './capture/session'\nexport { MonitorProvider } from './MonitorProvider'\nexport type { MonitorProviderProps } from './MonitorProvider'\nexport { initWindowMonitor } from './window'\nexport type { WindowMonitorAPI } from './window'\nexport { monitorStore } from './store'\nexport { useDebugMode } from './hooks/useDebugMode'\nexport { isDevelopment, isProduction, MONITOR_VERSION } from './utils/env'\n\nlet flushInterval: ReturnType<typeof setInterval> | null = null\nconst cleanupFns: Array<() => void> = []\n\nexport const FrontendMonitor = {\n init(config: MonitorConfig = {}): void {\n if (typeof window === 'undefined') return\n\n const baseUrl = config.baseUrl ?? process.env.NEXT_PUBLIC_API_URL ?? ''\n if (baseUrl) configureMonitorApi(baseUrl)\n monitorStore.getState().setConfig(config)\n ensureSessionCookie()\n\n if (config.captureJsErrors !== false) cleanupFns.push(installJsErrorCapture())\n if (config.captureConsole !== false) cleanupFns.push(installConsoleCapture())\n cleanupFns.push(installValidationCapture())\n\n const interval = config.flushInterval ?? 5000\n flushInterval = setInterval(() => monitorStore.getState().flush(), interval)\n\n const onHide = () => { if (document.visibilityState === 'hidden') monitorStore.getState().flush(true) }\n window.addEventListener('visibilitychange', onHide)\n window.addEventListener('beforeunload', () => monitorStore.getState().flush(true))\n\n if (config.debug) console.info('[FrontendMonitor] initialized', config)\n },\n\n capture(event: MonitorEvent): void {\n monitorStore.getState().push(event)\n },\n\n flush(): void {\n monitorStore.getState().flush()\n },\n\n destroy(): void {\n if (flushInterval !== null) { clearInterval(flushInterval); flushInterval = null }\n cleanupFns.forEach((fn) => fn())\n cleanupFns.length = 0\n },\n}\n","function simpleHash(str: string): string {\n let hash = 0\n for (let i = 0; i < str.length; i++) {\n hash = (hash << 5) - hash + str.charCodeAt(i)\n hash = hash & hash\n }\n return Math.abs(hash).toString(16).padStart(8, '0')\n}\n\nexport async function computeFingerprint(\n message: string,\n stack: string,\n url: string,\n): Promise<string> {\n const raw = `${message}|${stack}|${url}`\n if (typeof crypto !== 'undefined' && crypto.subtle) {\n try {\n const data = new TextEncoder().encode(raw)\n const buf = await crypto.subtle.digest('SHA-256', data)\n return Array.from(new Uint8Array(buf))\n .map((b) => b.toString(16).padStart(2, '0'))\n .join('')\n .slice(0, 64)\n } catch { /* fall through */ }\n }\n return simpleHash(raw)\n}\n","const SESSION_KEY = 'fm_session_id'\nconst COOKIE_MAX_AGE = 60 * 60 * 24 * 365\n\nfunction generateUUID(): string {\n if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n return crypto.randomUUID()\n }\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = (Math.random() * 16) | 0\n return (c === 'x' ? r : (r & 0x3) | 0x8).toString(16)\n })\n}\n\nfunction setCookie(name: string, value: string): void {\n if (typeof document === 'undefined') return\n document.cookie = `${name}=${value}; path=/; SameSite=Lax; max-age=${COOKIE_MAX_AGE}`\n}\n\nexport function getSessionId(): string {\n if (typeof localStorage === 'undefined') return ''\n let id = localStorage.getItem(SESSION_KEY)\n if (!id) {\n id = generateUUID()\n localStorage.setItem(SESSION_KEY, id)\n setCookie(SESSION_KEY, id)\n }\n return id\n}\n\nexport function ensureSessionCookie(): void {\n const id = getSessionId()\n if (id) setCookie(SESSION_KEY, id)\n}\n","import { createStore } from 'zustand/vanilla'\nimport type { MonitorEvent, MonitorConfig } from '../../types'\nimport { sendBatch } from '../transport/ingest'\nimport { MONITOR_VERSION } from '../utils/env'\nimport { DEFAULT_DEDUPE_STORE_TTL } from '../constants'\n\n// Circuit breaker: pause flushing after N consecutive transport failures\nconst CIRCUIT_BREAKER_THRESHOLD = 3\nconst CIRCUIT_BREAKER_COOLDOWN_MS = 60_000 // 1 minute\n\n// Global deduplication: skip pushing identical events within this window.\n// Protects against multiple capture sources (js-errors, console, ErrorTrackingProvider)\n// all firing for the same underlying error.\nconst STORE_DEDUP_MAX = 200\nconst _recentPushKeys = new Map<string, number>()\n\nfunction _pushDedupeKey(event: MonitorEvent): string {\n const msg = (event.message ?? '').slice(0, 100)\n return `${event.event_type}:${event.level}:${msg}:${event.http_url ?? event.url ?? ''}`\n}\n\nfunction _isRecentPush(key: string, ttl: number): boolean {\n const now = Date.now()\n const last = _recentPushKeys.get(key)\n if (last !== undefined && now - last < ttl) return true\n _recentPushKeys.set(key, now)\n if (_recentPushKeys.size > STORE_DEDUP_MAX) {\n for (const [k, ts] of _recentPushKeys) {\n if (now - ts > ttl) _recentPushKeys.delete(k)\n }\n }\n return false\n}\n\ninterface MonitorState {\n config: MonitorConfig\n buffer: MonitorEvent[]\n initialized: boolean\n _consecutiveFailures: number\n _pausedUntil: number\n push: (event: MonitorEvent) => void\n flush: (useBeacon?: boolean) => void\n setConfig: (config: MonitorConfig) => void\n}\n\nexport const monitorStore = createStore<MonitorState>((set, get) => ({\n config: {},\n buffer: [],\n initialized: false,\n _consecutiveFailures: 0,\n _pausedUntil: 0,\n\n push(event) {\n // Global dedup: skip if an identical event was pushed recently\n const { config, buffer } = get()\n const storeTtl = config.dedupeStoreTtl ?? DEFAULT_DEDUPE_STORE_TTL\n const dedupeKey = _pushDedupeKey(event)\n if (_isRecentPush(dedupeKey, storeTtl)) return\n const maxSize = config.maxBufferSize ?? 20\n const sanitized: MonitorEvent = {\n build_id: event.build_id ?? config.buildId ?? `sdk:${MONITOR_VERSION}`,\n ...event,\n // Enforce field size limits before buffering (last-resort backstop)\n message: event.message && event.message.length > 4997\n ? event.message.slice(0, 4997) + '...'\n : event.message,\n stack_trace: event.stack_trace && event.stack_trace.length > 10000\n ? event.stack_trace.slice(0, 9997) + '...'\n : event.stack_trace,\n // Cap extra payload — drop entirely if serialized size exceeds 32KB\n extra: (() => {\n if (!event.extra) return event.extra\n try {\n return JSON.stringify(event.extra).length > 32768 ? {} : event.extra\n } catch { return {} }\n })(),\n }\n const next = [...buffer, sanitized]\n set({ buffer: next })\n\n if (next.length >= maxSize || event.level === 'error') {\n get().flush()\n }\n },\n\n flush(useBeacon = false) {\n const { buffer, _pausedUntil } = get()\n if (buffer.length === 0) return\n\n // Circuit breaker: skip sending while paused\n if (Date.now() < _pausedUntil) return\n\n const batch = buffer.slice(0, 25)\n set({ buffer: buffer.slice(25) })\n\n sendBatch({ events: batch }, useBeacon).then(\n () => {\n // Success: reset failure counter\n set({ _consecutiveFailures: 0, _pausedUntil: 0 })\n },\n () => {\n // Failure: increment counter and maybe open circuit\n const failures = get()._consecutiveFailures + 1\n const pausedUntil = failures >= CIRCUIT_BREAKER_THRESHOLD\n ? Date.now() + CIRCUIT_BREAKER_COOLDOWN_MS\n : get()._pausedUntil\n set({ _consecutiveFailures: failures, _pausedUntil: pausedUntil })\n }\n )\n },\n\n setConfig(config) {\n set({ config, initialized: true })\n },\n}))\n","// AUTO-GENERATED by django_generator / ts_extras.wrapper\n// Typed error classes with DRF field-error support.\n// DO NOT EDIT — re-run `make gen`.\n\n/**\n * HTTP API Error with DRF field-specific validation errors.\n */\nexport class APIError extends Error {\n constructor(\n public statusCode: number,\n public statusText: string,\n public response: any,\n public url: string,\n message?: string,\n ) {\n super(message || `HTTP ${statusCode}: ${statusText}`);\n this.name = \"APIError\";\n }\n\n get details(): Record<string, any> | null {\n if (typeof this.response === \"object\" && this.response !== null) {\n return this.response;\n }\n return null;\n }\n\n get fieldErrors(): Record<string, string[]> | null {\n const details = this.details;\n if (!details) return null;\n const fieldErrors: Record<string, string[]> = {};\n for (const [key, value] of Object.entries(details)) {\n if (Array.isArray(value)) fieldErrors[key] = value;\n }\n return Object.keys(fieldErrors).length > 0 ? fieldErrors : null;\n }\n\n get errorMessage(): string {\n const details = this.details;\n if (!details) return this.message;\n if (details.detail) {\n return Array.isArray(details.detail) ? details.detail.join(\", \") : String(details.detail);\n }\n if (details.error) return String(details.error);\n if (details.message) return String(details.message);\n const fieldErrors = this.fieldErrors;\n if (fieldErrors) {\n const firstField = Object.keys(fieldErrors)[0];\n if (firstField) return `${firstField}: ${fieldErrors[firstField]?.join(\", \")}`;\n }\n return this.message;\n }\n\n get isValidationError(): boolean { return this.statusCode === 400; }\n get isAuthError(): boolean { return this.statusCode === 401; }\n get isPermissionError(): boolean { return this.statusCode === 403; }\n get isNotFoundError(): boolean { return this.statusCode === 404; }\n get isServerError(): boolean { return this.statusCode >= 500 && this.statusCode < 600; }\n}\n\n/** Network Error (connection failed, timeout, etc.) */\nexport class NetworkError extends Error {\n constructor(\n message: string,\n public url: string,\n public originalError?: Error,\n ) {\n super(message);\n this.name = \"NetworkError\";\n }\n}\n","// AUTO-GENERATED by django_generator / ts_extras.wrapper\n// Global auth store. Wired into the shared `client` from `client.gen.ts`\n// via `installAuthOnClient(client)` — called synchronously by the\n// post-processed bottom of client.gen.ts. No circular import here.\n// DO NOT EDIT — re-run `make gen`.\n\nimport { APIError } from './errors';\n\nconst ACCESS_KEY = 'cfg.access_token';\nconst REFRESH_KEY = 'cfg.refresh_token';\nconst API_KEY_KEY = 'cfg.api_key';\n\nconst isBrowser = typeof window !== 'undefined';\n\nexport type StorageMode = 'localStorage' | 'cookie';\n\n// ── Storage backends (browser-only; server-side reads return null) ─────────\n\ninterface KVStore {\n get(key: string): string | null;\n set(key: string, value: string | null): void;\n}\n\nconst localStorageBackend: KVStore = {\n get(key) {\n if (!isBrowser) return null;\n try { return window.localStorage.getItem(key); } catch { return null; }\n },\n set(key, value) {\n if (!isBrowser) return;\n try {\n if (value === null) window.localStorage.removeItem(key);\n else window.localStorage.setItem(key, value);\n } catch {}\n },\n};\n\n/** 30 days, matches typical refresh-token lifetime. */\nconst COOKIE_MAX_AGE = 60 * 60 * 24 * 30;\n\nconst cookieBackend: KVStore = {\n get(key) {\n if (!isBrowser) return null;\n try {\n const re = new RegExp(`(?:^|;\\\\s*)${encodeURIComponent(key)}=([^;]*)`);\n const m = document.cookie.match(re);\n return m ? decodeURIComponent(m[1]) : null;\n } catch { return null; }\n },\n set(key, value) {\n if (!isBrowser) return;\n try {\n const k = encodeURIComponent(key);\n const secure = window.location.protocol === 'https:' ? '; Secure' : '';\n if (value === null) {\n document.cookie = `${k}=; Path=/; Max-Age=0; SameSite=Lax${secure}`;\n } else {\n const v = encodeURIComponent(value);\n document.cookie = `${k}=${v}; Path=/; Max-Age=${COOKIE_MAX_AGE}; SameSite=Lax${secure}`;\n }\n } catch {}\n },\n};\n\nlet _storage: KVStore = localStorageBackend;\nlet _storageMode: StorageMode = 'localStorage';\n\n/** Detect locale from `NEXT_LOCALE` cookie or `navigator.language`. */\nfunction detectLocale(): string | null {\n try {\n if (typeof document !== 'undefined') {\n const m = document.cookie.match(/(?:^|;\\s*)NEXT_LOCALE=([^;]*)/);\n if (m) return decodeURIComponent(m[1]);\n }\n if (typeof navigator !== 'undefined' && navigator.language) {\n return navigator.language;\n }\n } catch {}\n return null;\n}\n\n/** Default baseUrl from `NEXT_PUBLIC_API_URL`.\n *\n * Both browser and server use NEXT_PUBLIC_API_URL — requests go\n * directly to Django without Next.js proxy.\n */\nfunction defaultBaseUrl(): string {\n try {\n if (typeof process !== 'undefined' && process.env) {\n if (process.env.NEXT_PUBLIC_STATIC_BUILD === 'true') return '';\n return process.env.NEXT_PUBLIC_API_URL || '';\n }\n } catch {}\n return '';\n}\n\n/** Default API key fallback from `NEXT_PUBLIC_API_KEY`.\n *\n * In the browser: returns null — requests go through the Next.js rewrite\n * and the key is injected server-side (never exposed in the bundle).\n * On the server: reads NEXT_PUBLIC_API_KEY as a fallback for SSR calls\n * that bypass the rewrite (e.g. server components calling Django directly).\n */\nfunction defaultApiKey(): string | null {\n if (isBrowser) return null;\n try {\n if (typeof process !== 'undefined' && process.env?.NEXT_PUBLIC_API_KEY) {\n return process.env.NEXT_PUBLIC_API_KEY;\n }\n } catch {}\n return null;\n}\n\n// ── In-memory overrides (win over storage / env) ───────────────────────────\nlet _localeOverride: string | null = null;\nlet _apiKeyOverride: string | null = null;\nlet _baseUrlOverride: string | null = null;\nlet _withCredentials = true;\nlet _onUnauthorized: ((response: Response) => void) | null = null;\n\n/**\n * User-supplied refresh handler. Receives the current refresh token,\n * must return a fresh access (and optional refresh) pair or null on failure.\n * Set once at app bootstrap via `auth.setRefreshHandler(...)`.\n */\ntype RefreshResult = { access: string; refresh?: string } | null;\ntype RefreshHandler = (refreshToken: string) => Promise<RefreshResult>;\nlet _refreshHandler: RefreshHandler | null = null;\n\n/** Single-flight: every concurrent 401 awaits the same refresh. */\nlet _refreshInflight: Promise<string | null> | null = null;\n\n/** Marker header — set on retried requests so we never loop on 401. */\nconst RETRY_MARKER = 'X-Auth-Retry';\n\n/**\n * Captured reference to the shared Hey API client. Set exactly once by\n * `installAuthOnClient(client)` (called from client.gen.ts). All `auth.set*`\n * methods that mutate transport config (baseUrl / credentials) push through\n * this reference. Until installed, those mutations are silently buffered as\n * in-memory state — the next request after install will pick them up.\n */\ntype HeyClient = {\n setConfig(opts: Record<string, unknown>): void;\n interceptors: {\n request: { use(fn: (req: Request) => Request | Promise<Request>): void };\n response: { use(fn: (res: Response, req: Request) => Response | Promise<Response>): void };\n error: { use(fn: (err: unknown, res: Response | undefined, req: Request | undefined, opts: unknown) => unknown): void };\n };\n};\nlet _client: HeyClient | null = null;\n\nfunction pushClientConfig(): void {\n if (!_client) return;\n _client.setConfig({\n baseUrl: auth.getBaseUrl(),\n credentials: _withCredentials ? 'include' : 'same-origin',\n });\n}\n\n/**\n * Global auth/config store. All getters read live state every call —\n * the interceptor below uses these to attach headers per-request.\n *\n * Default storage backend is `localStorage`. Switch to cookies (e.g.\n * for Next.js SSR cookie access) via `auth.setStorageMode('cookie')`\n * early in the app bootstrap.\n *\n * @example\n * import { auth } from '@your/api';\n * auth.setToken(jwt);\n * auth.clearTokens();\n * auth.setStorageMode('cookie');\n */\nexport const auth = {\n // ── Storage mode ──────────────────────────────────────────────────\n getStorageMode(): StorageMode { return _storageMode; },\n setStorageMode(mode: StorageMode): void {\n _storageMode = mode;\n _storage = mode === 'cookie' ? cookieBackend : localStorageBackend;\n },\n\n // ── Bearer token ──────────────────────────────────────────────────\n getToken(): string | null { return _storage.get(ACCESS_KEY); },\n setToken(token: string | null): void { _storage.set(ACCESS_KEY, token); },\n getRefreshToken(): string | null { return _storage.get(REFRESH_KEY); },\n setRefreshToken(token: string | null): void { _storage.set(REFRESH_KEY, token); },\n clearTokens(): void { _storage.set(ACCESS_KEY, null); _storage.set(REFRESH_KEY, null); },\n isAuthenticated(): boolean { return _storage.get(ACCESS_KEY) !== null; },\n\n // ── API key ───────────────────────────────────────────────────────\n getApiKey(): string | null {\n return _apiKeyOverride ?? _storage.get(API_KEY_KEY) ?? defaultApiKey();\n },\n setApiKey(key: string | null): void { _apiKeyOverride = key; },\n setApiKeyPersist(key: string | null): void {\n _apiKeyOverride = key;\n _storage.set(API_KEY_KEY, key);\n },\n clearApiKey(): void { _apiKeyOverride = null; _storage.set(API_KEY_KEY, null); },\n\n // ── Locale ────────────────────────────────────────────────────────\n getLocale(): string | null { return _localeOverride ?? detectLocale(); },\n setLocale(locale: string | null): void { _localeOverride = locale; },\n\n // ── Base URL ──────────────────────────────────────────────────────\n getBaseUrl(): string {\n const url = (_baseUrlOverride ?? defaultBaseUrl());\n return url.replace(/\\/$/, '');\n },\n setBaseUrl(url: string | null): void {\n _baseUrlOverride = url ? url.replace(/\\/$/, '') : null;\n pushClientConfig();\n },\n\n // ── Credentials toggle ────────────────────────────────────────────\n getWithCredentials(): boolean { return _withCredentials; },\n setWithCredentials(value: boolean): void {\n _withCredentials = value;\n pushClientConfig();\n },\n\n // ── 401 handler ───────────────────────────────────────────────────\n /**\n * Fired when the server returns 401 AND no refresh path recovers it\n * (no refresh token, no refresh handler, refresh failed, or retry\n * still 401). The app should clear local state and redirect to login.\n *\n * NOT fired for 401 that gets transparently recovered by the refresh\n * handler — those are invisible to callers.\n */\n onUnauthorized(cb: ((response: Response) => void) | null): void {\n _onUnauthorized = cb;\n },\n\n /**\n * Register the refresh strategy. The handler receives the current\n * refresh token and must call your refresh endpoint, returning\n * `{ access, refresh? }` on success or `null` on failure.\n *\n * @example\n * auth.setRefreshHandler(async (refresh) => {\n * const { data } = await Auth.tokenRefreshCreate({ body: { refresh } });\n * return data ? { access: data.access, refresh: data.refresh } : null;\n * });\n */\n setRefreshHandler(fn: RefreshHandler | null): void {\n _refreshHandler = fn;\n },\n};\n\n/**\n * Run the user-supplied refresh handler under single-flight, persist\n * the new tokens, and return the fresh access token (or null on any\n * failure path). All concurrent 401s share the same in-flight promise.\n */\nasync function tryRefresh(): Promise<string | null> {\n if (_refreshInflight) return _refreshInflight;\n if (!_refreshHandler) return null;\n const refresh = auth.getRefreshToken();\n if (!refresh) return null;\n\n _refreshInflight = (async () => {\n try {\n const result = await _refreshHandler!(refresh);\n if (!result?.access) return null;\n auth.setToken(result.access);\n if (result.refresh) auth.setRefreshToken(result.refresh);\n return result.access;\n } catch {\n return null;\n } finally {\n _refreshInflight = null;\n }\n })();\n\n return _refreshInflight;\n}\n\n/**\n * Wire the shared client to the global auth store. Called exactly\n * once from `client.gen.ts` (post-processed) right after\n * `createClient()`. Synchronous — no microtask, no TDZ races.\n *\n * Safe to call from server / SSR: storage backends short-circuit on\n * non-browser environments, so headers populated by the interceptor\n * are simply absent server-side (which is the correct behaviour\n * unless the caller explicitly sets a server-side token).\n */\nexport function installAuthOnClient(client: HeyClient): void {\n if (_client) return; // idempotent\n _client = client;\n\n client.setConfig({\n baseUrl: auth.getBaseUrl(),\n credentials: _withCredentials ? 'include' : 'same-origin',\n });\n\n client.interceptors.request.use((request) => {\n const token = auth.getToken();\n if (token) request.headers.set('Authorization', `Bearer ${token}`);\n\n const locale = auth.getLocale();\n if (locale) request.headers.set('Accept-Language', locale);\n\n const apiKey = auth.getApiKey();\n if (apiKey) request.headers.set('X-API-Key', apiKey);\n\n try {\n const tz = Intl.DateTimeFormat().resolvedOptions().timeZone;\n if (tz) request.headers.set('X-Timezone', tz);\n } catch {}\n request.headers.set('X-Client-Time', new Date().toISOString());\n\n return request;\n });\n\n // Wrap raw JSON error objects (thrown by hey-api on non-2xx responses) into\n // APIError so callers can do `error instanceof APIError` and read\n // `error.statusCode` / `error.response` consistently.\n client.interceptors.error.use((err, res, req) => {\n if (err instanceof APIError) return err;\n const url = (req as Request | undefined)?.url ?? '';\n const status = (res as Response | undefined)?.status ?? 0;\n const statusText = (res as Response | undefined)?.statusText ?? '';\n return new APIError(status, statusText, err, url);\n });\n\n client.interceptors.response.use(async (response, request) => {\n if (response.status !== 401) return response;\n\n // Already retried once — give up to avoid loops.\n if (request.headers.get(RETRY_MARKER)) {\n if (_onUnauthorized) {\n try { _onUnauthorized(response); } catch {}\n }\n return response;\n }\n\n const newToken = await tryRefresh();\n if (!newToken) {\n if (_onUnauthorized) {\n try { _onUnauthorized(response); } catch {}\n }\n return response;\n }\n\n // Retry the original request once with the new token. We mutate a\n // clone so the original Request body (already consumed by the\n // failed call) doesn't trip \"body already used\".\n const retry = request.clone();\n retry.headers.set('Authorization', `Bearer ${newToken}`);\n retry.headers.set(RETRY_MARKER, '1');\n try {\n const retried = await fetch(retry);\n if (retried.status === 401 && _onUnauthorized) {\n try { _onUnauthorized(retried); } catch {}\n }\n return retried;\n } catch {\n // Network error on retry — surface the original 401.\n if (_onUnauthorized) {\n try { _onUnauthorized(response); } catch {}\n }\n return response;\n }\n });\n}\n\nexport type Auth = typeof auth;\n","// AUTO-GENERATED by django_generator / ts_extras.wrapper\n// API logger built on consola. Optional dependency — install if you enable logging:\n// npm install consola\n// DO NOT EDIT — re-run `make gen`.\n\nimport { type ConsolaInstance, createConsola } from \"consola\";\n\nexport interface RequestLog {\n method: string;\n url: string;\n headers?: Record<string, string>;\n body?: any;\n timestamp: number;\n}\n\nexport interface ResponseLog {\n status: number;\n statusText: string;\n data?: any;\n duration: number;\n timestamp: number;\n}\n\nexport interface ErrorLog {\n message: string;\n statusCode?: number;\n fieldErrors?: Record<string, string[]>;\n duration: number;\n timestamp: number;\n}\n\nexport interface LoggerConfig {\n enabled: boolean;\n logRequests: boolean;\n logResponses: boolean;\n logErrors: boolean;\n logBodies: boolean;\n logHeaders: boolean;\n consola?: ConsolaInstance;\n}\n\nconst DEFAULT_CONFIG: LoggerConfig = {\n enabled: typeof process !== \"undefined\" && process.env?.NODE_ENV !== \"production\",\n logRequests: true,\n logResponses: true,\n logErrors: true,\n logBodies: true,\n logHeaders: false,\n};\n\nconst SENSITIVE_HEADERS = [\n \"authorization\",\n \"cookie\",\n \"set-cookie\",\n \"x-api-key\",\n \"x-csrf-token\",\n];\n\nexport class APILogger {\n private config: LoggerConfig;\n private consola: ConsolaInstance;\n\n constructor(config: Partial<LoggerConfig> = {}) {\n this.config = { ...DEFAULT_CONFIG, ...config };\n this.consola = config.consola || createConsola({\n level: this.config.enabled ? 4 : 0,\n });\n }\n\n enable(): void { this.config.enabled = true; }\n disable(): void { this.config.enabled = false; }\n setConfig(config: Partial<LoggerConfig>): void {\n this.config = { ...this.config, ...config };\n }\n\n private filterHeaders(headers?: Record<string, string>): Record<string, string> {\n if (!headers) return {};\n const filtered: Record<string, string> = {};\n Object.keys(headers).forEach((key) => {\n filtered[key] = SENSITIVE_HEADERS.includes(key.toLowerCase()) ? \"***\" : (headers[key] || \"\");\n });\n return filtered;\n }\n\n logRequest(request: RequestLog): void {\n if (!this.config.enabled || !this.config.logRequests) return;\n const { method, url, headers, body } = request;\n this.consola.start(`${method} ${url}`);\n if (this.config.logHeaders && headers) this.consola.debug(\"Headers:\", this.filterHeaders(headers));\n if (this.config.logBodies && body) this.consola.debug(\"Body:\", body);\n }\n\n logResponse(request: RequestLog, response: ResponseLog): void {\n if (!this.config.enabled || !this.config.logResponses) return;\n const { method, url } = request;\n const { status, statusText, data, duration } = response;\n this.consola.success(`${method} ${url} ${status} ${statusText} (${duration}ms)`);\n if (this.config.logBodies && data) this.consola.debug(\"Response:\", data);\n }\n\n logError(request: RequestLog, error: ErrorLog): void {\n if (!this.config.enabled || !this.config.logErrors) return;\n const { method, url } = request;\n const { message, statusCode, fieldErrors, duration } = error;\n this.consola.error(`${method} ${url} ${statusCode || \"Network\"} Error (${duration}ms)`);\n this.consola.error(\"Message:\", message);\n if (fieldErrors && Object.keys(fieldErrors).length > 0) {\n this.consola.error(\"Field Errors:\");\n Object.entries(fieldErrors).forEach(([field, errors]) => {\n errors.forEach((err) => this.consola.error(` • ${field}: ${err}`));\n });\n }\n }\n\n info(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.info(message, ...args); }\n warn(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.warn(message, ...args); }\n error(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.error(message, ...args); }\n debug(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.debug(message, ...args); }\n success(message: string, ...args: any[]): void { if (this.config.enabled) this.consola.success(message, ...args); }\n withTag(tag: string): ConsolaInstance { return this.consola.withTag(tag); }\n}\n\nexport const defaultLogger = new APILogger();\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { ArrayStyle, ObjectStyle, SerializerOptions } from './pathSerializer.gen';\n\nexport type QuerySerializer = (query: Record<string, unknown>) => string;\n\nexport type BodySerializer = (body: unknown) => unknown;\n\ntype QuerySerializerOptionsObject = {\n allowReserved?: boolean;\n array?: Partial<SerializerOptions<ArrayStyle>>;\n object?: Partial<SerializerOptions<ObjectStyle>>;\n};\n\nexport type QuerySerializerOptions = QuerySerializerOptionsObject & {\n /**\n * Per-parameter serialization overrides. When provided, these settings\n * override the global array/object settings for specific parameter names.\n */\n parameters?: Record<string, QuerySerializerOptionsObject>;\n};\n\nconst serializeFormDataPair = (data: FormData, key: string, value: unknown): void => {\n if (typeof value === 'string' || value instanceof Blob) {\n data.append(key, value);\n } else if (value instanceof Date) {\n data.append(key, value.toISOString());\n } else {\n data.append(key, JSON.stringify(value));\n }\n};\n\nconst serializeUrlSearchParamsPair = (data: URLSearchParams, key: string, value: unknown): void => {\n if (typeof value === 'string') {\n data.append(key, value);\n } else {\n data.append(key, JSON.stringify(value));\n }\n};\n\nexport const formDataBodySerializer = {\n bodySerializer: (body: unknown): FormData => {\n const data = new FormData();\n\n Object.entries(body as Record<string, unknown>).forEach(([key, value]) => {\n if (value === undefined || value === null) {\n return;\n }\n if (Array.isArray(value)) {\n value.forEach((v) => serializeFormDataPair(data, key, v));\n } else {\n serializeFormDataPair(data, key, value);\n }\n });\n\n return data;\n },\n};\n\nexport const jsonBodySerializer = {\n bodySerializer: (body: unknown): string =>\n JSON.stringify(body, (_key, value) => (typeof value === 'bigint' ? value.toString() : value)),\n};\n\nexport const urlSearchParamsBodySerializer = {\n bodySerializer: (body: unknown): string => {\n const data = new URLSearchParams();\n\n Object.entries(body as Record<string, unknown>).forEach(([key, value]) => {\n if (value === undefined || value === null) {\n return;\n }\n if (Array.isArray(value)) {\n value.forEach((v) => serializeUrlSearchParamsPair(data, key, v));\n } else {\n serializeUrlSearchParamsPair(data, key, value);\n }\n });\n\n return data.toString();\n },\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\ntype Slot = 'body' | 'headers' | 'path' | 'query';\n\nexport type Field =\n | {\n in: Exclude<Slot, 'body'>;\n /**\n * Field name. This is the name we want the user to see and use.\n */\n key: string;\n /**\n * Field mapped name. This is the name we want to use in the request.\n * If omitted, we use the same value as `key`.\n */\n map?: string;\n }\n | {\n in: Extract<Slot, 'body'>;\n /**\n * Key isn't required for bodies.\n */\n key?: string;\n map?: string;\n }\n | {\n /**\n * Field name. This is the name we want the user to see and use.\n */\n key: string;\n /**\n * Field mapped name. This is the name we want to use in the request.\n * If `in` is omitted, `map` aliases `key` to the transport layer.\n */\n map: Slot;\n };\n\nexport interface Fields {\n allowExtra?: Partial<Record<Slot, boolean>>;\n args?: ReadonlyArray<Field>;\n}\n\nexport type FieldsConfig = ReadonlyArray<Field | Fields>;\n\nconst extraPrefixesMap: Record<string, Slot> = {\n $body_: 'body',\n $headers_: 'headers',\n $path_: 'path',\n $query_: 'query',\n};\nconst extraPrefixes = Object.entries(extraPrefixesMap);\n\ntype KeyMap = Map<\n string,\n | {\n in: Slot;\n map?: string;\n }\n | {\n in?: never;\n map: Slot;\n }\n>;\n\nconst buildKeyMap = (fields: FieldsConfig, map?: KeyMap): KeyMap => {\n if (!map) {\n map = new Map();\n }\n\n for (const config of fields) {\n if ('in' in config) {\n if (config.key) {\n map.set(config.key, {\n in: config.in,\n map: config.map,\n });\n }\n } else if ('key' in config) {\n map.set(config.key, {\n map: config.map,\n });\n } else if (config.args) {\n buildKeyMap(config.args, map);\n }\n }\n\n return map;\n};\n\ninterface Params {\n body: unknown;\n headers: Record<string, unknown>;\n path: Record<string, unknown>;\n query: Record<string, unknown>;\n}\n\nconst stripEmptySlots = (params: Params) => {\n for (const [slot, value] of Object.entries(params)) {\n if (value && typeof value === 'object' && !Array.isArray(value) && !Object.keys(value).length) {\n delete params[slot as Slot];\n }\n }\n};\n\nexport const buildClientParams = (args: ReadonlyArray<unknown>, fields: FieldsConfig) => {\n const params: Params = {\n body: {},\n headers: {},\n path: {},\n query: {},\n };\n\n const map = buildKeyMap(fields);\n\n let config: FieldsConfig[number] | undefined;\n\n for (const [index, arg] of args.entries()) {\n if (fields[index]) {\n config = fields[index];\n }\n\n if (!config) {\n continue;\n }\n\n if ('in' in config) {\n if (config.key) {\n const field = map.get(config.key)!;\n const name = field.map || config.key;\n if (field.in) {\n (params[field.in] as Record<string, unknown>)[name] = arg;\n }\n } else {\n params.body = arg;\n }\n } else {\n for (const [key, value] of Object.entries(arg ?? {})) {\n const field = map.get(key);\n\n if (field) {\n if (field.in) {\n const name = field.map || key;\n (params[field.in] as Record<string, unknown>)[name] = value;\n } else {\n params[field.map] = value;\n }\n } else {\n const extra = extraPrefixes.find(([prefix]) => key.startsWith(prefix));\n\n if (extra) {\n const [prefix, slot] = extra;\n (params[slot] as Record<string, unknown>)[key.slice(prefix.length)] = value;\n } else if ('allowExtra' in config && config.allowExtra) {\n for (const [slot, allowed] of Object.entries(config.allowExtra)) {\n if (allowed) {\n (params[slot as Slot] as Record<string, unknown>)[key] = value;\n break;\n }\n }\n }\n }\n }\n }\n }\n\n stripEmptySlots(params);\n\n return params;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { Config } from './types.gen';\n\nexport type ServerSentEventsOptions<TData = unknown> = Omit<RequestInit, 'method'> &\n Pick<Config, 'method' | 'responseTransformer' | 'responseValidator'> & {\n /**\n * Fetch API implementation. You can use this option to provide a custom\n * fetch instance.\n *\n * @default globalThis.fetch\n */\n fetch?: typeof fetch;\n /**\n * Implementing clients can call request interceptors inside this hook.\n */\n onRequest?: (url: string, init: RequestInit) => Promise<Request>;\n /**\n * Callback invoked when a network or parsing error occurs during streaming.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @param error The error that occurred.\n */\n onSseError?: (error: unknown) => void;\n /**\n * Callback invoked when an event is streamed from the server.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @param event Event streamed from the server.\n * @returns Nothing (void).\n */\n onSseEvent?: (event: StreamEvent<TData>) => void;\n serializedBody?: RequestInit['body'];\n /**\n * Default retry delay in milliseconds.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @default 3000\n */\n sseDefaultRetryDelay?: number;\n /**\n * Maximum number of retry attempts before giving up.\n */\n sseMaxRetryAttempts?: number;\n /**\n * Maximum retry delay in milliseconds.\n *\n * Applies only when exponential backoff is used.\n *\n * This option applies only if the endpoint returns a stream of events.\n *\n * @default 30000\n */\n sseMaxRetryDelay?: number;\n /**\n * Optional sleep function for retry backoff.\n *\n * Defaults to using `setTimeout`.\n */\n sseSleepFn?: (ms: number) => Promise<void>;\n url: string;\n };\n\nexport interface StreamEvent<TData = unknown> {\n data: TData;\n event?: string;\n id?: string;\n retry?: number;\n}\n\nexport type ServerSentEventsResult<TData = unknown, TReturn = void, TNext = unknown> = {\n stream: AsyncGenerator<\n TData extends Record<string, unknown> ? TData[keyof TData] : TData,\n TReturn,\n TNext\n >;\n};\n\nexport function createSseClient<TData = unknown>({\n onRequest,\n onSseError,\n onSseEvent,\n responseTransformer,\n responseValidator,\n sseDefaultRetryDelay,\n sseMaxRetryAttempts,\n sseMaxRetryDelay,\n sseSleepFn,\n url,\n ...options\n}: ServerSentEventsOptions): ServerSentEventsResult<TData> {\n let lastEventId: string | undefined;\n\n const sleep = sseSleepFn ?? ((ms: number) => new Promise((resolve) => setTimeout(resolve, ms)));\n\n const createStream = async function* () {\n let retryDelay: number = sseDefaultRetryDelay ?? 3000;\n let attempt = 0;\n const signal = options.signal ?? new AbortController().signal;\n\n while (true) {\n if (signal.aborted) break;\n\n attempt++;\n\n const headers =\n options.headers instanceof Headers\n ? options.headers\n : new Headers(options.headers as Record<string, string> | undefined);\n\n if (lastEventId !== undefined) {\n headers.set('Last-Event-ID', lastEventId);\n }\n\n try {\n const requestInit: RequestInit = {\n redirect: 'follow',\n ...options,\n body: options.serializedBody,\n headers,\n signal,\n };\n let request = new Request(url, requestInit);\n if (onRequest) {\n request = await onRequest(url, requestInit);\n }\n // fetch must be assigned here, otherwise it would throw the error:\n // TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation\n const _fetch = options.fetch ?? globalThis.fetch;\n const response = await _fetch(request);\n\n if (!response.ok) throw new Error(`SSE failed: ${response.status} ${response.statusText}`);\n\n if (!response.body) throw new Error('No body in SSE response');\n\n const reader = response.body.pipeThrough(new TextDecoderStream()).getReader();\n\n let buffer = '';\n\n const abortHandler = () => {\n try {\n reader.cancel();\n } catch {\n // noop\n }\n };\n\n signal.addEventListener('abort', abortHandler);\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n buffer += value;\n buffer = buffer.replace(/\\r\\n?/g, '\\n'); // normalize line endings\n\n const chunks = buffer.split('\\n\\n');\n buffer = chunks.pop() ?? '';\n\n for (const chunk of chunks) {\n const lines = chunk.split('\\n');\n const dataLines: Array<string> = [];\n let eventName: string | undefined;\n\n for (const line of lines) {\n if (line.startsWith('data:')) {\n dataLines.push(line.replace(/^data:\\s*/, ''));\n } else if (line.startsWith('event:')) {\n eventName = line.replace(/^event:\\s*/, '');\n } else if (line.startsWith('id:')) {\n lastEventId = line.replace(/^id:\\s*/, '');\n } else if (line.startsWith('retry:')) {\n const parsed = Number.parseInt(line.replace(/^retry:\\s*/, ''), 10);\n if (!Number.isNaN(parsed)) {\n retryDelay = parsed;\n }\n }\n }\n\n let data: unknown;\n let parsedJson = false;\n\n if (dataLines.length) {\n const rawData = dataLines.join('\\n');\n try {\n data = JSON.parse(rawData);\n parsedJson = true;\n } catch {\n data = rawData;\n }\n }\n\n if (parsedJson) {\n if (responseValidator) {\n await responseValidator(data);\n }\n\n if (responseTransformer) {\n data = await responseTransformer(data);\n }\n }\n\n onSseEvent?.({\n data,\n event: eventName,\n id: lastEventId,\n retry: retryDelay,\n });\n\n if (dataLines.length) {\n yield data as any;\n }\n }\n }\n } finally {\n signal.removeEventListener('abort', abortHandler);\n reader.releaseLock();\n }\n\n break; // exit loop on normal completion\n } catch (error) {\n // connection failed or aborted; retry after delay\n onSseError?.(error);\n\n if (sseMaxRetryAttempts !== undefined && attempt >= sseMaxRetryAttempts) {\n break; // stop after firing error\n }\n\n // exponential backoff: double retry each attempt, cap at 30s\n const backoff = Math.min(retryDelay * 2 ** (attempt - 1), sseMaxRetryDelay ?? 30000);\n await sleep(backoff);\n }\n }\n };\n\n const stream = createStream();\n\n return { stream };\n}\n","// This file is auto-generated by @hey-api/openapi-ts\n\ninterface SerializeOptions<T> extends SerializePrimitiveOptions, SerializerOptions<T> {}\n\ninterface SerializePrimitiveOptions {\n allowReserved?: boolean;\n name: string;\n}\n\nexport interface SerializerOptions<T> {\n /**\n * @default true\n */\n explode: boolean;\n style: T;\n}\n\nexport type ArrayStyle = 'form' | 'spaceDelimited' | 'pipeDelimited';\nexport type ArraySeparatorStyle = ArrayStyle | MatrixStyle;\ntype MatrixStyle = 'label' | 'matrix' | 'simple';\nexport type ObjectStyle = 'form' | 'deepObject';\ntype ObjectSeparatorStyle = ObjectStyle | MatrixStyle;\n\ninterface SerializePrimitiveParam extends SerializePrimitiveOptions {\n value: string;\n}\n\nexport const separatorArrayExplode = (style: ArraySeparatorStyle) => {\n switch (style) {\n case 'label':\n return '.';\n case 'matrix':\n return ';';\n case 'simple':\n return ',';\n default:\n return '&';\n }\n};\n\nexport const separatorArrayNoExplode = (style: ArraySeparatorStyle) => {\n switch (style) {\n case 'form':\n return ',';\n case 'pipeDelimited':\n return '|';\n case 'spaceDelimited':\n return '%20';\n default:\n return ',';\n }\n};\n\nexport const separatorObjectExplode = (style: ObjectSeparatorStyle) => {\n switch (style) {\n case 'label':\n return '.';\n case 'matrix':\n return ';';\n case 'simple':\n return ',';\n default:\n return '&';\n }\n};\n\nexport const serializeArrayParam = ({\n allowReserved,\n explode,\n name,\n style,\n value,\n}: SerializeOptions<ArraySeparatorStyle> & {\n value: unknown[];\n}) => {\n if (!explode) {\n const joinedValues = (\n allowReserved ? value : value.map((v) => encodeURIComponent(v as string))\n ).join(separatorArrayNoExplode(style));\n switch (style) {\n case 'label':\n return `.${joinedValues}`;\n case 'matrix':\n return `;${name}=${joinedValues}`;\n case 'simple':\n return joinedValues;\n default:\n return `${name}=${joinedValues}`;\n }\n }\n\n const separator = separatorArrayExplode(style);\n const joinedValues = value\n .map((v) => {\n if (style === 'label' || style === 'simple') {\n return allowReserved ? v : encodeURIComponent(v as string);\n }\n\n return serializePrimitiveParam({\n allowReserved,\n name,\n value: v as string,\n });\n })\n .join(separator);\n return style === 'label' || style === 'matrix' ? separator + joinedValues : joinedValues;\n};\n\nexport const serializePrimitiveParam = ({\n allowReserved,\n name,\n value,\n}: SerializePrimitiveParam) => {\n if (value === undefined || value === null) {\n return '';\n }\n\n if (typeof value === 'object') {\n throw new Error(\n 'Deeply-nested arrays/objects aren’t supported. Provide your own `querySerializer()` to handle these.',\n );\n }\n\n return `${name}=${allowReserved ? value : encodeURIComponent(value)}`;\n};\n\nexport const serializeObjectParam = ({\n allowReserved,\n explode,\n name,\n style,\n value,\n valueOnly,\n}: SerializeOptions<ObjectSeparatorStyle> & {\n value: Record<string, unknown> | Date;\n valueOnly?: boolean;\n}) => {\n if (value instanceof Date) {\n return valueOnly ? value.toISOString() : `${name}=${value.toISOString()}`;\n }\n\n if (style !== 'deepObject' && !explode) {\n let values: string[] = [];\n Object.entries(value).forEach(([key, v]) => {\n values = [...values, key, allowReserved ? (v as string) : encodeURIComponent(v as string)];\n });\n const joinedValues = values.join(',');\n switch (style) {\n case 'form':\n return `${name}=${joinedValues}`;\n case 'label':\n return `.${joinedValues}`;\n case 'matrix':\n return `;${name}=${joinedValues}`;\n default:\n return joinedValues;\n }\n }\n\n const separator = separatorObjectExplode(style);\n const joinedValues = Object.entries(value)\n .map(([key, v]) =>\n serializePrimitiveParam({\n allowReserved,\n name: style === 'deepObject' ? `${name}[${key}]` : key,\n value: v as string,\n }),\n )\n .join(separator);\n return style === 'label' || style === 'matrix' ? separator + joinedValues : joinedValues;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { BodySerializer, QuerySerializer } from './bodySerializer.gen';\nimport {\n type ArraySeparatorStyle,\n serializeArrayParam,\n serializeObjectParam,\n serializePrimitiveParam,\n} from './pathSerializer.gen';\n\nexport interface PathSerializer {\n path: Record<string, unknown>;\n url: string;\n}\n\nexport const PATH_PARAM_RE = /\\{[^{}]+\\}/g;\n\nexport const defaultPathSerializer = ({ path, url: _url }: PathSerializer) => {\n let url = _url;\n const matches = _url.match(PATH_PARAM_RE);\n if (matches) {\n for (const match of matches) {\n let explode = false;\n let name = match.substring(1, match.length - 1);\n let style: ArraySeparatorStyle = 'simple';\n\n if (name.endsWith('*')) {\n explode = true;\n name = name.substring(0, name.length - 1);\n }\n\n if (name.startsWith('.')) {\n name = name.substring(1);\n style = 'label';\n } else if (name.startsWith(';')) {\n name = name.substring(1);\n style = 'matrix';\n }\n\n const value = path[name];\n\n if (value === undefined || value === null) {\n continue;\n }\n\n if (Array.isArray(value)) {\n url = url.replace(match, serializeArrayParam({ explode, name, style, value }));\n continue;\n }\n\n if (typeof value === 'object') {\n url = url.replace(\n match,\n serializeObjectParam({\n explode,\n name,\n style,\n value: value as Record<string, unknown>,\n valueOnly: true,\n }),\n );\n continue;\n }\n\n if (style === 'matrix') {\n url = url.replace(\n match,\n `;${serializePrimitiveParam({\n name,\n value: value as string,\n })}`,\n );\n continue;\n }\n\n const replaceValue = encodeURIComponent(\n style === 'label' ? `.${value as string}` : (value as string),\n );\n url = url.replace(match, replaceValue);\n }\n }\n return url;\n};\n\nexport const getUrl = ({\n baseUrl,\n path,\n query,\n querySerializer,\n url: _url,\n}: {\n baseUrl?: string;\n path?: Record<string, unknown>;\n query?: Record<string, unknown>;\n querySerializer: QuerySerializer;\n url: string;\n}) => {\n const pathUrl = _url.startsWith('/') ? _url : `/${_url}`;\n let url = (baseUrl ?? '') + pathUrl;\n if (path) {\n url = defaultPathSerializer({ path, url });\n }\n let search = query ? querySerializer(query) : '';\n if (search.startsWith('?')) {\n search = search.substring(1);\n }\n if (search) {\n url += `?${search}`;\n }\n return url;\n};\n\nexport function getValidRequestBody(options: {\n body?: unknown;\n bodySerializer?: BodySerializer | null;\n serializedBody?: unknown;\n}) {\n const hasBody = options.body !== undefined;\n const isSerializedBody = hasBody && options.bodySerializer;\n\n if (isSerializedBody) {\n if ('serializedBody' in options) {\n const hasSerializedBody =\n options.serializedBody !== undefined && options.serializedBody !== '';\n\n return hasSerializedBody ? options.serializedBody : null;\n }\n\n // not all clients implement a serializedBody property (i.e., client-axios)\n return options.body !== '' ? options.body : null;\n }\n\n // plain/text body\n if (hasBody) {\n return options.body;\n }\n\n // no body was provided\n return undefined;\n}\n","// This file is auto-generated by @hey-api/openapi-ts\n\nexport type AuthToken = string | undefined;\n\nexport interface Auth {\n /**\n * Which part of the request do we use to send the auth?\n *\n * @default 'header'\n */\n in?: 'header' | 'query' | 'cookie';\n /**\n * Header or query parameter name.\n *\n * @default 'Authorization'\n */\n name?: string;\n scheme?: 'basic' | 'bearer';\n type: 'apiKey' | 'http';\n}\n\nexport const getAuthToken = async (\n auth: Auth,\n callback: ((auth: Auth) => Promise<AuthToken> | AuthToken) | AuthToken,\n): Promise<string | undefined> => {\n const token = typeof callback === 'function' ? await callback(auth) : callback;\n\n if (!token) {\n return;\n }\n\n if (auth.scheme === 'bearer') {\n return `Bearer ${token}`;\n }\n\n if (auth.scheme === 'basic') {\n return `Basic ${btoa(token)}`;\n }\n\n return token;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport { getAuthToken } from '../core/auth.gen';\nimport type { QuerySerializerOptions } from '../core/bodySerializer.gen';\nimport { jsonBodySerializer } from '../core/bodySerializer.gen';\nimport {\n serializeArrayParam,\n serializeObjectParam,\n serializePrimitiveParam,\n} from '../core/pathSerializer.gen';\nimport { getUrl } from '../core/utils.gen';\nimport type { Client, ClientOptions, Config, RequestOptions } from './types.gen';\n\nexport const createQuerySerializer = <T = unknown>({\n parameters = {},\n ...args\n}: QuerySerializerOptions = {}) => {\n const querySerializer = (queryParams: T) => {\n const search: string[] = [];\n if (queryParams && typeof queryParams === 'object') {\n for (const name in queryParams) {\n const value = queryParams[name];\n\n if (value === undefined || value === null) {\n continue;\n }\n\n const options = parameters[name] || args;\n\n if (Array.isArray(value)) {\n const serializedArray = serializeArrayParam({\n allowReserved: options.allowReserved,\n explode: true,\n name,\n style: 'form',\n value,\n ...options.array,\n });\n if (serializedArray) search.push(serializedArray);\n } else if (typeof value === 'object') {\n const serializedObject = serializeObjectParam({\n allowReserved: options.allowReserved,\n explode: true,\n name,\n style: 'deepObject',\n value: value as Record<string, unknown>,\n ...options.object,\n });\n if (serializedObject) search.push(serializedObject);\n } else {\n const serializedPrimitive = serializePrimitiveParam({\n allowReserved: options.allowReserved,\n name,\n value: value as string,\n });\n if (serializedPrimitive) search.push(serializedPrimitive);\n }\n }\n }\n return search.join('&');\n };\n return querySerializer;\n};\n\n/**\n * Infers parseAs value from provided Content-Type header.\n */\nexport const getParseAs = (contentType: string | null): Exclude<Config['parseAs'], 'auto'> => {\n if (!contentType) {\n // If no Content-Type header is provided, the best we can do is return the raw response body,\n // which is effectively the same as the 'stream' option.\n return 'stream';\n }\n\n const cleanContent = contentType.split(';')[0]?.trim();\n\n if (!cleanContent) {\n return;\n }\n\n if (cleanContent.startsWith('application/json') || cleanContent.endsWith('+json')) {\n return 'json';\n }\n\n if (cleanContent === 'multipart/form-data') {\n return 'formData';\n }\n\n if (\n ['application/', 'audio/', 'image/', 'video/'].some((type) => cleanContent.startsWith(type))\n ) {\n return 'blob';\n }\n\n if (cleanContent.startsWith('text/')) {\n return 'text';\n }\n\n return;\n};\n\nconst checkForExistence = (\n options: Pick<RequestOptions, 'auth' | 'query'> & {\n headers: Headers;\n },\n name?: string,\n): boolean => {\n if (!name) {\n return false;\n }\n if (\n options.headers.has(name) ||\n options.query?.[name] ||\n options.headers.get('Cookie')?.includes(`${name}=`)\n ) {\n return true;\n }\n return false;\n};\n\nexport const setAuthParams = async ({\n security,\n ...options\n}: Pick<Required<RequestOptions>, 'security'> &\n Pick<RequestOptions, 'auth' | 'query'> & {\n headers: Headers;\n }) => {\n for (const auth of security) {\n if (checkForExistence(options, auth.name)) {\n continue;\n }\n\n const token = await getAuthToken(auth, options.auth);\n\n if (!token) {\n continue;\n }\n\n const name = auth.name ?? 'Authorization';\n\n switch (auth.in) {\n case 'query':\n if (!options.query) {\n options.query = {};\n }\n options.query[name] = token;\n break;\n case 'cookie':\n options.headers.append('Cookie', `${name}=${token}`);\n break;\n case 'header':\n default:\n options.headers.set(name, token);\n break;\n }\n }\n};\n\nexport const buildUrl: Client['buildUrl'] = (options) =>\n getUrl({\n baseUrl: options.baseUrl as string,\n path: options.path,\n query: options.query,\n querySerializer:\n typeof options.querySerializer === 'function'\n ? options.querySerializer\n : createQuerySerializer(options.querySerializer),\n url: options.url,\n });\n\nexport const mergeConfigs = (a: Config, b: Config): Config => {\n const config = { ...a, ...b };\n if (config.baseUrl?.endsWith('/')) {\n config.baseUrl = config.baseUrl.substring(0, config.baseUrl.length - 1);\n }\n config.headers = mergeHeaders(a.headers, b.headers);\n return config;\n};\n\nconst headersEntries = (headers: Headers): Array<[string, string]> => {\n const entries: Array<[string, string]> = [];\n headers.forEach((value, key) => {\n entries.push([key, value]);\n });\n return entries;\n};\n\nexport const mergeHeaders = (\n ...headers: Array<Required<Config>['headers'] | undefined>\n): Headers => {\n const mergedHeaders = new Headers();\n for (const header of headers) {\n if (!header) {\n continue;\n }\n\n const iterator = header instanceof Headers ? headersEntries(header) : Object.entries(header);\n\n for (const [key, value] of iterator) {\n if (value === null) {\n mergedHeaders.delete(key);\n } else if (Array.isArray(value)) {\n for (const v of value) {\n mergedHeaders.append(key, v as string);\n }\n } else if (value !== undefined) {\n // assume object headers are meant to be JSON stringified, i.e., their\n // content value in OpenAPI specification is 'application/json'\n mergedHeaders.set(\n key,\n typeof value === 'object' ? JSON.stringify(value) : (value as string),\n );\n }\n }\n }\n return mergedHeaders;\n};\n\ntype ErrInterceptor<Err, Res, Req, Options> = (\n error: Err,\n /** response may be undefined due to a network error where no response object is produced */\n response: Res | undefined,\n /** request may be undefined, because error may be from building the request object itself */\n request: Req | undefined,\n options: Options,\n) => Err | Promise<Err>;\n\ntype ReqInterceptor<Req, Options> = (request: Req, options: Options) => Req | Promise<Req>;\n\ntype ResInterceptor<Res, Req, Options> = (\n response: Res,\n request: Req,\n options: Options,\n) => Res | Promise<Res>;\n\nclass Interceptors<Interceptor> {\n fns: Array<Interceptor | null> = [];\n\n clear(): void {\n this.fns = [];\n }\n\n eject(id: number | Interceptor): void {\n const index = this.getInterceptorIndex(id);\n if (this.fns[index]) {\n this.fns[index] = null;\n }\n }\n\n exists(id: number | Interceptor): boolean {\n const index = this.getInterceptorIndex(id);\n return Boolean(this.fns[index]);\n }\n\n getInterceptorIndex(id: number | Interceptor): number {\n if (typeof id === 'number') {\n return this.fns[id] ? id : -1;\n }\n return this.fns.indexOf(id);\n }\n\n update(id: number | Interceptor, fn: Interceptor): number | Interceptor | false {\n const index = this.getInterceptorIndex(id);\n if (this.fns[index]) {\n this.fns[index] = fn;\n return id;\n }\n return false;\n }\n\n use(fn: Interceptor): number {\n this.fns.push(fn);\n return this.fns.length - 1;\n }\n}\n\nexport interface Middleware<Req, Res, Err, Options> {\n error: Interceptors<ErrInterceptor<Err, Res, Req, Options>>;\n request: Interceptors<ReqInterceptor<Req, Options>>;\n response: Interceptors<ResInterceptor<Res, Req, Options>>;\n}\n\nexport const createInterceptors = <Req, Res, Err, Options>(): Middleware<\n Req,\n Res,\n Err,\n Options\n> => ({\n error: new Interceptors<ErrInterceptor<Err, Res, Req, Options>>(),\n request: new Interceptors<ReqInterceptor<Req, Options>>(),\n response: new Interceptors<ResInterceptor<Res, Req, Options>>(),\n});\n\nconst defaultQuerySerializer = createQuerySerializer({\n allowReserved: false,\n array: {\n explode: true,\n style: 'form',\n },\n object: {\n explode: true,\n style: 'deepObject',\n },\n});\n\nconst defaultHeaders = {\n 'Content-Type': 'application/json',\n};\n\nexport const createConfig = <T extends ClientOptions = ClientOptions>(\n override: Config<Omit<ClientOptions, keyof T> & T> = {},\n): Config<Omit<ClientOptions, keyof T> & T> => ({\n ...jsonBodySerializer,\n headers: defaultHeaders,\n parseAs: 'auto',\n querySerializer: defaultQuerySerializer,\n ...override,\n});\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport { createSseClient } from '../core/serverSentEvents.gen';\nimport type { HttpMethod } from '../core/types.gen';\nimport { getValidRequestBody } from '../core/utils.gen';\nimport type { Client, Config, RequestOptions, ResolvedRequestOptions } from './types.gen';\nimport {\n buildUrl,\n createConfig,\n createInterceptors,\n getParseAs,\n mergeConfigs,\n mergeHeaders,\n setAuthParams,\n} from './utils.gen';\n\ntype ReqInit = Omit<RequestInit, 'body' | 'headers'> & {\n body?: any;\n headers: ReturnType<typeof mergeHeaders>;\n};\n\nexport const createClient = (config: Config = {}): Client => {\n let _config = mergeConfigs(createConfig(), config);\n\n const getConfig = (): Config => ({ ..._config });\n\n const setConfig = (config: Config): Config => {\n _config = mergeConfigs(_config, config);\n return getConfig();\n };\n\n const interceptors = createInterceptors<Request, Response, unknown, ResolvedRequestOptions>();\n\n const beforeRequest = async <\n TData = unknown,\n TResponseStyle extends 'data' | 'fields' = 'fields',\n ThrowOnError extends boolean = boolean,\n Url extends string = string,\n >(\n options: RequestOptions<TData, TResponseStyle, ThrowOnError, Url>,\n ) => {\n const opts = {\n ..._config,\n ...options,\n fetch: options.fetch ?? _config.fetch ?? globalThis.fetch,\n headers: mergeHeaders(_config.headers, options.headers),\n serializedBody: undefined as string | undefined,\n };\n\n if (opts.security) {\n await setAuthParams({\n ...opts,\n security: opts.security,\n });\n }\n\n if (opts.requestValidator) {\n await opts.requestValidator(opts);\n }\n\n if (opts.body !== undefined && opts.bodySerializer) {\n opts.serializedBody = opts.bodySerializer(opts.body) as string | undefined;\n }\n\n // remove Content-Type header if body is empty to avoid sending invalid requests\n if (opts.body === undefined || opts.serializedBody === '') {\n opts.headers.delete('Content-Type');\n }\n\n const resolvedOpts = opts as typeof opts &\n ResolvedRequestOptions<TResponseStyle, ThrowOnError, Url>;\n const url = buildUrl(resolvedOpts);\n\n return { opts: resolvedOpts, url };\n };\n\n const request: Client['request'] = async (options) => {\n const throwOnError = options.throwOnError ?? _config.throwOnError;\n const responseStyle = options.responseStyle ?? _config.responseStyle;\n\n let request: Request | undefined;\n let response: Response | undefined;\n\n try {\n const { opts, url } = await beforeRequest(options);\n const requestInit: ReqInit = {\n redirect: 'follow',\n ...opts,\n body: getValidRequestBody(opts),\n };\n\n request = new Request(url, requestInit);\n\n for (const fn of interceptors.request.fns) {\n if (fn) {\n request = await fn(request, opts);\n }\n }\n\n // fetch must be assigned here, otherwise it would throw the error:\n // TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation\n const _fetch = opts.fetch!;\n\n response = await _fetch(request);\n\n for (const fn of interceptors.response.fns) {\n if (fn) {\n response = await fn(response, request, opts);\n }\n }\n\n const result = {\n request,\n response,\n };\n\n if (response.ok) {\n const parseAs =\n (opts.parseAs === 'auto'\n ? getParseAs(response.headers.get('Content-Type'))\n : opts.parseAs) ?? 'json';\n\n if (response.status === 204 || response.headers.get('Content-Length') === '0') {\n let emptyData: any;\n switch (parseAs) {\n case 'arrayBuffer':\n case 'blob':\n case 'text':\n emptyData = await response[parseAs]();\n break;\n case 'formData':\n emptyData = new FormData();\n break;\n case 'stream':\n emptyData = response.body;\n break;\n case 'json':\n default:\n emptyData = {};\n break;\n }\n return opts.responseStyle === 'data'\n ? emptyData\n : {\n data: emptyData,\n ...result,\n };\n }\n\n let data: any;\n switch (parseAs) {\n case 'arrayBuffer':\n case 'blob':\n case 'formData':\n case 'text':\n data = await response[parseAs]();\n break;\n case 'json': {\n // Some servers return 200 with no Content-Length and empty body.\n // response.json() would throw; read as text and parse if non-empty.\n const text = await response.text();\n data = text ? JSON.parse(text) : {};\n break;\n }\n case 'stream':\n return opts.responseStyle === 'data'\n ? response.body\n : {\n data: response.body,\n ...result,\n };\n }\n\n if (parseAs === 'json') {\n if (opts.responseValidator) {\n await opts.responseValidator(data);\n }\n\n if (opts.responseTransformer) {\n data = await opts.responseTransformer(data);\n }\n }\n\n return opts.responseStyle === 'data'\n ? data\n : {\n data,\n ...result,\n };\n }\n\n const textError = await response.text();\n let jsonError: unknown;\n\n try {\n jsonError = JSON.parse(textError);\n } catch {\n // noop\n }\n\n throw jsonError ?? textError;\n } catch (error) {\n let finalError = error;\n\n for (const fn of interceptors.error.fns) {\n if (fn) {\n finalError = await fn(finalError, response, request, options as ResolvedRequestOptions);\n }\n }\n\n finalError = finalError || {};\n\n if (throwOnError) {\n throw finalError;\n }\n\n // TODO: we probably want to return error and improve types\n return responseStyle === 'data'\n ? undefined\n : {\n error: finalError,\n request,\n response,\n };\n }\n };\n\n const makeMethodFn = (method: Uppercase<HttpMethod>) => (options: RequestOptions) =>\n request({ ...options, method });\n\n const makeSseFn = (method: Uppercase<HttpMethod>) => async (options: RequestOptions) => {\n const { opts, url } = await beforeRequest(options);\n return createSseClient({\n ...opts,\n body: opts.body as BodyInit | null | undefined,\n method,\n onRequest: async (url, init) => {\n let request = new Request(url, init);\n for (const fn of interceptors.request.fns) {\n if (fn) {\n request = await fn(request, opts);\n }\n }\n return request;\n },\n serializedBody: getValidRequestBody(opts) as BodyInit | null | undefined,\n url,\n });\n };\n\n const _buildUrl: Client['buildUrl'] = (options) => buildUrl({ ..._config, ...options });\n\n return {\n buildUrl: _buildUrl,\n connect: makeMethodFn('CONNECT'),\n delete: makeMethodFn('DELETE'),\n get: makeMethodFn('GET'),\n getConfig,\n head: makeMethodFn('HEAD'),\n interceptors,\n options: makeMethodFn('OPTIONS'),\n patch: makeMethodFn('PATCH'),\n post: makeMethodFn('POST'),\n put: makeMethodFn('PUT'),\n request,\n setConfig,\n sse: {\n connect: makeSseFn('CONNECT'),\n delete: makeSseFn('DELETE'),\n get: makeSseFn('GET'),\n head: makeSseFn('HEAD'),\n options: makeSseFn('OPTIONS'),\n patch: makeSseFn('PATCH'),\n post: makeSseFn('POST'),\n put: makeSseFn('PUT'),\n trace: makeSseFn('TRACE'),\n },\n trace: makeMethodFn('TRACE'),\n } as Client;\n};\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport { type ClientOptions, type Config, createClient, createConfig } from './client';\nimport type { ClientOptions as ClientOptions2 } from './types.gen';\n\n/**\n * The `createClientConfig()` function will be called on client initialization\n * and the returned object will become the client's initial configuration.\n *\n * You may want to initialize your client this way instead of calling\n * `setConfig()`. This is useful for example if you're using Next.js\n * to ensure your client always has the correct values.\n */\nexport type CreateClientConfig<T extends ClientOptions = ClientOptions2> = (override?: Config<ClientOptions & T>) => Config<Required<ClientOptions> & T>;\n\nexport const client = createClient(createConfig<ClientOptions2>({ baseUrl: 'http://localhost:8000' }));\n\n// auto-init: install auth on client\nimport { installAuthOnClient } from './helpers/auth';\ninstallAuthOnClient(client);\n","// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { Client, Options as Options2, TDataShape } from './client';\nimport { client } from './client.gen';\nimport type { CfgMonitorIngestCreateData, CfgMonitorIngestCreateResponses } from './types.gen';\n\nexport type Options<TData extends TDataShape = TDataShape, ThrowOnError extends boolean = boolean, TResponse = unknown> = Options2<TData, ThrowOnError, TResponse> & {\n /**\n * You can provide a client instance returned by `createClient()` instead of\n * individual options. This might be also useful if you want to implement a\n * custom client.\n */\n client?: Client;\n /**\n * You can pass arbitrary values through the `meta` object. This can be\n * used to access values that aren't defined as part of the SDK function.\n */\n meta?: Record<string, unknown>;\n};\n\nexport class CfgMonitor {\n /**\n * Ingest browser events\n *\n * Accepts a batch of up to 50 frontend events. No authentication required — anonymous visitors can send events.\n */\n public static cfgMonitorIngestCreate<ThrowOnError extends boolean = false>(options: Options<CfgMonitorIngestCreateData, ThrowOnError>) {\n return (options.client ?? client).post<CfgMonitorIngestCreateResponses, unknown, ThrowOnError>({\n url: '/cfg/monitor/ingest/',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n });\n }\n}\n","// AUTO-GENERATED by django_generator / ts_extras.wrapper\n// Thin per-group proxy over the global `auth` store. All actual auth\n// wiring lives in `helpers/auth.ts` (one interceptor, one source of\n// truth). DO NOT EDIT — re-run `make gen`.\n\nimport { auth } from '../helpers/auth';\nimport { APILogger, type LoggerConfig } from '../helpers/logger';\n\nimport { CfgMonitor } from '../sdk.gen';\n\n\n\nexport interface APIOptions {\n /** Logger config (defaults to dev-only). */\n logger?: Partial<LoggerConfig>;\n /** Locale for `Accept-Language`. If omitted, auto-detected from cookie/navigator. */\n locale?: string;\n /** API key sent as `X-API-Key`. Falls back to NEXT_PUBLIC_API_KEY. */\n apiKey?: string;\n /** Send Django session/CSRF cookies cross-origin. Defaults to true. */\n withCredentials?: boolean;\n}\n\n/**\n * Per-group ergonomic facade.\n *\n * Calling `setToken/setApiKey/setLocale/setBaseUrl` proxies to the\n * global `auth` store — the change applies to **every** group's API\n * instance because they share the same HTTP client and interceptor.\n *\n * Use the global `auth` object directly when you don't need a group\n * facade: `import { auth } from '@your/api'; auth.setToken(jwt);`\n */\nexport class API {\n readonly logger: APILogger;\n\n readonly cfgMonitor = CfgMonitor;\n\n constructor(_baseUrl?: string, opts: APIOptions = {}) {\n this.logger = new APILogger(opts.logger);\n if (_baseUrl) auth.setBaseUrl(_baseUrl);\n if (opts.locale !== undefined) auth.setLocale(opts.locale);\n if (opts.apiKey !== undefined) auth.setApiKey(opts.apiKey);\n if (opts.withCredentials !== undefined) auth.setWithCredentials(opts.withCredentials);\n }\n\n // ── Base URL ────────────────────────────────────────────────────────────\n getBaseUrl(): string { return auth.getBaseUrl(); }\n setBaseUrl(url: string): void { auth.setBaseUrl(url); }\n\n // ── Tokens ──────────────────────────────────────────────────────────────\n getToken(): string | null { return auth.getToken(); }\n setToken(token: string | null): void { auth.setToken(token); }\n getRefreshToken(): string | null { return auth.getRefreshToken(); }\n setRefreshToken(token: string | null): void { auth.setRefreshToken(token); }\n clearToken(): void { auth.clearTokens(); }\n isAuthenticated(): boolean { return auth.isAuthenticated(); }\n\n // ── Locale / API key ────────────────────────────────────────────────────\n getLocale(): string | null { return auth.getLocale(); }\n setLocale(locale: string | null): void { auth.setLocale(locale); }\n getApiKey(): string | null { return auth.getApiKey(); }\n setApiKey(key: string | null): void { auth.setApiKey(key); }\n\n // ── 401 handling ────────────────────────────────────────────────────────\n /** Fired only on terminal 401 (after refresh+retry path is exhausted). */\n onUnauthorized(cb: ((response: Response) => void) | null): void {\n auth.onUnauthorized(cb);\n }\n /** Provide a refresh strategy. See `auth.setRefreshHandler` for the contract. */\n setRefreshHandler(\n fn: ((refreshToken: string) => Promise<{ access: string; refresh?: string } | null>) | null,\n ): void {\n auth.setRefreshHandler(fn);\n }\n}\n\nexport { CfgMonitor };\nexport { auth };\n","/**\n * BaseClient for @djangocfg/monitor\n *\n * Singleton monitorApi instance for the frontend monitor ingest endpoint.\n * Uses MemoryStorageAdapter — ingest is public (no auth tokens needed).\n */\n\nimport { API } from './generated/_cfg_monitor'\n\nexport const monitorApi = new API('')\n\nexport function configureMonitorApi(baseUrl: string): void {\n monitorApi.setBaseUrl(baseUrl)\n}\n\nexport class BaseClient {\n protected static monitorApi = monitorApi\n}\n","// This file is auto-generated by @hey-api/openapi-ts\n\nexport type ClientOptions = {\n baseUrl: 'http://localhost:8000' | (string & {});\n};\n\n/**\n * Single browser event payload.\n */\nexport type FrontendEventIngestRequest = {\n event_type: FrontendEventTypeEnum;\n message: string;\n level?: FrontendEventLevelEnum;\n stack_trace?: string;\n url?: string;\n fingerprint?: string;\n http_status?: number | null;\n http_method?: string;\n http_url?: string;\n session_id?: string;\n user_agent?: string;\n build_id?: string;\n environment?: string;\n extra?: unknown;\n project_name?: string;\n};\n\n/**\n * * `error` - Error\n * * `warning` - Warning\n * * `info` - Info\n * * `debug` - Debug\n */\nexport enum FrontendEventLevelEnum {\n ERROR = 'error',\n WARNING = 'warning',\n INFO = 'info',\n DEBUG = 'debug'\n}\n\n/**\n * * `JS_ERROR` - Js Error\n * * `NETWORK_ERROR` - Network Error\n * * `ERROR` - Error\n * * `WARNING` - Warning\n * * `PAGE_VIEW` - Page View\n * * `PERFORMANCE` - Performance\n * * `CONSOLE` - Console\n */\nexport enum FrontendEventTypeEnum {\n JS_ERROR = 'JS_ERROR',\n NETWORK_ERROR = 'NETWORK_ERROR',\n ERROR = 'ERROR',\n WARNING = 'WARNING',\n PAGE_VIEW = 'PAGE_VIEW',\n PERFORMANCE = 'PERFORMANCE',\n CONSOLE = 'CONSOLE'\n}\n\n/**\n * Batch of up to 50 browser events.\n */\nexport type IngestBatchRequest = {\n events: Array<FrontendEventIngestRequest>;\n};\n\nexport type CfgMonitorIngestCreateData = {\n body: IngestBatchRequest;\n path?: never;\n query?: never;\n url: '/cfg/monitor/ingest/';\n};\n\nexport type CfgMonitorIngestCreateResponses = {\n /**\n * Accepted\n */\n 202: unknown;\n};\n","export { monitorApi, configureMonitorApi, BaseClient } from './BaseClient'\nexport type { FrontendEventIngestRequest, IngestBatchRequest } from './generated/_cfg_monitor/types.gen'\nexport { FrontendEventTypeEnum as EventType, FrontendEventLevelEnum as EventLevel } from './generated/_cfg_monitor/types.gen'\n\n/** Ingest path — matches the generated client. Single source of truth for sendBeacon fallback. */\nexport const INGEST_PATH = '/cfg/monitor/ingest/'\n","import { monitorApi, INGEST_PATH } from '../../_api'\nimport { CfgMonitor } from '../../_api/generated/sdk.gen'\nimport type { IngestBatchRequest } from '../../_api'\n\n/**\n * Send a batch of events to the ingest endpoint.\n *\n * `useBeacon=true` is for page-unload scenarios — `fetch` with `keepalive: true`\n * lets the request survive after the document goes away (browser-supported\n * replacement for navigator.sendBeacon when we need JSON + custom headers).\n */\nexport async function sendBatch(\n batch: IngestBatchRequest,\n useBeacon = false,\n): Promise<void> {\n if (batch.events.length === 0) return\n\n if (useBeacon && typeof fetch !== 'undefined') {\n const baseUrl = monitorApi.getBaseUrl()\n await fetch(`${baseUrl}${INGEST_PATH}`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(batch),\n keepalive: true,\n credentials: 'include',\n })\n return\n }\n\n await CfgMonitor.cfgMonitorIngestCreate({ body: batch, throwOnError: true })\n}\n","/**\n * Environment utilities.\n */\n\n/** True only in next dev / jest / vitest */\nexport const isDevelopment = process.env.NODE_ENV === 'development'\n\n/** True in any non-development environment */\nexport const isProduction = !isDevelopment\n\n/** Package version */\nexport const MONITOR_VERSION: string = (process.env.MONITOR_VERSION as string) ?? '2.1.230'\n","/**\n * Internal URL patterns for the monitor transport.\n * Used to filter out self-generated errors and prevent capture→flush feedback loops.\n */\n\n/** Matches any request to the monitor ingest endpoint */\nexport const MONITOR_INGEST_PATTERN = /cfg\\/monitor\\/ingest/\n\n/** Default deduplication TTL for per-capture-source filtering (ms) */\nexport const DEFAULT_DEDUPE_TTL = 5_000\n\n/** Default deduplication TTL for global store-level filtering (ms) */\nexport const DEFAULT_DEDUPE_STORE_TTL = 30_000\n","import { computeFingerprint } from './fingerprint'\nimport { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { MONITOR_INGEST_PATTERN, DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\nconst MSG_MAX = 2000\n\nfunction truncate(s: string, max = MSG_MAX): string {\n return s.length > max ? s.slice(0, max - 1) + '…' : s\n}\n\nfunction isMonitorOwnError(msg: string, stack?: string): boolean {\n return MONITOR_INGEST_PATTERN.test(msg) || MONITOR_INGEST_PATTERN.test(stack ?? '')\n}\n\n// Hydration mismatches caused by browser extensions (Grammarly, translators, etc.)\n// These are not application bugs — filtering them prevents alert noise.\nconst HYDRATION_NOISE: RegExp[] = [\n /hydration failed/i,\n /there was an error while hydrating/i,\n /minified react error #418/i,\n /minified react error #423/i,\n /minified react error #425/i,\n /text content does not match server-rendered html/i,\n]\n\nfunction isHydrationNoise(msg: string): boolean {\n return HYDRATION_NOISE.some((p) => p.test(msg))\n}\n\n// Client-side dedup: skip re-sending the same fingerprint within dedupeTtl.\n// Protects against crash-loop pages flooding the ingest endpoint.\nconst recentFingerprints = new Map<string, number>()\n\nfunction isRecentlySent(fingerprint: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentFingerprints.get(fingerprint)\n if (last !== undefined && now - last < ttl) return true\n recentFingerprints.set(fingerprint, now)\n if (recentFingerprints.size > 100) {\n const oldest = [...recentFingerprints.entries()].sort((a, b) => a[1] - b[1])[0]\n recentFingerprints.delete(oldest[0])\n }\n return false\n}\n\nexport function installJsErrorCapture(): () => void {\n if (typeof window === 'undefined') return () => {}\n\n const onError = async (\n message: string | Event,\n source?: string,\n lineno?: number,\n colno?: number,\n error?: Error,\n ) => {\n try {\n const msg = truncate(typeof message === 'string' ? message : String(message))\n if (isHydrationNoise(msg)) return\n const stack = error?.stack ?? `at ${source}:${lineno}:${colno}`\n if (isMonitorOwnError(msg, stack)) return\n const url = window.location.href\n const fingerprint = await computeFingerprint(msg, stack, url)\n if (isRecentlySent(fingerprint)) return\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.JS_ERROR,\n level: EventLevel.ERROR,\n message: msg,\n stack_trace: stack,\n url,\n fingerprint,\n session_id: getSessionId(),\n user_agent: navigator.userAgent,\n project_name: config.project,\n environment: config.environment,\n build_id: config.buildId ?? '',\n })\n } catch { /* never crash */ }\n }\n\n const onUnhandledRejection = async (e: PromiseRejectionEvent) => {\n try {\n const reason = e.reason\n const msg = truncate(reason instanceof Error ? reason.message\n : typeof reason === 'string' ? reason\n : 'Unhandled promise rejection')\n if (isHydrationNoise(msg)) return\n const stack = reason instanceof Error ? (reason.stack ?? '') : ''\n if (isMonitorOwnError(msg, stack)) return\n const url = window.location.href\n const fingerprint = await computeFingerprint(msg, stack, url)\n if (isRecentlySent(fingerprint)) return\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.JS_ERROR,\n level: EventLevel.ERROR,\n message: msg,\n stack_trace: stack,\n url,\n fingerprint,\n session_id: getSessionId(),\n user_agent: navigator.userAgent,\n project_name: config.project,\n environment: config.environment,\n build_id: config.buildId ?? '',\n })\n } catch { /* never crash */ }\n }\n\n const errHandler = (e: ErrorEvent) => onError(e.message, e.filename, e.lineno, e.colno, e.error)\n window.addEventListener('error', errHandler)\n window.addEventListener('unhandledrejection', onUnhandledRejection)\n\n return () => {\n window.removeEventListener('error', errHandler)\n window.removeEventListener('unhandledrejection', onUnhandledRejection)\n }\n}\n","import { computeFingerprint } from './fingerprint'\nimport { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { MONITOR_INGEST_PATTERN, DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\ntype ConsoleLevel = 'warn' | 'error'\n\nconst levelMap: Record<ConsoleLevel, EventLevel> = {\n warn: EventLevel.WARNING,\n error: EventLevel.ERROR,\n}\nconst typeMap: Record<ConsoleLevel, EventType> = {\n warn: EventType.WARNING,\n error: EventType.ERROR,\n}\n\nconst ARG_MAX = 500\n\n// Dedup: skip re-sending the same console message within TTL (read from config)\nconst recentConsoleFingerprints = new Map<string, number>()\n\nfunction isRecentConsole(fingerprint: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentConsoleFingerprints.get(fingerprint)\n if (last !== undefined && now - last < ttl) return true\n recentConsoleFingerprints.set(fingerprint, now)\n if (recentConsoleFingerprints.size > 100) {\n const oldest = [...recentConsoleFingerprints.entries()].sort((a, b) => a[1] - b[1])[0]\n recentConsoleFingerprints.delete(oldest[0])\n }\n return false\n}\n\nfunction stringifyArg(a: unknown): string {\n let s: string\n if (typeof a === 'string') s = a\n else if (a instanceof Error) s = a.message\n else { try { s = JSON.stringify(a) } catch { s = String(a) } }\n return s.length > ARG_MAX ? s.slice(0, ARG_MAX - 1) + '…' : s\n}\n\nfunction stringify(args: unknown[]): string {\n return args.map(stringifyArg).join(' ')\n}\n\nasync function captureConsoleEvent(level: ConsoleLevel, args: unknown[]) {\n try {\n const message = stringify(args)\n if (MONITOR_INGEST_PATTERN.test(message)) return\n const url = typeof window !== 'undefined' ? window.location.href : ''\n const fingerprint = await computeFingerprint(message, '', url)\n if (isRecentConsole(fingerprint)) return\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: typeMap[level],\n level: levelMap[level],\n message,\n url,\n fingerprint,\n session_id: getSessionId(),\n user_agent: typeof navigator !== 'undefined' ? navigator.userAgent : '',\n project_name: config.project,\n environment: config.environment,\n })\n } catch { /* never crash */ }\n}\n\nexport function installConsoleCapture(): () => void {\n if (typeof window === 'undefined') return () => {}\n\n try {\n const g = globalThis as Record<string, unknown>\n if (g.consola && typeof (g.consola as { addReporter?: unknown }).addReporter === 'function') {\n const consolaInst = g.consola as {\n addReporter: (r: unknown) => void\n removeReporter: (r: unknown) => void\n }\n const reporter = {\n log(logObj: { level: number; args: unknown[] }) {\n if (logObj.level === 1) captureConsoleEvent('error', logObj.args)\n else if (logObj.level === 2) captureConsoleEvent('warn', logObj.args)\n },\n }\n consolaInst.addReporter(reporter)\n return () => consolaInst.removeReporter(reporter)\n }\n } catch { /* consola not available */ }\n\n const origWarn = console.warn.bind(console)\n const origError = console.error.bind(console)\n console.warn = (...args: unknown[]) => { origWarn(...args); captureConsoleEvent('warn', args) }\n console.error = (...args: unknown[]) => { origError(...args); captureConsoleEvent('error', args) }\n return () => { console.warn = origWarn; console.error = origError }\n}\n","import { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\n// Dedup: skip re-sending the same validation error within TTL (read from config)\nconst recentValidations = new Map<string, number>()\n\nfunction isRecentValidation(key: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentValidations.get(key)\n if (last !== undefined && now - last < ttl) return true\n recentValidations.set(key, now)\n if (recentValidations.size > 50) {\n for (const [k, ts] of recentValidations) {\n if (now - ts > ttl) recentValidations.delete(k)\n }\n }\n return false\n}\n\ninterface ValidationErrorDetail {\n operation: string\n path: string\n method: string\n error: { message: string }\n}\n\nexport function installValidationCapture(): () => void {\n if (typeof window === 'undefined') return () => {}\n\n const handler = (event: Event) => {\n if (!(event instanceof CustomEvent)) return\n try {\n const detail = event.detail as ValidationErrorDetail\n const dedupeKey = `${detail.operation}:${detail.path}:${detail.method}`\n if (isRecentValidation(dedupeKey)) return\n const { config } = monitorStore.getState()\n const rawMsg = `Zod validation error in ${detail.operation}: ${detail.error?.message ?? 'unknown'}`\n monitorStore.getState().push({\n event_type: EventType.WARNING,\n level: EventLevel.WARNING,\n message: rawMsg.length > 500 ? rawMsg.slice(0, 499) + '…' : rawMsg,\n url: window.location.href,\n http_method: detail.method,\n http_url: detail.path,\n session_id: getSessionId(),\n user_agent: navigator.userAgent,\n project_name: config.project,\n environment: config.environment,\n extra: { operation: detail.operation, path: detail.path, method: detail.method },\n })\n } catch { /* never crash */ }\n }\n\n window.addEventListener('zod-validation-error', handler)\n return () => window.removeEventListener('zod-validation-error', handler)\n}\n","import { getSessionId } from './session'\nimport { monitorStore } from '../store'\nimport { DEFAULT_DEDUPE_TTL } from '../constants'\nimport { EventType, EventLevel } from '../../_api'\n\n// Dedup: skip re-sending the same network error within TTL (read from config)\nconst recentNetworkErrors = new Map<string, number>()\n\nfunction isRecentNetwork(key: string): boolean {\n const ttl = monitorStore.getState().config.dedupeTtl ?? DEFAULT_DEDUPE_TTL\n const now = Date.now()\n const last = recentNetworkErrors.get(key)\n if (last !== undefined && now - last < ttl) return true\n recentNetworkErrors.set(key, now)\n if (recentNetworkErrors.size > 100) {\n for (const [k, ts] of recentNetworkErrors) {\n if (now - ts > ttl) recentNetworkErrors.delete(k)\n }\n }\n return false\n}\n\nexport async function monitoredFetch(\n input: RequestInfo | URL,\n init?: RequestInit,\n): Promise<Response> {\n const url = typeof input === 'string' ? input : input instanceof URL ? input.href : input.url\n const method = (init?.method ?? 'GET').toUpperCase()\n\n try {\n const response = await fetch(input, init)\n if (!response.ok) {\n const netKey = `${response.status}:${method}:${url}`\n if (isRecentNetwork(netKey)) return response\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.NETWORK_ERROR,\n level: response.status >= 500 ? EventLevel.ERROR : EventLevel.WARNING,\n message: `HTTP ${response.status} ${response.statusText} — ${method} ${url}`,\n url: typeof window !== 'undefined' ? window.location.href : '',\n http_status: response.status,\n http_method: method,\n http_url: url,\n session_id: getSessionId(),\n user_agent: typeof navigator !== 'undefined' ? navigator.userAgent : '',\n project_name: config.project,\n environment: config.environment,\n })\n }\n return response\n } catch (err) {\n const errMsg = err instanceof Error ? err.message : 'network-error'\n const netKey = `err:${errMsg.slice(0, 50)}:${method}:${url}`\n if (!isRecentNetwork(netKey)) {\n const { config } = monitorStore.getState()\n monitorStore.getState().push({\n event_type: EventType.NETWORK_ERROR,\n level: EventLevel.ERROR,\n message: err instanceof Error ? err.message : `Network error — ${method} ${url}`,\n url: typeof window !== 'undefined' ? window.location.href : '',\n http_method: method,\n http_url: url,\n session_id: getSessionId(),\n user_agent: typeof navigator !== 'undefined' ? navigator.userAgent : '',\n project_name: config.project,\n environment: config.environment,\n })\n }\n throw err\n }\n}\n","'use client'\n\n/**\n * MonitorProvider\n *\n * Initialises FrontendMonitor on mount and tears it down on unmount.\n * Drop it once into your root layout — no other setup needed.\n *\n * @example\n * // app/layout.tsx\n * import { MonitorProvider } from '@djangocfg/monitor/client'\n *\n * export default function RootLayout({ children }) {\n * return (\n * <html>\n * <body>\n * <MonitorProvider project=\"my-app\" environment={process.env.NODE_ENV} />\n * {children}\n * </body>\n * </html>\n * )\n * }\n */\n\nimport { memo, useEffect } from 'react'\nimport { FrontendMonitor } from './index'\nimport { initWindowMonitor } from './window'\nimport type { MonitorConfig } from '../types'\n\nexport interface MonitorProviderProps extends MonitorConfig {\n /** Optional: render children inside the provider (or use as a standalone leaf) */\n children?: React.ReactNode\n}\n\n/**\n * MonitorProvider — initialises FrontendMonitor on mount.\n *\n * Memoised: re-renders only when `children` or config props change.\n * The init effect runs once on mount (config is captured in closure).\n */\nfunction MonitorProviderRaw({ children, ...config }: MonitorProviderProps) {\n useEffect(() => {\n FrontendMonitor.init(config)\n initWindowMonitor()\n return () => FrontendMonitor.destroy()\n }, []) // eslint-disable-line react-hooks/exhaustive-deps\n\n return children ?? null\n}\n\nexport const MonitorProvider = memo(MonitorProviderRaw)\n","/**\n * window.monitor — global debug API for browser console testing.\n *\n * Automatically installed by MonitorProvider after FrontendMonitor.init().\n * Allows manual event firing from DevTools without importing the module.\n *\n * @example\n * // In browser DevTools console:\n * window.monitor.error('Something broke')\n * window.monitor.warn('Low disk space', { extra: 'context' })\n * window.monitor.network(404, 'GET', '/api/users/')\n * window.monitor.flush()\n * window.monitor.status()\n */\n\nimport { monitorStore } from './store'\nimport { EventType, EventLevel } from '../_api'\nimport { getSessionId } from './capture/session'\nimport { MONITOR_VERSION } from './utils/env'\nimport type { MonitorEvent } from '../types'\n\nexport interface WindowMonitorAPI {\n /** Capture a custom error event */\n error(message: string, extra?: Record<string, unknown>): void\n /** Capture a custom warning event */\n warn(message: string, extra?: Record<string, unknown>): void\n /** Capture a custom info event */\n info(message: string, extra?: Record<string, unknown>): void\n /** Capture a network error event */\n network(status: number, method: string, url: string, extra?: Record<string, unknown>): void\n /** Capture a raw event (full control) */\n capture(event: MonitorEvent): void\n /** Force-flush the event buffer to backend */\n flush(): void\n /** Show current monitor state (config + buffer size) */\n status(): void\n}\n\ndeclare global {\n interface Window {\n monitor?: WindowMonitorAPI\n }\n}\n\nfunction makeEvent(\n type: MonitorEvent['event_type'],\n level: MonitorEvent['level'],\n message: string,\n extra?: Record<string, unknown>,\n): MonitorEvent {\n const state = monitorStore.getState()\n const cfg = state.config\n return {\n event_type: type,\n level,\n message,\n session_id: getSessionId(),\n url: window.location.href,\n user_agent: navigator.userAgent,\n project_name: cfg.project ?? '',\n environment: cfg.environment ?? '',\n ...(extra ? { extra } : {}),\n }\n}\n\nexport function initWindowMonitor(): void {\n if (typeof window === 'undefined') return\n\n const api: WindowMonitorAPI = {\n error(message, extra) {\n monitorStore.getState().push(makeEvent(EventType.JS_ERROR, EventLevel.ERROR, message, extra))\n console.log('[monitor] error captured →', message)\n },\n\n warn(message, extra) {\n monitorStore.getState().push(makeEvent(EventType.WARNING, EventLevel.WARNING, message, extra))\n console.log('[monitor] warn captured →', message)\n },\n\n info(message, extra) {\n monitorStore.getState().push(makeEvent(EventType.WARNING, EventLevel.INFO, message, extra))\n console.log('[monitor] info captured →', message)\n },\n\n network(status, method, url, extra) {\n const event = makeEvent(\n EventType.NETWORK_ERROR,\n status >= 500 ? EventLevel.ERROR : EventLevel.WARNING,\n `${method} ${url} → ${status}`,\n extra,\n )\n monitorStore.getState().push({ ...event, http_status: status, http_method: method, http_url: url })\n console.log('[monitor] network captured →', method, url, status)\n },\n\n capture(event) {\n monitorStore.getState().push(event)\n console.log('[monitor] event captured →', event)\n },\n\n flush() {\n monitorStore.getState().flush()\n console.log('[monitor] flushed')\n },\n\n status() {\n const state = monitorStore.getState()\n console.group('[monitor] status')\n console.log('sdk version:', MONITOR_VERSION)\n console.log('build_id:', state.config.buildId ?? `sdk:${MONITOR_VERSION}`)\n console.log('config:', state.config)\n console.log('buffer size:', state.buffer.length)\n console.log('initialized:', state.initialized)\n console.log('session_id:', getSessionId())\n console.groupEnd()\n },\n }\n\n window.monitor = api\n}\n","'use client'\n\n/**\n * useDebugMode — shared debug mode detection hook.\n *\n * Logic:\n * - development: always true (no localStorage needed)\n * - production:\n * - ?debug=1 in URL → persist to localStorage, remove param from URL\n * - ?debug=0 in URL → clear localStorage, disable debug mode\n * - localStorage.__debug_mode__ === '1' → true\n * - otherwise → false\n *\n * @example\n * const isDebug = useDebugMode()\n */\n\nimport { useEffect, useState } from 'react'\nimport { isDevelopment } from '../utils/env'\n\nconst LS_KEY = '__debug_mode__'\n\nfunction readFromStorage(): boolean {\n try {\n return localStorage.getItem(LS_KEY) === '1'\n } catch {\n return false\n }\n}\n\nfunction persistToStorage(): void {\n try {\n localStorage.setItem(LS_KEY, '1')\n } catch {\n // ignore — private browsing or quota exceeded\n }\n}\n\nfunction clearFromStorage(): void {\n try {\n localStorage.removeItem(LS_KEY)\n } catch {\n // ignore\n }\n}\n\nfunction consumeDebugParam(): boolean | null {\n if (typeof window === 'undefined') return null\n const params = new URLSearchParams(window.location.search)\n const value = params.get('debug')\n if (value === null) return null\n\n if (value === '1') {\n persistToStorage()\n } else {\n // ?debug=0 or any other value → explicitly disable and clear stored flag\n clearFromStorage()\n }\n\n params.delete('debug')\n const newUrl = `${window.location.pathname}${params.toString() ? `?${params.toString()}` : ''}${window.location.hash}`\n window.history.replaceState(null, '', newUrl)\n return value === '1'\n}\n\nexport function useDebugMode(): boolean {\n // In development, always true — no side effects needed\n if (isDevelopment) return true\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const [isDebug, setIsDebug] = useState(false)\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useEffect(() => {\n const fromUrl = consumeDebugParam()\n if (fromUrl !== null) {\n setIsDebug(fromUrl)\n return\n }\n setIsDebug(readFromStorage())\n }, [])\n\n return isDebug\n}\n"],"mappings":"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","names":["COOKIE_MAX_AGE","client","joinedValues","auth","auth","config","request","url","FrontendEventLevelEnum","FrontendEventTypeEnum","import_react"]}