farvex 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/index.cjs +57 -6
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +57 -6
- package/dist/index.js.map +1 -1
- package/dist/react/index.cjs.map +1 -1
- package/dist/react/index.d.cts +5 -4
- package/dist/react/index.d.ts +5 -4
- package/dist/react/index.js.map +1 -1
- package/dist/{types-DhJEeeui.d.cts → types-Dgwrb3rf.d.cts} +1 -1
- package/dist/{types-DhJEeeui.d.ts → types-Dgwrb3rf.d.ts} +1 -1
- package/package.json +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/api/generated/core/bodySerializer.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/client.ts","../src/api/generated/client.gen.ts","../src/api/generated/sdk.gen.ts","../src/core/events.ts","../src/core/realtime.ts","../src/core/store.ts","../src/core/client.ts"],"names":["joinedValues","config","request","url","client"],"mappings":"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","file":"index.js","sourcesContent":["// 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\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 async function setAuthParams(\n options: Pick<RequestOptions, 'auth' | 'query' | 'security'> & {\n headers: Headers;\n },\n): Promise<void> {\n for (const auth of options.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(opts);\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","import { createClient, type Client } from \"./generated/client\";\nimport type { Problem } from \"./generated\";\n\nexport type Auth = {\n getAccessToken: () => string | Promise<string>;\n onUnauthorized?: () => void | Promise<void>;\n};\n\nexport type ApiConfig = {\n apiUrl: string;\n auth: Auth;\n fetch?: typeof fetch;\n};\n\nexport class CallpadError extends Error {\n constructor(\n readonly code: string,\n message: string,\n readonly status?: number,\n ) {\n super(message);\n this.name = \"CallpadError\";\n }\n}\n\ntype ApiResult<T> =\n | {\n data: T;\n error?: undefined;\n response?: Response;\n }\n | {\n data?: undefined;\n error: unknown;\n response?: Response;\n };\n\nexport const apiClient = (config: ApiConfig): Client => {\n const client = createClient({\n baseUrl: config.apiUrl,\n fetch: config.fetch,\n });\n\n client.interceptors.request.use(async (request) => {\n const token = await config.auth.getAccessToken();\n request.headers.set(\"Authorization\", `Bearer ${token}`);\n return request;\n });\n\n return client;\n};\n\nexport const unwrap = async <T>(\n result: Promise<ApiResult<T>>,\n auth?: Auth,\n): Promise<NonNullable<T>> => {\n const response = await result;\n\n if (response.error !== undefined) {\n if (response.response?.status === 401) {\n await auth?.onUnauthorized?.();\n }\n throw errorFrom(response.error, response.response?.status);\n }\n\n if (response.data === undefined) {\n throw new CallpadError(\"empty_response\", \"API response did not include data\");\n }\n\n return response.data as NonNullable<T>;\n};\n\nconst errorFrom = (error: unknown, status?: number): CallpadError => {\n if (isProblem(error)) {\n return new CallpadError(error.code, error.message, status);\n }\n if (error instanceof Error) {\n return new CallpadError(\"request_failed\", error.message, status);\n }\n if (typeof error === \"string\" && error.length > 0) {\n return new CallpadError(\"request_failed\", error, status);\n }\n return new CallpadError(\"request_failed\", \"Request failed\", status);\n};\n\nconst isProblem = (value: unknown): value is Problem => {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n const problem = value as Partial<Problem>;\n return typeof problem.code === \"string\" && typeof problem.message === \"string\";\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>());\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 { AcceptSessionParticipantData, AcceptSessionParticipantErrors, AcceptSessionParticipantResponses, ActivateNumberData, ActivateNumberErrors, ActivateNumberResponses, AddContactNoteData, AddContactNoteErrors, AddContactNoteResponses, AddSessionParticipantData, AddSessionParticipantErrors, AddSessionParticipantResponses, AssignNumberData, AssignNumberErrors, AssignNumberResponses, BulkActivateNumbersData, BulkActivateNumbersErrors, BulkActivateNumbersResponses, BulkCreateAgentsData, BulkCreateAgentsErrors, BulkCreateAgentsResponses, BulkSuspendNumbersData, BulkSuspendNumbersErrors, BulkSuspendNumbersResponses, CancelNumberSubscriptionData, CancelNumberSubscriptionErrors, CancelNumberSubscriptionResponses, CreateAgentData, CreateAgentErrors, CreateAgentResponses, CreateBillingTopupData, CreateBillingTopupErrors, CreateBillingTopupResponses, CreateCallNoteData, CreateCallNoteErrors, CreateCallNoteResponses, CreateCallRecordingUrlData, CreateCallRecordingUrlErrors, CreateCallRecordingUrlResponses, CreateCallTaskData, CreateCallTaskErrors, CreateCallTaskResponses, CreateContactData, CreateContactErrors, CreateContactResponses, CreateExtensionData, CreateExtensionErrors, CreateExtensionResponses, CreateSessionData, CreateSessionErrors, CreateSessionResponses, CreateSessionTokenData, CreateSessionTokenErrors, CreateSessionTokenResponses, CreateTeamData, CreateTeamErrors, CreateTeamResponses, DeleteAgentData, DeleteAgentErrors, DeleteAgentResponses, DeleteBillingPaymentMethodData, DeleteBillingPaymentMethodErrors, DeleteBillingPaymentMethodResponses, DeleteCallNoteData, DeleteCallNoteErrors, DeleteCallNoteResponses, DeleteContactData, DeleteContactErrors, DeleteContactNoteData, DeleteContactNoteErrors, DeleteContactNoteResponses, DeleteContactResponses, DeleteExtensionData, DeleteExtensionErrors, DeleteExtensionResponses, DeleteTeamData, DeleteTeamErrors, DeleteTeamResponses, DuplicateTeamData, DuplicateTeamErrors, DuplicateTeamResponses, EndSessionData, EndSessionErrors, EndSessionResponses, EstimateBillingVoiceChargeData, EstimateBillingVoiceChargeErrors, EstimateBillingVoiceChargeResponses, ExportBillingTransactionsData, ExportBillingTransactionsErrors, ExportBillingTransactionsResponses, ExportVendorCallsData, ExportVendorCallsErrors, ExportVendorCallsResponses, GetAgentData, GetAgentErrors, GetAgentResponses, GetAgentStatsData, GetAgentStatsErrors, GetAgentStatsResponses, GetBillingTopupData, GetBillingTopupErrors, GetBillingTopupResponses, GetBillingWalletData, GetBillingWalletErrors, GetBillingWalletResponses, GetContactData, GetContactErrors, GetContactResponses, GetHealthzData, GetHealthzErrors, GetHealthzResponses, GetMyCallData, GetMyCallErrors, GetMyCallResponses, GetNumberData, GetNumberErrors, GetNumberResponses, GetNumberSubscriptionData, GetNumberSubscriptionErrors, GetNumberSubscriptionResponses, GetReadyzData, GetReadyzErrors, GetReadyzResponses, GetRealtimeTokenData, GetRealtimeTokenErrors, GetRealtimeTokenResponses, GetRoutingPolicyData, GetRoutingPolicyErrors, GetRoutingPolicyResponses, GetSessionData, GetSessionErrors, GetSessionResponses, GetTeamData, GetTeamErrors, GetTeamResponses, GetTeamStatsData, GetTeamStatsErrors, GetTeamStatsResponses, GetTelephoneData, GetTelephoneErrors, GetTelephoneResponses, GetVendorCallData, GetVendorCallErrors, GetVendorCallResponses, GetVendorData, GetVendorErrors, GetVendorMemberData, GetVendorMemberErrors, GetVendorMemberResponses, GetVendorResponses, LeaveSessionData, LeaveSessionErrors, LeaveSessionResponses, ListAgentsData, ListAgentsErrors, ListAgentsResponses, ListBillingPaymentMethodsData, ListBillingPaymentMethodsErrors, ListBillingPaymentMethodsResponses, ListBillingTopupsData, ListBillingTopupsErrors, ListBillingTopupsResponses, ListBillingTransactionsData, ListBillingTransactionsErrors, ListBillingTransactionsResponses, ListCallNotesData, ListCallNotesErrors, ListCallNotesResponses, ListCallRecordingsData, ListCallRecordingsErrors, ListCallRecordingsResponses, ListCallTasksData, ListCallTasksErrors, ListCallTasksResponses, ListContactNotesData, ListContactNotesErrors, ListContactNotesResponses, ListContactsData, ListContactsErrors, ListContactsResponses, ListExtensionsData, ListExtensionsErrors, ListExtensionsResponses, ListMyCallsData, ListMyCallsErrors, ListMyCallsResponses, ListNumberCatalogData, ListNumberCatalogErrors, ListNumberCatalogResponses, ListNumbersData, ListNumbersErrors, ListNumbersResponses, ListSessionsData, ListSessionsErrors, ListSessionsResponses, ListTeamsData, ListTeamsErrors, ListTeamsResponses, ListVendorCallsData, ListVendorCallsErrors, ListVendorCallsResponses, ListVendorMembersData, ListVendorMembersErrors, ListVendorMembersResponses, PurchaseNumbersData, PurchaseNumbersErrors, PurchaseNumbersResponses, PutRoutingPolicyData, PutRoutingPolicyErrors, PutRoutingPolicyResponses, QuoteNumberPurchaseData, QuoteNumberPurchaseErrors, QuoteNumberPurchaseResponses, RejectSessionParticipantData, RejectSessionParticipantErrors, RejectSessionParticipantResponses, RemoveSessionParticipantData, RemoveSessionParticipantErrors, RemoveSessionParticipantResponses, StartRecordingData, StartRecordingErrors, StartRecordingResponses, StopRecordingData, StopRecordingErrors, StopRecordingResponses, SuspendNumberData, SuspendNumberErrors, SuspendNumberResponses, SyncTelephoneData, SyncTelephoneErrors, SyncTelephoneResponses, UnassignNumberData, UnassignNumberErrors, UnassignNumberResponses, UpdateAgentData, UpdateAgentErrors, UpdateAgentResponses, UpdateBillingWalletSettingsData, UpdateBillingWalletSettingsErrors, UpdateBillingWalletSettingsResponses, UpdateCallNoteData, UpdateCallNoteErrors, UpdateCallNoteResponses, UpdateCallTaskData, UpdateCallTaskErrors, UpdateCallTaskResponses, UpdateCallWrapUpData, UpdateCallWrapUpErrors, UpdateCallWrapUpResponses, UpdateContactData, UpdateContactErrors, UpdateContactResponses, UpdateExtensionData, UpdateExtensionErrors, UpdateExtensionResponses, UpdateTeamData, UpdateTeamErrors, UpdateTeamResponses, UpdateTelephoneSettingsData, UpdateTelephoneSettingsErrors, UpdateTelephoneSettingsResponses, VerifyBillingTopupData, VerifyBillingTopupErrors, VerifyBillingTopupResponses } 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\n/**\n * health\n *\n * Report process liveness without checking external dependencies.\n */\nexport const getHealthz = <ThrowOnError extends boolean = false>(options?: Options<GetHealthzData, ThrowOnError>) => (options?.client ?? client).get<GetHealthzResponses, GetHealthzErrors, ThrowOnError>({ url: '/healthz', ...options });\n\n/**\n * readiness\n *\n * Check whether required database connections are reachable.\n */\nexport const getReadyz = <ThrowOnError extends boolean = false>(options?: Options<GetReadyzData, ThrowOnError>) => (options?.client ?? client).get<GetReadyzResponses, GetReadyzErrors, ThrowOnError>({ url: '/readyz', ...options });\n\n/**\n * realtime token\n *\n * Issue a Centrifugo connection token for the authenticated user.\n */\nexport const getRealtimeToken = <ThrowOnError extends boolean = false>(options?: Options<GetRealtimeTokenData, ThrowOnError>) => (options?.client ?? client).get<GetRealtimeTokenResponses, GetRealtimeTokenErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/realtime/token',\n ...options\n});\n\n/**\n * list sessions\n *\n * List live sessions visible to the authenticated user.\n */\nexport const listSessions = <ThrowOnError extends boolean = false>(options?: Options<ListSessionsData, ThrowOnError>) => (options?.client ?? client).get<ListSessionsResponses, ListSessionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions',\n ...options\n});\n\n/**\n * get session\n *\n * Get one live session visible to the authenticated user.\n */\nexport const getSession = <ThrowOnError extends boolean = false>(options: Options<GetSessionData, ThrowOnError>) => (options.client ?? client).get<GetSessionResponses, GetSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}',\n ...options\n});\n\n/**\n * create join token\n *\n * Issue a LiveKit join grant for the current participant.\n */\nexport const createSessionToken = <ThrowOnError extends boolean = false>(options: Options<CreateSessionTokenData, ThrowOnError>) => (options.client ?? client).post<CreateSessionTokenResponses, CreateSessionTokenErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/tokens',\n ...options\n});\n\n/**\n * leave session\n *\n * Mark the current participant as left.\n */\nexport const leaveSession = <ThrowOnError extends boolean = false>(options: Options<LeaveSessionData, ThrowOnError>) => (options.client ?? client).post<LeaveSessionResponses, LeaveSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/leave',\n ...options\n});\n\n/**\n * end session\n *\n * End a full session as a vendor-side host.\n */\nexport const endSession = <ThrowOnError extends boolean = false>(options: Options<EndSessionData, ThrowOnError>) => (options.client ?? client).post<EndSessionResponses, EndSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/end',\n ...options\n});\n\n/**\n * start recording\n *\n * Start the vendor-side call recording for an active session.\n */\nexport const startRecording = <ThrowOnError extends boolean = false>(options: Options<StartRecordingData, ThrowOnError>) => (options.client ?? client).post<StartRecordingResponses, StartRecordingErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/recording/start',\n ...options\n});\n\n/**\n * stop recording\n *\n * Stop the current manual call recording for an active session.\n */\nexport const stopRecording = <ThrowOnError extends boolean = false>(options: Options<StopRecordingData, ThrowOnError>) => (options.client ?? client).post<StopRecordingResponses, StopRecordingErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/recording/stop',\n ...options\n});\n\n/**\n * add participant\n *\n * Add a contact or phone participant to a controllable session.\n */\nexport const addSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<AddSessionParticipantData, ThrowOnError>) => (options.client ?? client).post<AddSessionParticipantResponses, AddSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * remove participant\n *\n * Remove a participant from a controllable session.\n */\nexport const removeSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<RemoveSessionParticipantData, ThrowOnError>) => (options.client ?? client).delete<RemoveSessionParticipantResponses, RemoveSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants/{participantId}',\n ...options\n});\n\n/**\n * accept invite\n *\n * Accept the current user's invited participant.\n */\nexport const acceptSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<AcceptSessionParticipantData, ThrowOnError>) => (options.client ?? client).post<AcceptSessionParticipantResponses, AcceptSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants/{participantId}/accept',\n ...options\n});\n\n/**\n * reject invite\n *\n * Reject the current user's invited participant.\n */\nexport const rejectSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<RejectSessionParticipantData, ThrowOnError>) => (options.client ?? client).post<RejectSessionParticipantResponses, RejectSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants/{participantId}/reject',\n ...options\n});\n\n/**\n * create session\n *\n * Create a live voice session for the vendor.\n */\nexport const createSession = <ThrowOnError extends boolean = false>(options: Options<CreateSessionData, ThrowOnError>) => (options.client ?? client).post<CreateSessionResponses, CreateSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/sessions',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list my calls\n *\n * List call history visible to the authenticated user.\n */\nexport const listMyCalls = <ThrowOnError extends boolean = false>(options?: Options<ListMyCallsData, ThrowOnError>) => (options?.client ?? client).get<ListMyCallsResponses, ListMyCallsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/calls',\n ...options\n});\n\n/**\n * get my call\n *\n * Get one call visible to the authenticated user.\n */\nexport const getMyCall = <ThrowOnError extends boolean = false>(options: Options<GetMyCallData, ThrowOnError>) => (options.client ?? client).get<GetMyCallResponses, GetMyCallErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/calls/{callId}',\n ...options\n});\n\n/**\n * list vendor calls\n *\n * List vendor call history for an authenticated vendor member.\n */\nexport const listVendorCalls = <ThrowOnError extends boolean = false>(options: Options<ListVendorCallsData, ThrowOnError>) => (options.client ?? client).get<ListVendorCallsResponses, ListVendorCallsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls',\n ...options\n});\n\n/**\n * export vendor calls\n *\n * Export vendor call history as CSV using the same filters as the list endpoint.\n */\nexport const exportVendorCalls = <ThrowOnError extends boolean = false>(options: Options<ExportVendorCallsData, ThrowOnError>) => (options.client ?? client).get<ExportVendorCallsResponses, ExportVendorCallsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/export',\n ...options\n});\n\n/**\n * get vendor call\n *\n * Get one vendor call by ID.\n */\nexport const getVendorCall = <ThrowOnError extends boolean = false>(options: Options<GetVendorCallData, ThrowOnError>) => (options.client ?? client).get<GetVendorCallResponses, GetVendorCallErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}',\n ...options\n});\n\n/**\n * list call recordings\n *\n * List user-facing recordings for one vendor call.\n */\nexport const listCallRecordings = <ThrowOnError extends boolean = false>(options: Options<ListCallRecordingsData, ThrowOnError>) => (options.client ?? client).get<ListCallRecordingsResponses, ListCallRecordingsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/recordings',\n ...options\n});\n\n/**\n * create recording URL\n *\n * Create a short-lived playback URL for an available call recording.\n */\nexport const createCallRecordingUrl = <ThrowOnError extends boolean = false>(options: Options<CreateCallRecordingUrlData, ThrowOnError>) => (options.client ?? client).post<CreateCallRecordingUrlResponses, CreateCallRecordingUrlErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/recordings/{recordingId}/url',\n ...options\n});\n\n/**\n * wrap up call\n *\n * Update vendor wrap-up fields. Omitted fields are unchanged.\n */\nexport const updateCallWrapUp = <ThrowOnError extends boolean = false>(options: Options<UpdateCallWrapUpData, ThrowOnError>) => (options.client ?? client).patch<UpdateCallWrapUpResponses, UpdateCallWrapUpErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/wrap-up',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list call notes\n *\n * List vendor notes attached to a call.\n */\nexport const listCallNotes = <ThrowOnError extends boolean = false>(options: Options<ListCallNotesData, ThrowOnError>) => (options.client ?? client).get<ListCallNotesResponses, ListCallNotesErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes',\n ...options\n});\n\n/**\n * create call note\n *\n * Add a vendor note to a call.\n */\nexport const createCallNote = <ThrowOnError extends boolean = false>(options: Options<CreateCallNoteData, ThrowOnError>) => (options.client ?? client).post<CreateCallNoteResponses, CreateCallNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete call note\n *\n * Delete a vendor call note.\n */\nexport const deleteCallNote = <ThrowOnError extends boolean = false>(options: Options<DeleteCallNoteData, ThrowOnError>) => (options.client ?? client).delete<DeleteCallNoteResponses, DeleteCallNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes/{noteId}',\n ...options\n});\n\n/**\n * update call note\n *\n * Update a vendor call note.\n */\nexport const updateCallNote = <ThrowOnError extends boolean = false>(options: Options<UpdateCallNoteData, ThrowOnError>) => (options.client ?? client).put<UpdateCallNoteResponses, UpdateCallNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes/{noteId}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list call tasks\n *\n * List vendor follow-up tasks attached to a call.\n */\nexport const listCallTasks = <ThrowOnError extends boolean = false>(options: Options<ListCallTasksData, ThrowOnError>) => (options.client ?? client).get<ListCallTasksResponses, ListCallTasksErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/tasks',\n ...options\n});\n\n/**\n * create call task\n *\n * Create a vendor follow-up task for a call.\n */\nexport const createCallTask = <ThrowOnError extends boolean = false>(options: Options<CreateCallTaskData, ThrowOnError>) => (options.client ?? client).post<CreateCallTaskResponses, CreateCallTaskErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/tasks',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * update call task\n *\n * Update a vendor call task.\n */\nexport const updateCallTask = <ThrowOnError extends boolean = false>(options: Options<UpdateCallTaskData, ThrowOnError>) => (options.client ?? client).put<UpdateCallTaskResponses, UpdateCallTaskErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/tasks/{taskId}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * telephone settings\n *\n * Get vendor telephone settings and provider sync status.\n */\nexport const getTelephone = <ThrowOnError extends boolean = false>(options: Options<GetTelephoneData, ThrowOnError>) => (options.client ?? client).get<GetTelephoneResponses, GetTelephoneErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/telephone',\n ...options\n});\n\n/**\n * update telephone settings\n *\n * Update vendor telephone enablement and audio processing settings.\n */\nexport const updateTelephoneSettings = <ThrowOnError extends boolean = false>(options: Options<UpdateTelephoneSettingsData, ThrowOnError>) => (options.client ?? client).patch<UpdateTelephoneSettingsResponses, UpdateTelephoneSettingsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/telephone/settings',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * sync telephone\n *\n * Sync LiveKit SIP resources for the vendor and return provider status.\n */\nexport const syncTelephone = <ThrowOnError extends boolean = false>(options: Options<SyncTelephoneData, ThrowOnError>) => (options.client ?? client).post<SyncTelephoneResponses, SyncTelephoneErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/telephone/sync',\n ...options\n});\n\n/**\n * get routing policy\n *\n * Get the routing policy for a team or agent target. If no policy is saved, returns the default open policy with a null id.\n */\nexport const getRoutingPolicy = <ThrowOnError extends boolean = false>(options: Options<GetRoutingPolicyData, ThrowOnError>) => (options.client ?? client).get<GetRoutingPolicyResponses, GetRoutingPolicyErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/routing/policies/{targetKind}/{targetId}',\n ...options\n});\n\n/**\n * replace routing policy\n *\n * Replace the full routing policy for a team or agent target.\n */\nexport const putRoutingPolicy = <ThrowOnError extends boolean = false>(options: Options<PutRoutingPolicyData, ThrowOnError>) => (options.client ?? client).put<PutRoutingPolicyResponses, PutRoutingPolicyErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/routing/policies/{targetKind}/{targetId}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list contacts\n *\n * Paginated list of contacts for the vendor, with search, filters, and sorting.\n */\nexport const listContacts = <ThrowOnError extends boolean = false>(options: Options<ListContactsData, ThrowOnError>) => (options.client ?? client).get<ListContactsResponses, ListContactsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts',\n ...options\n});\n\n/**\n * create contact\n *\n * Create a vendor contact with optional tags and inline notes.\n */\nexport const createContact = <ThrowOnError extends boolean = false>(options: Options<CreateContactData, ThrowOnError>) => (options.client ?? client).post<CreateContactResponses, CreateContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete contact\n *\n * Delete a contact from the vendor contact list.\n */\nexport const deleteContact = <ThrowOnError extends boolean = false>(options: Options<DeleteContactData, ThrowOnError>) => (options.client ?? client).delete<DeleteContactResponses, DeleteContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}',\n ...options\n});\n\n/**\n * get contact\n *\n * Get a full contact profile. Notes are fetched separately.\n */\nexport const getContact = <ThrowOnError extends boolean = false>(options: Options<GetContactData, ThrowOnError>) => (options.client ?? client).get<GetContactResponses, GetContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}',\n ...options\n});\n\n/**\n * update contact\n *\n * Update contact fields such as profile, status, owner, and tags.\n */\nexport const updateContact = <ThrowOnError extends boolean = false>(options: Options<UpdateContactData, ThrowOnError>) => (options.client ?? client).put<UpdateContactResponses, UpdateContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list notes\n *\n * Paginated notes attached to a contact.\n */\nexport const listContactNotes = <ThrowOnError extends boolean = false>(options: Options<ListContactNotesData, ThrowOnError>) => (options.client ?? client).get<ListContactNotesResponses, ListContactNotesErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}/notes',\n ...options\n});\n\n/**\n * add note\n *\n * Add a timestamped note to a contact.\n */\nexport const addContactNote = <ThrowOnError extends boolean = false>(options: Options<AddContactNoteData, ThrowOnError>) => (options.client ?? client).post<AddContactNoteResponses, AddContactNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}/notes',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete note\n *\n * Delete a note from a contact.\n */\nexport const deleteContactNote = <ThrowOnError extends boolean = false>(options: Options<DeleteContactNoteData, ThrowOnError>) => (options.client ?? client).delete<DeleteContactNoteResponses, DeleteContactNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}/notes/{noteId}',\n ...options\n});\n\n/**\n * vendor info\n *\n * Get the current vendor profile for the route slug.\n */\nexport const getVendor = <ThrowOnError extends boolean = false>(options: Options<GetVendorData, ThrowOnError>) => (options.client ?? client).get<GetVendorResponses, GetVendorErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}',\n ...options\n});\n\n/**\n * team members\n *\n * Paginated vendor members, with optional search.\n */\nexport const listVendorMembers = <ThrowOnError extends boolean = false>(options: Options<ListVendorMembersData, ThrowOnError>) => (options.client ?? client).get<ListVendorMembersResponses, ListVendorMembersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/members',\n ...options\n});\n\n/**\n * team member\n *\n * Get a single vendor member by Gopaddi user ID.\n */\nexport const getVendorMember = <ThrowOnError extends boolean = false>(options: Options<GetVendorMemberData, ThrowOnError>) => (options.client ?? client).get<GetVendorMemberResponses, GetVendorMemberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/members/{userId}',\n ...options\n});\n\n/**\n * wallet\n *\n * Get wallet balance, top-up minimum, and supported payment channels.\n */\nexport const getBillingWallet = <ThrowOnError extends boolean = false>(options: Options<GetBillingWalletData, ThrowOnError>) => (options.client ?? client).get<GetBillingWalletResponses, GetBillingWalletErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/wallet',\n ...options\n});\n\n/**\n * update wallet settings\n *\n * Update low-balance and auto top-up settings.\n */\nexport const updateBillingWalletSettings = <ThrowOnError extends boolean = false>(options: Options<UpdateBillingWalletSettingsData, ThrowOnError>) => (options.client ?? client).patch<UpdateBillingWalletSettingsResponses, UpdateBillingWalletSettingsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/wallet/settings',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list top-ups\n *\n * Paginated wallet top-up requests.\n */\nexport const listBillingTopups = <ThrowOnError extends boolean = false>(options: Options<ListBillingTopupsData, ThrowOnError>) => (options.client ?? client).get<ListBillingTopupsResponses, ListBillingTopupsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups',\n ...options\n});\n\n/**\n * create top-up\n *\n * Create a Paystack checkout top-up for the vendor wallet.\n */\nexport const createBillingTopup = <ThrowOnError extends boolean = false>(options: Options<CreateBillingTopupData, ThrowOnError>) => (options.client ?? client).post<CreateBillingTopupResponses, CreateBillingTopupErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * get top-up\n *\n * Get a wallet top-up request.\n */\nexport const getBillingTopup = <ThrowOnError extends boolean = false>(options: Options<GetBillingTopupData, ThrowOnError>) => (options.client ?? client).get<GetBillingTopupResponses, GetBillingTopupErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups/{topupId}',\n ...options\n});\n\n/**\n * verify top-up\n *\n * Verify a Paystack top-up and return the resulting wallet state.\n */\nexport const verifyBillingTopup = <ThrowOnError extends boolean = false>(options: Options<VerifyBillingTopupData, ThrowOnError>) => (options.client ?? client).post<VerifyBillingTopupResponses, VerifyBillingTopupErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups/{topupId}/verify',\n ...options\n});\n\n/**\n * payment methods\n *\n * List saved reusable billing payment methods.\n */\nexport const listBillingPaymentMethods = <ThrowOnError extends boolean = false>(options: Options<ListBillingPaymentMethodsData, ThrowOnError>) => (options.client ?? client).get<ListBillingPaymentMethodsResponses, ListBillingPaymentMethodsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/payment-methods',\n ...options\n});\n\n/**\n * delete payment method\n *\n * Disable a saved payment method.\n */\nexport const deleteBillingPaymentMethod = <ThrowOnError extends boolean = false>(options: Options<DeleteBillingPaymentMethodData, ThrowOnError>) => (options.client ?? client).delete<DeleteBillingPaymentMethodResponses, DeleteBillingPaymentMethodErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/payment-methods/{paymentMethodId}',\n ...options\n});\n\n/**\n * estimate voice charge\n *\n * Estimate the initial hold for app-media or telephony voice charging.\n */\nexport const estimateBillingVoiceCharge = <ThrowOnError extends boolean = false>(options: Options<EstimateBillingVoiceChargeData, ThrowOnError>) => (options.client ?? client).post<EstimateBillingVoiceChargeResponses, EstimateBillingVoiceChargeErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/voice/estimate',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * transactions\n *\n * Paginated wallet transactions with kind, status, and date filters.\n */\nexport const listBillingTransactions = <ThrowOnError extends boolean = false>(options: Options<ListBillingTransactionsData, ThrowOnError>) => (options.client ?? client).get<ListBillingTransactionsResponses, ListBillingTransactionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/transactions',\n ...options\n});\n\n/**\n * export transactions\n *\n * Export wallet transactions as CSV using the same transaction filters.\n */\nexport const exportBillingTransactions = <ThrowOnError extends boolean = false>(options: Options<ExportBillingTransactionsData, ThrowOnError>) => (options.client ?? client).get<ExportBillingTransactionsResponses, ExportBillingTransactionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/transactions/export',\n ...options\n});\n\n/**\n * list agents\n *\n * Paginated list of agents for the vendor, with search, filters, and sorting.\n */\nexport const listAgents = <ThrowOnError extends boolean = false>(options: Options<ListAgentsData, ThrowOnError>) => (options.client ?? client).get<ListAgentsResponses, ListAgentsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents',\n ...options\n});\n\n/**\n * create agent\n *\n * Register a Gopaddi user as an agent for this vendor.\n */\nexport const createAgent = <ThrowOnError extends boolean = false>(options: Options<CreateAgentData, ThrowOnError>) => (options.client ?? client).post<CreateAgentResponses, CreateAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * bulk create agents\n *\n * Register multiple vendor members as agents in one request.\n */\nexport const bulkCreateAgents = <ThrowOnError extends boolean = false>(options: Options<BulkCreateAgentsData, ThrowOnError>) => (options.client ?? client).post<BulkCreateAgentsResponses, BulkCreateAgentsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/bulk',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * agent stats\n *\n * Aggregate agent counts by status for this vendor.\n */\nexport const getAgentStats = <ThrowOnError extends boolean = false>(options: Options<GetAgentStatsData, ThrowOnError>) => (options.client ?? client).get<GetAgentStatsResponses, GetAgentStatsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/stats',\n ...options\n});\n\n/**\n * delete agent\n *\n * Remove an agent and clean up directory assignments.\n */\nexport const deleteAgent = <ThrowOnError extends boolean = false>(options: Options<DeleteAgentData, ThrowOnError>) => (options.client ?? client).delete<DeleteAgentResponses, DeleteAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/{id}',\n ...options\n});\n\n/**\n * get agent\n *\n * Full agent profile including teams, extensions, and assigned numbers.\n */\nexport const getAgent = <ThrowOnError extends boolean = false>(options: Options<GetAgentData, ThrowOnError>) => (options.client ?? client).get<GetAgentResponses, GetAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/{id}',\n ...options\n});\n\n/**\n * update agent\n *\n * Update agent role, status, or outbound number.\n */\nexport const updateAgent = <ThrowOnError extends boolean = false>(options: Options<UpdateAgentData, ThrowOnError>) => (options.client ?? client).put<UpdateAgentResponses, UpdateAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list teams\n *\n * Paginated list of teams for the vendor, with search, filters, and sorting.\n */\nexport const listTeams = <ThrowOnError extends boolean = false>(options: Options<ListTeamsData, ThrowOnError>) => (options.client ?? client).get<ListTeamsResponses, ListTeamsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams',\n ...options\n});\n\n/**\n * create team\n *\n * Create a team with optional members and assigned numbers.\n */\nexport const createTeam = <ThrowOnError extends boolean = false>(options: Options<CreateTeamData, ThrowOnError>) => (options.client ?? client).post<CreateTeamResponses, CreateTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * team stats\n *\n * Aggregate team counts, assigned numbers, and total members.\n */\nexport const getTeamStats = <ThrowOnError extends boolean = false>(options: Options<GetTeamStatsData, ThrowOnError>) => (options.client ?? client).get<GetTeamStatsResponses, GetTeamStatsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/stats',\n ...options\n});\n\n/**\n * delete team\n *\n * Delete a team and clean up member, number, and extension links.\n */\nexport const deleteTeam = <ThrowOnError extends boolean = false>(options: Options<DeleteTeamData, ThrowOnError>) => (options.client ?? client).delete<DeleteTeamResponses, DeleteTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}',\n ...options\n});\n\n/**\n * get team\n *\n * Full team detail including members, numbers, extensions, and routing policy.\n */\nexport const getTeam = <ThrowOnError extends boolean = false>(options: Options<GetTeamData, ThrowOnError>) => (options.client ?? client).get<GetTeamResponses, GetTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}',\n ...options\n});\n\n/**\n * update team\n *\n * Update team properties, membership, assigned numbers, or routing policy.\n */\nexport const updateTeam = <ThrowOnError extends boolean = false>(options: Options<UpdateTeamData, ThrowOnError>) => (options.client ?? client).put<UpdateTeamResponses, UpdateTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * duplicate team\n *\n * Clone a team's configuration and members into a new team.\n */\nexport const duplicateTeam = <ThrowOnError extends boolean = false>(options: Options<DuplicateTeamData, ThrowOnError>) => (options.client ?? client).post<DuplicateTeamResponses, DuplicateTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}/duplicate',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list numbers\n *\n * Paginated vendor phone numbers, with search, filters, and sorting.\n */\nexport const listNumbers = <ThrowOnError extends boolean = false>(options: Options<ListNumbersData, ThrowOnError>) => (options.client ?? client).get<ListNumbersResponses, ListNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers',\n ...options\n});\n\n/**\n * catalog\n *\n * List purchasable phone numbers from the number catalog.\n */\nexport const listNumberCatalog = <ThrowOnError extends boolean = false>(options: Options<ListNumberCatalogData, ThrowOnError>) => (options.client ?? client).get<ListNumberCatalogResponses, ListNumberCatalogErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/catalog',\n ...options\n});\n\n/**\n * purchase numbers\n *\n * Purchase catalog numbers and optionally assign them during checkout.\n */\nexport const purchaseNumbers = <ThrowOnError extends boolean = false>(options: Options<PurchaseNumbersData, ThrowOnError>) => (options.client ?? client).post<PurchaseNumbersResponses, PurchaseNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/purchases',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * quote purchase\n *\n * Quote catalog numbers before purchase.\n */\nexport const quoteNumberPurchase = <ThrowOnError extends boolean = false>(options: Options<QuoteNumberPurchaseData, ThrowOnError>) => (options.client ?? client).post<QuoteNumberPurchaseResponses, QuoteNumberPurchaseErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/purchase-quotes',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * get number subscription\n *\n * Get billing subscription state for a purchased number.\n */\nexport const getNumberSubscription = <ThrowOnError extends boolean = false>(options: Options<GetNumberSubscriptionData, ThrowOnError>) => (options.client ?? client).get<GetNumberSubscriptionResponses, GetNumberSubscriptionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/subscription',\n ...options\n});\n\n/**\n * cancel number subscription\n *\n * Schedule number subscription cancellation at the end of the paid period.\n */\nexport const cancelNumberSubscription = <ThrowOnError extends boolean = false>(options: Options<CancelNumberSubscriptionData, ThrowOnError>) => (options.client ?? client).post<CancelNumberSubscriptionResponses, CancelNumberSubscriptionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/subscription/cancel',\n ...options\n});\n\n/**\n * bulk suspend\n *\n * Suspend multiple active vendor numbers in one request.\n */\nexport const bulkSuspendNumbers = <ThrowOnError extends boolean = false>(options: Options<BulkSuspendNumbersData, ThrowOnError>) => (options.client ?? client).post<BulkSuspendNumbersResponses, BulkSuspendNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/bulk/suspend',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * bulk activate\n *\n * Activate multiple suspended vendor numbers in one request.\n */\nexport const bulkActivateNumbers = <ThrowOnError extends boolean = false>(options: Options<BulkActivateNumbersData, ThrowOnError>) => (options.client ?? client).post<BulkActivateNumbersResponses, BulkActivateNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/bulk/activate',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * get number\n *\n * Get a phone number with current status and assignment.\n */\nexport const getNumber = <ThrowOnError extends boolean = false>(options: Options<GetNumberData, ThrowOnError>) => (options.client ?? client).get<GetNumberResponses, GetNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}',\n ...options\n});\n\n/**\n * assign number\n *\n * Assign or reassign a phone number to a team or agent.\n */\nexport const assignNumber = <ThrowOnError extends boolean = false>(options: Options<AssignNumberData, ThrowOnError>) => (options.client ?? client).put<AssignNumberResponses, AssignNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/assign',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * unassign number\n *\n * Remove the current assignment from a phone number.\n */\nexport const unassignNumber = <ThrowOnError extends boolean = false>(options: Options<UnassignNumberData, ThrowOnError>) => (options.client ?? client).put<UnassignNumberResponses, UnassignNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/unassign',\n ...options\n});\n\n/**\n * suspend number\n *\n * Change an active phone number to suspended.\n */\nexport const suspendNumber = <ThrowOnError extends boolean = false>(options: Options<SuspendNumberData, ThrowOnError>) => (options.client ?? client).put<SuspendNumberResponses, SuspendNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/suspend',\n ...options\n});\n\n/**\n * activate number\n *\n * Change a suspended phone number back to active.\n */\nexport const activateNumber = <ThrowOnError extends boolean = false>(options: Options<ActivateNumberData, ThrowOnError>) => (options.client ?? client).put<ActivateNumberResponses, ActivateNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/activate',\n ...options\n});\n\n/**\n * list extensions\n *\n * List extensions on a phone number within a team.\n */\nexport const listExtensions = <ThrowOnError extends boolean = false>(options: Options<ListExtensionsData, ThrowOnError>) => (options.client ?? client).get<ListExtensionsResponses, ListExtensionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions',\n ...options\n});\n\n/**\n * create extension\n *\n * Add an extension to a team-owned phone number.\n */\nexport const createExtension = <ThrowOnError extends boolean = false>(options: Options<CreateExtensionData, ThrowOnError>) => (options.client ?? client).post<CreateExtensionResponses, CreateExtensionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete extension\n *\n * Remove an extension from a phone number.\n */\nexport const deleteExtension = <ThrowOnError extends boolean = false>(options: Options<DeleteExtensionData, ThrowOnError>) => (options.client ?? client).delete<DeleteExtensionResponses, DeleteExtensionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions/{id}',\n ...options\n});\n\n/**\n * update extension\n *\n * Update extension number, label, assignee, or status.\n */\nexport const updateExtension = <ThrowOnError extends boolean = false>(options: Options<UpdateExtensionData, ThrowOnError>) => (options.client ?? client).put<UpdateExtensionResponses, UpdateExtensionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n","import type { ClientEvents, Unsubscribe } from \"./types\";\n\ntype Listener<K extends keyof ClientEvents> = (payload: ClientEvents[K]) => void;\n\nexport type Emitter = {\n on: <K extends keyof ClientEvents>(event: K, fn: Listener<K>) => Unsubscribe;\n emit: <K extends keyof ClientEvents>(event: K, payload: ClientEvents[K]) => void;\n};\n\nexport const createEmitter = (): Emitter => {\n const listeners = new Map<keyof ClientEvents, Set<Listener<keyof ClientEvents>>>();\n\n const emit = <K extends keyof ClientEvents>(event: K, payload: ClientEvents[K]): void => {\n const fns = listeners.get(event) as Set<Listener<K>> | undefined;\n if (!fns) {\n return;\n }\n for (const fn of fns) {\n try {\n fn(payload);\n } catch (err) {\n if (event !== \"error\") {\n emit(\"error\", err instanceof Error ? err : new Error(\"Event listener failed\"));\n }\n }\n }\n };\n\n return {\n on: (event, fn) => {\n let fns = listeners.get(event);\n if (!fns) {\n fns = new Set();\n listeners.set(event, fns);\n }\n fns.add(fn as Listener<keyof ClientEvents>);\n return () => {\n fns?.delete(fn as Listener<keyof ClientEvents>);\n if (fns?.size === 0) {\n listeners.delete(event);\n }\n };\n },\n emit,\n };\n};\n","import { Centrifuge, UnauthorizedError } from \"centrifuge\";\n\nimport { CallpadError, unwrap, type Auth } from \"../api/client\";\nimport { getRealtimeToken, type RealtimeToken, type VoiceSession } from \"../api/generated\";\nimport type { Client } from \"../api/generated/client\";\nimport type { Emitter } from \"./events\";\nimport type { RemoveSessionPayload, SessionStore } from \"./store\";\nimport type { ClientStatus } from \"./types\";\nimport type { Nullable } from \"../shared/types\";\n\ntype RealtimeMessage =\n | { event: \"session.upsert\"; data: VoiceSession }\n | { event: \"session.remove\"; data: RemoveSessionPayload };\n\nexport type Realtime = {\n connect: () => Promise<void>;\n disconnect: () => Promise<void>;\n dispose: () => Promise<void>;\n};\n\nexport const createRealtime = (\n client: Client,\n auth: Auth,\n store: SessionStore,\n emitter: Emitter,\n): Realtime => {\n let rt: Nullable<Centrifuge> = null;\n let disposed = false;\n\n const fetchToken = async (): Promise<RealtimeToken> => unwrap(getRealtimeToken({ client }), auth);\n\n const refreshToken = async (): Promise<string> => {\n try {\n const token = await fetchToken();\n return token.token;\n } catch (err) {\n if (err instanceof CallpadError && (err.status === 401 || err.status === 403)) {\n throw new UnauthorizedError(err.message);\n }\n throw err;\n }\n };\n\n const applyMessage = (message: RealtimeMessage): void => {\n if (message.event === \"session.upsert\") {\n const change = store.upsert(message.data);\n if (change === \"added\") {\n emitter.emit(\"session.added\", message.data);\n }\n if (change === \"updated\") {\n emitter.emit(\"session.updated\", message.data);\n }\n return;\n }\n\n if (store.remove(message.data)) {\n emitter.emit(\"session.removed\", {\n sessionId: message.data.id,\n vendor: message.data.vendor,\n version: message.data.version,\n });\n }\n };\n\n const setStatus = (status: ClientStatus): void => {\n store.setStatus(status);\n emitter.emit(\"status\", status);\n };\n\n const disconnect = async (): Promise<void> => {\n rt?.disconnect();\n rt = null;\n if (!disposed) {\n setStatus(\"offline\");\n }\n };\n\n return {\n connect: async () => {\n if (rt) {\n return;\n }\n disposed = false;\n setStatus(\"connecting\");\n\n try {\n const first = await fetchToken();\n rt = new Centrifuge(first.url, {\n token: first.token,\n getToken: refreshToken,\n });\n rt.on(\"connecting\", () => {\n const next = store.getStatus() === \"ready\" ? \"reconnecting\" : \"connecting\";\n setStatus(next);\n });\n rt.on(\"connected\", () => {\n setStatus(\"ready\");\n });\n rt.on(\"disconnected\", () => {\n if (!disposed) {\n setStatus(\"offline\");\n }\n });\n rt.on(\"error\", (ctx) => {\n emitter.emit(\"error\", new Error(ctx.error.message));\n });\n rt.on(\"publication\", (ctx) => {\n try {\n const message = parseMessage(ctx.data);\n if (message) {\n applyMessage(message);\n }\n } catch (err) {\n emitter.emit(\"error\", err instanceof Error ? err : new Error(\"Realtime event failed\"));\n }\n });\n rt.connect();\n await rt.ready();\n } catch (err) {\n await disconnect();\n throw err;\n }\n },\n disconnect,\n dispose: async () => {\n disposed = true;\n rt?.disconnect();\n rt = null;\n setStatus(\"disposed\");\n },\n };\n};\n\nconst parseMessage = (value: unknown): Nullable<RealtimeMessage> => {\n if (!value || typeof value !== \"object\") {\n return null;\n }\n const message = value as Partial<RealtimeMessage>;\n if (message.event === \"session.upsert\" && message.data) {\n return message as RealtimeMessage;\n }\n if (message.event === \"session.remove\" && message.data) {\n return message as RealtimeMessage;\n }\n return null;\n};\n","import type { ClientStatus, SessionAction, SessionInvite, StoreTopic, Unsubscribe } from \"./types\";\nimport type { SessionRecordingControl, VoiceParticipant, VoiceSession } from \"../api/generated\";\nimport type { Nullable } from \"../shared/types\";\n\nexport type RemoveSessionPayload = {\n id: string;\n vendor?: string;\n version?: number;\n};\n\nexport type UpsertMode = \"event\" | \"command\";\n\nexport type SessionStore = {\n getStatus: () => ClientStatus;\n setStatus: (status: ClientStatus) => void;\n list: () => readonly VoiceSession[];\n get: (sessionId?: string) => Nullable<VoiceSession>;\n invites: () => readonly SessionInvite[];\n invite: (sessionId: string) => Nullable<SessionInvite>;\n sync: (items: readonly VoiceSession[]) => void;\n upsert: (session: VoiceSession, mode?: UpsertMode) => \"added\" | \"updated\" | null;\n remove: (payload: RemoveSessionPayload) => boolean;\n patchRecording: (control: SessionRecordingControl) => Nullable<VoiceSession>;\n can: (session: VoiceSession, action: SessionAction) => boolean;\n subscribe: (topic: StoreTopic, fn: () => void) => Unsubscribe;\n};\n\nexport const createSessionStore = (userId: number): SessionStore => {\n const sessions = new Map<string, VoiceSession>();\n const subscribers = new Map<StoreTopic, Set<() => void>>();\n let status: ClientStatus = \"idle\";\n let activeId: Nullable<string> = null;\n let listCache: readonly VoiceSession[] = [];\n let invitesCache: readonly SessionInvite[] = [];\n let inviteKey = \"\";\n\n const emit = (topic: StoreTopic): void => {\n const fns = subscribers.get(topic);\n if (!fns) {\n return;\n }\n for (const fn of fns) {\n fn();\n }\n };\n\n const subscribe = (topic: StoreTopic, fn: () => void): Unsubscribe => {\n let fns = subscribers.get(topic);\n if (!fns) {\n fns = new Set();\n subscribers.set(topic, fns);\n }\n fns.add(fn);\n return () => {\n fns?.delete(fn);\n if (fns?.size === 0) {\n subscribers.delete(topic);\n }\n };\n };\n\n const refresh = (): void => {\n listCache = Array.from(sessions.values()).sort((a, b) =>\n b.createdAt.localeCompare(a.createdAt),\n );\n if (activeId) {\n const active = sessions.get(activeId);\n if (!active || active.state === \"ended\") {\n activeId = null;\n }\n }\n if (!activeId) {\n activeId = listCache.find((session) => session.state !== \"ended\")?.id ?? null;\n }\n };\n\n const refreshInvites = (): boolean => {\n const invites = listCache\n .map((session) => inviteFrom(session, userId))\n .filter((invite) => invite !== null);\n const nextKey = invites\n .map(\n (invite) =>\n `${invite.session.id}:${invite.participant.id}:${invite.participant.state}:${invite.participant.inviteExpiresAt ?? \"\"}`,\n )\n .join(\"|\");\n if (nextKey === inviteKey) {\n invitesCache = invites;\n return false;\n }\n inviteKey = nextKey;\n invitesCache = invites;\n return true;\n };\n\n const notifySessionChange = (sessionId: string): void => {\n refresh();\n const invitesChanged = refreshInvites();\n emit(`session:${sessionId}`);\n emit(\"sessions\");\n if (invitesChanged) {\n emit(\"invites\");\n }\n };\n\n const get = (sessionId?: string): Nullable<VoiceSession> => {\n if (sessionId) {\n return sessions.get(sessionId) ?? null;\n }\n if (!activeId) {\n return null;\n }\n return sessions.get(activeId) ?? null;\n };\n\n const upsert = (\n session: VoiceSession,\n mode: UpsertMode = \"event\",\n ): \"added\" | \"updated\" | null => {\n const prev = sessions.get(session.id);\n const stale = prev\n ? mode === \"command\"\n ? session.version < prev.version\n : session.version <= prev.version\n : false;\n if (stale) {\n return null;\n }\n sessions.set(session.id, session);\n notifySessionChange(session.id);\n return prev ? \"updated\" : \"added\";\n };\n\n return {\n getStatus: () => status,\n setStatus: (next) => {\n if (status === next) {\n return;\n }\n status = next;\n emit(\"status\");\n },\n list: () => listCache,\n get,\n invites: () => invitesCache,\n invite: (sessionId) => invitesCache.find((invite) => invite.session.id === sessionId) ?? null,\n sync: (items) => {\n for (const session of items) {\n const prev = sessions.get(session.id);\n if (!prev || session.version >= prev.version) {\n sessions.set(session.id, session);\n }\n }\n refresh();\n const invitesChanged = refreshInvites();\n emit(\"sessions\");\n for (const session of items) {\n emit(`session:${session.id}`);\n }\n if (invitesChanged) {\n emit(\"invites\");\n }\n },\n upsert,\n remove: (payload) => {\n const prev = sessions.get(payload.id);\n if (!prev) {\n return false;\n }\n if (payload.version !== undefined && payload.version < prev.version) {\n return false;\n }\n sessions.delete(payload.id);\n notifySessionChange(payload.id);\n return true;\n },\n patchRecording: (control) => {\n const prev = sessions.get(control.sessionId);\n if (!prev || control.sessionVersion < prev.version) {\n return null;\n }\n const next = {\n ...prev,\n version: Math.max(prev.version, control.sessionVersion),\n recording: control.recording,\n };\n sessions.set(next.id, next);\n notifySessionChange(next.id);\n return next;\n },\n can: (session, action) => can(session, userId, action),\n subscribe,\n };\n};\n\nconst selfParticipant = (session: VoiceSession, userId: number): Nullable<VoiceParticipant> =>\n session.participants.find((participant) => participant.userId === userId) ?? null;\n\nconst inviteFrom = (session: VoiceSession, userId: number): Nullable<SessionInvite> => {\n const participant = selfParticipant(session, userId);\n if (!participant || participant.state !== \"invited\") {\n return null;\n }\n return { session, participant };\n};\n\nconst can = (session: VoiceSession, userId: number, action: SessionAction): boolean => {\n const self = selfParticipant(session, userId);\n if (!self || session.state === \"ended\") {\n return false;\n }\n\n switch (action) {\n case \"accept\":\n case \"reject\":\n return self.state === \"invited\";\n case \"join\":\n return self.transport === \"webrtc\" && (self.state === \"accepted\" || self.state === \"joined\");\n case \"leave\":\n return self.state === \"accepted\" || self.state === \"joined\";\n case \"end\":\n case \"addParticipant\":\n case \"removeParticipant\":\n return isHost(self) && (self.state === \"accepted\" || self.state === \"joined\");\n case \"startRecording\":\n return isHost(self) && session.state === \"active\" && session.recording.status === \"off\";\n case \"stopRecording\":\n return isHost(self) && session.recording.status === \"recording\";\n }\n};\n\nconst isHost = (participant: VoiceParticipant): boolean =>\n participant.role === \"host\" &&\n (participant.kind === \"agent\" || participant.kind === \"vendor_user\");\n","import { apiClient, unwrap } from \"../api/client\";\nimport {\n acceptSessionParticipant,\n addSessionParticipant,\n createSession,\n createSessionToken,\n endSession,\n leaveSession,\n listSessions,\n rejectSessionParticipant,\n removeSessionParticipant,\n startRecording as apiStartRecording,\n stopRecording as apiStopRecording,\n} from \"../api/generated\";\nimport type { SessionRecordingControl, StartedSession, VoiceSession } from \"../api/generated\";\nimport { createEmitter } from \"./events\";\nimport { createRealtime } from \"./realtime\";\nimport { createSessionStore, type UpsertMode } from \"./store\";\nimport type {\n CustomerStartInput,\n HostClient,\n HostClientConfig,\n HostControls,\n HostParticipantInput,\n HostStartInput,\n ListQuery,\n ParticipantRef,\n SessionClient,\n SessionClientConfig,\n Sessions,\n} from \"./types\";\n\nexport const createSessionClient = (config: SessionClientConfig): SessionClient => {\n const core = createCore(config);\n\n return {\n kind: \"session\",\n get status() {\n return core.store.getStatus();\n },\n sessions: {\n ...createCommonSessions(core),\n start: (input) => startSession(core, input.vendor, input.target),\n },\n invites: {\n list: core.store.invites,\n get: core.store.invite,\n },\n connect: core.connect,\n disconnect: core.realtime.disconnect,\n dispose: core.realtime.dispose,\n on: core.emitter.on,\n subscribe: core.store.subscribe,\n };\n};\n\nexport const createHostClient = (config: HostClientConfig): HostClient => {\n const core = createCore(config);\n\n return {\n kind: \"host\",\n vendor: config.vendor,\n get status() {\n return core.store.getStatus();\n },\n sessions: {\n ...createCommonSessions(core),\n start: (input) => startSession(core, config.vendor, input.target),\n },\n invites: {\n list: core.store.invites,\n get: core.store.invite,\n },\n host: createHostControls(core),\n connect: core.connect,\n disconnect: core.realtime.disconnect,\n dispose: core.realtime.dispose,\n on: core.emitter.on,\n subscribe: core.store.subscribe,\n };\n};\n\ntype Core = ReturnType<typeof createCore>;\n\nconst createCore = (config: SessionClientConfig) => {\n const api = apiClient(config);\n const store = createSessionStore(config.userId);\n const emitter = createEmitter();\n const realtime = createRealtime(api, config.auth, store, emitter);\n\n const applySession = (session: VoiceSession, mode: UpsertMode = \"event\"): VoiceSession => {\n const change = store.upsert(session, mode);\n if (change === \"added\") {\n emitter.emit(\"session.added\", session);\n }\n if (change === \"updated\") {\n emitter.emit(\"session.updated\", session);\n }\n return session;\n };\n\n const applyStarted = (started: StartedSession, mode: UpsertMode = \"event\"): StartedSession => {\n applySession(started.session, mode);\n return started;\n };\n\n const patchRecording = (control: SessionRecordingControl): SessionRecordingControl => {\n const session = store.patchRecording(control);\n if (session) {\n emitter.emit(\"session.updated\", session);\n }\n return control;\n };\n\n const connect = async (): Promise<void> => {\n try {\n await realtime.connect();\n } catch (err) {\n emitter.emit(\"error\", err instanceof Error ? err : new Error(\"Connection failed\"));\n throw err;\n }\n };\n\n return {\n api,\n auth: config.auth,\n store,\n emitter,\n realtime,\n connect,\n applySession,\n applyStarted,\n patchRecording,\n };\n};\n\nconst createCommonSessions = (core: Core): Omit<Sessions, \"start\"> => ({\n list: core.store.list,\n get: core.store.get,\n sync: async (query?: ListQuery) => {\n const response = await unwrap(listSessions({ client: core.api, query }), core.auth);\n core.store.sync(response.items);\n return core.store.list();\n },\n join: (sessionId) =>\n unwrap(createSessionToken({ client: core.api, path: { sessionId } }), core.auth),\n accept: async (input) =>\n core.applyStarted(\n await unwrap(\n acceptSessionParticipant({\n client: core.api,\n path: {\n sessionId: input.sessionId,\n participantId: input.participantId,\n },\n }),\n core.auth,\n ),\n \"command\",\n ),\n reject: async (input) =>\n core.applySession(\n await unwrap(\n rejectSessionParticipant({\n client: core.api,\n path: {\n sessionId: input.sessionId,\n participantId: input.participantId,\n },\n }),\n core.auth,\n ),\n \"command\",\n ),\n leave: async (sessionId) =>\n core.applySession(\n await unwrap(leaveSession({ client: core.api, path: { sessionId } }), core.auth),\n \"command\",\n ),\n can: core.store.can,\n});\n\nconst createHostControls = (core: Core): HostControls => ({\n end: async (sessionId) => {\n await unwrap(endSession({ client: core.api, path: { sessionId } }), core.auth);\n if (core.store.remove({ id: sessionId })) {\n core.emitter.emit(\"session.removed\", { sessionId });\n }\n },\n addParticipant: async (input: HostParticipantInput) =>\n core.applyStarted(\n await unwrap(\n addSessionParticipant({\n client: core.api,\n path: { sessionId: input.sessionId },\n body: { target: input.target },\n }),\n core.auth,\n ),\n \"command\",\n ),\n removeParticipant: async (input: ParticipantRef) =>\n core.applySession(\n await unwrap(\n removeSessionParticipant({\n client: core.api,\n path: {\n sessionId: input.sessionId,\n participantId: input.participantId,\n },\n }),\n core.auth,\n ),\n \"command\",\n ),\n startRecording: async (sessionId) =>\n core.patchRecording(\n await unwrap(apiStartRecording({ client: core.api, path: { sessionId } }), core.auth),\n ),\n stopRecording: async (sessionId) =>\n core.patchRecording(\n await unwrap(apiStopRecording({ client: core.api, path: { sessionId } }), core.auth),\n ),\n});\n\nconst startSession = async (\n core: Core,\n vendor: string,\n target: CustomerStartInput[\"target\"] | HostStartInput[\"target\"],\n): Promise<StartedSession> =>\n core.applyStarted(\n await unwrap(\n createSession({\n client: core.api,\n path: { vendor },\n body: { target },\n }),\n core.auth,\n ),\n \"command\",\n );\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/api/generated/core/bodySerializer.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/client.ts","../src/api/generated/client.gen.ts","../src/api/generated/sdk.gen.ts","../src/core/events.ts","../src/core/realtime.ts","../src/core/store.ts","../src/core/client.ts"],"names":["joinedValues","config","request","url","client"],"mappings":"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","file":"index.js","sourcesContent":["// 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\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 async function setAuthParams(\n options: Pick<RequestOptions, 'auth' | 'query' | 'security'> & {\n headers: Headers;\n },\n): Promise<void> {\n for (const auth of options.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(opts);\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","import { createClient, type Client } from \"./generated/client\";\nimport type { Problem } from \"./generated\";\n\nexport type Auth = {\n getAccessToken: () => string | Promise<string>;\n onUnauthorized?: () => void | Promise<void>;\n};\n\nexport type ApiConfig = {\n apiUrl: string;\n auth: Auth;\n fetch?: typeof fetch;\n};\n\nexport class CallpadError extends Error {\n constructor(\n readonly code: string,\n message: string,\n readonly status?: number,\n ) {\n super(message);\n this.name = \"CallpadError\";\n }\n}\n\ntype ApiResult<T> =\n | {\n data: T;\n error?: undefined;\n response?: Response;\n }\n | {\n data?: undefined;\n error: unknown;\n response?: Response;\n };\n\nexport const apiClient = (config: ApiConfig): Client => {\n const client = createClient({\n baseUrl: config.apiUrl,\n fetch: config.fetch,\n });\n\n client.interceptors.request.use(async (request) => {\n const token = await config.auth.getAccessToken();\n request.headers.set(\"Authorization\", `Bearer ${token}`);\n return request;\n });\n\n return client;\n};\n\nexport const unwrap = async <T>(\n result: Promise<ApiResult<T>>,\n auth?: Auth,\n): Promise<NonNullable<T>> => {\n const response = await result;\n\n if (response.error !== undefined) {\n if (response.response?.status === 401) {\n await auth?.onUnauthorized?.();\n }\n throw errorFrom(response.error, response.response?.status);\n }\n\n if (response.data === undefined) {\n throw new CallpadError(\"empty_response\", \"API response did not include data\");\n }\n\n return response.data as NonNullable<T>;\n};\n\nconst errorFrom = (error: unknown, status?: number): CallpadError => {\n if (isProblem(error)) {\n return new CallpadError(error.code, error.message, status);\n }\n if (error instanceof Error) {\n return new CallpadError(\"request_failed\", error.message, status);\n }\n if (typeof error === \"string\" && error.length > 0) {\n return new CallpadError(\"request_failed\", error, status);\n }\n return new CallpadError(\"request_failed\", \"Request failed\", status);\n};\n\nconst isProblem = (value: unknown): value is Problem => {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n const problem = value as Partial<Problem>;\n return typeof problem.code === \"string\" && typeof problem.message === \"string\";\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>());\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 { AcceptSessionParticipantData, AcceptSessionParticipantErrors, AcceptSessionParticipantResponses, ActivateNumberData, ActivateNumberErrors, ActivateNumberResponses, AddContactNoteData, AddContactNoteErrors, AddContactNoteResponses, AddSessionParticipantData, AddSessionParticipantErrors, AddSessionParticipantResponses, AssignNumberData, AssignNumberErrors, AssignNumberResponses, BulkActivateNumbersData, BulkActivateNumbersErrors, BulkActivateNumbersResponses, BulkCreateAgentsData, BulkCreateAgentsErrors, BulkCreateAgentsResponses, BulkSuspendNumbersData, BulkSuspendNumbersErrors, BulkSuspendNumbersResponses, CancelNumberSubscriptionData, CancelNumberSubscriptionErrors, CancelNumberSubscriptionResponses, CreateAgentData, CreateAgentErrors, CreateAgentResponses, CreateBillingTopupData, CreateBillingTopupErrors, CreateBillingTopupResponses, CreateCallNoteData, CreateCallNoteErrors, CreateCallNoteResponses, CreateCallRecordingUrlData, CreateCallRecordingUrlErrors, CreateCallRecordingUrlResponses, CreateCallTaskData, CreateCallTaskErrors, CreateCallTaskResponses, CreateContactData, CreateContactErrors, CreateContactResponses, CreateExtensionData, CreateExtensionErrors, CreateExtensionResponses, CreateSessionData, CreateSessionErrors, CreateSessionResponses, CreateSessionTokenData, CreateSessionTokenErrors, CreateSessionTokenResponses, CreateTeamData, CreateTeamErrors, CreateTeamResponses, DeleteAgentData, DeleteAgentErrors, DeleteAgentResponses, DeleteBillingPaymentMethodData, DeleteBillingPaymentMethodErrors, DeleteBillingPaymentMethodResponses, DeleteCallNoteData, DeleteCallNoteErrors, DeleteCallNoteResponses, DeleteContactData, DeleteContactErrors, DeleteContactNoteData, DeleteContactNoteErrors, DeleteContactNoteResponses, DeleteContactResponses, DeleteExtensionData, DeleteExtensionErrors, DeleteExtensionResponses, DeleteTeamData, DeleteTeamErrors, DeleteTeamResponses, DuplicateTeamData, DuplicateTeamErrors, DuplicateTeamResponses, EndSessionData, EndSessionErrors, EndSessionResponses, EstimateBillingVoiceChargeData, EstimateBillingVoiceChargeErrors, EstimateBillingVoiceChargeResponses, ExportBillingTransactionsData, ExportBillingTransactionsErrors, ExportBillingTransactionsResponses, ExportVendorCallsData, ExportVendorCallsErrors, ExportVendorCallsResponses, GetAgentData, GetAgentErrors, GetAgentResponses, GetAgentStatsData, GetAgentStatsErrors, GetAgentStatsResponses, GetBillingTopupData, GetBillingTopupErrors, GetBillingTopupResponses, GetBillingWalletData, GetBillingWalletErrors, GetBillingWalletResponses, GetContactData, GetContactErrors, GetContactResponses, GetHealthzData, GetHealthzErrors, GetHealthzResponses, GetMyCallData, GetMyCallErrors, GetMyCallResponses, GetNumberData, GetNumberErrors, GetNumberResponses, GetNumberSubscriptionData, GetNumberSubscriptionErrors, GetNumberSubscriptionResponses, GetReadyzData, GetReadyzErrors, GetReadyzResponses, GetRealtimeTokenData, GetRealtimeTokenErrors, GetRealtimeTokenResponses, GetRoutingPolicyData, GetRoutingPolicyErrors, GetRoutingPolicyResponses, GetSessionData, GetSessionErrors, GetSessionResponses, GetTeamData, GetTeamErrors, GetTeamResponses, GetTeamStatsData, GetTeamStatsErrors, GetTeamStatsResponses, GetTelephoneData, GetTelephoneErrors, GetTelephoneResponses, GetVendorCallData, GetVendorCallErrors, GetVendorCallResponses, GetVendorData, GetVendorErrors, GetVendorMemberData, GetVendorMemberErrors, GetVendorMemberResponses, GetVendorResponses, LeaveSessionData, LeaveSessionErrors, LeaveSessionResponses, ListAgentsData, ListAgentsErrors, ListAgentsResponses, ListBillingPaymentMethodsData, ListBillingPaymentMethodsErrors, ListBillingPaymentMethodsResponses, ListBillingTopupsData, ListBillingTopupsErrors, ListBillingTopupsResponses, ListBillingTransactionsData, ListBillingTransactionsErrors, ListBillingTransactionsResponses, ListCallNotesData, ListCallNotesErrors, ListCallNotesResponses, ListCallRecordingsData, ListCallRecordingsErrors, ListCallRecordingsResponses, ListCallTasksData, ListCallTasksErrors, ListCallTasksResponses, ListContactNotesData, ListContactNotesErrors, ListContactNotesResponses, ListContactsData, ListContactsErrors, ListContactsResponses, ListExtensionsData, ListExtensionsErrors, ListExtensionsResponses, ListMyCallsData, ListMyCallsErrors, ListMyCallsResponses, ListNumberCatalogData, ListNumberCatalogErrors, ListNumberCatalogResponses, ListNumbersData, ListNumbersErrors, ListNumbersResponses, ListSessionsData, ListSessionsErrors, ListSessionsResponses, ListTeamsData, ListTeamsErrors, ListTeamsResponses, ListVendorCallsData, ListVendorCallsErrors, ListVendorCallsResponses, ListVendorMembersData, ListVendorMembersErrors, ListVendorMembersResponses, PurchaseNumbersData, PurchaseNumbersErrors, PurchaseNumbersResponses, PutRoutingPolicyData, PutRoutingPolicyErrors, PutRoutingPolicyResponses, QuoteNumberPurchaseData, QuoteNumberPurchaseErrors, QuoteNumberPurchaseResponses, RejectSessionParticipantData, RejectSessionParticipantErrors, RejectSessionParticipantResponses, RemoveSessionParticipantData, RemoveSessionParticipantErrors, RemoveSessionParticipantResponses, StartRecordingData, StartRecordingErrors, StartRecordingResponses, StopRecordingData, StopRecordingErrors, StopRecordingResponses, SuspendNumberData, SuspendNumberErrors, SuspendNumberResponses, SyncTelephoneData, SyncTelephoneErrors, SyncTelephoneResponses, UnassignNumberData, UnassignNumberErrors, UnassignNumberResponses, UpdateAgentData, UpdateAgentErrors, UpdateAgentResponses, UpdateBillingWalletSettingsData, UpdateBillingWalletSettingsErrors, UpdateBillingWalletSettingsResponses, UpdateCallNoteData, UpdateCallNoteErrors, UpdateCallNoteResponses, UpdateCallTaskData, UpdateCallTaskErrors, UpdateCallTaskResponses, UpdateCallWrapUpData, UpdateCallWrapUpErrors, UpdateCallWrapUpResponses, UpdateContactData, UpdateContactErrors, UpdateContactResponses, UpdateExtensionData, UpdateExtensionErrors, UpdateExtensionResponses, UpdateTeamData, UpdateTeamErrors, UpdateTeamResponses, UpdateTelephoneSettingsData, UpdateTelephoneSettingsErrors, UpdateTelephoneSettingsResponses, VerifyBillingTopupData, VerifyBillingTopupErrors, VerifyBillingTopupResponses } 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\n/**\n * health\n *\n * Report process liveness without checking external dependencies.\n */\nexport const getHealthz = <ThrowOnError extends boolean = false>(options?: Options<GetHealthzData, ThrowOnError>) => (options?.client ?? client).get<GetHealthzResponses, GetHealthzErrors, ThrowOnError>({ url: '/healthz', ...options });\n\n/**\n * readiness\n *\n * Check whether required database connections are reachable.\n */\nexport const getReadyz = <ThrowOnError extends boolean = false>(options?: Options<GetReadyzData, ThrowOnError>) => (options?.client ?? client).get<GetReadyzResponses, GetReadyzErrors, ThrowOnError>({ url: '/readyz', ...options });\n\n/**\n * realtime token\n *\n * Issue a Centrifugo connection token for the authenticated user.\n */\nexport const getRealtimeToken = <ThrowOnError extends boolean = false>(options?: Options<GetRealtimeTokenData, ThrowOnError>) => (options?.client ?? client).get<GetRealtimeTokenResponses, GetRealtimeTokenErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/realtime/token',\n ...options\n});\n\n/**\n * list sessions\n *\n * List live sessions visible to the authenticated user.\n */\nexport const listSessions = <ThrowOnError extends boolean = false>(options?: Options<ListSessionsData, ThrowOnError>) => (options?.client ?? client).get<ListSessionsResponses, ListSessionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions',\n ...options\n});\n\n/**\n * get session\n *\n * Get one live session visible to the authenticated user.\n */\nexport const getSession = <ThrowOnError extends boolean = false>(options: Options<GetSessionData, ThrowOnError>) => (options.client ?? client).get<GetSessionResponses, GetSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}',\n ...options\n});\n\n/**\n * create join token\n *\n * Issue a LiveKit join grant for the current participant.\n */\nexport const createSessionToken = <ThrowOnError extends boolean = false>(options: Options<CreateSessionTokenData, ThrowOnError>) => (options.client ?? client).post<CreateSessionTokenResponses, CreateSessionTokenErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/tokens',\n ...options\n});\n\n/**\n * leave session\n *\n * Mark the current participant as left.\n */\nexport const leaveSession = <ThrowOnError extends boolean = false>(options: Options<LeaveSessionData, ThrowOnError>) => (options.client ?? client).post<LeaveSessionResponses, LeaveSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/leave',\n ...options\n});\n\n/**\n * end session\n *\n * End a full session as a vendor-side host.\n */\nexport const endSession = <ThrowOnError extends boolean = false>(options: Options<EndSessionData, ThrowOnError>) => (options.client ?? client).post<EndSessionResponses, EndSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/end',\n ...options\n});\n\n/**\n * start recording\n *\n * Start the vendor-side call recording for an active session.\n */\nexport const startRecording = <ThrowOnError extends boolean = false>(options: Options<StartRecordingData, ThrowOnError>) => (options.client ?? client).post<StartRecordingResponses, StartRecordingErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/recording/start',\n ...options\n});\n\n/**\n * stop recording\n *\n * Stop the current manual call recording for an active session.\n */\nexport const stopRecording = <ThrowOnError extends boolean = false>(options: Options<StopRecordingData, ThrowOnError>) => (options.client ?? client).post<StopRecordingResponses, StopRecordingErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/recording/stop',\n ...options\n});\n\n/**\n * add participant\n *\n * Add a contact or phone participant to a controllable session.\n */\nexport const addSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<AddSessionParticipantData, ThrowOnError>) => (options.client ?? client).post<AddSessionParticipantResponses, AddSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * remove participant\n *\n * Remove a participant from a controllable session.\n */\nexport const removeSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<RemoveSessionParticipantData, ThrowOnError>) => (options.client ?? client).delete<RemoveSessionParticipantResponses, RemoveSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants/{participantId}',\n ...options\n});\n\n/**\n * accept invite\n *\n * Accept the current user's invited participant.\n */\nexport const acceptSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<AcceptSessionParticipantData, ThrowOnError>) => (options.client ?? client).post<AcceptSessionParticipantResponses, AcceptSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants/{participantId}/accept',\n ...options\n});\n\n/**\n * reject invite\n *\n * Reject the current user's invited participant.\n */\nexport const rejectSessionParticipant = <ThrowOnError extends boolean = false>(options: Options<RejectSessionParticipantData, ThrowOnError>) => (options.client ?? client).post<RejectSessionParticipantResponses, RejectSessionParticipantErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/sessions/{sessionId}/participants/{participantId}/reject',\n ...options\n});\n\n/**\n * create session\n *\n * Create a live voice session for the vendor.\n */\nexport const createSession = <ThrowOnError extends boolean = false>(options: Options<CreateSessionData, ThrowOnError>) => (options.client ?? client).post<CreateSessionResponses, CreateSessionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/sessions',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list my calls\n *\n * List call history visible to the authenticated user.\n */\nexport const listMyCalls = <ThrowOnError extends boolean = false>(options?: Options<ListMyCallsData, ThrowOnError>) => (options?.client ?? client).get<ListMyCallsResponses, ListMyCallsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/calls',\n ...options\n});\n\n/**\n * get my call\n *\n * Get one call visible to the authenticated user.\n */\nexport const getMyCall = <ThrowOnError extends boolean = false>(options: Options<GetMyCallData, ThrowOnError>) => (options.client ?? client).get<GetMyCallResponses, GetMyCallErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/calls/{callId}',\n ...options\n});\n\n/**\n * list vendor calls\n *\n * List vendor call history for an authenticated vendor member.\n */\nexport const listVendorCalls = <ThrowOnError extends boolean = false>(options: Options<ListVendorCallsData, ThrowOnError>) => (options.client ?? client).get<ListVendorCallsResponses, ListVendorCallsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls',\n ...options\n});\n\n/**\n * export vendor calls\n *\n * Export vendor call history as CSV using the same filters as the list endpoint.\n */\nexport const exportVendorCalls = <ThrowOnError extends boolean = false>(options: Options<ExportVendorCallsData, ThrowOnError>) => (options.client ?? client).get<ExportVendorCallsResponses, ExportVendorCallsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/export',\n ...options\n});\n\n/**\n * get vendor call\n *\n * Get one vendor call by ID.\n */\nexport const getVendorCall = <ThrowOnError extends boolean = false>(options: Options<GetVendorCallData, ThrowOnError>) => (options.client ?? client).get<GetVendorCallResponses, GetVendorCallErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}',\n ...options\n});\n\n/**\n * list call recordings\n *\n * List user-facing recordings for one vendor call.\n */\nexport const listCallRecordings = <ThrowOnError extends boolean = false>(options: Options<ListCallRecordingsData, ThrowOnError>) => (options.client ?? client).get<ListCallRecordingsResponses, ListCallRecordingsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/recordings',\n ...options\n});\n\n/**\n * create recording URL\n *\n * Create a short-lived playback URL for an available call recording.\n */\nexport const createCallRecordingUrl = <ThrowOnError extends boolean = false>(options: Options<CreateCallRecordingUrlData, ThrowOnError>) => (options.client ?? client).post<CreateCallRecordingUrlResponses, CreateCallRecordingUrlErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/recordings/{recordingId}/url',\n ...options\n});\n\n/**\n * wrap up call\n *\n * Update vendor wrap-up fields. Omitted fields are unchanged.\n */\nexport const updateCallWrapUp = <ThrowOnError extends boolean = false>(options: Options<UpdateCallWrapUpData, ThrowOnError>) => (options.client ?? client).patch<UpdateCallWrapUpResponses, UpdateCallWrapUpErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/wrap-up',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list call notes\n *\n * List vendor notes attached to a call.\n */\nexport const listCallNotes = <ThrowOnError extends boolean = false>(options: Options<ListCallNotesData, ThrowOnError>) => (options.client ?? client).get<ListCallNotesResponses, ListCallNotesErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes',\n ...options\n});\n\n/**\n * create call note\n *\n * Add a vendor note to a call.\n */\nexport const createCallNote = <ThrowOnError extends boolean = false>(options: Options<CreateCallNoteData, ThrowOnError>) => (options.client ?? client).post<CreateCallNoteResponses, CreateCallNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete call note\n *\n * Delete a vendor call note.\n */\nexport const deleteCallNote = <ThrowOnError extends boolean = false>(options: Options<DeleteCallNoteData, ThrowOnError>) => (options.client ?? client).delete<DeleteCallNoteResponses, DeleteCallNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes/{noteId}',\n ...options\n});\n\n/**\n * update call note\n *\n * Update a vendor call note.\n */\nexport const updateCallNote = <ThrowOnError extends boolean = false>(options: Options<UpdateCallNoteData, ThrowOnError>) => (options.client ?? client).put<UpdateCallNoteResponses, UpdateCallNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/notes/{noteId}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list call tasks\n *\n * List vendor follow-up tasks attached to a call.\n */\nexport const listCallTasks = <ThrowOnError extends boolean = false>(options: Options<ListCallTasksData, ThrowOnError>) => (options.client ?? client).get<ListCallTasksResponses, ListCallTasksErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/tasks',\n ...options\n});\n\n/**\n * create call task\n *\n * Create a vendor follow-up task for a call.\n */\nexport const createCallTask = <ThrowOnError extends boolean = false>(options: Options<CreateCallTaskData, ThrowOnError>) => (options.client ?? client).post<CreateCallTaskResponses, CreateCallTaskErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/tasks',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * update call task\n *\n * Update a vendor call task.\n */\nexport const updateCallTask = <ThrowOnError extends boolean = false>(options: Options<UpdateCallTaskData, ThrowOnError>) => (options.client ?? client).put<UpdateCallTaskResponses, UpdateCallTaskErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/calls/{callId}/tasks/{taskId}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * telephone settings\n *\n * Get vendor telephone settings and provider sync status.\n */\nexport const getTelephone = <ThrowOnError extends boolean = false>(options: Options<GetTelephoneData, ThrowOnError>) => (options.client ?? client).get<GetTelephoneResponses, GetTelephoneErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/telephone',\n ...options\n});\n\n/**\n * update telephone settings\n *\n * Update vendor telephone enablement and audio processing settings.\n */\nexport const updateTelephoneSettings = <ThrowOnError extends boolean = false>(options: Options<UpdateTelephoneSettingsData, ThrowOnError>) => (options.client ?? client).patch<UpdateTelephoneSettingsResponses, UpdateTelephoneSettingsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/telephone/settings',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * sync telephone\n *\n * Sync LiveKit SIP resources for the vendor and return provider status.\n */\nexport const syncTelephone = <ThrowOnError extends boolean = false>(options: Options<SyncTelephoneData, ThrowOnError>) => (options.client ?? client).post<SyncTelephoneResponses, SyncTelephoneErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/telephone/sync',\n ...options\n});\n\n/**\n * get routing policy\n *\n * Get the routing policy for a team or agent target. If no policy is saved, returns the default open policy with a null id.\n */\nexport const getRoutingPolicy = <ThrowOnError extends boolean = false>(options: Options<GetRoutingPolicyData, ThrowOnError>) => (options.client ?? client).get<GetRoutingPolicyResponses, GetRoutingPolicyErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/routing/policies/{targetKind}/{targetId}',\n ...options\n});\n\n/**\n * replace routing policy\n *\n * Replace the full routing policy for a team or agent target.\n */\nexport const putRoutingPolicy = <ThrowOnError extends boolean = false>(options: Options<PutRoutingPolicyData, ThrowOnError>) => (options.client ?? client).put<PutRoutingPolicyResponses, PutRoutingPolicyErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/routing/policies/{targetKind}/{targetId}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list contacts\n *\n * Paginated list of contacts for the vendor, with search, filters, and sorting.\n */\nexport const listContacts = <ThrowOnError extends boolean = false>(options: Options<ListContactsData, ThrowOnError>) => (options.client ?? client).get<ListContactsResponses, ListContactsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts',\n ...options\n});\n\n/**\n * create contact\n *\n * Create a vendor contact with optional tags and inline notes.\n */\nexport const createContact = <ThrowOnError extends boolean = false>(options: Options<CreateContactData, ThrowOnError>) => (options.client ?? client).post<CreateContactResponses, CreateContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete contact\n *\n * Delete a contact from the vendor contact list.\n */\nexport const deleteContact = <ThrowOnError extends boolean = false>(options: Options<DeleteContactData, ThrowOnError>) => (options.client ?? client).delete<DeleteContactResponses, DeleteContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}',\n ...options\n});\n\n/**\n * get contact\n *\n * Get a full contact profile. Notes are fetched separately.\n */\nexport const getContact = <ThrowOnError extends boolean = false>(options: Options<GetContactData, ThrowOnError>) => (options.client ?? client).get<GetContactResponses, GetContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}',\n ...options\n});\n\n/**\n * update contact\n *\n * Update contact fields such as profile, status, owner, and tags.\n */\nexport const updateContact = <ThrowOnError extends boolean = false>(options: Options<UpdateContactData, ThrowOnError>) => (options.client ?? client).put<UpdateContactResponses, UpdateContactErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list notes\n *\n * Paginated notes attached to a contact.\n */\nexport const listContactNotes = <ThrowOnError extends boolean = false>(options: Options<ListContactNotesData, ThrowOnError>) => (options.client ?? client).get<ListContactNotesResponses, ListContactNotesErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}/notes',\n ...options\n});\n\n/**\n * add note\n *\n * Add a timestamped note to a contact.\n */\nexport const addContactNote = <ThrowOnError extends boolean = false>(options: Options<AddContactNoteData, ThrowOnError>) => (options.client ?? client).post<AddContactNoteResponses, AddContactNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}/notes',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete note\n *\n * Delete a note from a contact.\n */\nexport const deleteContactNote = <ThrowOnError extends boolean = false>(options: Options<DeleteContactNoteData, ThrowOnError>) => (options.client ?? client).delete<DeleteContactNoteResponses, DeleteContactNoteErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/contacts/{id}/notes/{noteId}',\n ...options\n});\n\n/**\n * vendor info\n *\n * Get the current vendor profile for the route slug.\n */\nexport const getVendor = <ThrowOnError extends boolean = false>(options: Options<GetVendorData, ThrowOnError>) => (options.client ?? client).get<GetVendorResponses, GetVendorErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}',\n ...options\n});\n\n/**\n * team members\n *\n * Paginated vendor members, with optional search.\n */\nexport const listVendorMembers = <ThrowOnError extends boolean = false>(options: Options<ListVendorMembersData, ThrowOnError>) => (options.client ?? client).get<ListVendorMembersResponses, ListVendorMembersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/members',\n ...options\n});\n\n/**\n * team member\n *\n * Get a single vendor member by Gopaddi user ID.\n */\nexport const getVendorMember = <ThrowOnError extends boolean = false>(options: Options<GetVendorMemberData, ThrowOnError>) => (options.client ?? client).get<GetVendorMemberResponses, GetVendorMemberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/members/{userId}',\n ...options\n});\n\n/**\n * wallet\n *\n * Get wallet balance, top-up minimum, and supported payment channels.\n */\nexport const getBillingWallet = <ThrowOnError extends boolean = false>(options: Options<GetBillingWalletData, ThrowOnError>) => (options.client ?? client).get<GetBillingWalletResponses, GetBillingWalletErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/wallet',\n ...options\n});\n\n/**\n * update wallet settings\n *\n * Update low-balance and auto top-up settings.\n */\nexport const updateBillingWalletSettings = <ThrowOnError extends boolean = false>(options: Options<UpdateBillingWalletSettingsData, ThrowOnError>) => (options.client ?? client).patch<UpdateBillingWalletSettingsResponses, UpdateBillingWalletSettingsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/wallet/settings',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list top-ups\n *\n * Paginated wallet top-up requests.\n */\nexport const listBillingTopups = <ThrowOnError extends boolean = false>(options: Options<ListBillingTopupsData, ThrowOnError>) => (options.client ?? client).get<ListBillingTopupsResponses, ListBillingTopupsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups',\n ...options\n});\n\n/**\n * create top-up\n *\n * Create a Paystack checkout top-up for the vendor wallet.\n */\nexport const createBillingTopup = <ThrowOnError extends boolean = false>(options: Options<CreateBillingTopupData, ThrowOnError>) => (options.client ?? client).post<CreateBillingTopupResponses, CreateBillingTopupErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * get top-up\n *\n * Get a wallet top-up request.\n */\nexport const getBillingTopup = <ThrowOnError extends boolean = false>(options: Options<GetBillingTopupData, ThrowOnError>) => (options.client ?? client).get<GetBillingTopupResponses, GetBillingTopupErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups/{topupId}',\n ...options\n});\n\n/**\n * verify top-up\n *\n * Verify a Paystack top-up and return the resulting wallet state.\n */\nexport const verifyBillingTopup = <ThrowOnError extends boolean = false>(options: Options<VerifyBillingTopupData, ThrowOnError>) => (options.client ?? client).post<VerifyBillingTopupResponses, VerifyBillingTopupErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/topups/{topupId}/verify',\n ...options\n});\n\n/**\n * payment methods\n *\n * List saved reusable billing payment methods.\n */\nexport const listBillingPaymentMethods = <ThrowOnError extends boolean = false>(options: Options<ListBillingPaymentMethodsData, ThrowOnError>) => (options.client ?? client).get<ListBillingPaymentMethodsResponses, ListBillingPaymentMethodsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/payment-methods',\n ...options\n});\n\n/**\n * delete payment method\n *\n * Disable a saved payment method.\n */\nexport const deleteBillingPaymentMethod = <ThrowOnError extends boolean = false>(options: Options<DeleteBillingPaymentMethodData, ThrowOnError>) => (options.client ?? client).delete<DeleteBillingPaymentMethodResponses, DeleteBillingPaymentMethodErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/payment-methods/{paymentMethodId}',\n ...options\n});\n\n/**\n * estimate voice charge\n *\n * Estimate the initial hold for app-media or telephony voice charging.\n */\nexport const estimateBillingVoiceCharge = <ThrowOnError extends boolean = false>(options: Options<EstimateBillingVoiceChargeData, ThrowOnError>) => (options.client ?? client).post<EstimateBillingVoiceChargeResponses, EstimateBillingVoiceChargeErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/voice/estimate',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * transactions\n *\n * Paginated wallet transactions with kind, status, and date filters.\n */\nexport const listBillingTransactions = <ThrowOnError extends boolean = false>(options: Options<ListBillingTransactionsData, ThrowOnError>) => (options.client ?? client).get<ListBillingTransactionsResponses, ListBillingTransactionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/transactions',\n ...options\n});\n\n/**\n * export transactions\n *\n * Export wallet transactions as CSV using the same transaction filters.\n */\nexport const exportBillingTransactions = <ThrowOnError extends boolean = false>(options: Options<ExportBillingTransactionsData, ThrowOnError>) => (options.client ?? client).get<ExportBillingTransactionsResponses, ExportBillingTransactionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/billing/transactions/export',\n ...options\n});\n\n/**\n * list agents\n *\n * Paginated list of agents for the vendor, with search, filters, and sorting.\n */\nexport const listAgents = <ThrowOnError extends boolean = false>(options: Options<ListAgentsData, ThrowOnError>) => (options.client ?? client).get<ListAgentsResponses, ListAgentsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents',\n ...options\n});\n\n/**\n * create agent\n *\n * Register a Gopaddi user as an agent for this vendor.\n */\nexport const createAgent = <ThrowOnError extends boolean = false>(options: Options<CreateAgentData, ThrowOnError>) => (options.client ?? client).post<CreateAgentResponses, CreateAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * bulk create agents\n *\n * Register multiple vendor members as agents in one request.\n */\nexport const bulkCreateAgents = <ThrowOnError extends boolean = false>(options: Options<BulkCreateAgentsData, ThrowOnError>) => (options.client ?? client).post<BulkCreateAgentsResponses, BulkCreateAgentsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/bulk',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * agent stats\n *\n * Aggregate agent counts by status for this vendor.\n */\nexport const getAgentStats = <ThrowOnError extends boolean = false>(options: Options<GetAgentStatsData, ThrowOnError>) => (options.client ?? client).get<GetAgentStatsResponses, GetAgentStatsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/stats',\n ...options\n});\n\n/**\n * delete agent\n *\n * Remove an agent and clean up directory assignments.\n */\nexport const deleteAgent = <ThrowOnError extends boolean = false>(options: Options<DeleteAgentData, ThrowOnError>) => (options.client ?? client).delete<DeleteAgentResponses, DeleteAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/{id}',\n ...options\n});\n\n/**\n * get agent\n *\n * Full agent profile including teams, extensions, and assigned numbers.\n */\nexport const getAgent = <ThrowOnError extends boolean = false>(options: Options<GetAgentData, ThrowOnError>) => (options.client ?? client).get<GetAgentResponses, GetAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/{id}',\n ...options\n});\n\n/**\n * update agent\n *\n * Update agent role, status, or outbound number.\n */\nexport const updateAgent = <ThrowOnError extends boolean = false>(options: Options<UpdateAgentData, ThrowOnError>) => (options.client ?? client).put<UpdateAgentResponses, UpdateAgentErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/agents/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list teams\n *\n * Paginated list of teams for the vendor, with search, filters, and sorting.\n */\nexport const listTeams = <ThrowOnError extends boolean = false>(options: Options<ListTeamsData, ThrowOnError>) => (options.client ?? client).get<ListTeamsResponses, ListTeamsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams',\n ...options\n});\n\n/**\n * create team\n *\n * Create a team with optional members and assigned numbers.\n */\nexport const createTeam = <ThrowOnError extends boolean = false>(options: Options<CreateTeamData, ThrowOnError>) => (options.client ?? client).post<CreateTeamResponses, CreateTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * team stats\n *\n * Aggregate team counts, assigned numbers, and total members.\n */\nexport const getTeamStats = <ThrowOnError extends boolean = false>(options: Options<GetTeamStatsData, ThrowOnError>) => (options.client ?? client).get<GetTeamStatsResponses, GetTeamStatsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/stats',\n ...options\n});\n\n/**\n * delete team\n *\n * Delete a team and clean up member, number, and extension links.\n */\nexport const deleteTeam = <ThrowOnError extends boolean = false>(options: Options<DeleteTeamData, ThrowOnError>) => (options.client ?? client).delete<DeleteTeamResponses, DeleteTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}',\n ...options\n});\n\n/**\n * get team\n *\n * Full team detail including members, numbers, extensions, and routing policy.\n */\nexport const getTeam = <ThrowOnError extends boolean = false>(options: Options<GetTeamData, ThrowOnError>) => (options.client ?? client).get<GetTeamResponses, GetTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}',\n ...options\n});\n\n/**\n * update team\n *\n * Update team properties, membership, assigned numbers, or routing policy.\n */\nexport const updateTeam = <ThrowOnError extends boolean = false>(options: Options<UpdateTeamData, ThrowOnError>) => (options.client ?? client).put<UpdateTeamResponses, UpdateTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * duplicate team\n *\n * Clone a team's configuration and members into a new team.\n */\nexport const duplicateTeam = <ThrowOnError extends boolean = false>(options: Options<DuplicateTeamData, ThrowOnError>) => (options.client ?? client).post<DuplicateTeamResponses, DuplicateTeamErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{id}/duplicate',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * list numbers\n *\n * Paginated vendor phone numbers, with search, filters, and sorting.\n */\nexport const listNumbers = <ThrowOnError extends boolean = false>(options: Options<ListNumbersData, ThrowOnError>) => (options.client ?? client).get<ListNumbersResponses, ListNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers',\n ...options\n});\n\n/**\n * catalog\n *\n * List purchasable phone numbers from the number catalog.\n */\nexport const listNumberCatalog = <ThrowOnError extends boolean = false>(options: Options<ListNumberCatalogData, ThrowOnError>) => (options.client ?? client).get<ListNumberCatalogResponses, ListNumberCatalogErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/catalog',\n ...options\n});\n\n/**\n * purchase numbers\n *\n * Purchase catalog numbers and optionally assign them during checkout.\n */\nexport const purchaseNumbers = <ThrowOnError extends boolean = false>(options: Options<PurchaseNumbersData, ThrowOnError>) => (options.client ?? client).post<PurchaseNumbersResponses, PurchaseNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/purchases',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * quote purchase\n *\n * Quote catalog numbers before purchase.\n */\nexport const quoteNumberPurchase = <ThrowOnError extends boolean = false>(options: Options<QuoteNumberPurchaseData, ThrowOnError>) => (options.client ?? client).post<QuoteNumberPurchaseResponses, QuoteNumberPurchaseErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/purchase-quotes',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * get number subscription\n *\n * Get billing subscription state for a purchased number.\n */\nexport const getNumberSubscription = <ThrowOnError extends boolean = false>(options: Options<GetNumberSubscriptionData, ThrowOnError>) => (options.client ?? client).get<GetNumberSubscriptionResponses, GetNumberSubscriptionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/subscription',\n ...options\n});\n\n/**\n * cancel number subscription\n *\n * Schedule number subscription cancellation at the end of the paid period.\n */\nexport const cancelNumberSubscription = <ThrowOnError extends boolean = false>(options: Options<CancelNumberSubscriptionData, ThrowOnError>) => (options.client ?? client).post<CancelNumberSubscriptionResponses, CancelNumberSubscriptionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/subscription/cancel',\n ...options\n});\n\n/**\n * bulk suspend\n *\n * Suspend multiple active vendor numbers in one request.\n */\nexport const bulkSuspendNumbers = <ThrowOnError extends boolean = false>(options: Options<BulkSuspendNumbersData, ThrowOnError>) => (options.client ?? client).post<BulkSuspendNumbersResponses, BulkSuspendNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/bulk/suspend',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * bulk activate\n *\n * Activate multiple suspended vendor numbers in one request.\n */\nexport const bulkActivateNumbers = <ThrowOnError extends boolean = false>(options: Options<BulkActivateNumbersData, ThrowOnError>) => (options.client ?? client).post<BulkActivateNumbersResponses, BulkActivateNumbersErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/bulk/activate',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * get number\n *\n * Get a phone number with current status and assignment.\n */\nexport const getNumber = <ThrowOnError extends boolean = false>(options: Options<GetNumberData, ThrowOnError>) => (options.client ?? client).get<GetNumberResponses, GetNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}',\n ...options\n});\n\n/**\n * assign number\n *\n * Assign or reassign a phone number to a team or agent.\n */\nexport const assignNumber = <ThrowOnError extends boolean = false>(options: Options<AssignNumberData, ThrowOnError>) => (options.client ?? client).put<AssignNumberResponses, AssignNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/assign',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * unassign number\n *\n * Remove the current assignment from a phone number.\n */\nexport const unassignNumber = <ThrowOnError extends boolean = false>(options: Options<UnassignNumberData, ThrowOnError>) => (options.client ?? client).put<UnassignNumberResponses, UnassignNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/unassign',\n ...options\n});\n\n/**\n * suspend number\n *\n * Change an active phone number to suspended.\n */\nexport const suspendNumber = <ThrowOnError extends boolean = false>(options: Options<SuspendNumberData, ThrowOnError>) => (options.client ?? client).put<SuspendNumberResponses, SuspendNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/suspend',\n ...options\n});\n\n/**\n * activate number\n *\n * Change a suspended phone number back to active.\n */\nexport const activateNumber = <ThrowOnError extends boolean = false>(options: Options<ActivateNumberData, ThrowOnError>) => (options.client ?? client).put<ActivateNumberResponses, ActivateNumberErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/numbers/{id}/activate',\n ...options\n});\n\n/**\n * list extensions\n *\n * List extensions on a phone number within a team.\n */\nexport const listExtensions = <ThrowOnError extends boolean = false>(options: Options<ListExtensionsData, ThrowOnError>) => (options.client ?? client).get<ListExtensionsResponses, ListExtensionsErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions',\n ...options\n});\n\n/**\n * create extension\n *\n * Add an extension to a team-owned phone number.\n */\nexport const createExtension = <ThrowOnError extends boolean = false>(options: Options<CreateExtensionData, ThrowOnError>) => (options.client ?? client).post<CreateExtensionResponses, CreateExtensionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n\n/**\n * delete extension\n *\n * Remove an extension from a phone number.\n */\nexport const deleteExtension = <ThrowOnError extends boolean = false>(options: Options<DeleteExtensionData, ThrowOnError>) => (options.client ?? client).delete<DeleteExtensionResponses, DeleteExtensionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions/{id}',\n ...options\n});\n\n/**\n * update extension\n *\n * Update extension number, label, assignee, or status.\n */\nexport const updateExtension = <ThrowOnError extends boolean = false>(options: Options<UpdateExtensionData, ThrowOnError>) => (options.client ?? client).put<UpdateExtensionResponses, UpdateExtensionErrors, ThrowOnError>({\n security: [{ scheme: 'bearer', type: 'http' }],\n url: '/api/v1/vendors/{vendor}/teams/{teamId}/numbers/{numberId}/extensions/{id}',\n ...options,\n headers: {\n 'Content-Type': 'application/json',\n ...options.headers\n }\n});\n","import type { ClientEvents, Unsubscribe } from \"./types\";\n\ntype Listener<K extends keyof ClientEvents> = (payload: ClientEvents[K]) => void;\n\nexport type Emitter = {\n on: <K extends keyof ClientEvents>(event: K, fn: Listener<K>) => Unsubscribe;\n emit: <K extends keyof ClientEvents>(event: K, payload: ClientEvents[K]) => void;\n};\n\nexport const createEmitter = (): Emitter => {\n const listeners = new Map<keyof ClientEvents, Set<Listener<keyof ClientEvents>>>();\n\n const emit = <K extends keyof ClientEvents>(event: K, payload: ClientEvents[K]): void => {\n const fns = listeners.get(event) as Set<Listener<K>> | undefined;\n if (!fns) {\n return;\n }\n for (const fn of fns) {\n try {\n fn(payload);\n } catch (err) {\n if (event !== \"error\") {\n emit(\"error\", err instanceof Error ? err : new Error(\"Event listener failed\"));\n }\n }\n }\n };\n\n return {\n on: (event, fn) => {\n let fns = listeners.get(event);\n if (!fns) {\n fns = new Set();\n listeners.set(event, fns);\n }\n fns.add(fn as Listener<keyof ClientEvents>);\n return () => {\n fns?.delete(fn as Listener<keyof ClientEvents>);\n if (fns?.size === 0) {\n listeners.delete(event);\n }\n };\n },\n emit,\n };\n};\n","import { Centrifuge, UnauthorizedError } from \"centrifuge\";\n\nimport { CallpadError, unwrap, type Auth } from \"../api/client\";\nimport { getRealtimeToken, type RealtimeToken, type VoiceSession } from \"../api/generated\";\nimport type { Client } from \"../api/generated/client\";\nimport type { Emitter } from \"./events\";\nimport type { RemoveSessionPayload, SessionStore } from \"./store\";\nimport type { ClientStatus } from \"./types\";\nimport type { Nullable } from \"../shared/types\";\n\ntype RealtimeMessage =\n | { event: \"session.upsert\"; data: VoiceSession }\n | { event: \"session.remove\"; data: RemoveSessionPayload };\n\nexport type Realtime = {\n connect: () => Promise<void>;\n disconnect: () => Promise<void>;\n dispose: () => Promise<void>;\n};\n\nexport const createRealtime = (\n client: Client,\n auth: Auth,\n store: SessionStore,\n emitter: Emitter,\n): Realtime => {\n let rt: Nullable<Centrifuge> = null;\n let disposed = false;\n\n const fetchToken = async (): Promise<RealtimeToken> => unwrap(getRealtimeToken({ client }), auth);\n\n const refreshToken = async (): Promise<string> => {\n try {\n const token = await fetchToken();\n return token.token;\n } catch (err) {\n if (err instanceof CallpadError && (err.status === 401 || err.status === 403)) {\n throw new UnauthorizedError(err.message);\n }\n throw err;\n }\n };\n\n const applyMessage = (message: RealtimeMessage): void => {\n if (message.event === \"session.upsert\") {\n const change = store.upsert(message.data);\n if (change === \"added\") {\n emitter.emit(\"session.added\", message.data);\n }\n if (change === \"updated\") {\n emitter.emit(\"session.updated\", message.data);\n }\n return;\n }\n\n if (store.remove(message.data)) {\n emitter.emit(\"session.removed\", {\n sessionId: message.data.id,\n vendor: message.data.vendor,\n version: message.data.version,\n });\n }\n };\n\n const setStatus = (status: ClientStatus): void => {\n store.setStatus(status);\n emitter.emit(\"status\", status);\n };\n\n const disconnect = async (): Promise<void> => {\n rt?.disconnect();\n rt = null;\n if (!disposed) {\n setStatus(\"offline\");\n }\n };\n\n return {\n connect: async () => {\n if (rt) {\n return;\n }\n disposed = false;\n setStatus(\"connecting\");\n\n try {\n const first = await fetchToken();\n rt = new Centrifuge(first.url, {\n token: first.token,\n getToken: refreshToken,\n });\n rt.on(\"connecting\", () => {\n const next = store.getStatus() === \"ready\" ? \"reconnecting\" : \"connecting\";\n setStatus(next);\n });\n rt.on(\"connected\", () => {\n setStatus(\"ready\");\n });\n rt.on(\"disconnected\", () => {\n if (!disposed) {\n setStatus(\"offline\");\n }\n });\n rt.on(\"error\", (ctx) => {\n emitter.emit(\"error\", new Error(ctx.error.message));\n });\n rt.on(\"publication\", (ctx) => {\n try {\n const message = parseMessage(ctx.data);\n if (message) {\n applyMessage(message);\n }\n } catch (err) {\n emitter.emit(\"error\", err instanceof Error ? err : new Error(\"Realtime event failed\"));\n }\n });\n rt.connect();\n await rt.ready();\n } catch (err) {\n await disconnect();\n throw err;\n }\n },\n disconnect,\n dispose: async () => {\n disposed = true;\n rt?.disconnect();\n rt = null;\n setStatus(\"disposed\");\n },\n };\n};\n\nconst parseMessage = (value: unknown): Nullable<RealtimeMessage> => {\n if (!value || typeof value !== \"object\") {\n return null;\n }\n const message = value as Partial<RealtimeMessage>;\n if (message.event === \"session.upsert\" && message.data) {\n return message as RealtimeMessage;\n }\n if (message.event === \"session.remove\" && message.data) {\n return message as RealtimeMessage;\n }\n return null;\n};\n","import type { ClientStatus, SessionAction, SessionInvite, StoreTopic, Unsubscribe } from \"./types\";\nimport type { SessionRecordingControl, VoiceParticipant, VoiceSession } from \"../api/generated\";\nimport type { Nullable } from \"../shared/types\";\n\nexport type RemoveSessionPayload = {\n id: string;\n vendor?: string;\n version?: number;\n};\n\nexport type UpsertMode = \"event\" | \"command\";\n\nexport type SessionStore = {\n getStatus: () => ClientStatus;\n setStatus: (status: ClientStatus) => void;\n list: () => readonly VoiceSession[];\n get: (sessionId?: string) => Nullable<VoiceSession>;\n invites: () => readonly SessionInvite[];\n invite: (sessionId: string) => Nullable<SessionInvite>;\n sync: (items: readonly VoiceSession[]) => void;\n upsert: (session: VoiceSession, mode?: UpsertMode) => \"added\" | \"updated\" | null;\n remove: (payload: RemoveSessionPayload) => boolean;\n patchRecording: (control: SessionRecordingControl) => Nullable<VoiceSession>;\n can: (session: VoiceSession, action: SessionAction) => boolean;\n subscribe: (topic: StoreTopic, fn: () => void) => Unsubscribe;\n dispose: () => void;\n};\n\nexport const createSessionStore = (userId: number): SessionStore => {\n const sessions = new Map<string, VoiceSession>();\n const subscribers = new Map<StoreTopic, Set<() => void>>();\n let status: ClientStatus = \"idle\";\n let activeId: Nullable<string> = null;\n let listCache: readonly VoiceSession[] = [];\n let invitesCache: readonly SessionInvite[] = [];\n let inviteKey = \"\";\n let inviteExpiryTimer: Nullable<ReturnType<typeof globalThis.setTimeout>> = null;\n\n const emit = (topic: StoreTopic): void => {\n const fns = subscribers.get(topic);\n if (!fns) {\n return;\n }\n for (const fn of fns) {\n fn();\n }\n };\n\n const subscribe = (topic: StoreTopic, fn: () => void): Unsubscribe => {\n let fns = subscribers.get(topic);\n if (!fns) {\n fns = new Set();\n subscribers.set(topic, fns);\n }\n fns.add(fn);\n return () => {\n fns?.delete(fn);\n if (fns?.size === 0) {\n subscribers.delete(topic);\n }\n };\n };\n\n const refresh = (): void => {\n listCache = Array.from(sessions.values()).sort((a, b) =>\n b.createdAt.localeCompare(a.createdAt),\n );\n if (activeId) {\n const active = sessions.get(activeId);\n if (!active || active.state === \"ended\") {\n activeId = null;\n }\n }\n if (!activeId) {\n activeId = listCache.find((session) => session.state !== \"ended\")?.id ?? null;\n }\n };\n\n const refreshInvites = (): boolean => {\n const now = Date.now();\n const invites = listCache\n .map((session) => inviteFrom(session, userId, now))\n .filter((invite) => invite !== null);\n scheduleInviteExpiry(invites, now);\n const nextKey = invites\n .map(\n (invite) =>\n `${invite.session.id}:${invite.participant.id}:${invite.participant.state}:${invite.participant.inviteExpiresAt ?? \"\"}`,\n )\n .join(\"|\");\n if (nextKey === inviteKey) {\n invitesCache = invites;\n return false;\n }\n inviteKey = nextKey;\n invitesCache = invites;\n return true;\n };\n\n const clearInviteExpiryTimer = (): void => {\n if (inviteExpiryTimer) {\n globalThis.clearTimeout(inviteExpiryTimer);\n inviteExpiryTimer = null;\n }\n };\n\n const scheduleInviteExpiry = (invites: readonly SessionInvite[], now: number): void => {\n clearInviteExpiryTimer();\n const nextExpiry = invites.reduce<Nullable<number>>((min, invite) => {\n const expiresAt = inviteExpiryMs(invite.participant);\n if (expiresAt === null) {\n return min;\n }\n return min === null ? expiresAt : Math.min(min, expiresAt);\n }, null);\n if (nextExpiry === null) {\n return;\n }\n\n inviteExpiryTimer = globalThis.setTimeout(\n () => {\n inviteExpiryTimer = null;\n if (refreshInvites()) {\n emit(\"invites\");\n }\n },\n Math.max(0, nextExpiry - now),\n );\n };\n\n const notifySessionChange = (sessionId: string): void => {\n refresh();\n const invitesChanged = refreshInvites();\n emit(`session:${sessionId}`);\n emit(\"sessions\");\n if (invitesChanged) {\n emit(\"invites\");\n }\n };\n\n const get = (sessionId?: string): Nullable<VoiceSession> => {\n if (sessionId) {\n return sessions.get(sessionId) ?? null;\n }\n if (!activeId) {\n return null;\n }\n return sessions.get(activeId) ?? null;\n };\n\n const upsert = (\n session: VoiceSession,\n mode: UpsertMode = \"event\",\n ): \"added\" | \"updated\" | null => {\n const prev = sessions.get(session.id);\n const stale = prev\n ? mode === \"command\"\n ? session.version < prev.version\n : session.version <= prev.version\n : false;\n if (stale) {\n return null;\n }\n sessions.set(session.id, session);\n notifySessionChange(session.id);\n return prev ? \"updated\" : \"added\";\n };\n\n return {\n getStatus: () => status,\n setStatus: (next) => {\n if (status === next) {\n return;\n }\n status = next;\n emit(\"status\");\n },\n list: () => listCache,\n get,\n invites: () => invitesCache,\n invite: (sessionId) => invitesCache.find((invite) => invite.session.id === sessionId) ?? null,\n sync: (items) => {\n for (const session of items) {\n const prev = sessions.get(session.id);\n if (!prev || session.version >= prev.version) {\n sessions.set(session.id, session);\n }\n }\n refresh();\n const invitesChanged = refreshInvites();\n emit(\"sessions\");\n for (const session of items) {\n emit(`session:${session.id}`);\n }\n if (invitesChanged) {\n emit(\"invites\");\n }\n },\n upsert,\n remove: (payload) => {\n const prev = sessions.get(payload.id);\n if (!prev) {\n return false;\n }\n if (payload.version !== undefined && payload.version < prev.version) {\n return false;\n }\n sessions.delete(payload.id);\n notifySessionChange(payload.id);\n return true;\n },\n patchRecording: (control) => {\n const prev = sessions.get(control.sessionId);\n if (!prev || control.sessionVersion < prev.version) {\n return null;\n }\n const next = {\n ...prev,\n version: Math.max(prev.version, control.sessionVersion),\n recording: control.recording,\n };\n sessions.set(next.id, next);\n notifySessionChange(next.id);\n return next;\n },\n can: (session, action) => can(session, userId, action),\n dispose: () => {\n clearInviteExpiryTimer();\n subscribers.clear();\n },\n subscribe,\n };\n};\n\nconst selfParticipant = (session: VoiceSession, userId: number): Nullable<VoiceParticipant> =>\n session.participants.find((participant) => participant.userId === userId) ?? null;\n\nconst inviteFrom = (\n session: VoiceSession,\n userId: number,\n now: number,\n): Nullable<SessionInvite> => {\n const participant = selfParticipant(session, userId);\n if (!participant || session.state === \"ended\" || !isActiveInvite(participant, now)) {\n return null;\n }\n return { session, participant };\n};\n\nconst can = (session: VoiceSession, userId: number, action: SessionAction): boolean => {\n const self = selfParticipant(session, userId);\n if (!self || session.state === \"ended\") {\n return false;\n }\n\n switch (action) {\n case \"accept\":\n case \"reject\":\n return isActiveInvite(self);\n case \"join\":\n return self.transport === \"webrtc\" && (self.state === \"accepted\" || self.state === \"joined\");\n case \"leave\":\n return self.state === \"accepted\" || self.state === \"joined\";\n case \"end\":\n case \"addParticipant\":\n case \"removeParticipant\":\n return isHost(self) && (self.state === \"accepted\" || self.state === \"joined\");\n case \"startRecording\":\n return isHost(self) && session.state === \"active\" && session.recording.status === \"off\";\n case \"stopRecording\":\n return isHost(self) && session.recording.status === \"recording\";\n }\n};\n\nconst isActiveInvite = (participant: VoiceParticipant, now = Date.now()): boolean => {\n const expiresAt = inviteExpiryMs(participant);\n return participant.state === \"invited\" && expiresAt !== null && expiresAt > now;\n};\n\nconst inviteExpiryMs = (participant: VoiceParticipant): Nullable<number> => {\n if (!participant.inviteExpiresAt) {\n return null;\n }\n const expiresAt = Date.parse(participant.inviteExpiresAt);\n return Number.isFinite(expiresAt) ? expiresAt : null;\n};\n\nconst isHost = (participant: VoiceParticipant): boolean =>\n participant.role === \"host\" &&\n (participant.kind === \"agent\" || participant.kind === \"vendor_user\");\n","import { apiClient, unwrap } from \"../api/client\";\nimport {\n acceptSessionParticipant,\n addSessionParticipant,\n createSession,\n createSessionToken,\n endSession,\n leaveSession,\n listSessions,\n rejectSessionParticipant,\n removeSessionParticipant,\n startRecording as apiStartRecording,\n stopRecording as apiStopRecording,\n} from \"../api/generated\";\nimport type { SessionRecordingControl, StartedSession, VoiceSession } from \"../api/generated\";\nimport { createEmitter } from \"./events\";\nimport { createRealtime } from \"./realtime\";\nimport { createSessionStore, type UpsertMode } from \"./store\";\nimport type {\n CustomerStartInput,\n HostClient,\n HostClientConfig,\n HostControls,\n HostParticipantInput,\n HostStartInput,\n ListQuery,\n ParticipantRef,\n SessionClient,\n SessionClientConfig,\n Sessions,\n} from \"./types\";\n\nexport const createSessionClient = (config: SessionClientConfig): SessionClient => {\n const core = createCore(config);\n\n return {\n kind: \"session\",\n get status() {\n return core.store.getStatus();\n },\n sessions: {\n ...createCommonSessions(core),\n start: (input) => startSession(core, input.vendor, input.target),\n },\n invites: {\n list: core.store.invites,\n get: core.store.invite,\n },\n connect: core.connect,\n disconnect: core.realtime.disconnect,\n dispose: core.dispose,\n on: core.emitter.on,\n subscribe: core.store.subscribe,\n };\n};\n\nexport const createHostClient = (config: HostClientConfig): HostClient => {\n const core = createCore(config);\n\n return {\n kind: \"host\",\n vendor: config.vendor,\n get status() {\n return core.store.getStatus();\n },\n sessions: {\n ...createCommonSessions(core),\n start: (input) => startSession(core, config.vendor, input.target),\n },\n invites: {\n list: core.store.invites,\n get: core.store.invite,\n },\n host: createHostControls(core),\n connect: core.connect,\n disconnect: core.realtime.disconnect,\n dispose: core.dispose,\n on: core.emitter.on,\n subscribe: core.store.subscribe,\n };\n};\n\ntype Core = ReturnType<typeof createCore>;\n\nconst createCore = (config: SessionClientConfig) => {\n const api = apiClient(config);\n const store = createSessionStore(config.userId);\n const emitter = createEmitter();\n const realtime = createRealtime(api, config.auth, store, emitter);\n\n const applySession = (session: VoiceSession, mode: UpsertMode = \"event\"): VoiceSession => {\n const change = store.upsert(session, mode);\n if (change === \"added\") {\n emitter.emit(\"session.added\", session);\n }\n if (change === \"updated\") {\n emitter.emit(\"session.updated\", session);\n }\n return session;\n };\n\n const applyStarted = (started: StartedSession, mode: UpsertMode = \"event\"): StartedSession => {\n applySession(started.session, mode);\n return started;\n };\n\n const patchRecording = (control: SessionRecordingControl): SessionRecordingControl => {\n const session = store.patchRecording(control);\n if (session) {\n emitter.emit(\"session.updated\", session);\n }\n return control;\n };\n\n const connect = async (): Promise<void> => {\n try {\n await realtime.connect();\n } catch (err) {\n emitter.emit(\"error\", err instanceof Error ? err : new Error(\"Connection failed\"));\n throw err;\n }\n };\n\n const dispose = async (): Promise<void> => {\n await realtime.dispose();\n store.dispose();\n };\n\n return {\n api,\n auth: config.auth,\n store,\n emitter,\n realtime,\n connect,\n dispose,\n applySession,\n applyStarted,\n patchRecording,\n };\n};\n\nconst createCommonSessions = (core: Core): Omit<Sessions, \"start\"> => ({\n list: core.store.list,\n get: core.store.get,\n sync: async (query?: ListQuery) => {\n const response = await unwrap(listSessions({ client: core.api, query }), core.auth);\n core.store.sync(response.items);\n return core.store.list();\n },\n join: (sessionId) =>\n unwrap(createSessionToken({ client: core.api, path: { sessionId } }), core.auth),\n accept: async (input) =>\n core.applyStarted(\n await unwrap(\n acceptSessionParticipant({\n client: core.api,\n path: {\n sessionId: input.sessionId,\n participantId: input.participantId,\n },\n }),\n core.auth,\n ),\n \"command\",\n ),\n reject: async (input) =>\n core.applySession(\n await unwrap(\n rejectSessionParticipant({\n client: core.api,\n path: {\n sessionId: input.sessionId,\n participantId: input.participantId,\n },\n }),\n core.auth,\n ),\n \"command\",\n ),\n leave: async (sessionId) =>\n core.applySession(\n await unwrap(leaveSession({ client: core.api, path: { sessionId } }), core.auth),\n \"command\",\n ),\n can: core.store.can,\n});\n\nconst createHostControls = (core: Core): HostControls => ({\n end: async (sessionId) => {\n await unwrap(endSession({ client: core.api, path: { sessionId } }), core.auth);\n if (core.store.remove({ id: sessionId })) {\n core.emitter.emit(\"session.removed\", { sessionId });\n }\n },\n addParticipant: async (input: HostParticipantInput) =>\n core.applyStarted(\n await unwrap(\n addSessionParticipant({\n client: core.api,\n path: { sessionId: input.sessionId },\n body: { target: input.target },\n }),\n core.auth,\n ),\n \"command\",\n ),\n removeParticipant: async (input: ParticipantRef) =>\n core.applySession(\n await unwrap(\n removeSessionParticipant({\n client: core.api,\n path: {\n sessionId: input.sessionId,\n participantId: input.participantId,\n },\n }),\n core.auth,\n ),\n \"command\",\n ),\n startRecording: async (sessionId) =>\n core.patchRecording(\n await unwrap(apiStartRecording({ client: core.api, path: { sessionId } }), core.auth),\n ),\n stopRecording: async (sessionId) =>\n core.patchRecording(\n await unwrap(apiStopRecording({ client: core.api, path: { sessionId } }), core.auth),\n ),\n});\n\nconst startSession = async (\n core: Core,\n vendor: string,\n target: CustomerStartInput[\"target\"] | HostStartInput[\"target\"],\n): Promise<StartedSession> =>\n core.applyStarted(\n await unwrap(\n createSession({\n client: core.api,\n path: { vendor },\n body: { target },\n }),\n core.auth,\n ),\n \"command\",\n );\n"]}
|