@spader/spall-sdk 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/app.d.ts +7 -0
- package/dist/app.d.ts.map +1 -0
- package/dist/client.d.ts +20 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +1642 -0
- package/dist/client.js.map +21 -0
- package/dist/gen/client/client.gen.d.ts +3 -0
- package/dist/gen/client/client.gen.d.ts.map +1 -0
- package/dist/gen/client/index.d.ts +9 -0
- package/dist/gen/client/index.d.ts.map +1 -0
- package/dist/gen/client/types.gen.d.ts +118 -0
- package/dist/gen/client/types.gen.d.ts.map +1 -0
- package/dist/gen/client/utils.gen.d.ts +34 -0
- package/dist/gen/client/utils.gen.d.ts.map +1 -0
- package/dist/gen/client.gen.d.ts +13 -0
- package/dist/gen/client.gen.d.ts.map +1 -0
- package/dist/gen/core/auth.gen.d.ts +19 -0
- package/dist/gen/core/auth.gen.d.ts.map +1 -0
- package/dist/gen/core/bodySerializer.gen.d.ts +26 -0
- package/dist/gen/core/bodySerializer.gen.d.ts.map +1 -0
- package/dist/gen/core/params.gen.d.ts +44 -0
- package/dist/gen/core/params.gen.d.ts.map +1 -0
- package/dist/gen/core/pathSerializer.gen.d.ts +34 -0
- package/dist/gen/core/pathSerializer.gen.d.ts.map +1 -0
- package/dist/gen/core/queryKeySerializer.gen.d.ts +19 -0
- package/dist/gen/core/queryKeySerializer.gen.d.ts.map +1 -0
- package/dist/gen/core/serverSentEvents.gen.d.ts +72 -0
- package/dist/gen/core/serverSentEvents.gen.d.ts.map +1 -0
- package/dist/gen/core/types.gen.d.ts +79 -0
- package/dist/gen/core/types.gen.d.ts.map +1 -0
- package/dist/gen/core/utils.gen.d.ts +20 -0
- package/dist/gen/core/utils.gen.d.ts.map +1 -0
- package/dist/gen/index.d.ts +3 -0
- package/dist/gen/index.d.ts.map +1 -0
- package/dist/gen/sdk.gen.d.ts +358 -0
- package/dist/gen/sdk.gen.d.ts.map +1 -0
- package/dist/gen/types.gen.d.ts +1596 -0
- package/dist/gen/types.gen.d.ts.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2925 -0
- package/dist/index.js.map +32 -0
- package/dist/lock.d.ts +20 -0
- package/dist/lock.d.ts.map +1 -0
- package/dist/log.d.ts +22 -0
- package/dist/log.d.ts.map +1 -0
- package/dist/routes/commit.d.ts +19 -0
- package/dist/routes/commit.d.ts.map +1 -0
- package/dist/routes/corpus.d.ts +317 -0
- package/dist/routes/corpus.d.ts.map +1 -0
- package/dist/routes/note.d.ts +79 -0
- package/dist/routes/note.d.ts.map +1 -0
- package/dist/routes/query.d.ts +314 -0
- package/dist/routes/query.d.ts.map +1 -0
- package/dist/routes/sse.d.ts +75 -0
- package/dist/routes/sse.d.ts.map +1 -0
- package/dist/routes/workspace.d.ts +102 -0
- package/dist/routes/workspace.d.ts.map +1 -0
- package/dist/serve.d.ts +2 -0
- package/dist/serve.d.ts.map +1 -0
- package/dist/server.d.ts +27 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +1433 -0
- package/dist/server.js.map +21 -0
- package/dist/sse.d.ts +8 -0
- package/dist/sse.d.ts.map +1 -0
- package/dist/util.d.ts +5 -0
- package/dist/util.d.ts.map +1 -0
- package/openapi.json +5694 -0
- package/package.json +70 -0
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/gen/core/serverSentEvents.gen.ts", "../src/gen/core/pathSerializer.gen.ts", "../src/gen/core/utils.gen.ts", "../src/gen/core/auth.gen.ts", "../src/gen/core/bodySerializer.gen.ts", "../src/gen/client/utils.gen.ts", "../src/gen/client/client.gen.ts", "../src/gen/core/params.gen.ts", "../src/gen/client.gen.ts", "../src/gen/sdk.gen.ts", "../src/lock.ts", "../src/client.ts", "../src/server.ts", "../src/app.ts", "../src/log.ts", "../src/routes/corpus.ts", "../src/util.ts", "../src/routes/workspace.ts", "../src/routes/note.ts", "../src/routes/query.ts", "../src/routes/commit.ts", "../src/routes/sse.ts", "../src/sse.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport type { Config } from \"./types.gen\";\n\nexport type ServerSentEventsOptions<TData = unknown> = Omit<\n RequestInit,\n \"method\"\n> &\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<\n TData = unknown,\n TReturn = void,\n TNext = unknown,\n> = {\n stream: AsyncGenerator<\n TData extends Record<string, unknown> ? TData[keyof TData] : TData,\n TReturn,\n TNext\n >;\n};\n\nexport const 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 =\n sseSleepFn ??\n ((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)\n throw new Error(\n `SSE failed: ${response.status} ${response.statusText}`,\n );\n\n if (!response.body) throw new Error(\"No body in SSE response\");\n\n const reader = response.body\n .pipeThrough(new TextDecoderStream())\n .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 // Normalize line endings: CRLF -> LF, then CR -> LF\n buffer = buffer.replace(/\\r\\n/g, \"\\n\").replace(/\\r/g, \"\\n\");\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(\n line.replace(/^retry:\\s*/, \"\"),\n 10,\n );\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 (\n sseMaxRetryAttempts !== undefined &&\n attempt >= sseMaxRetryAttempts\n ) {\n break; // stop after firing error\n }\n\n // exponential backoff: double retry each attempt, cap at 30s\n const backoff = Math.min(\n retryDelay * 2 ** (attempt - 1),\n sseMaxRetryDelay ?? 30000,\n );\n await sleep(backoff);\n }\n }\n };\n\n const stream = createStream();\n\n return { stream };\n};\n",
|
|
6
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\ninterface SerializeOptions<T>\n 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\"\n ? separator + joinedValues\n : 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 = [\n ...values,\n key,\n allowReserved ? (v as string) : encodeURIComponent(v as string),\n ];\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\"\n ? separator + joinedValues\n : joinedValues;\n};\n",
|
|
7
|
+
"// 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(\n match,\n serializeArrayParam({ explode, name, style, value }),\n );\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",
|
|
8
|
+
"// 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 =\n 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",
|
|
9
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport type {\n ArrayStyle,\n ObjectStyle,\n SerializerOptions,\n} from \"./pathSerializer.gen\";\n\nexport type QuerySerializer = (query: Record<string, unknown>) => string;\n\nexport type BodySerializer = (body: any) => any;\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 = (\n data: FormData,\n key: string,\n value: unknown,\n): 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 = (\n data: URLSearchParams,\n key: string,\n value: unknown,\n): 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: <T extends Record<string, any> | Array<Record<string, any>>>(\n body: T,\n ): FormData => {\n const data = new FormData();\n\n Object.entries(body).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: <T>(body: T): string =>\n JSON.stringify(body, (_key, value) =>\n typeof value === \"bigint\" ? value.toString() : value,\n ),\n};\n\nexport const urlSearchParamsBodySerializer = {\n bodySerializer: <T extends Record<string, any> | Array<Record<string, any>>>(\n body: T,\n ): string => {\n const data = new URLSearchParams();\n\n Object.entries(body).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",
|
|
10
|
+
"// 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 {\n Client,\n ClientOptions,\n Config,\n RequestOptions,\n} 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 = (\n contentType: string | null,\n): 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 (\n cleanContent.startsWith(\"application/json\") ||\n cleanContent.endsWith(\"+json\")\n ) {\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) =>\n cleanContent.startsWith(type),\n )\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 =\n header instanceof Headers\n ? headersEntries(header)\n : 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: Res,\n request: Req,\n options: Options,\n) => Err | Promise<Err>;\n\ntype ReqInterceptor<Req, Options> = (\n request: Req,\n options: Options,\n) => 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(\n id: number | Interceptor,\n fn: Interceptor,\n ): 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",
|
|
11
|
+
"// 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 {\n Client,\n Config,\n RequestOptions,\n ResolvedRequestOptions,\n} 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<\n Request,\n Response,\n unknown,\n ResolvedRequestOptions\n >();\n\n const beforeRequest = async (options: RequestOptions) => {\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,\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);\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 url = buildUrl(opts);\n\n return { opts, url };\n };\n\n const request: Client[\"request\"] = async (options) => {\n // @ts-expect-error\n const { opts, url } = await beforeRequest(options);\n const requestInit: ReqInit = {\n redirect: \"follow\",\n ...opts,\n body: getValidRequestBody(opts),\n };\n\n let 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 let response: Response;\n\n try {\n response = await _fetch(request);\n } catch (error) {\n // Handle fetch exceptions (AbortError, network errors, etc.)\n let finalError = error;\n\n for (const fn of interceptors.error.fns) {\n if (fn) {\n finalError = (await fn(\n error,\n undefined as any,\n request,\n opts,\n )) as unknown;\n }\n }\n\n finalError = finalError || ({} as unknown);\n\n if (opts.throwOnError) {\n throw finalError;\n }\n\n // Return error response\n return opts.responseStyle === \"data\"\n ? undefined\n : {\n error: finalError,\n request,\n response: undefined as any,\n };\n }\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 (\n response.status === 204 ||\n response.headers.get(\"Content-Length\") === \"0\"\n ) {\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 const error = jsonError ?? textError;\n let finalError = error;\n\n for (const fn of interceptors.error.fns) {\n if (fn) {\n finalError = (await fn(error, response, request, opts)) as string;\n }\n }\n\n finalError = finalError || ({} as string);\n\n if (opts.throwOnError) {\n throw finalError;\n }\n\n // TODO: we probably want to return error and improve types\n return opts.responseStyle === \"data\"\n ? undefined\n : {\n error: finalError,\n ...result,\n };\n };\n\n const makeMethodFn =\n (method: Uppercase<HttpMethod>) => (options: RequestOptions) =>\n request({ ...options, method });\n\n const makeSseFn =\n (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 headers: opts.headers as unknown as Record<string, string>,\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\n | BodyInit\n | null\n | undefined,\n url,\n });\n };\n\n return {\n 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",
|
|
12
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\ntype Slot = \"body\" | \"headers\" | \"path\" | \"query\";\n\nexport type Field =\n | {\n in: Exclude<Slot, \"body\">;\n /**\n * Field name. This is the name we want the user to see and use.\n */\n key: string;\n /**\n * Field mapped name. This is the name we want to use in the request.\n * If omitted, we use the same value as `key`.\n */\n map?: string;\n }\n | {\n in: Extract<Slot, \"body\">;\n /**\n * Key isn't required for bodies.\n */\n key?: string;\n map?: string;\n }\n | {\n /**\n * Field name. This is the name we want the user to see and use.\n */\n key: string;\n /**\n * Field mapped name. This is the name we want to use in the request.\n * If `in` is omitted, `map` aliases `key` to the transport layer.\n */\n map: Slot;\n };\n\nexport interface Fields {\n allowExtra?: Partial<Record<Slot, boolean>>;\n args?: ReadonlyArray<Field>;\n}\n\nexport type FieldsConfig = ReadonlyArray<Field | Fields>;\n\nconst extraPrefixesMap: Record<string, Slot> = {\n $body_: \"body\",\n $headers_: \"headers\",\n $path_: \"path\",\n $query_: \"query\",\n};\nconst extraPrefixes = Object.entries(extraPrefixesMap);\n\ntype KeyMap = Map<\n string,\n | {\n in: Slot;\n map?: string;\n }\n | {\n in?: never;\n map: Slot;\n }\n>;\n\nconst buildKeyMap = (fields: FieldsConfig, map?: KeyMap): KeyMap => {\n if (!map) {\n map = new Map();\n }\n\n for (const config of fields) {\n if (\"in\" in config) {\n if (config.key) {\n map.set(config.key, {\n in: config.in,\n map: config.map,\n });\n }\n } else if (\"key\" in config) {\n map.set(config.key, {\n map: config.map,\n });\n } else if (config.args) {\n buildKeyMap(config.args, map);\n }\n }\n\n return map;\n};\n\ninterface Params {\n body: unknown;\n headers: Record<string, unknown>;\n path: Record<string, unknown>;\n query: Record<string, unknown>;\n}\n\nconst stripEmptySlots = (params: Params) => {\n for (const [slot, value] of Object.entries(params)) {\n if (value && typeof value === \"object\" && !Object.keys(value).length) {\n delete params[slot as Slot];\n }\n }\n};\n\nexport const buildClientParams = (\n args: ReadonlyArray<unknown>,\n fields: FieldsConfig,\n) => {\n const params: Params = {\n body: {},\n headers: {},\n path: {},\n query: {},\n };\n\n const map = buildKeyMap(fields);\n\n let config: FieldsConfig[number] | undefined;\n\n for (const [index, arg] of args.entries()) {\n if (fields[index]) {\n config = fields[index];\n }\n\n if (!config) {\n continue;\n }\n\n if (\"in\" in config) {\n if (config.key) {\n const field = map.get(config.key)!;\n const name = field.map || config.key;\n if (field.in) {\n (params[field.in] as Record<string, unknown>)[name] = arg;\n }\n } else {\n params.body = arg;\n }\n } else {\n for (const [key, value] of Object.entries(arg ?? {})) {\n const field = map.get(key);\n\n if (field) {\n if (field.in) {\n const name = field.map || key;\n (params[field.in] as Record<string, unknown>)[name] = value;\n } else {\n params[field.map] = value;\n }\n } else {\n const extra = extraPrefixes.find(([prefix]) =>\n key.startsWith(prefix),\n );\n\n if (extra) {\n const [prefix, slot] = extra;\n (params[slot] as Record<string, unknown>)[\n key.slice(prefix.length)\n ] = value;\n } else if (\"allowExtra\" in config && config.allowExtra) {\n for (const [slot, allowed] of Object.entries(config.allowExtra)) {\n if (allowed) {\n (params[slot as Slot] as Record<string, unknown>)[key] = value;\n break;\n }\n }\n }\n }\n }\n }\n }\n\n stripEmptySlots(params);\n\n return params;\n};\n",
|
|
13
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport {\n type ClientOptions,\n type Config,\n createClient,\n createConfig,\n} 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> = (\n override?: Config<ClientOptions & T>,\n) => Config<Required<ClientOptions> & T>;\n\nexport const client = createClient(createConfig<ClientOptions2>());\n",
|
|
14
|
+
"// This file is auto-generated by @hey-api/openapi-ts\n\nimport {\n buildClientParams,\n type Client,\n type Options as Options2,\n type TDataShape,\n} from \"./client\";\nimport { client } from \"./client.gen\";\nimport type {\n CommitRunResponses,\n CorpusCreateResponses,\n CorpusDeleteErrors,\n CorpusDeleteResponses,\n CorpusGetErrors,\n CorpusGetResponses,\n CorpusListErrors,\n CorpusListResponses,\n EventsResponses,\n HealthResponses,\n NoteAddErrors,\n NoteAddResponses,\n NoteGetByIdErrors,\n NoteGetByIdResponses,\n NoteGetErrors,\n NoteGetResponses,\n NoteListByPathErrors,\n NoteListByPathResponses,\n NoteListErrors,\n NoteListResponses,\n NoteSyncResponses,\n NoteUpdateErrors,\n NoteUpdateResponses,\n NoteUpsertErrors,\n NoteUpsertResponses,\n QueryCreateErrors,\n QueryCreateResponses,\n QueryFetchErrors,\n QueryFetchResponses,\n QueryGetErrors,\n QueryGetResponses,\n QueryNotesErrors,\n QueryNotesResponses,\n QueryPathsErrors,\n QueryPathsResponses,\n QueryRecentResponses,\n QuerySearchErrors,\n QuerySearchResponses,\n QueryVsearchErrors,\n QueryVsearchResponses,\n ServerShutdownResponses,\n SseNoteAddResponses,\n SseNoteSyncResponses,\n SseNoteUpdateResponses,\n SseNoteUpsertResponses,\n WorkspaceCreateResponses,\n WorkspaceDeleteErrors,\n WorkspaceDeleteResponses,\n WorkspaceGetErrors,\n WorkspaceGetResponses,\n WorkspaceListErrors,\n WorkspaceListResponses,\n} from \"./types.gen\";\n\nexport type Options<\n TData extends TDataShape = TDataShape,\n ThrowOnError extends boolean = boolean,\n> = Options2<TData, ThrowOnError> & {\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\nclass HeyApiClient {\n protected client: Client;\n\n constructor(args?: { client?: Client }) {\n this.client = args?.client ?? client;\n }\n}\n\nclass HeyApiRegistry<T> {\n private readonly defaultKey = \"default\";\n\n private readonly instances: Map<string, T> = new Map();\n\n get(key?: string): T {\n const instance = this.instances.get(key ?? this.defaultKey);\n if (!instance) {\n throw new Error(\n `No SDK client found. Create one with \"new SpallClient()\" to fix this error.`,\n );\n }\n return instance;\n }\n\n set(value: T, key?: string): void {\n this.instances.set(key ?? this.defaultKey, value);\n }\n}\n\nexport class Workspace extends HeyApiClient {\n /**\n * Get workspace\n *\n * Look up a workspace by name or id.\n */\n public get<ThrowOnError extends boolean = false>(\n parameters?: {\n name?: string;\n id?: number;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"query\", key: \"name\" },\n { in: \"query\", key: \"id\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n WorkspaceGetResponses,\n WorkspaceGetErrors,\n ThrowOnError\n >({\n url: \"/workspace\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Create a workspace\n *\n * Get or create a workspace. Returns existing workspace if name matches, creates new one otherwise.\n */\n public create<ThrowOnError extends boolean = false>(\n parameters?: {\n name?: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"body\", key: \"name\" }] }],\n );\n return (options?.client ?? this.client).post<\n WorkspaceCreateResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/workspace\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * List workspaces\n *\n * List all workspaces.\n */\n public list<ThrowOnError extends boolean = false>(\n options?: Options<never, ThrowOnError>,\n ) {\n return (options?.client ?? this.client).get<\n WorkspaceListResponses,\n WorkspaceListErrors,\n ThrowOnError\n >({ url: \"/workspace/list\", ...options });\n }\n\n /**\n * Delete workspace\n *\n * Delete a workspace by ID.\n */\n public delete<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"path\", key: \"id\" }] }],\n );\n return (options?.client ?? this.client).delete<\n WorkspaceDeleteResponses,\n WorkspaceDeleteErrors,\n ThrowOnError\n >({\n url: \"/workspace/{id}\",\n ...options,\n ...params,\n });\n }\n}\n\nexport class Note extends HeyApiClient {\n /**\n * List notes\n *\n * List all note paths in a corpus.\n */\n public list<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"path\", key: \"id\" }] }],\n );\n return (options?.client ?? this.client).get<\n NoteListResponses,\n NoteListErrors,\n ThrowOnError\n >({\n url: \"/corpus/{id}/list\",\n ...options,\n ...params,\n });\n }\n\n /**\n * List notes by path\n *\n * List notes under a path prefix with keyset pagination. Returns full note content.\n */\n public listByPath<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n path?: string;\n limit?: number;\n after?: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"query\", key: \"path\" },\n { in: \"query\", key: \"limit\" },\n { in: \"query\", key: \"after\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n NoteListByPathResponses,\n NoteListByPathErrors,\n ThrowOnError\n >({\n url: \"/corpus/{id}/notes\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Get a note\n *\n * Get a note by path within a corpus.\n */\n public get<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n path: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"path\", key: \"path\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n NoteGetResponses,\n NoteGetErrors,\n ThrowOnError\n >({\n url: \"/corpus/{id}/note/{path}\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Upsert a note\n *\n * Create or update a note by path. Creates if not exists, updates if exists.\n */\n public upsert<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n path: string;\n content?: string;\n dupe?: boolean;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"path\", key: \"path\" },\n { in: \"body\", key: \"content\" },\n { in: \"body\", key: \"dupe\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).put<\n NoteUpsertResponses,\n NoteUpsertErrors,\n ThrowOnError\n >({\n url: \"/corpus/{id}/note/{path}\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * Sync a directory as notes\n *\n * Scan a directory, add matching notes, remove non-matches\n */\n public sync<ThrowOnError extends boolean = false>(\n parameters?: {\n directory?: string;\n glob?: string;\n path?: string;\n corpus?: number;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"body\", key: \"directory\" },\n { in: \"body\", key: \"glob\" },\n { in: \"body\", key: \"path\" },\n { in: \"body\", key: \"corpus\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).post<\n NoteSyncResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/corpus/sync\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * Add a note\n *\n * Add a note to a corpus and embed it. Requires corpus ID.\n */\n public add<ThrowOnError extends boolean = false>(\n parameters?: {\n corpus?: number;\n path?: string;\n content?: string;\n dupe?: boolean;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"body\", key: \"corpus\" },\n { in: \"body\", key: \"path\" },\n { in: \"body\", key: \"content\" },\n { in: \"body\", key: \"dupe\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).post<\n NoteAddResponses,\n NoteAddErrors,\n ThrowOnError\n >({\n url: \"/corpus/note\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * Get a note by ID\n *\n * Get a note by its globally unique ID.\n */\n public getById<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"path\", key: \"id\" }] }],\n );\n return (options?.client ?? this.client).get<\n NoteGetByIdResponses,\n NoteGetByIdErrors,\n ThrowOnError\n >({\n url: \"/note/{id}\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Update a note\n *\n * Update a note's content by ID. Re-embeds the content.\n */\n public update<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n content?: string;\n dupe?: boolean;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"body\", key: \"content\" },\n { in: \"body\", key: \"dupe\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).put<\n NoteUpdateResponses,\n NoteUpdateErrors,\n ThrowOnError\n >({\n url: \"/note/{id}\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n}\n\nexport class Corpus extends HeyApiClient {\n /**\n * Get corpus\n *\n * Look up a corpus by name or id. Returns default corpus if neither specified.\n */\n public get<ThrowOnError extends boolean = false>(\n parameters?: {\n name?: string;\n id?: number;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"query\", key: \"name\" },\n { in: \"query\", key: \"id\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n CorpusGetResponses,\n CorpusGetErrors,\n ThrowOnError\n >({\n url: \"/corpus\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Create a corpus\n *\n * Get or create a corpus. Returns existing corpus if name matches, creates new one otherwise.\n */\n public create<ThrowOnError extends boolean = false>(\n parameters?: {\n name?: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"body\", key: \"name\" }] }],\n );\n return (options?.client ?? this.client).post<\n CorpusCreateResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/corpus\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * List corpora\n *\n * List all corpora.\n */\n public list<ThrowOnError extends boolean = false>(\n options?: Options<never, ThrowOnError>,\n ) {\n return (options?.client ?? this.client).get<\n CorpusListResponses,\n CorpusListErrors,\n ThrowOnError\n >({ url: \"/corpus/list\", ...options });\n }\n\n /**\n * Delete corpus\n *\n * Delete a corpus and all associated notes by ID.\n */\n public delete<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"path\", key: \"id\" }] }],\n );\n return (options?.client ?? this.client).delete<\n CorpusDeleteResponses,\n CorpusDeleteErrors,\n ThrowOnError\n >({\n url: \"/corpus/{id}\",\n ...options,\n ...params,\n });\n }\n}\n\nexport class Query extends HeyApiClient {\n /**\n * Create a query\n *\n * Create a query scope for aggregating notes across multiple corpora.\n */\n public create<ThrowOnError extends boolean = false>(\n parameters?: {\n viewer?: number;\n tracked?: boolean;\n corpora?: Array<number>;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"body\", key: \"viewer\" },\n { in: \"body\", key: \"tracked\" },\n { in: \"body\", key: \"corpora\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).post<\n QueryCreateResponses,\n QueryCreateErrors,\n ThrowOnError\n >({\n url: \"/query\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * List recent queries\n *\n * Get the most recently created queries.\n */\n public recent<ThrowOnError extends boolean = false>(\n parameters?: {\n limit?: number;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"query\", key: \"limit\" }] }],\n );\n return (options?.client ?? this.client).get<\n QueryRecentResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/query/recent\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Get a query\n *\n * Get a query by ID.\n */\n public get<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ in: \"path\", key: \"id\" }] }],\n );\n return (options?.client ?? this.client).get<\n QueryGetResponses,\n QueryGetErrors,\n ThrowOnError\n >({\n url: \"/query/{id}\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Query notes\n *\n * List notes across all corpora in a query with keyset pagination.\n */\n public notes<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n path?: string;\n limit?: number;\n after?: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"query\", key: \"path\" },\n { in: \"query\", key: \"limit\" },\n { in: \"query\", key: \"after\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n QueryNotesResponses,\n QueryNotesErrors,\n ThrowOnError\n >({\n url: \"/query/{id}/notes\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Keyword search\n *\n * Search note content across all corpora in a query using FTS5.\n */\n public search<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n q: string;\n path?: string;\n limit?: number;\n mode?: \"plain\" | \"fts\";\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"query\", key: \"q\" },\n { in: \"query\", key: \"path\" },\n { in: \"query\", key: \"limit\" },\n { in: \"query\", key: \"mode\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n QuerySearchResponses,\n QuerySearchErrors,\n ThrowOnError\n >({\n url: \"/query/{id}/search\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Vector search\n *\n * Semantic search across all corpora in a query using embeddings.\n */\n public vsearch<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n q: string;\n path?: string;\n limit?: number;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"query\", key: \"q\" },\n { in: \"query\", key: \"path\" },\n { in: \"query\", key: \"limit\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n QueryVsearchResponses,\n QueryVsearchErrors,\n ThrowOnError\n >({\n url: \"/query/{id}/vsearch\",\n ...options,\n ...params,\n });\n }\n\n /**\n * Fetch notes by ID\n *\n * Fetch full note content for a list of note IDs through a query scope. Records access for reweighting.\n */\n public fetch<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n ids?: Array<number>;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"body\", key: \"ids\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).post<\n QueryFetchResponses,\n QueryFetchErrors,\n ThrowOnError\n >({\n url: \"/query/{id}/fetch\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * List paths\n *\n * List all note paths across corpora in a query, grouped by corpus.\n */\n public paths<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n path?: string;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"query\", key: \"path\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).get<\n QueryPathsResponses,\n QueryPathsErrors,\n ThrowOnError\n >({\n url: \"/query/{id}/paths\",\n ...options,\n ...params,\n });\n }\n}\n\nexport class Commit extends HeyApiClient {\n /**\n * Commit staged events\n *\n * Move all rows from staging to committed.\n */\n public run<ThrowOnError extends boolean = false>(\n parameters?: {\n body?: {\n [key: string]: unknown;\n };\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [{ args: [{ key: \"body\", map: \"body\" }] }],\n );\n return (options?.client ?? this.client).post<\n CommitRunResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/commit\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n}\n\nexport class Note2 extends HeyApiClient {\n /**\n * Index a directory (SSE)\n *\n * Scan a directory and embed all matching notes. Streams progress events.\n */\n public sync<ThrowOnError extends boolean = false>(\n parameters?: {\n directory?: string;\n glob?: string;\n path?: string;\n corpus?: number;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"body\", key: \"directory\" },\n { in: \"body\", key: \"glob\" },\n { in: \"body\", key: \"path\" },\n { in: \"body\", key: \"corpus\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).sse.post<\n SseNoteSyncResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/sse/corpus/sync\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * Add a note (SSE)\n *\n * Add a note to a corpus and embed it. Streams progress events.\n */\n public add<ThrowOnError extends boolean = false>(\n parameters?: {\n corpus?: number;\n path?: string;\n content?: string;\n dupe?: boolean;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"body\", key: \"corpus\" },\n { in: \"body\", key: \"path\" },\n { in: \"body\", key: \"content\" },\n { in: \"body\", key: \"dupe\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).sse.post<\n SseNoteAddResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/sse/corpus/note\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * Upsert a note (SSE)\n *\n * Create or update a note by path. Streams progress events.\n */\n public upsert<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n path: string;\n content?: string;\n dupe?: boolean;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"path\", key: \"path\" },\n { in: \"body\", key: \"content\" },\n { in: \"body\", key: \"dupe\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).sse.put<\n SseNoteUpsertResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/sse/corpus/{id}/note/{path}\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n\n /**\n * Update a note (SSE)\n *\n * Update a note's content by ID. Re-embeds the content. Streams progress events.\n */\n public update<ThrowOnError extends boolean = false>(\n parameters: {\n id: string;\n content?: string;\n dupe?: boolean;\n },\n options?: Options<never, ThrowOnError>,\n ) {\n const params = buildClientParams(\n [parameters],\n [\n {\n args: [\n { in: \"path\", key: \"id\" },\n { in: \"body\", key: \"content\" },\n { in: \"body\", key: \"dupe\" },\n ],\n },\n ],\n );\n return (options?.client ?? this.client).sse.put<\n SseNoteUpdateResponses,\n unknown,\n ThrowOnError\n >({\n url: \"/sse/note/{id}\",\n ...options,\n ...params,\n headers: {\n \"Content-Type\": \"application/json\",\n ...options?.headers,\n ...params.headers,\n },\n });\n }\n}\n\nexport class Sse extends HeyApiClient {\n private _note?: Note2;\n get note(): Note2 {\n return (this._note ??= new Note2({ client: this.client }));\n }\n}\n\nexport class Server extends HeyApiClient {\n /**\n * Shutdown server\n *\n * Request the server to stop.\n */\n public shutdown<ThrowOnError extends boolean = false>(\n options?: Options<never, ThrowOnError>,\n ) {\n return (options?.client ?? this.client).post<\n ServerShutdownResponses,\n unknown,\n ThrowOnError\n >({ url: \"/shutdown\", ...options });\n }\n}\n\nexport class SpallClient extends HeyApiClient {\n public static readonly __registry = new HeyApiRegistry<SpallClient>();\n\n constructor(args?: { client?: Client; key?: string }) {\n super(args);\n SpallClient.__registry.set(this, args?.key);\n }\n\n /**\n * Health check\n *\n * Check if the server is running\n */\n public health<ThrowOnError extends boolean = false>(\n options?: Options<never, ThrowOnError>,\n ) {\n return (options?.client ?? this.client).get<\n HealthResponses,\n unknown,\n ThrowOnError\n >({ url: \"/health\", ...options });\n }\n\n /**\n * Event stream\n *\n * Subscribe to all server events via SSE\n */\n public events<ThrowOnError extends boolean = false>(\n options?: Options<never, ThrowOnError>,\n ) {\n return (options?.client ?? this.client).sse.get<\n EventsResponses,\n unknown,\n ThrowOnError\n >({ url: \"/events\", ...options });\n }\n\n private _workspace?: Workspace;\n get workspace(): Workspace {\n return (this._workspace ??= new Workspace({ client: this.client }));\n }\n\n private _note?: Note;\n get note(): Note {\n return (this._note ??= new Note({ client: this.client }));\n }\n\n private _corpus?: Corpus;\n get corpus(): Corpus {\n return (this._corpus ??= new Corpus({ client: this.client }));\n }\n\n private _query?: Query;\n get query(): Query {\n return (this._query ??= new Query({ client: this.client }));\n }\n\n private _commit?: Commit;\n get commit(): Commit {\n return (this._commit ??= new Commit({ client: this.client }));\n }\n\n private _sse?: Sse;\n get sse(): Sse {\n return (this._sse ??= new Sse({ client: this.client }));\n }\n\n private _server?: Server;\n get server(): Server {\n return (this._server ??= new Server({ client: this.client }));\n }\n}\n",
|
|
15
|
+
"import { mkdirSync, existsSync, readFileSync, writeFileSync, rmSync } from \"fs\";\nimport { join } from \"path\";\n\nimport { Config } from \"@spader/spall-core/config\";\n\ntype LockData = { pid: number; port: number | null };\n\nfunction debugEnabled(): boolean {\n const value = process.env.SPALL_DEBUG;\n return value === \"1\" || value === \"true\";\n}\n\nfunction debug(message: string): void {\n if (debugEnabled()) {\n console.error(`[spall:debug] ${message}`);\n }\n}\n\nexport namespace Cache {\n export function ensure(): void {\n const dir = Config.get().dirs.data;\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n }\n}\n\nexport namespace Lock {\n export function path(): string {\n return join(Config.get().dirs.data, \"server.lock\");\n }\n\n export function read(): LockData | null {\n try {\n const content = readFileSync(path(), \"utf-8\");\n return JSON.parse(content) as LockData;\n } catch {\n return null;\n }\n }\n\n export function create(): boolean {\n Cache.ensure();\n try {\n writeFileSync(path(), JSON.stringify({ pid: process.pid, port: null }), {\n flag: \"wx\",\n });\n return true;\n } catch {\n return false;\n }\n }\n\n export function update(port: number): void {\n Cache.ensure();\n writeFileSync(path(), JSON.stringify({ pid: process.pid, port }));\n }\n\n export function takeover(): void {\n Cache.ensure();\n writeFileSync(path(), JSON.stringify({ pid: process.pid, port: null }));\n }\n\n export function remove(): void {\n rmSync(path(), { force: true });\n }\n}\n\nexport function isProcessAlive(pid: number): boolean {\n try {\n process.kill(pid, 0);\n return true;\n } catch {\n return false;\n }\n}\n\nexport async function checkHealth(port: number): Promise<boolean> {\n try {\n const response = await fetch(`http://127.0.0.1:${port}/health`);\n return response.ok;\n } catch {\n return false;\n }\n}\n\nconst Role = {\n Leader: \"leader\",\n Follower: \"follower\",\n} as const;\n\ntype AcquireResult =\n | { role: typeof Role.Leader }\n | { role: typeof Role.Follower; url: string };\n\nasync function acquire(): Promise<AcquireResult> {\n while (true) {\n if (Lock.create()) {\n debug(`Acquired startup lock as leader pid=${process.pid}`);\n return { role: Role.Leader };\n }\n\n const lock = Lock.read();\n\n // the claimant died after check but before read; narrow, but no big deal\n if (!lock) {\n debug(\"Startup lock disappeared before it could be read; retrying\");\n continue;\n }\n\n // if the lock has a port, there should be a healthy server.\n // - if we can connect, we're done\n // - if we can't, it's a stale lock. remove it and start over.\n if (lock.port !== null) {\n if (await checkHealth(lock.port)) {\n debug(`Following healthy server pid=${lock.pid} port=${lock.port}`);\n return { role: Role.Follower, url: `http://127.0.0.1:${lock.port}` };\n }\n\n debug(`Removing stale unhealthy lock pid=${lock.pid} port=${lock.port}`);\n Lock.remove();\n continue;\n }\n\n // at this point, the lock file exists but has no port.\n // - if its pid is running, assume the server is starting\n // - if it isn't, it's a stale lock.\n if (!isProcessAlive(lock.pid)) {\n debug(`Removing stale startup lock pid=${lock.pid}`);\n Lock.remove();\n continue;\n }\n\n // give the other client time to start the server\n debug(`Waiting for leader pid=${lock.pid} to publish server port`);\n await Bun.sleep(50);\n }\n}\n\n// atomically start a local server, or connect to an existing one.\nexport async function ensure(): Promise<string> {\n const result = await acquire();\n\n if (result.role === Role.Follower) {\n debug(`ensure returning follower url ${result.url}`);\n return result.url;\n }\n\n // do our best to invoke the server regardless of how we're installed\n const script = join(import.meta.dir, \"serve.ts\");\n debug(`ensure spawning local server from ${script}`);\n Bun.spawn([process.execPath, script], {\n stdin: \"ignore\",\n stdout: \"ignore\",\n stderr: \"ignore\",\n env: {\n ...process.env,\n SPALL_CACHE_DIR: Config.get().dirs.cache,\n },\n }).unref();\n\n // spin, waiting for the server to write its port to the lock file\n for (let i = 0; i < 40; i++) {\n await Bun.sleep(50);\n const lock = Lock.read();\n if (lock && lock.port !== null) {\n debug(`ensure observed server port ${lock.port}`);\n return `http://127.0.0.1:${lock.port}`;\n }\n }\n\n debug(\"ensure timed out waiting for local server port\");\n throw new Error(\n \"Claimed leader role, but timed out waiting for server to start\",\n );\n}\n",
|
|
16
|
+
"import { createClient } from \"./gen/client/client.gen\";\nimport { SpallClient } from \"./gen/sdk.gen\";\nimport { ensure } from \"./lock\";\nimport { Config } from \"@spader/spall-core/config\";\n\nexport { SpallClient };\n\nexport * from \"./gen/types.gen\";\n\nconst URL_KEY = Symbol.for(\"spall.client.url\");\n\nfunction debugEnabled(): boolean {\n const value = process.env.SPALL_DEBUG;\n return value === \"1\" || value === \"true\";\n}\n\nfunction debug(message: string): void {\n if (debugEnabled()) {\n console.error(`[spall:debug] ${message}`);\n }\n}\n\ntype TaggedEvent = { tag: string };\nexport namespace Client {\n /** Get the base URL a client was connected to. */\n export function url(client: SpallClient): string {\n return (client as any)[URL_KEY];\n }\n\n export function unwrap<T>(\n result: { data?: T; error?: unknown } | undefined,\n ): T {\n if (!result || result.error || !result.data) {\n throw result?.error ?? new Error(\"No data\");\n }\n return result.data;\n }\n\n export async function connect(signal?: AbortSignal): Promise<SpallClient> {\n const remoteUrl = Config.get().server.url;\n if (remoteUrl) {\n debug(`Client.connect using configured remote server ${remoteUrl}`);\n try {\n const res = await fetch(`${remoteUrl}/health`, { signal });\n if (!res.ok) throw new Error(`Remote server returned ${res.status}`);\n } catch (err: any) {\n debug(\n `Client.connect failed remote health check for ${remoteUrl}: ${err?.message ?? err}`,\n );\n throw new Error(\n `Cannot reach remote server at ${remoteUrl}: ${err?.message ?? err}`,\n );\n }\n debug(`Client.connect attached to configured remote server ${remoteUrl}`);\n return attach(remoteUrl, signal);\n }\n\n debug(\"Client.connect acquiring local server lock\");\n const url = await ensure();\n debug(`Client.connect attached to local server ${url}`);\n return attach(url, signal);\n }\n\n export function attach(url: string, signal?: AbortSignal): SpallClient {\n const client = createClient({ baseUrl: url, signal });\n const spall = new SpallClient({ client });\n (spall as any)[URL_KEY] = url;\n return spall;\n }\n\n // consume an SSE stream until you see the event you want; useful for\n // endpoints that return a stream for progress but for which you just want\n // to get the final result\n export async function until<TEvent extends TaggedEvent, TTag extends string>(\n stream: AsyncGenerator<TEvent, unknown, unknown>,\n tag: TTag,\n handler?: (event: TEvent) => void,\n ): Promise<Extract<TEvent, { tag: TTag }>> {\n const isErrorEvent = (\n event: TEvent,\n ): event is TEvent & {\n tag: \"error\";\n error?: { code?: string; message?: string };\n } => event.tag === \"error\" && \"error\" in (event as Record<string, unknown>);\n\n for await (const event of stream) {\n handler?.(event);\n\n if (isErrorEvent(event)) {\n const e = event.error;\n const err = new Error(e?.message ?? \"unknown error\");\n (err as any).code = e?.code ?? \"error\";\n throw err;\n }\n\n if (event?.tag === tag) {\n return event as Extract<TEvent, { tag: TTag }>;\n }\n }\n throw new Error(`Stream ended without receiving '${tag}' event`);\n }\n}\n",
|
|
17
|
+
"import { consola } from \"consola\";\nimport pc from \"picocolors\";\n\nimport { type EventUnion } from \"@spader/spall-core\";\nimport { Bus } from \"@spader/spall-core/event\";\nimport { Config } from \"@spader/spall-core/config\";\nimport { Model } from \"@spader/spall-core/model\";\nimport { App } from \"./app\";\nimport { Lock, isProcessAlive, checkHealth } from \"./lock\";\nimport { Store } from \"@spader/spall-core\";\nimport { ServerLog } from \"./log\";\n\nexport { Lock } from \"./lock\";\nexport { ensure } from \"./lock\";\nexport { isProcessAlive, checkHealth } from \"./lock\";\n\nfunction formatBytes(bytes: number): string {\n if (bytes < 1024) return `${bytes} B`;\n if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(1)} KB`;\n if (bytes < 1024 * 1024 * 1024)\n return `${(bytes / (1024 * 1024)).toFixed(1)} MB`;\n return `${(bytes / (1024 * 1024 * 1024)).toFixed(1)} GB`;\n}\n\nfunction parseBooleanEnv(value: string | undefined): boolean | undefined {\n if (!value) return undefined;\n if (value === \"1\" || value === \"true\") return true;\n if (value === \"0\" || value === \"false\") return false;\n return undefined;\n}\n\nfunction parseNumberEnv(value: string | undefined): number | undefined {\n if (!value) return undefined;\n const parsed = Number(value);\n return Number.isFinite(parsed) ? parsed : undefined;\n}\n\nexport namespace Server {\n let server: Bun.Server | null = null;\n let persist = false;\n let activeRequests = 0;\n let timer: Timer;\n let idleTimeoutMs = 1000;\n let resolved: (() => void) | null = null;\n let unsubscribeBus: (() => void) | null = null;\n let processHandlersInstalled = false;\n\n function installProcessHandlers(): void {\n if (processHandlersInstalled) return;\n processHandlersInstalled = true;\n\n process.once(\"SIGINT\", () => {\n consola.info(`Received ${pc.gray(\"SIGINT\")}`);\n stop();\n });\n process.once(\"SIGTERM\", () => {\n consola.info(`Received ${pc.gray(\"SIGTERM\")}`);\n stop();\n });\n\n process.on(\"uncaughtException\", (err) => {\n ServerLog.error(err);\n consola.error(\"Uncaught exception:\", err);\n });\n process.on(\"unhandledRejection\", (err) => {\n ServerLog.error(err);\n consola.error(\"Unhandled rejection:\", err);\n });\n }\n\n export type Options = {\n persist: boolean;\n idleTimeoutMs: number;\n force: boolean;\n };\n\n export namespace Sse {\n let count = 0;\n\n export function active(): boolean {\n return count > 0;\n }\n\n export function track(): void {\n count++;\n clearTimeout(timer);\n }\n\n export function untrack(): void {\n count--;\n clearTimeout(timer);\n }\n\n export function reset(): void {\n count = 0;\n }\n }\n\n export function increment(): void {\n activeRequests++;\n clearTimeout(timer);\n }\n\n export function decrement(): void {\n activeRequests--;\n resetShutdownTimer();\n }\n\n function resetShutdownTimer(): void {\n if (persist) return;\n if (activeRequests > 0 || Sse.active()) return;\n\n timer = setTimeout(() => {\n if (activeRequests === 0 && !Sse.active()) {\n stop();\n }\n }, idleTimeoutMs);\n }\n\n export interface ServerResult {\n port: number;\n stopped: Promise<void>;\n }\n\n export function render(event: EventUnion): string {\n switch (event.tag) {\n case \"model.download\":\n return `Downloading ${pc.cyan(event.info.name)}`;\n case \"model.downloaded\":\n return `Finished downloading ${pc.cyanBright(event.info.name)}`;\n case \"model.progress\": {\n const percent = (event.downloaded / event.total) * 100;\n const percentStr = percent.toFixed(0).padStart(3);\n\n return `${pc.cyan(event.info.name)} ${pc.bold(percentStr + \"%\")}`;\n }\n case \"model.load\":\n return `Loaded ${pc.cyanBright(event.info.name)}`;\n case \"model.failed\":\n return `${pc.red(\"Failed to load model:\")} ${event.error}`;\n case \"store.create\":\n return `Creating database at ${pc.cyanBright(event.path)}`;\n case \"store.created\":\n return `Created database at ${pc.cyanBright(event.path)}`;\n case \"note.created\":\n return `${pc.cyanBright(event.info.path)} (${formatBytes(event.info.content.length)}, hash: ${event.info.contentHash})`;\n case \"note.updated\":\n return `${pc.cyanBright(event.info.path)} (${formatBytes(event.info.content.length)}, hash: ${event.info.contentHash})`;\n case \"embed.cancel\":\n return \"Cancelled embedding\";\n }\n\n return event.tag;\n }\n\n export async function start(\n request?: Partial<Options>,\n ): Promise<ServerResult> {\n const env: Partial<Options> = {\n persist: parseBooleanEnv(process.env.SPALL_SERVER_PERSIST),\n force: parseBooleanEnv(process.env.SPALL_SERVER_FORCE),\n idleTimeoutMs: parseNumberEnv(process.env.SPALL_SERVER_IDLE_TIMEOUT_MS),\n };\n const config: Partial<Options> = {\n idleTimeoutMs: Config.get().server.idleTimeout * 1000,\n };\n\n const options: Options = {\n persist: request?.persist ?? env.persist ?? false,\n idleTimeoutMs:\n request?.idleTimeoutMs ??\n env.idleTimeoutMs ??\n config.idleTimeoutMs ??\n 1000,\n force: request?.force ?? env.force ?? false,\n };\n\n Store.ensure();\n\n // set module level fields\n persist = options.persist;\n idleTimeoutMs = options.idleTimeoutMs;\n\n // sanity check; this function should only be called when you have the\n // process lock, so we *can* unconditionally write our pid and port to\n // the lock.\n //\n // but we're nice and check if the current pid + port is a healthy server,\n // in case the user tried to spin up two daemons on accident\n const existing = Lock.read();\n if (\n existing &&\n existing.port !== null &&\n (await checkHealth(existing.port))\n ) {\n if (options.force) {\n const pid = `${pc.gray(\"pid\")} ${pc.yellow(existing.pid)}`;\n const port = `${pc.gray(\"port\")} ${pc.cyan(existing.port)}`;\n consola.info(`Killing existing server (${pid}, ${port})`);\n\n // claim lock before killing so there's no window where lock doesn't exist\n Lock.takeover();\n\n try {\n process.kill(existing.pid, \"SIGTERM\");\n\n for (let i = 0; i < 40; i++) {\n if (!isProcessAlive(existing.pid)) break;\n await Bun.sleep(50);\n }\n } catch {\n // the process is already dead\n }\n } else {\n throw new Error(`Server is already running at port ${existing.port}`);\n }\n }\n\n server = Bun.serve({\n port: 0,\n fetch: App.get().fetch,\n idleTimeout: 0,\n });\n\n const port = server.port;\n if (!port) {\n server.stop();\n throw new Error(\"Failed to start server\");\n }\n\n consola.log(`Listening on port ${pc.cyanBright(String(port))}`);\n\n Lock.update(port);\n ServerLog.init(port);\n\n installProcessHandlers();\n\n resetShutdownTimer();\n\n const stopped = new Promise<void>((resolve) => {\n resolved = resolve;\n });\n\n unsubscribeBus?.();\n unsubscribeBus = Bus.subscribe((event: EventUnion) => {\n consola.info(`${pc.gray(event.tag)} ${render(event)}`);\n ServerLog.event(event);\n });\n\n // Kick off model download/load in background (errors published as model.failed event)\n Model.load().catch(() => {});\n\n return { port, stopped };\n }\n\n export function stop(): void {\n if (!server) return;\n consola.info(\"Stopping server\");\n server.stop();\n server = null;\n Sse.reset();\n unsubscribeBus?.();\n unsubscribeBus = null;\n // Only remove lock if we still own it (--force may have overwritten it)\n const lock = Lock.read();\n if (lock && lock.pid === process.pid) {\n Lock.remove();\n }\n resolved?.();\n resolved = null;\n }\n}\n",
|
|
18
|
+
"import { Hono } from \"hono\";\nimport { logger } from \"hono/logger\";\nimport { describeRoute, generateSpecs, resolver } from \"hono-openapi\";\nimport { z } from \"zod\";\n\nimport { Server } from \"./server\";\nimport { ServerLog } from \"./log\";\nimport { CorpusRoutes } from \"./routes/corpus\";\nimport { WorkspaceRoutes } from \"./routes/workspace\";\nimport { NoteRoutes } from \"./routes/note\";\nimport { QueryRoutes } from \"./routes/query\";\nimport { CommitRoutes } from \"./routes/commit\";\nimport { SseRoutes } from \"./routes/sse\";\nimport { Sse } from \"./sse\";\nimport { EventUnion } from \"@spader/spall-core\";\n\nexport namespace App {\n const app = new Hono();\n let loaded = false;\n\n export function ensure() {\n if (loaded) return;\n loaded = true;\n\n app\n .use(async (_, next) => {\n Server.increment();\n try {\n await next();\n } finally {\n Server.decrement();\n }\n })\n .use(logger())\n .use(logger(ServerLog.appLog))\n .route(\"/workspace\", WorkspaceRoutes())\n .route(\"/corpus\", CorpusRoutes())\n .route(\"/note\", NoteRoutes())\n .route(\"/query\", QueryRoutes())\n .route(\"/commit\", CommitRoutes())\n .route(\"/sse\", SseRoutes())\n .get(\n \"/health\",\n describeRoute({\n summary: \"Health check\",\n description: \"Check if the server is running\",\n operationId: \"health\",\n responses: {\n 200: {\n description: \"Server is healthy\",\n content: {\n \"text/plain\": {\n schema: resolver(z.string()),\n },\n },\n },\n },\n }),\n (c) => {\n return c.text(\"ok\");\n },\n )\n .get(\n \"/events\",\n describeRoute({\n summary: \"Event stream\",\n description: \"Subscribe to all server events via SSE\",\n operationId: \"events\",\n responses: {\n 200: {\n description: \"Event stream\",\n content: {\n \"text/event-stream\": {\n schema: resolver(EventUnion),\n },\n },\n },\n },\n }),\n (c) => {\n return Sse.subscribe(c);\n },\n );\n\n app.post(\n \"/shutdown\",\n describeRoute({\n summary: \"Shutdown server\",\n description: \"Request the server to stop.\",\n operationId: \"server.shutdown\",\n responses: {\n 200: {\n description: \"Shutdown acknowledged\",\n content: {\n \"application/json\": {\n schema: resolver(z.object({ ok: z.literal(true) })),\n },\n },\n },\n },\n }),\n async (c) => {\n // Let the response flush before stopping.\n setTimeout(() => {\n try {\n process.kill(process.pid, \"SIGTERM\");\n } catch {\n // ignore\n }\n }, 0);\n return c.json({ ok: true as const });\n },\n );\n\n return app;\n }\n\n export function get(): Hono {\n ensure();\n return app;\n }\n\n export async function spec(): Promise<Record<string, unknown>> {\n return generateSpecs(App.get(), {\n documentation: {\n info: {\n title: \"spall\",\n version: \"0.0.1\",\n description: \"Local semantic note store with embeddings\",\n },\n openapi: \"3.1.1\",\n },\n });\n }\n}\n",
|
|
19
|
+
"import { mkdirSync, appendFileSync } from \"fs\";\nimport { dirname, join } from \"path\";\nimport { Config } from \"@spader/spall-core/config\";\n\n/**\n * Server file logger.\n *\n * Log directory: ~/.local/share/spall/logs/$isotimestamp_$pid_$port/\n * - events.log -- bus events + errors (JSONL)\n * - app.log -- hono HTTP request logs (plain text lines)\n */\nexport namespace ServerLog {\n let dir: string | null = null;\n let eventsPath: string;\n let appPath: string;\n\n function ts(): string {\n return new Date().toISOString();\n }\n\n export function init(port: number): void {\n const stamp = new Date()\n .toISOString()\n .replace(/:/g, \"-\")\n .replace(/\\.\\d+Z$/, \"Z\");\n const name = `${stamp}_${process.pid}_${port}`;\n dir = join(Config.get().dirs.data, \"logs\", name);\n mkdirSync(dir, { recursive: true });\n eventsPath = join(dir, \"events.log\");\n appPath = join(dir, \"app.log\");\n }\n\n function safeAppend(path: string, line: string): void {\n try {\n appendFileSync(path, line + \"\\n\");\n } catch {\n try {\n mkdirSync(dirname(path), { recursive: true });\n appendFileSync(path, line + \"\\n\");\n } catch {\n // Best-effort logging should never crash server/tests.\n }\n }\n }\n\n /** Write a bus event to events.log as JSONL. */\n export function event(e: { tag: string; [k: string]: unknown }): void {\n if (!dir) return;\n const line = JSON.stringify({ ts: ts(), ...e });\n safeAppend(eventsPath, line);\n }\n\n /** Write an error to events.log. */\n export function error(err: unknown): void {\n if (!dir) return;\n const message =\n err instanceof Error\n ? { message: err.message, stack: err.stack }\n : { message: String(err) };\n const line = JSON.stringify({ ts: ts(), tag: \"error\", ...message });\n safeAppend(eventsPath, line);\n }\n\n const ANSI_RE = /\\x1b\\[[0-9;]*m/g;\n\n /** Hono logger print function -- writes to app.log. */\n export function appLog(message: string, ...rest: string[]): void {\n if (!dir) return;\n const raw = `${ts()} ${message} ${rest.join(\" \")}`.trimEnd();\n safeAppend(appPath, raw.replace(ANSI_RE, \"\"));\n }\n\n /** Returns the log directory path, or null if not initialized. */\n export function path(): string | null {\n return dir;\n }\n}\n",
|
|
20
|
+
"import { Hono } from \"hono\";\nimport { describeRoute, resolver, validator } from \"hono-openapi\";\n\nimport { lazy } from \"../util\";\nimport { Corpus, Note, Error } from \"@spader/spall-core\";\n\nexport const CorpusRoutes = lazy(() =>\n new Hono()\n .get(\n \"/:id/list\",\n describeRoute({\n summary: \"List notes\",\n description: \"List all note paths in a corpus.\",\n operationId: \"note.list\",\n responses: {\n 200: {\n description: \"List of notes\",\n content: {\n \"application/json\": {\n schema: resolver(Note.ListItem.array()),\n },\n },\n },\n 404: {\n description: \"Corpus not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (c) => {\n const id = c.req.param(\"id\");\n const result = await Note.list({\n corpus: Corpus.Id.parse(id),\n })\n .then((result) => c.json(result))\n .catch((error: any) => c.json(Error.from(error), 404));\n return result;\n },\n )\n .get(\n \"/:id/notes\",\n describeRoute({\n summary: \"List notes by path\",\n description:\n \"List notes under a path prefix with keyset pagination. Returns full note content.\",\n operationId: \"note.listByPath\",\n responses: {\n 200: {\n description: \"Paginated notes\",\n content: {\n \"application/json\": {\n schema: resolver(Note.Page),\n },\n },\n },\n 404: {\n description: \"Corpus not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"query\", Note.listByPath.schema.omit({ corpus: true })),\n async (c) => {\n const id = c.req.param(\"id\");\n const query = c.req.valid(\"query\");\n try {\n const result = Note.listByPath({\n corpus: Corpus.Id.parse(id),\n ...query,\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .get(\n \"/:id/note/:path{.+}\",\n describeRoute({\n summary: \"Get a note\",\n description: \"Get a note by path within a corpus.\",\n operationId: \"note.get\",\n responses: {\n 200: {\n description: \"Note with content\",\n content: {\n \"application/json\": {\n schema: resolver(Note.Info),\n },\n },\n },\n 404: {\n description: \"Corpus or note not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (c) => {\n const id = c.req.param(\"id\");\n const path = c.req.param(\"path\");\n try {\n const result = Note.get({\n corpus: Corpus.Id.parse(id),\n path,\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .post(\n \"/\",\n describeRoute({\n summary: \"Create a corpus\",\n description:\n \"Get or create a corpus. Returns existing corpus if name matches, creates new one otherwise.\",\n operationId: \"corpus.create\",\n responses: {\n 200: {\n description: \"Corpus info\",\n content: {\n \"application/json\": {\n schema: resolver(Corpus.Info),\n },\n },\n },\n },\n }),\n validator(\"json\", Corpus.create.schema),\n async (context) => {\n const input = context.req.valid(\"json\") ?? {};\n const result = await Corpus.create(input);\n return context.json(result);\n },\n )\n .get(\n \"/list\",\n describeRoute({\n summary: \"List corpora\",\n description: \"List all corpora.\",\n operationId: \"corpus.list\",\n responses: {\n 200: {\n description: \"List of corpora\",\n content: {\n \"application/json\": {\n schema: resolver(Corpus.Info.array()),\n },\n },\n },\n 500: {\n description: \"Server error\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (c) => {\n try {\n const result = await Corpus.list({});\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 500);\n }\n },\n )\n .get(\n \"/\",\n describeRoute({\n summary: \"Get corpus\",\n description:\n \"Look up a corpus by name or id. Returns default corpus if neither specified.\",\n operationId: \"corpus.get\",\n responses: {\n 200: {\n description: \"Corpus info\",\n content: {\n \"application/json\": {\n schema: resolver(Corpus.Info),\n },\n },\n },\n 404: {\n description: \"Corpus not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"query\", Corpus.get.schema),\n async (context) => {\n const query = context.req.valid(\"query\");\n try {\n const result = await Corpus.get(query);\n return context.json(result);\n } catch (error: any) {\n return context.json(Error.from(error), 404);\n }\n },\n )\n .delete(\n \"/:id\",\n describeRoute({\n summary: \"Delete corpus\",\n description: \"Delete a corpus and all associated notes by ID.\",\n operationId: \"corpus.delete\",\n responses: {\n 204: {\n description: \"Corpus deleted successfully\",\n },\n 404: {\n description: \"Corpus not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (context) => {\n try {\n const id = context.req.param(\"id\");\n await Corpus.remove({ id: Corpus.Id.parse(id) });\n return context.body(null, 204);\n } catch (error: any) {\n return context.json(Error.from(error), 404);\n }\n },\n )\n .post(\n \"/sync\",\n describeRoute({\n summary: \"Sync a directory as notes\",\n description: \"Scan a directory, add matching notes, remove non-matches\",\n operationId: \"note.sync\",\n responses: {\n 204: {\n description: \"Index complete\",\n },\n },\n }),\n validator(\"json\", Note.sync.schema),\n async (context) => {\n const body = context.req.valid(\"json\");\n await Note.sync(body);\n return context.body(null, 204);\n },\n )\n .post(\n \"/note\",\n describeRoute({\n summary: \"Add a note\",\n description: \"Add a note to a corpus and embed it. Requires corpus ID.\",\n operationId: \"note.add\",\n responses: {\n 200: {\n description: \"Created note\",\n content: {\n \"application/json\": {\n schema: resolver(Note.Info),\n },\n },\n },\n 404: {\n description: \"Corpus not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"json\", Note.add.schema),\n async (context) => {\n const body = context.req.valid(\"json\");\n try {\n const result = await Note.add(body);\n return context.json(result);\n } catch (error: any) {\n return context.json(Error.from(error), 404);\n }\n },\n )\n .put(\n \"/:id/note/:path{.+}\",\n describeRoute({\n summary: \"Upsert a note\",\n description:\n \"Create or update a note by path. Creates if not exists, updates if exists.\",\n operationId: \"note.upsert\",\n responses: {\n 200: {\n description: \"Created or updated note\",\n content: {\n \"application/json\": {\n schema: resolver(Note.Info),\n },\n },\n },\n 404: {\n description: \"Corpus not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"json\", Note.upsert.schema.omit({ corpus: true, path: true })),\n async (context) => {\n const id = context.req.param(\"id\");\n const path = context.req.param(\"path\");\n const body = context.req.valid(\"json\");\n try {\n const result = await Note.upsert({\n corpus: Corpus.Id.parse(id),\n path,\n ...body,\n });\n return context.json(result);\n } catch (error: any) {\n return context.json(Error.from(error), 404);\n }\n },\n ),\n);\n",
|
|
21
|
+
"export function lazy<T>(fn: () => T) {\n let value: T | undefined\n let loaded = false\n\n const result = (): T => {\n if (loaded) return value as T\n loaded = true\n value = fn()\n return value as T\n }\n\n result.reset = () => {\n loaded = false\n value = undefined\n }\n\n return result\n}\n",
|
|
22
|
+
"import { Hono } from \"hono\";\nimport { describeRoute, resolver, validator } from \"hono-openapi\";\n\nimport { lazy } from \"../util\";\nimport { Workspace, Error } from \"@spader/spall-core\";\n\nexport const WorkspaceRoutes = lazy(() =>\n new Hono()\n .post(\n \"/\",\n describeRoute({\n summary: \"Create a workspace\",\n description:\n \"Get or create a workspace. Returns existing workspace if name matches, creates new one otherwise.\",\n operationId: \"workspace.create\",\n responses: {\n 200: {\n description: \"Workspace info\",\n content: {\n \"application/json\": {\n schema: resolver(Workspace.Info),\n },\n },\n },\n },\n }),\n validator(\"json\", Workspace.create.schema),\n async (context) => {\n const input = context.req.valid(\"json\") ?? {};\n const result = await Workspace.create(input);\n return context.json(result);\n },\n )\n .get(\n \"/list\",\n describeRoute({\n summary: \"List workspaces\",\n description: \"List all workspaces.\",\n operationId: \"workspace.list\",\n responses: {\n 200: {\n description: \"List of workspaces\",\n content: {\n \"application/json\": {\n schema: resolver(Workspace.Info.array()),\n },\n },\n },\n 500: {\n description: \"Server error\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (c) => {\n try {\n const result = await Workspace.list({});\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 500);\n }\n },\n )\n .get(\n \"/\",\n describeRoute({\n summary: \"Get workspace\",\n description: \"Look up a workspace by name or id.\",\n operationId: \"workspace.get\",\n responses: {\n 200: {\n description: \"Workspace info\",\n content: {\n \"application/json\": {\n schema: resolver(Workspace.Info),\n },\n },\n },\n 404: {\n description: \"Workspace not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"query\", Workspace.get.schema),\n async (context) => {\n const query = context.req.valid(\"query\");\n try {\n const result = await Workspace.get(query);\n return context.json(result);\n } catch (error: any) {\n return context.json(Error.from(error), 404);\n }\n },\n )\n .delete(\n \"/:id\",\n describeRoute({\n summary: \"Delete workspace\",\n description: \"Delete a workspace by ID.\",\n operationId: \"workspace.delete\",\n responses: {\n 204: {\n description: \"Workspace deleted successfully\",\n },\n 404: {\n description: \"Workspace not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (context) => {\n try {\n const id = context.req.param(\"id\");\n await Workspace.remove({ id: Workspace.Id.parse(id) });\n return context.body(null, 204);\n } catch (error: any) {\n return context.json(Error.from(error), 404);\n }\n },\n ),\n);\n",
|
|
23
|
+
"import { Hono } from \"hono\";\nimport { describeRoute, resolver, validator } from \"hono-openapi\";\n\nimport { lazy } from \"../util\";\nimport { Note, Error } from \"@spader/spall-core\";\n\nexport const NoteRoutes = lazy(() =>\n new Hono()\n .get(\n \"/:id\",\n describeRoute({\n summary: \"Get a note by ID\",\n description: \"Get a note by its globally unique ID.\",\n operationId: \"note.getById\",\n responses: {\n 200: {\n description: \"Note with content\",\n content: {\n \"application/json\": {\n schema: resolver(Note.Info),\n },\n },\n },\n 404: {\n description: \"Note not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (c) => {\n const id = c.req.param(\"id\");\n try {\n const result = Note.getById({\n id: Note.Id.parse(id),\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .put(\n \"/:id\",\n describeRoute({\n summary: \"Update a note\",\n description: \"Update a note's content by ID. Re-embeds the content.\",\n operationId: \"note.update\",\n responses: {\n 200: {\n description: \"Updated note\",\n content: {\n \"application/json\": {\n schema: resolver(Note.Info),\n },\n },\n },\n 404: {\n description: \"Note not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"json\", Note.update.schema.omit({ id: true })),\n async (context) => {\n const id = context.req.param(\"id\");\n const body = context.req.valid(\"json\");\n try {\n const result = await Note.update({\n id: Note.Id.parse(id),\n ...body,\n });\n return context.json(result);\n } catch (error: any) {\n return context.json(Error.from(error), 404);\n }\n },\n ),\n);\n",
|
|
24
|
+
"import { Hono } from \"hono\";\nimport { describeRoute, resolver, validator } from \"hono-openapi\";\n\nimport { lazy } from \"../util\";\nimport { Query, Note, Error } from \"@spader/spall-core\";\n\nexport const QueryRoutes = lazy(() =>\n new Hono()\n .post(\n \"/\",\n describeRoute({\n summary: \"Create a query\",\n description:\n \"Create a query scope for aggregating notes across multiple corpora.\",\n operationId: \"query.create\",\n responses: {\n 200: {\n description: \"Query info\",\n content: {\n \"application/json\": {\n schema: resolver(Query.Info),\n },\n },\n },\n 404: {\n description: \"Query not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"json\", Query.create.schema),\n async (c) => {\n const body = c.req.valid(\"json\");\n try {\n const result = Query.create(body);\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .get(\n \"/recent\",\n describeRoute({\n summary: \"List recent queries\",\n description: \"Get the most recently created queries.\",\n operationId: \"query.recent\",\n responses: {\n 200: {\n description: \"Recent queries\",\n content: {\n \"application/json\": {\n schema: resolver(Query.RecentResults),\n },\n },\n },\n },\n }),\n validator(\"query\", Query.recent.schema),\n async (c) => {\n const query = c.req.valid(\"query\");\n const result = Query.recent(query);\n return c.json(result);\n },\n )\n .get(\n \"/:id\",\n describeRoute({\n summary: \"Get a query\",\n description: \"Get a query by ID.\",\n operationId: \"query.get\",\n responses: {\n 200: {\n description: \"Query info\",\n content: {\n \"application/json\": {\n schema: resolver(Query.Info),\n },\n },\n },\n 404: {\n description: \"Query not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n async (c) => {\n const id = c.req.param(\"id\");\n try {\n const result = Query.get({ id: Query.Id.parse(id) });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .get(\n \"/:id/notes\",\n describeRoute({\n summary: \"Query notes\",\n description:\n \"List notes across all corpora in a query with keyset pagination.\",\n operationId: \"query.notes\",\n responses: {\n 200: {\n description: \"Paginated notes\",\n content: {\n \"application/json\": {\n schema: resolver(Note.Page),\n },\n },\n },\n 404: {\n description: \"Query not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"query\", Query.notes.schema.omit({ id: true })),\n async (c) => {\n const id = c.req.param(\"id\");\n const query = c.req.valid(\"query\");\n try {\n const result = Query.notes({\n id: Query.Id.parse(id),\n ...query,\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .get(\n \"/:id/search\",\n describeRoute({\n summary: \"Keyword search\",\n description:\n \"Search note content across all corpora in a query using FTS5.\",\n operationId: \"query.search\",\n responses: {\n 200: {\n description: \"Search results\",\n content: {\n \"application/json\": {\n schema: resolver(Query.SearchResults),\n },\n },\n },\n 404: {\n description: \"Query not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"query\", Query.search.schema.omit({ id: true })),\n async (c) => {\n const id = c.req.param(\"id\");\n const query = c.req.valid(\"query\");\n try {\n const result = Query.search({\n id: Query.Id.parse(id),\n ...query,\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .get(\n \"/:id/vsearch\",\n describeRoute({\n summary: \"Vector search\",\n description:\n \"Semantic search across all corpora in a query using embeddings.\",\n operationId: \"query.vsearch\",\n responses: {\n 200: {\n description: \"Search results\",\n content: {\n \"application/json\": {\n schema: resolver(Query.VSearchResults),\n },\n },\n },\n 404: {\n description: \"Query not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"query\", Query.vsearch.schema.omit({ id: true })),\n async (c) => {\n const id = c.req.param(\"id\");\n const query = c.req.valid(\"query\");\n try {\n const result = await Query.vsearch({\n id: Query.Id.parse(id),\n ...query,\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .post(\n \"/:id/fetch\",\n describeRoute({\n summary: \"Fetch notes by ID\",\n description:\n \"Fetch full note content for a list of note IDs through a query scope. Records access for reweighting.\",\n operationId: \"query.fetch\",\n responses: {\n 200: {\n description: \"Fetched notes\",\n content: {\n \"application/json\": {\n schema: resolver(Query.FetchResults),\n },\n },\n },\n 404: {\n description: \"Query not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"json\", Query.fetch.schema.omit({ id: true })),\n async (c) => {\n const id = c.req.param(\"id\");\n const body = c.req.valid(\"json\");\n try {\n const result = Query.fetch({\n id: Query.Id.parse(id),\n ...body,\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n )\n .get(\n \"/:id/paths\",\n describeRoute({\n summary: \"List paths\",\n description:\n \"List all note paths across corpora in a query, grouped by corpus.\",\n operationId: \"query.paths\",\n responses: {\n 200: {\n description: \"Paths grouped by corpus\",\n content: {\n \"application/json\": {\n schema: resolver(Query.PathsResults),\n },\n },\n },\n 404: {\n description: \"Query not found\",\n content: {\n \"application/json\": {\n schema: resolver(Error.Info),\n },\n },\n },\n },\n }),\n validator(\"query\", Query.paths.schema.omit({ id: true })),\n async (c) => {\n const id = c.req.param(\"id\");\n const query = c.req.valid(\"query\");\n try {\n const result = Query.paths({\n id: Query.Id.parse(id),\n ...query,\n });\n return c.json(result);\n } catch (error: any) {\n return c.json(Error.from(error), 404);\n }\n },\n ),\n);\n",
|
|
25
|
+
"import { Hono } from \"hono\";\nimport { describeRoute, resolver, validator } from \"hono-openapi\";\n\nimport { lazy } from \"../util\";\nimport { Commit } from \"@spader/spall-core\";\n\nexport const CommitRoutes = lazy(() =>\n new Hono().post(\n \"/\",\n describeRoute({\n summary: \"Commit staged events\",\n description: \"Move all rows from staging to committed.\",\n operationId: \"commit.run\",\n responses: {\n 200: {\n description: \"Commit result\",\n content: {\n \"application/json\": {\n schema: resolver(Commit.Result),\n },\n },\n },\n },\n }),\n validator(\"json\", Commit.run.schema),\n async (c) => {\n const body = c.req.valid(\"json\");\n const result = Commit.run(body);\n return c.json(result);\n },\n ),\n);\n",
|
|
26
|
+
"import { Hono } from \"hono\";\nimport { describeRoute, resolver, validator } from \"hono-openapi\";\n\nimport { lazy } from \"../util\";\nimport { Sse } from \"../sse\";\nimport { Corpus, Note, EventUnion } from \"@spader/spall-core\";\n\nexport const SseRoutes = lazy(() =>\n new Hono()\n .post(\n \"/corpus/sync\",\n describeRoute({\n summary: \"Index a directory (SSE)\",\n description:\n \"Scan a directory and embed all matching notes. Streams progress events.\",\n operationId: \"sse.note.sync\",\n responses: {\n 200: {\n description: \"Event stream\",\n content: {\n \"text/event-stream\": {\n schema: resolver(EventUnion),\n },\n },\n },\n },\n }),\n validator(\"json\", Note.sync.schema),\n async (context) => {\n const body = context.req.valid(\"json\");\n return Sse.stream(context, Note.sync, body);\n },\n )\n .post(\n \"/corpus/note\",\n describeRoute({\n summary: \"Add a note (SSE)\",\n description:\n \"Add a note to a corpus and embed it. Streams progress events.\",\n operationId: \"sse.note.add\",\n responses: {\n 200: {\n description: \"Event stream\",\n content: {\n \"text/event-stream\": {\n schema: resolver(EventUnion),\n },\n },\n },\n },\n }),\n validator(\"json\", Note.add.schema),\n async (context) => {\n const body = context.req.valid(\"json\");\n return Sse.stream(context, Note.add, body);\n },\n )\n .put(\n \"/corpus/:id/note/:path{.+}\",\n describeRoute({\n summary: \"Upsert a note (SSE)\",\n description:\n \"Create or update a note by path. Streams progress events.\",\n operationId: \"sse.note.upsert\",\n responses: {\n 200: {\n description: \"Event stream\",\n content: {\n \"text/event-stream\": {\n schema: resolver(EventUnion),\n },\n },\n },\n },\n }),\n validator(\"json\", Note.upsert.schema.omit({ corpus: true, path: true })),\n async (context) => {\n const id = context.req.param(\"id\");\n const path = context.req.param(\"path\");\n const body = context.req.valid(\"json\");\n return Sse.stream(context, Note.upsert, {\n corpus: Corpus.Id.parse(id),\n path,\n ...body,\n });\n },\n )\n .put(\n \"/note/:id\",\n describeRoute({\n summary: \"Update a note (SSE)\",\n description:\n \"Update a note's content by ID. Re-embeds the content. Streams progress events.\",\n operationId: \"sse.note.update\",\n responses: {\n 200: {\n description: \"Event stream\",\n content: {\n \"text/event-stream\": {\n schema: resolver(EventUnion),\n },\n },\n },\n },\n }),\n validator(\"json\", Note.update.schema.omit({ id: true })),\n async (context) => {\n const id = context.req.param(\"id\");\n const body = context.req.valid(\"json\");\n return Sse.stream(context, Note.update, {\n id: Note.Id.parse(id),\n ...body,\n });\n },\n ),\n);\n",
|
|
27
|
+
"import { streamSSE } from \"hono/streaming\";\n\nimport { Bus, Context, EventUnion, Error, Store } from \"@spader/spall-core\";\nimport { Server } from \"./server\";\n\nexport namespace Sse {\n type SseContext = Parameters<typeof streamSSE>[0];\n\n // wrap hono's sse streaming with code to\n // - track the sse connection\n // - clean up subscriptions when finished\n // - give access to a per-request cancellation signal\n export function stream<T>(\n context: SseContext,\n handler: (arg: T) => Promise<unknown>,\n input: T,\n ) {\n return streamSSE(context, async (stream) => {\n Server.Sse.track()\n\n const write = async (event: EventUnion) => {\n if (stream.aborted) return;\n await stream.writeSSE({ data: JSON.stringify(event) });\n };\n\n let unsubscribe = Bus.subscribe(write);\n\n // run the actual work we want to do through a thin wrapper that gives\n // access to the cancellation signal\n const [result, ctx] = Context.run(() => handler(input));\n\n stream.onAbort(() => {\n ctx.aborted = true;\n unsubscribe();\n unsubscribe = () => false;\n });\n\n try {\n await result;\n } catch (error) {\n if (!(error instanceof Store.CancelledError)) {\n await write({ tag: \"error\", error: Error.from(error) });\n }\n } finally {\n unsubscribe();\n Server.Sse.untrack();\n }\n });\n }\n\n // the same, but for permanent stream\n export function subscribe(context: SseContext) {\n return streamSSE(context, async (stream) => {\n Server.Sse.track();\n\n const write = async (event: EventUnion) => {\n await stream.writeSSE({ data: JSON.stringify(event) });\n };\n\n // Send initial connection event so clients know stream is ready\n await write({ tag: \"sse.connected\" });\n\n const unsubscribe = Bus.subscribe(write);\n\n // wait for client disconnect\n await new Promise<void>((resolve) => {\n if (stream.aborted) return resolve();\n stream.onAbort(resolve);\n });\n\n unsubscribe();\n Server.Sse.untrack();\n });\n }\n}\n"
|
|
28
|
+
],
|
|
29
|
+
"mappings": "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",
|
|
30
|
+
"debugId": "89FBAF084CCE603F64756E2164756E21",
|
|
31
|
+
"names": []
|
|
32
|
+
}
|
package/dist/lock.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
type LockData = {
|
|
2
|
+
pid: number;
|
|
3
|
+
port: number | null;
|
|
4
|
+
};
|
|
5
|
+
export declare namespace Cache {
|
|
6
|
+
function ensure(): void;
|
|
7
|
+
}
|
|
8
|
+
export declare namespace Lock {
|
|
9
|
+
function path(): string;
|
|
10
|
+
function read(): LockData | null;
|
|
11
|
+
function create(): boolean;
|
|
12
|
+
function update(port: number): void;
|
|
13
|
+
function takeover(): void;
|
|
14
|
+
function remove(): void;
|
|
15
|
+
}
|
|
16
|
+
export declare function isProcessAlive(pid: number): boolean;
|
|
17
|
+
export declare function checkHealth(port: number): Promise<boolean>;
|
|
18
|
+
export declare function ensure(): Promise<string>;
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=lock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock.d.ts","sourceRoot":"","sources":["../src/lock.ts"],"names":[],"mappings":"AAKA,KAAK,QAAQ,GAAG;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,CAAC;AAarD,yBAAiB,KAAK,CAAC;IACrB,SAAgB,MAAM,IAAI,IAAI,CAK7B;CACF;AAED,yBAAiB,IAAI,CAAC;IACpB,SAAgB,IAAI,IAAI,MAAM,CAE7B;IAED,SAAgB,IAAI,IAAI,QAAQ,GAAG,IAAI,CAOtC;IAED,SAAgB,MAAM,IAAI,OAAO,CAUhC;IAED,SAAgB,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAGzC;IAED,SAAgB,QAAQ,IAAI,IAAI,CAG/B;IAED,SAAgB,MAAM,IAAI,IAAI,CAE7B;CACF;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAOnD;AAED,wBAAsB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAOhE;AAwDD,wBAAsB,MAAM,IAAI,OAAO,CAAC,MAAM,CAAC,CAmC9C"}
|
package/dist/log.d.ts
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Server file logger.
|
|
3
|
+
*
|
|
4
|
+
* Log directory: ~/.local/share/spall/logs/$isotimestamp_$pid_$port/
|
|
5
|
+
* - events.log -- bus events + errors (JSONL)
|
|
6
|
+
* - app.log -- hono HTTP request logs (plain text lines)
|
|
7
|
+
*/
|
|
8
|
+
export declare namespace ServerLog {
|
|
9
|
+
function init(port: number): void;
|
|
10
|
+
/** Write a bus event to events.log as JSONL. */
|
|
11
|
+
function event(e: {
|
|
12
|
+
tag: string;
|
|
13
|
+
[k: string]: unknown;
|
|
14
|
+
}): void;
|
|
15
|
+
/** Write an error to events.log. */
|
|
16
|
+
function error(err: unknown): void;
|
|
17
|
+
/** Hono logger print function -- writes to app.log. */
|
|
18
|
+
function appLog(message: string, ...rest: string[]): void;
|
|
19
|
+
/** Returns the log directory path, or null if not initialized. */
|
|
20
|
+
function path(): string | null;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=log.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"log.d.ts","sourceRoot":"","sources":["../src/log.ts"],"names":[],"mappings":"AAIA;;;;;;GAMG;AACH,yBAAiB,SAAS,CAAC;IASzB,SAAgB,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAUvC;IAeD,gDAAgD;IAChD,SAAgB,KAAK,CAAC,CAAC,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,GAAG,IAAI,CAIpE;IAED,oCAAoC;IACpC,SAAgB,KAAK,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAQxC;IAID,uDAAuD;IACvD,SAAgB,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAI/D;IAED,kEAAkE;IAClE,SAAgB,IAAI,IAAI,MAAM,GAAG,IAAI,CAEpC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export declare const CommitRoutes: {
|
|
2
|
+
(): import("hono/hono-base").HonoBase<import("hono/types").BlankEnv, {
|
|
3
|
+
"/": {
|
|
4
|
+
$post: {
|
|
5
|
+
input: {
|
|
6
|
+
json: Record<string, never>;
|
|
7
|
+
};
|
|
8
|
+
output: {
|
|
9
|
+
moved: number;
|
|
10
|
+
committedAt: number;
|
|
11
|
+
};
|
|
12
|
+
outputFormat: "json";
|
|
13
|
+
status: import("hono/utils/http-status").ContentfulStatusCode;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
}, "/", "/">;
|
|
17
|
+
reset(): void;
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=commit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commit.d.ts","sourceRoot":"","sources":["../../src/routes/commit.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;CAyBxB,CAAC"}
|