tsarr 2.10.0 → 2.11.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/LICENSE +21 -0
- package/README.md +120 -233
- package/dist/cli/commands/doctor.d.ts.map +1 -1
- package/dist/cli/commands/manual-import.d.ts +30 -0
- package/dist/cli/commands/manual-import.d.ts.map +1 -0
- package/dist/cli/commands/radarr.d.ts.map +1 -1
- package/dist/cli/commands/sonarr.d.ts.map +1 -1
- package/dist/cli/index.js +5200 -4854
- package/dist/cli/index.js.map +133 -0
- package/dist/clients/bazarr.d.ts +124 -124
- package/dist/clients/bazarr.js +88 -97
- package/dist/clients/bazarr.js.map +22 -0
- package/dist/clients/lidarr.d.ts +146 -146
- package/dist/clients/lidarr.js +88 -97
- package/dist/clients/lidarr.js.map +23 -0
- package/dist/clients/prowlarr.d.ts +28 -28
- package/dist/clients/prowlarr.js +88 -97
- package/dist/clients/prowlarr.js.map +23 -0
- package/dist/clients/qbittorrent.d.ts +2 -0
- package/dist/clients/qbittorrent.d.ts.map +1 -1
- package/dist/clients/qbittorrent.js +119 -102
- package/dist/clients/qbittorrent.js.map +21 -0
- package/dist/clients/radarr.d.ts +193 -149
- package/dist/clients/radarr.d.ts.map +1 -1
- package/dist/clients/radarr.js +128 -97
- package/dist/clients/radarr.js.map +23 -0
- package/dist/clients/readarr.d.ts +148 -148
- package/dist/clients/readarr.js +88 -97
- package/dist/clients/readarr.js.map +23 -0
- package/dist/clients/seerr-types.d.ts +1 -1
- package/dist/clients/seerr-types.d.ts.map +1 -1
- package/dist/clients/seerr.d.ts +16 -16
- package/dist/clients/seerr.js +88 -97
- package/dist/clients/seerr.js.map +22 -0
- package/dist/clients/sonarr.d.ts +201 -167
- package/dist/clients/sonarr.d.ts.map +1 -1
- package/dist/clients/sonarr.js +104 -107
- package/dist/clients/sonarr.js.map +23 -0
- package/dist/generated/bazarr/client/client.gen.d.ts.map +1 -1
- package/dist/generated/bazarr/client/types.gen.d.ts +5 -2
- package/dist/generated/bazarr/client/types.gen.d.ts.map +1 -1
- package/dist/generated/bazarr/client/utils.gen.d.ts +5 -1
- package/dist/generated/bazarr/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/lidarr/client/client.gen.d.ts.map +1 -1
- package/dist/generated/lidarr/client/types.gen.d.ts +5 -2
- package/dist/generated/lidarr/client/types.gen.d.ts.map +1 -1
- package/dist/generated/lidarr/client/utils.gen.d.ts +5 -1
- package/dist/generated/lidarr/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/prowlarr/client/client.gen.d.ts.map +1 -1
- package/dist/generated/prowlarr/client/types.gen.d.ts +5 -2
- package/dist/generated/prowlarr/client/types.gen.d.ts.map +1 -1
- package/dist/generated/prowlarr/client/utils.gen.d.ts +5 -1
- package/dist/generated/prowlarr/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/qbittorrent/client/client.gen.d.ts.map +1 -1
- package/dist/generated/qbittorrent/client/types.gen.d.ts +5 -2
- package/dist/generated/qbittorrent/client/types.gen.d.ts.map +1 -1
- package/dist/generated/qbittorrent/client/utils.gen.d.ts +5 -1
- package/dist/generated/qbittorrent/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/radarr/client/client.gen.d.ts.map +1 -1
- package/dist/generated/radarr/client/types.gen.d.ts +5 -2
- package/dist/generated/radarr/client/types.gen.d.ts.map +1 -1
- package/dist/generated/radarr/client/utils.gen.d.ts +5 -1
- package/dist/generated/radarr/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/readarr/client/client.gen.d.ts.map +1 -1
- package/dist/generated/readarr/client/types.gen.d.ts +5 -2
- package/dist/generated/readarr/client/types.gen.d.ts.map +1 -1
- package/dist/generated/readarr/client/utils.gen.d.ts +5 -1
- package/dist/generated/readarr/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/seerr/client/client.gen.d.ts.map +1 -1
- package/dist/generated/seerr/client/types.gen.d.ts +5 -2
- package/dist/generated/seerr/client/types.gen.d.ts.map +1 -1
- package/dist/generated/seerr/client/utils.gen.d.ts +5 -1
- package/dist/generated/seerr/client/utils.gen.d.ts.map +1 -1
- package/dist/generated/seerr/index.d.ts +2 -2
- package/dist/generated/seerr/index.d.ts.map +1 -1
- package/dist/generated/seerr/sdk.gen.d.ts +13 -1
- package/dist/generated/seerr/sdk.gen.d.ts.map +1 -1
- package/dist/generated/seerr/types.gen.d.ts +78 -7
- package/dist/generated/seerr/types.gen.d.ts.map +1 -1
- package/dist/generated/sonarr/client/client.gen.d.ts.map +1 -1
- package/dist/generated/sonarr/client/types.gen.d.ts +5 -2
- package/dist/generated/sonarr/client/types.gen.d.ts.map +1 -1
- package/dist/generated/sonarr/client/utils.gen.d.ts +5 -1
- package/dist/generated/sonarr/client/utils.gen.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +12 -0
- package/dist/tsarr-2.11.1.tgz +0 -0
- package/package.json +18 -9
- package/dist/tsarr-2.10.0.tgz +0 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/core/errors.ts", "../../src/core/fetch.ts", "../../src/generated/qbittorrent/core/bodySerializer.gen.ts", "../../src/generated/qbittorrent/core/serverSentEvents.gen.ts", "../../src/generated/qbittorrent/core/pathSerializer.gen.ts", "../../src/generated/qbittorrent/core/utils.gen.ts", "../../src/generated/qbittorrent/core/auth.gen.ts", "../../src/generated/qbittorrent/client/utils.gen.ts", "../../src/generated/qbittorrent/client/client.gen.ts", "../../src/generated/qbittorrent/client.gen.ts", "../../src/generated/qbittorrent/sdk.gen.ts", "../../src/clients/qbittorrent.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"export class TsarrError extends Error {\n constructor(\n message: string,\n public code?: string,\n public statusCode?: number,\n public details?: unknown\n ) {\n super(message);\n this.name = 'TsarrError';\n }\n}\n\nexport class ApiKeyError extends TsarrError {\n constructor(message = 'Invalid or missing API key') {\n super(message, 'API_KEY_ERROR', 401);\n this.name = 'ApiKeyError';\n }\n}\n\nexport class ConnectionError extends TsarrError {\n constructor(message: string, details?: unknown) {\n super(message, 'CONNECTION_ERROR', undefined, details);\n this.name = 'ConnectionError';\n }\n}\n\nexport class ValidationError extends TsarrError {\n constructor(message: string, details?: unknown) {\n super(message, 'VALIDATION_ERROR', undefined, details);\n this.name = 'ValidationError';\n }\n}\n\nexport class NotFoundError extends TsarrError {\n constructor(resource: string) {\n super(`Resource not found: ${resource}`, 'NOT_FOUND', 404);\n this.name = 'NotFoundError';\n }\n}\n",
|
|
6
|
+
"import { ConnectionError } from './errors';\n\nexport interface RetryOptions {\n /** Maximum number of retry attempts for transient failures (default: 3) */\n maxRetries?: number;\n /** Initial delay in ms before the first retry (default: 1000) */\n initialDelayMs?: number;\n /** Maximum delay in ms between retries (default: 10000) */\n maxDelayMs?: number;\n}\n\nexport interface ResilientFetchOptions {\n /** Request timeout in milliseconds (default: 30000) */\n timeout?: number;\n /** Retry configuration for transient failures. Omit to disable retries. */\n retry?: RetryOptions;\n}\n\nconst DEFAULT_TIMEOUT = 30_000;\nconst DEFAULT_MAX_RETRIES = 3;\nconst DEFAULT_INITIAL_DELAY = 1_000;\nconst DEFAULT_MAX_DELAY = 10_000;\n\nconst RETRYABLE_STATUS_CODES = new Set([408, 429, 502, 503, 504]);\n\nfunction isRetryable(error: unknown): boolean {\n if (error instanceof DOMException && error.name === 'AbortError') {\n return false;\n }\n if (error instanceof TypeError) {\n // Network errors from fetch (e.g. DNS failure, connection refused)\n return true;\n }\n return false;\n}\n\nfunction getRetryDelay(attempt: number, initialDelayMs: number, maxDelayMs: number): number {\n const delay = initialDelayMs * 2 ** attempt;\n const jitter = delay * 0.2 * Math.random();\n return Math.min(delay + jitter, maxDelayMs);\n}\n\n/**\n * Creates a fetch function with timeout and retry support.\n *\n * - Timeout uses AbortController to cancel requests that exceed the limit.\n * - Retry uses exponential backoff with jitter for transient failures\n * (network errors and 408/429/502/503/504 status codes).\n */\nexport function createResilientFetch(options: ResilientFetchOptions = {}): typeof fetch {\n const timeout = options.timeout ?? DEFAULT_TIMEOUT;\n const maxRetries = options.retry ? (options.retry.maxRetries ?? DEFAULT_MAX_RETRIES) : 0;\n const initialDelayMs = options.retry?.initialDelayMs ?? DEFAULT_INITIAL_DELAY;\n const maxDelayMs = options.retry?.maxDelayMs ?? DEFAULT_MAX_DELAY;\n\n const resilientFetch = async (\n input: RequestInfo | URL,\n init?: RequestInit\n ): Promise<Response> => {\n let lastError: unknown;\n const template = createRequestTemplate(input, init);\n\n for (let attempt = 0; attempt <= maxRetries; attempt++) {\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), timeout);\n\n // Merge abort signals: respect caller's signal and our timeout\n const callerSignal = init?.signal;\n if (callerSignal?.aborted) {\n clearTimeout(timeoutId);\n throw callerSignal.reason ?? new DOMException('The operation was aborted.', 'AbortError');\n }\n\n const onCallerAbort = () => controller.abort(callerSignal!.reason);\n callerSignal?.addEventListener('abort', onCallerAbort, { once: true });\n\n try {\n const response = await globalThis.fetch(\n new Request(template.clone(), { signal: controller.signal })\n );\n\n clearTimeout(timeoutId);\n callerSignal?.removeEventListener('abort', onCallerAbort);\n\n if (RETRYABLE_STATUS_CODES.has(response.status) && attempt < maxRetries) {\n lastError = new ConnectionError(`Request failed with status ${response.status}`);\n const delay = getRetryDelay(attempt, initialDelayMs, maxDelayMs);\n await new Promise(resolve => setTimeout(resolve, delay));\n continue;\n }\n\n return response;\n } catch (error) {\n clearTimeout(timeoutId);\n callerSignal?.removeEventListener('abort', onCallerAbort);\n\n // If the caller aborted, don't retry\n if (callerSignal?.aborted) {\n throw callerSignal.reason ?? new DOMException('The operation was aborted.', 'AbortError');\n }\n\n // Timeout: wrap as ConnectionError\n if (error instanceof DOMException && error.name === 'AbortError') {\n lastError = new ConnectionError(`Request timed out after ${timeout}ms`);\n if (attempt < maxRetries) {\n const delay = getRetryDelay(attempt, initialDelayMs, maxDelayMs);\n await new Promise(resolve => setTimeout(resolve, delay));\n continue;\n }\n throw lastError;\n }\n\n if (isRetryable(error) && attempt < maxRetries) {\n lastError = error;\n const delay = getRetryDelay(attempt, initialDelayMs, maxDelayMs);\n await new Promise(resolve => setTimeout(resolve, delay));\n continue;\n }\n\n throw error;\n }\n }\n\n throw lastError;\n };\n\n return Object.assign(resilientFetch, {\n preconnect: globalThis.fetch.preconnect?.bind(globalThis.fetch),\n }) as typeof fetch;\n}\n\nfunction createRequestTemplate(input: RequestInfo | URL, init?: RequestInit): Request {\n const { signal: _signal, ...requestInit } = init ?? {};\n\n if (input instanceof Request) {\n return init ? new Request(input.clone(), requestInit) : input.clone();\n }\n\n return new Request(input, requestInit);\n}\n",
|
|
7
|
+
"// 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",
|
|
8
|
+
"// 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",
|
|
9
|
+
"// 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",
|
|
10
|
+
"// 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",
|
|
11
|
+
"// 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",
|
|
12
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport { getAuthToken } from '../core/auth.gen';\nimport type { QuerySerializerOptions } from '../core/bodySerializer.gen';\nimport { jsonBodySerializer } from '../core/bodySerializer.gen';\nimport {\n serializeArrayParam,\n serializeObjectParam,\n serializePrimitiveParam,\n} from '../core/pathSerializer.gen';\nimport { getUrl } from '../core/utils.gen';\nimport type { Client, ClientOptions, Config, RequestOptions } from './types.gen';\n\nexport const createQuerySerializer = <T = unknown>({\n parameters = {},\n ...args\n}: QuerySerializerOptions = {}) => {\n const querySerializer = (queryParams: T) => {\n const search: string[] = [];\n if (queryParams && typeof queryParams === 'object') {\n for (const name in queryParams) {\n const value = queryParams[name];\n\n if (value === undefined || value === null) {\n continue;\n }\n\n const options = parameters[name] || args;\n\n if (Array.isArray(value)) {\n const serializedArray = serializeArrayParam({\n allowReserved: options.allowReserved,\n explode: true,\n name,\n style: 'form',\n value,\n ...options.array,\n });\n if (serializedArray) search.push(serializedArray);\n } else if (typeof value === 'object') {\n const serializedObject = serializeObjectParam({\n allowReserved: options.allowReserved,\n explode: true,\n name,\n style: 'deepObject',\n value: value as Record<string, unknown>,\n ...options.object,\n });\n if (serializedObject) search.push(serializedObject);\n } else {\n const serializedPrimitive = serializePrimitiveParam({\n allowReserved: options.allowReserved,\n name,\n value: value as string,\n });\n if (serializedPrimitive) search.push(serializedPrimitive);\n }\n }\n }\n return search.join('&');\n };\n return querySerializer;\n};\n\n/**\n * Infers parseAs value from provided Content-Type header.\n */\nexport const getParseAs = (contentType: string | null): Exclude<Config['parseAs'], 'auto'> => {\n if (!contentType) {\n // If no Content-Type header is provided, the best we can do is return the raw response body,\n // which is effectively the same as the 'stream' option.\n return 'stream';\n }\n\n const cleanContent = contentType.split(';')[0]?.trim();\n\n if (!cleanContent) {\n return;\n }\n\n if (cleanContent.startsWith('application/json') || cleanContent.endsWith('+json')) {\n return 'json';\n }\n\n if (cleanContent === 'multipart/form-data') {\n return 'formData';\n }\n\n if (\n ['application/', 'audio/', 'image/', 'video/'].some((type) => cleanContent.startsWith(type))\n ) {\n return 'blob';\n }\n\n if (cleanContent.startsWith('text/')) {\n return 'text';\n }\n\n return;\n};\n\nconst checkForExistence = (\n options: Pick<RequestOptions, 'auth' | 'query'> & {\n headers: Headers;\n },\n name?: string,\n): boolean => {\n if (!name) {\n return false;\n }\n if (\n options.headers.has(name) ||\n options.query?.[name] ||\n options.headers.get('Cookie')?.includes(`${name}=`)\n ) {\n return true;\n }\n return false;\n};\n\nexport const setAuthParams = async ({\n security,\n ...options\n}: Pick<Required<RequestOptions>, 'security'> &\n Pick<RequestOptions, 'auth' | 'query'> & {\n headers: Headers;\n }) => {\n for (const auth of security) {\n if (checkForExistence(options, auth.name)) {\n continue;\n }\n\n const token = await getAuthToken(auth, options.auth);\n\n if (!token) {\n continue;\n }\n\n const name = auth.name ?? 'Authorization';\n\n switch (auth.in) {\n case 'query':\n if (!options.query) {\n options.query = {};\n }\n options.query[name] = token;\n break;\n case 'cookie':\n options.headers.append('Cookie', `${name}=${token}`);\n break;\n case 'header':\n default:\n options.headers.set(name, token);\n break;\n }\n }\n};\n\nexport const buildUrl: Client['buildUrl'] = (options) =>\n getUrl({\n baseUrl: options.baseUrl as string,\n path: options.path,\n query: options.query,\n querySerializer:\n typeof options.querySerializer === 'function'\n ? options.querySerializer\n : createQuerySerializer(options.querySerializer),\n url: options.url,\n });\n\nexport const mergeConfigs = (a: Config, b: Config): Config => {\n const config = { ...a, ...b };\n if (config.baseUrl?.endsWith('/')) {\n config.baseUrl = config.baseUrl.substring(0, config.baseUrl.length - 1);\n }\n config.headers = mergeHeaders(a.headers, b.headers);\n return config;\n};\n\nconst headersEntries = (headers: Headers): Array<[string, string]> => {\n const entries: Array<[string, string]> = [];\n headers.forEach((value, key) => {\n entries.push([key, value]);\n });\n return entries;\n};\n\nexport const mergeHeaders = (\n ...headers: Array<Required<Config>['headers'] | undefined>\n): Headers => {\n const mergedHeaders = new Headers();\n for (const header of headers) {\n if (!header) {\n continue;\n }\n\n const iterator = header instanceof Headers ? headersEntries(header) : Object.entries(header);\n\n for (const [key, value] of iterator) {\n if (value === null) {\n mergedHeaders.delete(key);\n } else if (Array.isArray(value)) {\n for (const v of value) {\n mergedHeaders.append(key, v as string);\n }\n } else if (value !== undefined) {\n // assume object headers are meant to be JSON stringified, i.e., their\n // content value in OpenAPI specification is 'application/json'\n mergedHeaders.set(\n key,\n typeof value === 'object' ? JSON.stringify(value) : (value as string),\n );\n }\n }\n }\n return mergedHeaders;\n};\n\ntype ErrInterceptor<Err, Res, Req, Options> = (\n error: Err,\n /** response may be undefined due to a network error where no response object is produced */\n response: Res | undefined,\n /** request may be undefined, because error may be from building the request object itself */\n request: Req | undefined,\n options: Options,\n) => Err | Promise<Err>;\n\ntype ReqInterceptor<Req, Options> = (request: Req, options: Options) => Req | Promise<Req>;\n\ntype ResInterceptor<Res, Req, Options> = (\n response: Res,\n request: Req,\n options: Options,\n) => Res | Promise<Res>;\n\nclass Interceptors<Interceptor> {\n fns: Array<Interceptor | null> = [];\n\n clear(): void {\n this.fns = [];\n }\n\n eject(id: number | Interceptor): void {\n const index = this.getInterceptorIndex(id);\n if (this.fns[index]) {\n this.fns[index] = null;\n }\n }\n\n exists(id: number | Interceptor): boolean {\n const index = this.getInterceptorIndex(id);\n return Boolean(this.fns[index]);\n }\n\n getInterceptorIndex(id: number | Interceptor): number {\n if (typeof id === 'number') {\n return this.fns[id] ? id : -1;\n }\n return this.fns.indexOf(id);\n }\n\n update(id: number | Interceptor, fn: Interceptor): number | Interceptor | false {\n const index = this.getInterceptorIndex(id);\n if (this.fns[index]) {\n this.fns[index] = fn;\n return id;\n }\n return false;\n }\n\n use(fn: Interceptor): number {\n this.fns.push(fn);\n return this.fns.length - 1;\n }\n}\n\nexport interface Middleware<Req, Res, Err, Options> {\n error: Interceptors<ErrInterceptor<Err, Res, Req, Options>>;\n request: Interceptors<ReqInterceptor<Req, Options>>;\n response: Interceptors<ResInterceptor<Res, Req, Options>>;\n}\n\nexport const createInterceptors = <Req, Res, Err, Options>(): Middleware<\n Req,\n Res,\n Err,\n Options\n> => ({\n error: new Interceptors<ErrInterceptor<Err, Res, Req, Options>>(),\n request: new Interceptors<ReqInterceptor<Req, Options>>(),\n response: new Interceptors<ResInterceptor<Res, Req, Options>>(),\n});\n\nconst defaultQuerySerializer = createQuerySerializer({\n allowReserved: false,\n array: {\n explode: true,\n style: 'form',\n },\n object: {\n explode: true,\n style: 'deepObject',\n },\n});\n\nconst defaultHeaders = {\n 'Content-Type': 'application/json',\n};\n\nexport const createConfig = <T extends ClientOptions = ClientOptions>(\n override: Config<Omit<ClientOptions, keyof T> & T> = {},\n): Config<Omit<ClientOptions, keyof T> & T> => ({\n ...jsonBodySerializer,\n headers: defaultHeaders,\n parseAs: 'auto',\n querySerializer: defaultQuerySerializer,\n ...override,\n});\n",
|
|
13
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport { createSseClient } from '../core/serverSentEvents.gen';\nimport type { HttpMethod } from '../core/types.gen';\nimport { getValidRequestBody } from '../core/utils.gen';\nimport type { Client, Config, RequestOptions, ResolvedRequestOptions } from './types.gen';\nimport {\n buildUrl,\n createConfig,\n createInterceptors,\n getParseAs,\n mergeConfigs,\n mergeHeaders,\n setAuthParams,\n} from './utils.gen';\n\ntype ReqInit = Omit<RequestInit, 'body' | 'headers'> & {\n body?: any;\n headers: ReturnType<typeof mergeHeaders>;\n};\n\nexport const createClient = (config: Config = {}): Client => {\n let _config = mergeConfigs(createConfig(), config);\n\n const getConfig = (): Config => ({ ..._config });\n\n const setConfig = (config: Config): Config => {\n _config = mergeConfigs(_config, config);\n return getConfig();\n };\n\n const interceptors = createInterceptors<Request, Response, unknown, ResolvedRequestOptions>();\n\n const beforeRequest = async <\n TData = unknown,\n TResponseStyle extends 'data' | 'fields' = 'fields',\n ThrowOnError extends boolean = boolean,\n Url extends string = string,\n >(\n options: RequestOptions<TData, TResponseStyle, ThrowOnError, Url>,\n ) => {\n const opts = {\n ..._config,\n ...options,\n fetch: options.fetch ?? _config.fetch ?? globalThis.fetch,\n headers: mergeHeaders(_config.headers, options.headers),\n serializedBody: undefined as string | undefined,\n };\n\n if (opts.security) {\n await setAuthParams({\n ...opts,\n security: opts.security,\n });\n }\n\n if (opts.requestValidator) {\n await opts.requestValidator(opts);\n }\n\n if (opts.body !== undefined && opts.bodySerializer) {\n opts.serializedBody = opts.bodySerializer(opts.body) as string | undefined;\n }\n\n // remove Content-Type header if body is empty to avoid sending invalid requests\n if (opts.body === undefined || opts.serializedBody === '') {\n opts.headers.delete('Content-Type');\n }\n\n const resolvedOpts = opts as typeof opts &\n ResolvedRequestOptions<TResponseStyle, ThrowOnError, Url>;\n const url = buildUrl(resolvedOpts);\n\n return { opts: resolvedOpts, url };\n };\n\n const request: Client['request'] = async (options) => {\n const throwOnError = options.throwOnError ?? _config.throwOnError;\n const responseStyle = options.responseStyle ?? _config.responseStyle;\n\n let request: Request | undefined;\n let response: Response | undefined;\n\n try {\n const { opts, url } = await beforeRequest(options);\n const requestInit: ReqInit = {\n redirect: 'follow',\n ...opts,\n body: getValidRequestBody(opts),\n };\n\n request = new Request(url, requestInit);\n\n for (const fn of interceptors.request.fns) {\n if (fn) {\n request = await fn(request, opts);\n }\n }\n\n // fetch must be assigned here, otherwise it would throw the error:\n // TypeError: Failed to execute 'fetch' on 'Window': Illegal invocation\n const _fetch = opts.fetch!;\n\n response = await _fetch(request);\n\n for (const fn of interceptors.response.fns) {\n if (fn) {\n response = await fn(response, request, opts);\n }\n }\n\n const result = {\n request,\n response,\n };\n\n if (response.ok) {\n const parseAs =\n (opts.parseAs === 'auto'\n ? getParseAs(response.headers.get('Content-Type'))\n : opts.parseAs) ?? 'json';\n\n if (response.status === 204 || response.headers.get('Content-Length') === '0') {\n let emptyData: any;\n switch (parseAs) {\n case 'arrayBuffer':\n case 'blob':\n case 'text':\n emptyData = await response[parseAs]();\n break;\n case 'formData':\n emptyData = new FormData();\n break;\n case 'stream':\n emptyData = response.body;\n break;\n case 'json':\n default:\n emptyData = {};\n break;\n }\n return opts.responseStyle === 'data'\n ? emptyData\n : {\n data: emptyData,\n ...result,\n };\n }\n\n let data: any;\n switch (parseAs) {\n case 'arrayBuffer':\n case 'blob':\n case 'formData':\n case 'text':\n data = await response[parseAs]();\n break;\n case 'json': {\n // Some servers return 200 with no Content-Length and empty body.\n // response.json() would throw; read as text and parse if non-empty.\n const text = await response.text();\n data = text ? JSON.parse(text) : {};\n break;\n }\n case 'stream':\n return opts.responseStyle === 'data'\n ? response.body\n : {\n data: response.body,\n ...result,\n };\n }\n\n if (parseAs === 'json') {\n if (opts.responseValidator) {\n await opts.responseValidator(data);\n }\n\n if (opts.responseTransformer) {\n data = await opts.responseTransformer(data);\n }\n }\n\n return opts.responseStyle === 'data'\n ? data\n : {\n data,\n ...result,\n };\n }\n\n const textError = await response.text();\n let jsonError: unknown;\n\n try {\n jsonError = JSON.parse(textError);\n } catch {\n // noop\n }\n\n throw jsonError ?? textError;\n } catch (error) {\n let finalError = error;\n\n for (const fn of interceptors.error.fns) {\n if (fn) {\n finalError = await fn(finalError, response, request, options as ResolvedRequestOptions);\n }\n }\n\n finalError = finalError || {};\n\n if (throwOnError) {\n throw finalError;\n }\n\n // TODO: we probably want to return error and improve types\n return responseStyle === 'data'\n ? undefined\n : {\n error: finalError,\n request,\n response,\n };\n }\n };\n\n const makeMethodFn = (method: Uppercase<HttpMethod>) => (options: RequestOptions) =>\n request({ ...options, method });\n\n const makeSseFn = (method: Uppercase<HttpMethod>) => async (options: RequestOptions) => {\n const { opts, url } = await beforeRequest(options);\n return createSseClient({\n ...opts,\n body: opts.body as BodyInit | null | undefined,\n method,\n onRequest: async (url, init) => {\n let request = new Request(url, init);\n for (const fn of interceptors.request.fns) {\n if (fn) {\n request = await fn(request, opts);\n }\n }\n return request;\n },\n serializedBody: getValidRequestBody(opts) as BodyInit | null | undefined,\n url,\n });\n };\n\n const _buildUrl: Client['buildUrl'] = (options) => buildUrl({ ..._config, ...options });\n\n return {\n buildUrl: _buildUrl,\n connect: makeMethodFn('CONNECT'),\n delete: makeMethodFn('DELETE'),\n get: makeMethodFn('GET'),\n getConfig,\n head: makeMethodFn('HEAD'),\n interceptors,\n options: makeMethodFn('OPTIONS'),\n patch: makeMethodFn('PATCH'),\n post: makeMethodFn('POST'),\n put: makeMethodFn('PUT'),\n request,\n setConfig,\n sse: {\n connect: makeSseFn('CONNECT'),\n delete: makeSseFn('DELETE'),\n get: makeSseFn('GET'),\n head: makeSseFn('HEAD'),\n options: makeSseFn('OPTIONS'),\n patch: makeSseFn('PATCH'),\n post: makeSseFn('POST'),\n put: makeSseFn('PUT'),\n trace: makeSseFn('TRACE'),\n },\n trace: makeMethodFn('TRACE'),\n } as Client;\n};\n",
|
|
14
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport { type ClientOptions, type Config, createClient, createConfig } from './client';\nimport type { ClientOptions as ClientOptions2 } from './types.gen';\n\n/**\n * The `createClientConfig()` function will be called on client initialization\n * and the returned object will become the client's initial configuration.\n *\n * You may want to initialize your client this way instead of calling\n * `setConfig()`. This is useful for example if you're using Next.js\n * to ensure your client always has the correct values.\n */\nexport type CreateClientConfig<T extends ClientOptions = ClientOptions2> = (override?: Config<ClientOptions & T>) => Config<Required<ClientOptions> & T>;\n\nexport const client = createClient(createConfig<ClientOptions2>({ baseUrl: 'http://localhost:8080/api/v2' }));\n",
|
|
15
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport { type Client, formDataBodySerializer, type Options as Options2, type TDataShape, urlSearchParamsBodySerializer } from './client';\nimport { client } from './client.gen';\nimport type { AppBuildInfoGetData, AppBuildInfoGetResponses, AppDefaultSavePathGetData, AppDefaultSavePathGetResponses, AppPreferencesGetData, AppPreferencesGetResponses, AppSetPreferencesPostData, AppSetPreferencesPostResponses, AppShutdownGetData, AppShutdownGetResponses, AppVersionGetData, AppVersionGetResponses, AppWebapiVersionGetData, AppWebapiVersionGetResponses, AuthLoginPostData, AuthLoginPostErrors, AuthLoginPostResponses, AuthLogoutPostData, AuthLogoutPostResponses, LogMainPostData, LogMainPostResponses, LogPeersPostData, LogPeersPostResponses, RssAddFeedPostData, RssAddFeedPostErrors, RssAddFeedPostResponses, RssAddFolderPostData, RssAddFolderPostErrors, RssAddFolderPostResponses, RssItemsPostData, RssItemsPostResponses, RssMarkAsReadPostData, RssMarkAsReadPostResponses, RssMatchingArticlesPostData, RssMatchingArticlesPostResponses, RssMoveItemPostData, RssMoveItemPostErrors, RssMoveItemPostResponses, RssRefreshItemPostData, RssRefreshItemPostResponses, RssRemoveItemPostData, RssRemoveItemPostErrors, RssRemoveItemPostResponses, RssRemoveRulePostData, RssRemoveRulePostResponses, RssRenameRulePostData, RssRenameRulePostResponses, RssRulesGetData, RssRulesGetResponses, RssSetRulePostData, RssSetRulePostResponses, SearchDeletePostData, SearchDeletePostErrors, SearchDeletePostResponses, SearchEnablePluginPostData, SearchEnablePluginPostResponses, SearchInstallPluginPostData, SearchInstallPluginPostResponses, SearchPluginsGetData, SearchPluginsGetResponses, SearchResultsPostData, SearchResultsPostErrors, SearchResultsPostResponses, SearchStartPostData, SearchStartPostErrors, SearchStartPostResponses, SearchStatusPostData, SearchStatusPostErrors, SearchStatusPostResponses, SearchStopPostData, SearchStopPostErrors, SearchStopPostResponses, SearchUninstallPluginPostData, SearchUninstallPluginPostResponses, SearchUpdatePluginsPostData, SearchUpdatePluginsPostResponses, SyncMaindataPostData, SyncMaindataPostResponses, SyncTorrentPeersPostData, SyncTorrentPeersPostErrors, SyncTorrentPeersPostResponses, TorrentsAddPeersPostData, TorrentsAddPeersPostErrors, TorrentsAddPeersPostResponses, TorrentsAddPostData, TorrentsAddPostErrors, TorrentsAddPostResponses, TorrentsAddTagsPostData, TorrentsAddTagsPostResponses, TorrentsAddTrackersPostData, TorrentsAddTrackersPostErrors, TorrentsAddTrackersPostResponses, TorrentsBottomPrioPostData, TorrentsBottomPrioPostErrors, TorrentsBottomPrioPostResponses, TorrentsCategoriesGetData, TorrentsCategoriesGetResponses, TorrentsCreateCategoryPostData, TorrentsCreateCategoryPostErrors, TorrentsCreateCategoryPostResponses, TorrentsCreateTagsPostData, TorrentsCreateTagsPostResponses, TorrentsDecreasePrioPostData, TorrentsDecreasePrioPostErrors, TorrentsDecreasePrioPostResponses, TorrentsDeletePostData, TorrentsDeletePostResponses, TorrentsDeleteTagsPostData, TorrentsDeleteTagsPostResponses, TorrentsDownloadLimitPostData, TorrentsDownloadLimitPostResponses, TorrentsEditCategoryPostData, TorrentsEditCategoryPostErrors, TorrentsEditCategoryPostResponses, TorrentsEditTrackerPostData, TorrentsEditTrackerPostErrors, TorrentsEditTrackerPostResponses, TorrentsFilePrioPostData, TorrentsFilePrioPostErrors, TorrentsFilePrioPostResponses, TorrentsFilesPostData, TorrentsFilesPostErrors, TorrentsFilesPostResponses, TorrentsIncreasePrioPostData, TorrentsIncreasePrioPostErrors, TorrentsIncreasePrioPostResponses, TorrentsInfoPostData, TorrentsInfoPostResponses, TorrentsPausePostData, TorrentsPausePostResponses, TorrentsPieceHashesPostData, TorrentsPieceHashesPostErrors, TorrentsPieceHashesPostResponses, TorrentsPieceStatesPostData, TorrentsPieceStatesPostErrors, TorrentsPieceStatesPostResponses, TorrentsPropertiesPostData, TorrentsPropertiesPostErrors, TorrentsPropertiesPostResponses, TorrentsReannouncePostData, TorrentsReannouncePostResponses, TorrentsRecheckPostData, TorrentsRecheckPostResponses, TorrentsRemoveCategoriesPostData, TorrentsRemoveCategoriesPostResponses, TorrentsRemoveTagsPostData, TorrentsRemoveTagsPostResponses, TorrentsRemoveTrackersPostData, TorrentsRemoveTrackersPostErrors, TorrentsRemoveTrackersPostResponses, TorrentsRenameFilePostData, TorrentsRenameFilePostErrors, TorrentsRenameFilePostResponses, TorrentsRenameFolderPostData, TorrentsRenameFolderPostErrors, TorrentsRenameFolderPostResponses, TorrentsRenamePostData, TorrentsRenamePostErrors, TorrentsRenamePostResponses, TorrentsResumePostData, TorrentsResumePostResponses, TorrentsSetAutoManagementPostData, TorrentsSetAutoManagementPostResponses, TorrentsSetCategoryPostData, TorrentsSetCategoryPostErrors, TorrentsSetCategoryPostResponses, TorrentsSetDownloadLimitPostData, TorrentsSetDownloadLimitPostResponses, TorrentsSetForceStartPostData, TorrentsSetForceStartPostResponses, TorrentsSetLocationPostData, TorrentsSetLocationPostErrors, TorrentsSetLocationPostResponses, TorrentsSetShareLimitsPostData, TorrentsSetShareLimitsPostResponses, TorrentsSetSuperSeedingPostData, TorrentsSetSuperSeedingPostResponses, TorrentsSetUploadLimitPostData, TorrentsSetUploadLimitPostResponses, TorrentsTagsGetData, TorrentsTagsGetResponses, TorrentsToggleFirstLastPiecePrioPostData, TorrentsToggleFirstLastPiecePrioPostResponses, TorrentsToggleSequentialDownloadPostData, TorrentsToggleSequentialDownloadPostResponses, TorrentsTopPrioPostData, TorrentsTopPrioPostErrors, TorrentsTopPrioPostResponses, TorrentsTrackersPostData, TorrentsTrackersPostErrors, TorrentsTrackersPostResponses, TorrentsUploadLimitPostData, TorrentsUploadLimitPostResponses, TorrentWebseedsPostData, TorrentWebseedsPostErrors, TorrentWebseedsPostResponses, TransferBanPeersPostData, TransferBanPeersPostResponses, TransferDownloadLimitGetData, TransferDownloadLimitGetResponses, TransferInfoGetData, TransferInfoGetResponses, TransferSetDownloadLimitPostData, TransferSetDownloadLimitPostResponses, TransferSetUploadLimitPostData, TransferSetUploadLimitPostResponses, TransferSpeedLimitsModeGetData, TransferSpeedLimitsModeGetResponses, TransferToggleSpeedLimitsModeGetData, TransferToggleSpeedLimitsModeGetResponses, TransferUploadLimitGetData, TransferUploadLimitGetResponses } 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 * Login\n *\n * Upon success, the response will contain a cookie with your SID. You must supply the cookie whenever you want to perform an operation that requires authentication.\n *\n */\nexport const authLoginPost = <ThrowOnError extends boolean = false>(options: Options<AuthLoginPostData, ThrowOnError>) => (options.client ?? client).post<AuthLoginPostResponses, AuthLoginPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n url: '/auth/login',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Logout\n */\nexport const authLogoutPost = <ThrowOnError extends boolean = false>(options?: Options<AuthLogoutPostData, ThrowOnError>) => (options?.client ?? client).post<AuthLogoutPostResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/auth/logout',\n ...options\n});\n\n/**\n * Get application version\n */\nexport const appVersionGet = <ThrowOnError extends boolean = false>(options?: Options<AppVersionGetData, ThrowOnError>) => (options?.client ?? client).get<AppVersionGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/app/version',\n ...options\n});\n\n/**\n * Get API version\n */\nexport const appWebapiVersionGet = <ThrowOnError extends boolean = false>(options?: Options<AppWebapiVersionGetData, ThrowOnError>) => (options?.client ?? client).get<AppWebapiVersionGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/app/webapiVersion',\n ...options\n});\n\n/**\n * Get build info\n */\nexport const appBuildInfoGet = <ThrowOnError extends boolean = false>(options?: Options<AppBuildInfoGetData, ThrowOnError>) => (options?.client ?? client).get<AppBuildInfoGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/app/buildInfo',\n ...options\n});\n\n/**\n * Shutdown application\n */\nexport const appShutdownGet = <ThrowOnError extends boolean = false>(options?: Options<AppShutdownGetData, ThrowOnError>) => (options?.client ?? client).get<AppShutdownGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/app/shutdown',\n ...options\n});\n\n/**\n * Get application preferences\n */\nexport const appPreferencesGet = <ThrowOnError extends boolean = false>(options?: Options<AppPreferencesGetData, ThrowOnError>) => (options?.client ?? client).get<AppPreferencesGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/app/preferences',\n ...options\n});\n\n/**\n * Set application preferences\n *\n * Notes:\n * 1. There is no need to pass all possible preferences' `token:value` pairs if you only want to change one option\n * 2. Paths in `scan_dirs` must exist, otherwise this option will have no effect\n * 3. String values must be quoted; integer and boolean values must never be quoted\n *\n * For a list of possible preference options see [Get application preferences](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-application-preferences)\n *\n */\nexport const appSetPreferencesPost = <ThrowOnError extends boolean = false>(options: Options<AppSetPreferencesPostData, ThrowOnError>) => (options.client ?? client).post<AppSetPreferencesPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/app/setPreferences',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get default save path\n */\nexport const appDefaultSavePathGet = <ThrowOnError extends boolean = false>(options?: Options<AppDefaultSavePathGetData, ThrowOnError>) => (options?.client ?? client).get<AppDefaultSavePathGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/app/defaultSavePath',\n ...options\n});\n\n/**\n * Get log\n */\nexport const logMainPost = <ThrowOnError extends boolean = false>(options: Options<LogMainPostData, ThrowOnError>) => (options.client ?? client).post<LogMainPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/log/main',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get peer log\n */\nexport const logPeersPost = <ThrowOnError extends boolean = false>(options: Options<LogPeersPostData, ThrowOnError>) => (options.client ?? client).post<LogPeersPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/log/peers',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get main data\n */\nexport const syncMaindataPost = <ThrowOnError extends boolean = false>(options: Options<SyncMaindataPostData, ThrowOnError>) => (options.client ?? client).post<SyncMaindataPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/sync/maindata',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent peers data\n */\nexport const syncTorrentPeersPost = <ThrowOnError extends boolean = false>(options: Options<SyncTorrentPeersPostData, ThrowOnError>) => (options.client ?? client).post<SyncTorrentPeersPostResponses, SyncTorrentPeersPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/sync/torrentPeers',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get global transfer info\n *\n * This method returns info you usually see in qBt status bar.\n */\nexport const transferInfoGet = <ThrowOnError extends boolean = false>(options?: Options<TransferInfoGetData, ThrowOnError>) => (options?.client ?? client).get<TransferInfoGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/info',\n ...options\n});\n\n/**\n * Get alternative speed limits state\n */\nexport const transferSpeedLimitsModeGet = <ThrowOnError extends boolean = false>(options?: Options<TransferSpeedLimitsModeGetData, ThrowOnError>) => (options?.client ?? client).get<TransferSpeedLimitsModeGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/speedLimitsMode',\n ...options\n});\n\n/**\n * Toggle alternative speed limits\n */\nexport const transferToggleSpeedLimitsModeGet = <ThrowOnError extends boolean = false>(options?: Options<TransferToggleSpeedLimitsModeGetData, ThrowOnError>) => (options?.client ?? client).get<TransferToggleSpeedLimitsModeGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/toggleSpeedLimitsMode',\n ...options\n});\n\n/**\n * Get global download limit\n */\nexport const transferDownloadLimitGet = <ThrowOnError extends boolean = false>(options?: Options<TransferDownloadLimitGetData, ThrowOnError>) => (options?.client ?? client).get<TransferDownloadLimitGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/downloadLimit',\n ...options\n});\n\n/**\n * Set global download limit\n */\nexport const transferSetDownloadLimitPost = <ThrowOnError extends boolean = false>(options: Options<TransferSetDownloadLimitPostData, ThrowOnError>) => (options.client ?? client).post<TransferSetDownloadLimitPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/setDownloadLimit',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get global upload limit\n */\nexport const transferUploadLimitGet = <ThrowOnError extends boolean = false>(options?: Options<TransferUploadLimitGetData, ThrowOnError>) => (options?.client ?? client).get<TransferUploadLimitGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/uploadLimit',\n ...options\n});\n\n/**\n * Set global upload limit\n */\nexport const transferSetUploadLimitPost = <ThrowOnError extends boolean = false>(options: Options<TransferSetUploadLimitPostData, ThrowOnError>) => (options.client ?? client).post<TransferSetUploadLimitPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/setUploadLimit',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Ban peers\n */\nexport const transferBanPeersPost = <ThrowOnError extends boolean = false>(options: Options<TransferBanPeersPostData, ThrowOnError>) => (options.client ?? client).post<TransferBanPeersPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/transfer/banPeers',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent list\n */\nexport const torrentsInfoPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsInfoPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsInfoPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/info',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent generic properties\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsPropertiesPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsPropertiesPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsPropertiesPostResponses, TorrentsPropertiesPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/properties',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent trackers\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsTrackersPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsTrackersPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsTrackersPostResponses, TorrentsTrackersPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/trackers',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent web seeds\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentWebseedsPost = <ThrowOnError extends boolean = false>(options: Options<TorrentWebseedsPostData, ThrowOnError>) => (options.client ?? client).post<TorrentWebseedsPostResponses, TorrentWebseedsPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/webseeds',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent contents\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsFilesPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsFilesPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsFilesPostResponses, TorrentsFilesPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/files',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent pieces' states\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsPieceStatesPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsPieceStatesPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsPieceStatesPostResponses, TorrentsPieceStatesPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/pieceStates',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent pieces' hashes\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsPieceHashesPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsPieceHashesPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsPieceHashesPostResponses, TorrentsPieceHashesPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/pieceHashes',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Pause torrents\n *\n * Requires knowing the torrent hashes. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsPausePost = <ThrowOnError extends boolean = false>(options: Options<TorrentsPausePostData, ThrowOnError>) => (options.client ?? client).post<TorrentsPausePostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/pause',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Resume torrents\n *\n * Requires knowing the torrent hashes. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsResumePost = <ThrowOnError extends boolean = false>(options: Options<TorrentsResumePostData, ThrowOnError>) => (options.client ?? client).post<TorrentsResumePostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/resume',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Delete torrents\n *\n * Requires knowing the torrent hashes. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsDeletePost = <ThrowOnError extends boolean = false>(options: Options<TorrentsDeletePostData, ThrowOnError>) => (options.client ?? client).post<TorrentsDeletePostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/delete',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Recheck torrents\n *\n * Requires knowing the torrent hashes. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsRecheckPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsRecheckPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsRecheckPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/recheck',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Reannounce torrents\n *\n * Requires knowing the torrent hashes. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsReannouncePost = <ThrowOnError extends boolean = false>(options: Options<TorrentsReannouncePostData, ThrowOnError>) => (options.client ?? client).post<TorrentsReannouncePostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/reannounce',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Add new torrent\n *\n * This method can add torrents from server local file or from URLs. `http://`, `https://`, `magnet:` and `bc://bt/` links are supported.\n */\nexport const torrentsAddPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsAddPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsAddPostResponses, TorrentsAddPostErrors, ThrowOnError>({\n ...formDataBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/add',\n ...options,\n headers: {\n 'Content-Type': null,\n ...options.headers\n }\n});\n\n/**\n * Add trackers to torrent\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsAddTrackersPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsAddTrackersPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsAddTrackersPostResponses, TorrentsAddTrackersPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/addTrackers',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Edit trackers\n */\nexport const torrentsEditTrackerPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsEditTrackerPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsEditTrackerPostResponses, TorrentsEditTrackerPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/editTracker',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Remove trackers\n */\nexport const torrentsRemoveTrackersPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsRemoveTrackersPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsRemoveTrackersPostResponses, TorrentsRemoveTrackersPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/removeTrackers',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Add peers\n */\nexport const torrentsAddPeersPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsAddPeersPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsAddPeersPostResponses, TorrentsAddPeersPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/addPeers',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Increase torrent priority\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsIncreasePrioPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsIncreasePrioPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsIncreasePrioPostResponses, TorrentsIncreasePrioPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/increasePrio',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Decrease torrent priority\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsDecreasePrioPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsDecreasePrioPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsDecreasePrioPostResponses, TorrentsDecreasePrioPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/decreasePrio',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Maximal torrent priority\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsTopPrioPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsTopPrioPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsTopPrioPostResponses, TorrentsTopPrioPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/topPrio',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Minimal torrent priority\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsBottomPrioPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsBottomPrioPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsBottomPrioPostResponses, TorrentsBottomPrioPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/bottomPrio',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set file priority\n */\nexport const torrentsFilePrioPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsFilePrioPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsFilePrioPostResponses, TorrentsFilePrioPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/filePrio',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent download limit\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsDownloadLimitPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsDownloadLimitPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsDownloadLimitPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/downloadLimit',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set torrent download limit\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetDownloadLimitPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetDownloadLimitPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetDownloadLimitPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setDownloadLimit',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set torrent share limit\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetShareLimitsPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetShareLimitsPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetShareLimitsPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setShareLimits',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get torrent upload limit\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsUploadLimitPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsUploadLimitPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsUploadLimitPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/uploadLimit',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set torrent upload limit\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetUploadLimitPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetUploadLimitPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetUploadLimitPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setUploadLimit',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set torrent location\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetLocationPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetLocationPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetLocationPostResponses, TorrentsSetLocationPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setLocation',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set torrent name\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsRenamePost = <ThrowOnError extends boolean = false>(options: Options<TorrentsRenamePostData, ThrowOnError>) => (options.client ?? client).post<TorrentsRenamePostResponses, TorrentsRenamePostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/rename',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set torrent category\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetCategoryPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetCategoryPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetCategoryPostResponses, TorrentsSetCategoryPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setCategory',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get all categories\n */\nexport const torrentsCategoriesGet = <ThrowOnError extends boolean = false>(options?: Options<TorrentsCategoriesGetData, ThrowOnError>) => (options?.client ?? client).get<TorrentsCategoriesGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/categories',\n ...options\n});\n\n/**\n * Add new category\n */\nexport const torrentsCreateCategoryPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsCreateCategoryPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsCreateCategoryPostResponses, TorrentsCreateCategoryPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/createCategory',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Edit category\n */\nexport const torrentsEditCategoryPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsEditCategoryPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsEditCategoryPostResponses, TorrentsEditCategoryPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/editCategory',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Remove categories\n */\nexport const torrentsRemoveCategoriesPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsRemoveCategoriesPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsRemoveCategoriesPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/removeCategories',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Add torrent tags\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsAddTagsPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsAddTagsPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsAddTagsPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/addTags',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Remove torrent tags\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsRemoveTagsPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsRemoveTagsPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsRemoveTagsPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/removeTags',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get all tags\n */\nexport const torrentsTagsGet = <ThrowOnError extends boolean = false>(options?: Options<TorrentsTagsGetData, ThrowOnError>) => (options?.client ?? client).get<TorrentsTagsGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/tags',\n ...options\n});\n\n/**\n * Create tags\n */\nexport const torrentsCreateTagsPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsCreateTagsPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsCreateTagsPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/createTags',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Delete tags\n */\nexport const torrentsDeleteTagsPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsDeleteTagsPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsDeleteTagsPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/deleteTags',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set automatic torrent management\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetAutoManagementPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetAutoManagementPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetAutoManagementPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setAutoManagement',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Toggle sequential download\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsToggleSequentialDownloadPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsToggleSequentialDownloadPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsToggleSequentialDownloadPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/toggleSequentialDownload',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set first/last piece priority\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsToggleFirstLastPiecePrioPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsToggleFirstLastPiecePrioPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsToggleFirstLastPiecePrioPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/toggleFirstLastPiecePrio',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set force start\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetForceStartPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetForceStartPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetForceStartPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setForceStart',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set super seeding\n *\n * Requires knowing the torrent hash. You can get it from [torrent list](https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)#get-torrent-list).\n */\nexport const torrentsSetSuperSeedingPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsSetSuperSeedingPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsSetSuperSeedingPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/setSuperSeeding',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Rename file\n */\nexport const torrentsRenameFilePost = <ThrowOnError extends boolean = false>(options: Options<TorrentsRenameFilePostData, ThrowOnError>) => (options.client ?? client).post<TorrentsRenameFilePostResponses, TorrentsRenameFilePostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/renameFile',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Rename folder\n */\nexport const torrentsRenameFolderPost = <ThrowOnError extends boolean = false>(options: Options<TorrentsRenameFolderPostData, ThrowOnError>) => (options.client ?? client).post<TorrentsRenameFolderPostResponses, TorrentsRenameFolderPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/torrents/renameFolder',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Add folder\n */\nexport const rssAddFolderPost = <ThrowOnError extends boolean = false>(options: Options<RssAddFolderPostData, ThrowOnError>) => (options.client ?? client).post<RssAddFolderPostResponses, RssAddFolderPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/addFolder',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Add feed\n */\nexport const rssAddFeedPost = <ThrowOnError extends boolean = false>(options: Options<RssAddFeedPostData, ThrowOnError>) => (options.client ?? client).post<RssAddFeedPostResponses, RssAddFeedPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/addFeed',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Remove item\n */\nexport const rssRemoveItemPost = <ThrowOnError extends boolean = false>(options: Options<RssRemoveItemPostData, ThrowOnError>) => (options.client ?? client).post<RssRemoveItemPostResponses, RssRemoveItemPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/removeItem',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Move item\n */\nexport const rssMoveItemPost = <ThrowOnError extends boolean = false>(options: Options<RssMoveItemPostData, ThrowOnError>) => (options.client ?? client).post<RssMoveItemPostResponses, RssMoveItemPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/moveItem',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get all items\n */\nexport const rssItemsPost = <ThrowOnError extends boolean = false>(options: Options<RssItemsPostData, ThrowOnError>) => (options.client ?? client).post<RssItemsPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/items',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Mark as read\n *\n * If `articleId` is provided only the article is marked as read otherwise the whole feed is going to be marked as read.\n */\nexport const rssMarkAsReadPost = <ThrowOnError extends boolean = false>(options: Options<RssMarkAsReadPostData, ThrowOnError>) => (options.client ?? client).post<RssMarkAsReadPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/markAsRead',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Refresh item\n *\n * Refreshes folder or feed.\n */\nexport const rssRefreshItemPost = <ThrowOnError extends boolean = false>(options: Options<RssRefreshItemPostData, ThrowOnError>) => (options.client ?? client).post<RssRefreshItemPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/refreshItem',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Set auto-downloading rule\n */\nexport const rssSetRulePost = <ThrowOnError extends boolean = false>(options: Options<RssSetRulePostData, ThrowOnError>) => (options.client ?? client).post<RssSetRulePostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/setRule',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Rename auto-downloading rule\n */\nexport const rssRenameRulePost = <ThrowOnError extends boolean = false>(options: Options<RssRenameRulePostData, ThrowOnError>) => (options.client ?? client).post<RssRenameRulePostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/renameRule',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Remove auto-downloading rule\n */\nexport const rssRemoveRulePost = <ThrowOnError extends boolean = false>(options: Options<RssRemoveRulePostData, ThrowOnError>) => (options.client ?? client).post<RssRemoveRulePostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/removeRule',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get all auto-downloading rules\n */\nexport const rssRulesGet = <ThrowOnError extends boolean = false>(options?: Options<RssRulesGetData, ThrowOnError>) => (options?.client ?? client).get<RssRulesGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/rules',\n ...options\n});\n\n/**\n * Get all articles matching a rule\n */\nexport const rssMatchingArticlesPost = <ThrowOnError extends boolean = false>(options: Options<RssMatchingArticlesPostData, ThrowOnError>) => (options.client ?? client).post<RssMatchingArticlesPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/rss/matchingArticles',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Start search\n */\nexport const searchStartPost = <ThrowOnError extends boolean = false>(options: Options<SearchStartPostData, ThrowOnError>) => (options.client ?? client).post<SearchStartPostResponses, SearchStartPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/start',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Stop search\n */\nexport const searchStopPost = <ThrowOnError extends boolean = false>(options: Options<SearchStopPostData, ThrowOnError>) => (options.client ?? client).post<SearchStopPostResponses, SearchStopPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/stop',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get search status\n */\nexport const searchStatusPost = <ThrowOnError extends boolean = false>(options: Options<SearchStatusPostData, ThrowOnError>) => (options.client ?? client).post<SearchStatusPostResponses, SearchStatusPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/status',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get search results\n */\nexport const searchResultsPost = <ThrowOnError extends boolean = false>(options: Options<SearchResultsPostData, ThrowOnError>) => (options.client ?? client).post<SearchResultsPostResponses, SearchResultsPostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/results',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Delete search\n */\nexport const searchDeletePost = <ThrowOnError extends boolean = false>(options: Options<SearchDeletePostData, ThrowOnError>) => (options.client ?? client).post<SearchDeletePostResponses, SearchDeletePostErrors, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/delete',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Get search plugins\n */\nexport const searchPluginsGet = <ThrowOnError extends boolean = false>(options?: Options<SearchPluginsGetData, ThrowOnError>) => (options?.client ?? client).get<SearchPluginsGetResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/plugins',\n ...options\n});\n\n/**\n * Install search plugin\n */\nexport const searchInstallPluginPost = <ThrowOnError extends boolean = false>(options: Options<SearchInstallPluginPostData, ThrowOnError>) => (options.client ?? client).post<SearchInstallPluginPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/installPlugin',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Uninstall search plugin\n */\nexport const searchUninstallPluginPost = <ThrowOnError extends boolean = false>(options: Options<SearchUninstallPluginPostData, ThrowOnError>) => (options.client ?? client).post<SearchUninstallPluginPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/uninstallPlugin',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Enable search plugin\n */\nexport const searchEnablePluginPost = <ThrowOnError extends boolean = false>(options: Options<SearchEnablePluginPostData, ThrowOnError>) => (options.client ?? client).post<SearchEnablePluginPostResponses, unknown, ThrowOnError>({\n ...urlSearchParamsBodySerializer,\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/enablePlugin',\n ...options,\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...options.headers\n }\n});\n\n/**\n * Update search plugins\n */\nexport const searchUpdatePluginsPost = <ThrowOnError extends boolean = false>(options?: Options<SearchUpdatePluginsPostData, ThrowOnError>) => (options?.client ?? client).post<SearchUpdatePluginsPostResponses, unknown, ThrowOnError>({\n security: [{\n in: 'cookie',\n name: 'SID',\n type: 'apiKey'\n }],\n url: '/search/updatePlugins',\n ...options\n});\n",
|
|
16
|
+
"import { ConnectionError } from '../core/errors';\nimport { createResilientFetch } from '../core/fetch';\nimport type { QBittorrentClientConfig } from '../core/types';\nimport { client as qbittorrentClient } from '../generated/qbittorrent/client.gen';\nimport * as QBittorrentApi from '../generated/qbittorrent/index';\nimport type {\n TorrentInfo,\n TorrentsInfoPostData,\n TransferInfo,\n} from '../generated/qbittorrent/types.gen';\n\ntype TorrentFilter = NonNullable<TorrentsInfoPostData['body']['filter']>;\n\n/**\n * qBittorrent WebUI API client\n *\n * Uses cookie-based session authentication (SID) instead of API keys.\n *\n * @example\n * ```typescript\n * const qbit = new QBittorrentClient({\n * baseUrl: 'http://localhost:8080',\n * username: 'admin',\n * password: 'adminadmin'\n * });\n *\n * const torrents = await qbit.getTorrents();\n * ```\n */\nconst DEFAULT_TIMEOUT_MS = 30_000;\n\nexport class QBittorrentClient {\n private baseUrl: string;\n private username: string;\n private password: string;\n private sid: string | null = null;\n // qBT 4.x ships the session cookie as `SID`; qBT 5.x ships it as\n // `QBT_SID_<port>`. The generated SDK hardcodes `SID`, so we capture\n // the real name at login and rewrite outgoing Cookie headers.\n private cookieName = 'SID';\n private fetch: typeof globalThis.fetch;\n\n constructor(config: QBittorrentClientConfig) {\n if (!config.baseUrl) {\n throw new ConnectionError('No base URL provided');\n }\n\n this.baseUrl = config.baseUrl.replace(/\\/$/, '');\n this.username = config.username;\n this.password = config.password;\n const baseFetch = createResilientFetch({\n timeout: config.timeout ?? DEFAULT_TIMEOUT_MS,\n retry: config.retry,\n });\n this.fetch = ((input: RequestInfo | URL, init?: RequestInit) =>\n this.fetchWithCookieName(baseFetch, input, init)) as typeof globalThis.fetch;\n\n qbittorrentClient.setConfig({\n baseUrl: `${this.baseUrl}/api/v2`,\n auth: () => this.ensureAuth(),\n fetch: this.fetch,\n });\n }\n\n private async fetchWithCookieName(\n baseFetch: typeof globalThis.fetch,\n input: RequestInfo | URL,\n init?: RequestInit\n ): Promise<Response> {\n if (this.cookieName === 'SID') {\n return baseFetch(input, init);\n }\n // The generated SDK may pass either (url, init) or a pre-built Request.\n // Rewrite the Cookie header in whichever form actually carries it.\n if (input instanceof Request) {\n const cookie = input.headers.get('cookie');\n if (cookie?.includes('SID=')) {\n const headers = new Headers(input.headers);\n headers.set('cookie', cookie.replace(/(^|;\\s*)SID=/, `$1${this.cookieName}=`));\n return baseFetch(new Request(input, { headers }), init);\n }\n return baseFetch(input, init);\n }\n if (init?.headers) {\n const headers = new Headers(init.headers);\n const cookie = headers.get('cookie');\n if (cookie?.includes('SID=')) {\n headers.set('cookie', cookie.replace(/(^|;\\s*)SID=/, `$1${this.cookieName}=`));\n return baseFetch(input, { ...init, headers });\n }\n }\n return baseFetch(input, init);\n }\n\n private async ensureAuth(): Promise<string> {\n if (!this.sid) {\n await this.login();\n }\n return this.sid!;\n }\n\n private async login(): Promise<void> {\n const response = await this.fetch(`${this.baseUrl}/api/v2/auth/login`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n Referer: this.baseUrl,\n },\n body: new URLSearchParams({\n username: this.username,\n password: this.password,\n }),\n });\n\n if (!response.ok) {\n throw new ConnectionError(`qBittorrent login failed (${response.status})`);\n }\n\n // qBT 4.x returns 200 + \"Ok.\"; qBT 5.x returns 204 with an empty body.\n // Treat both as success — the real signal is the SID cookie below.\n const text = (await response.text()).trim();\n if (text && text !== 'Ok.') {\n throw new ConnectionError('qBittorrent authentication failed: invalid username or password');\n }\n\n const setCookie = response.headers.get('set-cookie');\n const sidMatch = setCookie?.match(/(SID|QBT_SID_\\d+)=([^;]+)/);\n if (!sidMatch) {\n throw new ConnectionError('qBittorrent login succeeded but no SID cookie received');\n }\n\n this.cookieName = sidMatch[1];\n this.sid = sidMatch[2];\n }\n\n // App APIs\n\n async getAppVersion(): Promise<string> {\n const result = await QBittorrentApi.appVersionGet();\n return (result.data as string) ?? '';\n }\n\n async getApiVersion(): Promise<string> {\n const result = await QBittorrentApi.appWebapiVersionGet();\n return (result.data as string) ?? '';\n }\n\n async getSystemStatus() {\n const version = await this.getAppVersion();\n return { version };\n }\n\n // Transfer APIs\n\n async getTransferInfo(): Promise<TransferInfo> {\n const result = await QBittorrentApi.transferInfoGet();\n return (result.data as TransferInfo) ?? {};\n }\n\n // Torrent APIs\n\n async getTorrents(filter?: TorrentFilter): Promise<TorrentInfo[]> {\n const result = await QBittorrentApi.torrentsInfoPost({\n body: {\n ...(filter ? { filter } : {}),\n },\n });\n return (result.data as TorrentInfo[]) ?? [];\n }\n\n async pauseTorrents(hashes: string): Promise<void> {\n await QBittorrentApi.torrentsPausePost({\n body: { hashes: hashes.split('|') },\n });\n }\n\n async resumeTorrents(hashes: string): Promise<void> {\n await QBittorrentApi.torrentsResumePost({\n body: { hashes: hashes.split('|') },\n });\n }\n\n async deleteTorrents(hashes: string, deleteFiles = false): Promise<void> {\n await QBittorrentApi.torrentsDeletePost({\n body: { hashes: hashes.split('|'), deleteFiles },\n });\n }\n}\n\n// Re-export types for external consumption\nexport * from './qbittorrent-types.js';\n"
|
|
17
|
+
],
|
|
18
|
+
"mappings": "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",
|
|
19
|
+
"debugId": "EEFE0D3C2E02FFD464756E2164756E21",
|
|
20
|
+
"names": []
|
|
21
|
+
}
|