@trigger.dev/core 3.0.0-beta.4 → 3.0.0-beta.40
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/catalog-EP9DGAGm.d.ts +242 -0
- package/dist/catalog-Gjy5NtAB.d.mts +242 -0
- package/dist/index.d.mts +60 -1
- package/dist/index.d.ts +60 -1
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +7 -1
- package/dist/index.mjs.map +1 -1
- package/dist/manager-S98VaLUy.d.mts +1402 -0
- package/dist/manager-S98VaLUy.d.ts +1402 -0
- package/dist/messages-xJbR1Vai.d.mts +18953 -0
- package/dist/messages-xJbR1Vai.d.ts +18953 -0
- package/dist/schemas-Sb0sJcEt.d.mts +2497 -0
- package/dist/schemas-Sb0sJcEt.d.ts +2497 -0
- package/dist/v3/dev/index.d.mts +28 -0
- package/dist/v3/dev/index.d.ts +28 -0
- package/dist/v3/dev/index.js +93 -0
- package/dist/v3/dev/index.js.map +1 -0
- package/dist/v3/dev/index.mjs +91 -0
- package/dist/v3/dev/index.mjs.map +1 -0
- package/dist/v3/index.d.mts +2140 -17560
- package/dist/v3/index.d.ts +2140 -17560
- package/dist/v3/index.js +2611 -2886
- package/dist/v3/index.js.map +1 -1
- package/dist/v3/index.mjs +2563 -2858
- package/dist/v3/index.mjs.map +1 -1
- package/dist/v3/otel/index.js +106 -50
- package/dist/v3/otel/index.js.map +1 -1
- package/dist/v3/otel/index.mjs +106 -50
- package/dist/v3/otel/index.mjs.map +1 -1
- package/dist/v3/prod/index.d.mts +45 -0
- package/dist/v3/prod/index.d.ts +45 -0
- package/dist/v3/prod/index.js +304 -0
- package/dist/v3/prod/index.js.map +1 -0
- package/dist/v3/prod/index.mjs +302 -0
- package/dist/v3/prod/index.mjs.map +1 -0
- package/dist/v3/utils/structuredLogger.d.mts +31 -0
- package/dist/v3/utils/structuredLogger.d.ts +31 -0
- package/dist/v3/utils/structuredLogger.js +88 -0
- package/dist/v3/utils/structuredLogger.js.map +1 -0
- package/dist/v3/utils/structuredLogger.mjs +86 -0
- package/dist/v3/utils/structuredLogger.mjs.map +1 -0
- package/dist/v3/workers/index.d.mts +142 -0
- package/dist/v3/workers/index.d.ts +142 -0
- package/dist/v3/workers/index.js +3485 -0
- package/dist/v3/workers/index.js.map +1 -0
- package/dist/v3/workers/index.mjs +3466 -0
- package/dist/v3/workers/index.mjs.map +1 -0
- package/dist/v3/zodIpc.d.mts +32 -0
- package/dist/v3/zodIpc.d.ts +32 -0
- package/dist/v3/zodIpc.js +268 -0
- package/dist/v3/zodIpc.js.map +1 -0
- package/dist/v3/zodIpc.mjs +266 -0
- package/dist/v3/zodIpc.mjs.map +1 -0
- package/dist/v3/zodMessageHandler.d.mts +69 -0
- package/dist/v3/zodMessageHandler.d.ts +69 -0
- package/dist/v3/zodMessageHandler.js +168 -0
- package/dist/v3/zodMessageHandler.js.map +1 -0
- package/dist/v3/zodMessageHandler.mjs +163 -0
- package/dist/v3/zodMessageHandler.mjs.map +1 -0
- package/dist/v3/zodNamespace.d.mts +3663 -0
- package/dist/v3/zodNamespace.d.ts +3663 -0
- package/dist/v3/zodNamespace.js +366 -0
- package/dist/v3/zodNamespace.js.map +1 -0
- package/dist/v3/zodNamespace.mjs +364 -0
- package/dist/v3/zodNamespace.mjs.map +1 -0
- package/dist/v3/zodSocket.d.mts +88 -0
- package/dist/v3/zodSocket.d.ts +88 -0
- package/dist/v3/zodSocket.js +319 -0
- package/dist/v3/zodSocket.js.map +1 -0
- package/dist/v3/zodSocket.mjs +315 -0
- package/dist/v3/zodSocket.mjs.map +1 -0
- package/dist/v3/zodfetch.d.mts +206 -0
- package/dist/v3/zodfetch.d.ts +206 -0
- package/dist/v3/zodfetch.js +614 -0
- package/dist/v3/zodfetch.js.map +1 -0
- package/dist/v3/zodfetch.mjs +594 -0
- package/dist/v3/zodfetch.mjs.map +1 -0
- package/package.json +79 -5
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/v3/zodSocket.ts","../../src/v3/utils/structuredLogger.ts"],"names":["io","ZodError","z","LogLevel","SimpleStructuredLogger","constructor","name","level","includes","process","env","DEBUG","debug","info","fields","child","log","message","args","console","error","warn","loggerFunction","structuredLog","length","timestamp","Date","JSON","stringify","fromZodError","messageSchema","object","version","string","type","payload","unknown","ZodSocketMessageHandler","options","schema","handlers","handleMessage","parsedMessage","parseMessage","Error","handler","String","ack","safeParse","success","data","messageWithVersion","parsedPayload","registerHandlers","emitter","logger","eventName","Object","keys","on","callback","hasCallback","stack","_schema","ZodSocketMessageSender","socket","send","emit","sendWithAck","callbackResult","emitWithAck","ZodSocketConnection","opts","uri","secure","host","port","namespace","transports","auth","token","authToken","extraHeaders","reconnectionDelay","reconnectionDelayMax","socketId","id","serverMessages","clientMessages","onError","onConnection","reason","description","onDisconnect","close","connect","bind"],"mappings":"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","sourcesContent":["import type { Socket } from \"socket.io-client\";\nimport { io } from \"socket.io-client\";\nimport { ZodError, z } from \"zod\";\nimport { EventEmitterLike, ZodMessageValueSchema } from \"./zodMessageHandler\";\nimport { LogLevel, SimpleStructuredLogger, StructuredLogger } from \"./utils/structuredLogger\";\nimport { fromZodError } from \"zod-validation-error\";\n\nexport interface ZodSocketMessageCatalogSchema {\n [key: string]:\n | {\n message: ZodMessageValueSchema<any>;\n }\n | {\n message: ZodMessageValueSchema<any>;\n callback?: ZodMessageValueSchema<any>;\n };\n}\n\nexport type ZodMessageCatalogToSocketIoEvents<TCatalog extends ZodSocketMessageCatalogSchema> = {\n [K in keyof TCatalog]: SocketMessageHasCallback<TCatalog, K> extends true\n ? (\n message: z.infer<GetSocketMessageSchema<TCatalog, K>>,\n callback: (ack: z.infer<GetSocketCallbackSchema<TCatalog, K>>) => void\n ) => void\n : (message: z.infer<GetSocketMessageSchema<TCatalog, K>>) => void;\n};\n\nexport type GetSocketMessageSchema<\n TRPCCatalog extends ZodSocketMessageCatalogSchema,\n TMessageType extends keyof TRPCCatalog,\n> = TRPCCatalog[TMessageType][\"message\"];\n\nexport type InferSocketMessageSchema<\n TRPCCatalog extends ZodSocketMessageCatalogSchema,\n TMessageType extends keyof TRPCCatalog,\n> = z.infer<GetSocketMessageSchema<TRPCCatalog, TMessageType>>;\n\nexport type GetSocketCallbackSchema<\n TRPCCatalog extends ZodSocketMessageCatalogSchema,\n TMessageType extends keyof TRPCCatalog,\n> = TRPCCatalog[TMessageType] extends { callback: any }\n ? TRPCCatalog[TMessageType][\"callback\"]\n : never;\n\nexport type InferSocketCallbackSchema<\n TRPCCatalog extends ZodSocketMessageCatalogSchema,\n TMessageType extends keyof TRPCCatalog,\n> = z.infer<GetSocketCallbackSchema<TRPCCatalog, TMessageType>>;\n\nexport type SocketMessageHasCallback<\n TRPCCatalog extends ZodSocketMessageCatalogSchema,\n TMessageType extends keyof TRPCCatalog,\n> = GetSocketCallbackSchema<TRPCCatalog, TMessageType> extends never ? false : true;\n\nexport type ZodSocketMessageHandlers<TCatalogSchema extends ZodSocketMessageCatalogSchema> =\n Partial<{\n [K in keyof TCatalogSchema]: (\n payload: z.infer<GetSocketMessageSchema<TCatalogSchema, K>>\n ) => Promise<\n SocketMessageHasCallback<TCatalogSchema, K> extends true\n ? z.input<GetSocketCallbackSchema<TCatalogSchema, K>>\n : void\n >;\n }>;\n\nexport type ZodSocketMessageHandlerOptions<TMessageCatalog extends ZodSocketMessageCatalogSchema> =\n {\n schema: TMessageCatalog;\n handlers?: ZodSocketMessageHandlers<TMessageCatalog>;\n };\n\ntype MessageFromSocketSchema<\n K extends keyof TMessageCatalog,\n TMessageCatalog extends ZodSocketMessageCatalogSchema,\n> = {\n type: K;\n payload: z.input<GetSocketMessageSchema<TMessageCatalog, K>>;\n};\n\nexport type MessagesFromSocketCatalog<TMessageCatalog extends ZodSocketMessageCatalogSchema> = {\n [K in keyof TMessageCatalog]: MessageFromSocketSchema<K, TMessageCatalog>;\n}[keyof TMessageCatalog];\n\nconst messageSchema = z.object({\n version: z.string(),\n type: z.string(),\n payload: z.unknown(),\n});\n\nexport class ZodSocketMessageHandler<TRPCCatalog extends ZodSocketMessageCatalogSchema> {\n #schema: TRPCCatalog;\n #handlers: ZodSocketMessageHandlers<TRPCCatalog> | undefined;\n\n constructor(options: ZodSocketMessageHandlerOptions<TRPCCatalog>) {\n this.#schema = options.schema;\n this.#handlers = options.handlers;\n }\n\n public async handleMessage(message: unknown) {\n const parsedMessage = this.parseMessage(message);\n\n if (!this.#handlers) {\n throw new Error(\"No handlers provided\");\n }\n\n const handler = this.#handlers[parsedMessage.type];\n\n if (!handler) {\n console.error(`No handler for message type: ${String(parsedMessage.type)}`);\n return;\n }\n\n const ack = await handler(parsedMessage.payload);\n\n return ack;\n }\n\n public parseMessage(message: unknown): MessagesFromSocketCatalog<TRPCCatalog> {\n const parsedMessage = messageSchema.safeParse(message);\n\n if (!parsedMessage.success) {\n throw new Error(`Failed to parse message: ${JSON.stringify(parsedMessage.error)}`);\n }\n\n const schema = this.#schema[parsedMessage.data.type][\"message\"];\n\n if (!schema) {\n throw new Error(`Unknown message type: ${parsedMessage.data.type}`);\n }\n\n const messageWithVersion = {\n version: parsedMessage.data.version,\n ...(typeof parsedMessage.data.payload === \"object\" ? parsedMessage.data.payload : {}),\n };\n\n const parsedPayload = schema.safeParse(messageWithVersion);\n\n if (!parsedPayload.success) {\n console.error(\"Failed to parse message payload\", {\n message,\n payload: messageWithVersion,\n });\n\n throw parsedPayload.error instanceof ZodError\n ? fromZodError(parsedPayload.error)\n : parsedPayload.error;\n }\n\n return {\n type: parsedMessage.data.type,\n payload: parsedPayload.data,\n };\n }\n\n public registerHandlers(emitter: EventEmitterLike, logger?: StructuredLogger) {\n const log = logger ?? console;\n\n if (!this.#handlers) {\n log.info(\"No handlers provided\");\n return;\n }\n\n for (const eventName of Object.keys(this.#handlers)) {\n emitter.on(eventName, async (message: any, callback?: any): Promise<void> => {\n log.info(`handling ${eventName}`, {\n payload: message,\n hasCallback: !!callback,\n });\n\n let ack;\n\n try {\n // FIXME: this only works if the message doesn't have genuine payload prop\n if (\"payload\" in message) {\n ack = await this.handleMessage({ type: eventName, ...message });\n } else {\n // Handle messages not sent by ZodMessageSender\n const { version, ...payload } = message;\n ack = await this.handleMessage({ type: eventName, version, payload });\n }\n } catch (error) {\n log.error(\"Error while handling message\", {\n error:\n error instanceof Error\n ? {\n message: error.message,\n stack: error.stack,\n }\n : error,\n });\n return;\n }\n\n if (callback && typeof callback === \"function\") {\n callback(ack);\n }\n });\n }\n }\n}\n\nexport type ZodSocketMessageSenderOptions<TMessageCatalog extends ZodSocketMessageCatalogSchema> = {\n schema: TMessageCatalog;\n socket: ZodSocket<any, TMessageCatalog>;\n};\n\nexport type GetSocketMessagesWithCallback<TMessageCatalog extends ZodSocketMessageCatalogSchema> = {\n [K in keyof TMessageCatalog]: SocketMessageHasCallback<TMessageCatalog, K> extends true\n ? K\n : never;\n}[keyof TMessageCatalog];\n\nexport type GetSocketMessagesWithoutCallback<\n TMessageCatalog extends ZodSocketMessageCatalogSchema,\n> = {\n [K in keyof TMessageCatalog]: SocketMessageHasCallback<TMessageCatalog, K> extends true\n ? never\n : K;\n}[keyof TMessageCatalog];\n\nexport class ZodSocketMessageSender<TMessageCatalog extends ZodSocketMessageCatalogSchema> {\n #schema: TMessageCatalog;\n #socket: ZodSocket<any, TMessageCatalog>;\n\n constructor(options: ZodSocketMessageSenderOptions<TMessageCatalog>) {\n this.#schema = options.schema;\n this.#socket = options.socket;\n }\n\n public send<K extends GetSocketMessagesWithoutCallback<TMessageCatalog>>(\n type: K,\n payload: z.input<GetSocketMessageSchema<TMessageCatalog, K>>\n ): void {\n const schema = this.#schema[type][\"message\"];\n\n if (!schema) {\n throw new Error(`Unknown message type: ${type as string}`);\n }\n\n const parsedPayload = schema.safeParse(payload);\n\n if (!parsedPayload.success) {\n throw new Error(`Failed to parse message payload: ${JSON.stringify(parsedPayload.error)}`);\n }\n\n // @ts-expect-error\n this.#socket.emit(type, { payload, version: \"v1\" });\n\n return;\n }\n\n public async sendWithAck<K extends GetSocketMessagesWithCallback<TMessageCatalog>>(\n type: K,\n payload: z.input<GetSocketMessageSchema<TMessageCatalog, K>>\n ): Promise<z.infer<GetSocketCallbackSchema<TMessageCatalog, K>>> {\n const schema = this.#schema[type][\"message\"];\n\n if (!schema) {\n throw new Error(`Unknown message type: ${type as string}`);\n }\n\n const parsedPayload = schema.safeParse(payload);\n\n if (!parsedPayload.success) {\n throw new Error(`Failed to parse message payload: ${JSON.stringify(parsedPayload.error)}`);\n }\n\n // @ts-expect-error\n const callbackResult = await this.#socket.emitWithAck(type, { payload, version: \"v1\" });\n\n return callbackResult;\n }\n}\n\nexport type ZodSocket<\n TListenEvents extends ZodSocketMessageCatalogSchema,\n TEmitEvents extends ZodSocketMessageCatalogSchema,\n> = Socket<\n ZodMessageCatalogToSocketIoEvents<TListenEvents>,\n ZodMessageCatalogToSocketIoEvents<TEmitEvents>\n>;\n\ninterface ZodSocketConnectionOptions<\n TClientMessages extends ZodSocketMessageCatalogSchema,\n TServerMessages extends ZodSocketMessageCatalogSchema,\n> {\n host: string;\n port?: number;\n secure?: boolean;\n namespace: string;\n clientMessages: TClientMessages;\n serverMessages: TServerMessages;\n extraHeaders?: {\n [header: string]: string;\n };\n handlers?: ZodSocketMessageHandlers<TServerMessages>;\n authToken?: string;\n onConnection?: (\n socket: ZodSocket<TServerMessages, TClientMessages>,\n handler: ZodSocketMessageHandler<TServerMessages>,\n sender: ZodSocketMessageSender<TClientMessages>,\n logger: StructuredLogger\n ) => Promise<void>;\n onDisconnect?: (\n socket: ZodSocket<TServerMessages, TClientMessages>,\n reason: Socket.DisconnectReason,\n description: any,\n logger: StructuredLogger\n ) => Promise<void>;\n onError?: (\n socket: ZodSocket<TServerMessages, TClientMessages>,\n err: Error,\n logger: StructuredLogger\n ) => Promise<void>;\n}\n\nexport class ZodSocketConnection<\n TClientMessages extends ZodSocketMessageCatalogSchema,\n TServerMessages extends ZodSocketMessageCatalogSchema,\n> {\n #sender: ZodSocketMessageSender<TClientMessages>;\n socket: ZodSocket<TServerMessages, TClientMessages>;\n\n #handler: ZodSocketMessageHandler<TServerMessages>;\n #logger: StructuredLogger;\n\n constructor(opts: ZodSocketConnectionOptions<TClientMessages, TServerMessages>) {\n const uri = `${opts.secure ? \"wss\" : \"ws\"}://${opts.host}:${\n opts.port ?? (opts.secure ? \"443\" : \"80\")\n }/${opts.namespace}`;\n\n const logger = new SimpleStructuredLogger(opts.namespace, LogLevel.info);\n logger.log(\"new zod socket\", { uri });\n\n this.socket = io(uri, {\n transports: [\"websocket\"],\n auth: {\n token: opts.authToken,\n },\n extraHeaders: opts.extraHeaders,\n reconnectionDelay: 500,\n reconnectionDelayMax: 1000,\n });\n\n this.#logger = logger.child({\n socketId: this.socket.id,\n });\n\n this.#handler = new ZodSocketMessageHandler({\n schema: opts.serverMessages,\n handlers: opts.handlers,\n });\n this.#handler.registerHandlers(this.socket, this.#logger);\n\n this.#sender = new ZodSocketMessageSender({\n schema: opts.clientMessages,\n socket: this.socket,\n });\n\n this.socket.on(\"connect_error\", async (error) => {\n this.#logger.error(`connect_error: ${error}`);\n\n if (opts.onError) {\n await opts.onError(this.socket, error, this.#logger);\n }\n });\n\n this.socket.on(\"connect\", async () => {\n this.#logger.info(\"connect\");\n\n if (opts.onConnection) {\n await opts.onConnection(this.socket, this.#handler, this.#sender, this.#logger);\n }\n });\n\n this.socket.on(\"disconnect\", async (reason, description) => {\n this.#logger.info(\"disconnect\", { reason, description });\n\n if (opts.onDisconnect) {\n await opts.onDisconnect(this.socket, reason, description, this.#logger);\n }\n });\n }\n\n close() {\n this.socket.close();\n }\n\n connect() {\n this.socket.connect();\n }\n\n get send() {\n return this.#sender.send.bind(this.#sender);\n }\n\n get sendWithAck() {\n return this.#sender.sendWithAck.bind(this.#sender);\n }\n}\n\nfunction createLogger(prefix: string) {\n return (...args: any[]) => console.log(prefix, ...args);\n}\n","type StructuredArgs = (Record<string, unknown> | undefined)[];\n\nexport interface StructuredLogger {\n log: (message: string, ...args: StructuredArgs) => any;\n error: (message: string, ...args: StructuredArgs) => any;\n warn: (message: string, ...args: StructuredArgs) => any;\n info: (message: string, ...args: StructuredArgs) => any;\n debug: (message: string, ...args: StructuredArgs) => any;\n child: (fields: Record<string, unknown>) => StructuredLogger;\n}\n\nexport enum LogLevel {\n \"log\",\n \"error\",\n \"warn\",\n \"info\",\n \"debug\",\n}\n\nexport class SimpleStructuredLogger implements StructuredLogger {\n constructor(\n private name: string,\n private level: LogLevel = [\"1\", \"true\"].includes(process.env.DEBUG ?? \"\")\n ? LogLevel.debug\n : LogLevel.info,\n private fields?: Record<string, unknown>\n ) {}\n\n child(fields: Record<string, unknown>, level?: LogLevel) {\n return new SimpleStructuredLogger(this.name, level, { ...this.fields, ...fields });\n }\n\n log(message: string, ...args: StructuredArgs) {\n if (this.level < LogLevel.log) return;\n\n this.#structuredLog(console.log, message, \"log\", ...args);\n }\n\n error(message: string, ...args: StructuredArgs) {\n if (this.level < LogLevel.error) return;\n\n this.#structuredLog(console.error, message, \"error\", ...args);\n }\n\n warn(message: string, ...args: StructuredArgs) {\n if (this.level < LogLevel.warn) return;\n\n this.#structuredLog(console.warn, message, \"warn\", ...args);\n }\n\n info(message: string, ...args: StructuredArgs) {\n if (this.level < LogLevel.info) return;\n\n this.#structuredLog(console.info, message, \"info\", ...args);\n }\n\n debug(message: string, ...args: StructuredArgs) {\n if (this.level < LogLevel.debug) return;\n\n this.#structuredLog(console.debug, message, \"debug\", ...args);\n }\n\n #structuredLog(\n loggerFunction: (message: string, ...args: any[]) => void,\n message: string,\n level: string,\n ...args: StructuredArgs\n ) {\n const structuredLog = {\n ...(args.length === 1 ? args[0] : args),\n ...this.fields,\n timestamp: new Date(),\n name: this.name,\n message,\n level,\n };\n\n loggerFunction(JSON.stringify(structuredLog));\n }\n}\n"]}
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { R as RetryOptions } from '../schemas-Sb0sJcEt.mjs';
|
|
3
|
+
|
|
4
|
+
interface CursorPageParams {
|
|
5
|
+
limit?: number;
|
|
6
|
+
after?: string;
|
|
7
|
+
before?: string;
|
|
8
|
+
}
|
|
9
|
+
interface OffsetLimitPageParams {
|
|
10
|
+
limit?: number;
|
|
11
|
+
page?: number;
|
|
12
|
+
}
|
|
13
|
+
interface PageResponse<Item> {
|
|
14
|
+
data: Array<Item>;
|
|
15
|
+
}
|
|
16
|
+
interface CursorPageResponse<Item> extends PageResponse<Item> {
|
|
17
|
+
pagination: {
|
|
18
|
+
next?: string;
|
|
19
|
+
previous?: string;
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
interface OffsetLimitPageResponse<Item> extends PageResponse<Item> {
|
|
23
|
+
pagination: {
|
|
24
|
+
currentPage: number;
|
|
25
|
+
totalPages: number;
|
|
26
|
+
count: number;
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
interface Page<Item> {
|
|
30
|
+
getPaginatedItems(): Item[];
|
|
31
|
+
hasNextPage(): boolean;
|
|
32
|
+
hasPreviousPage(): boolean;
|
|
33
|
+
}
|
|
34
|
+
declare class CursorPage<Item> implements CursorPageResponse<Item>, Page<Item>, AsyncIterable<Item> {
|
|
35
|
+
private pageFetcher;
|
|
36
|
+
data: Array<Item>;
|
|
37
|
+
pagination: {
|
|
38
|
+
next?: string;
|
|
39
|
+
previous?: string;
|
|
40
|
+
};
|
|
41
|
+
constructor(data: Array<Item>, pagination: {
|
|
42
|
+
next?: string;
|
|
43
|
+
previous?: string;
|
|
44
|
+
}, pageFetcher: (params: Omit<CursorPageParams, "limit">) => Promise<CursorPage<Item>>);
|
|
45
|
+
getPaginatedItems(): Item[];
|
|
46
|
+
hasNextPage(): boolean;
|
|
47
|
+
hasPreviousPage(): boolean;
|
|
48
|
+
getNextPage(): Promise<CursorPage<Item>>;
|
|
49
|
+
getPreviousPage(): Promise<CursorPage<Item>>;
|
|
50
|
+
iterPages(): AsyncGenerator<CursorPage<Item>, void, unknown>;
|
|
51
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<Item>, void, unknown>;
|
|
52
|
+
}
|
|
53
|
+
declare class OffsetLimitPage<Item> implements OffsetLimitPageResponse<Item>, Page<Item>, AsyncIterable<Item> {
|
|
54
|
+
private pageFetcher;
|
|
55
|
+
data: Array<Item>;
|
|
56
|
+
pagination: {
|
|
57
|
+
currentPage: number;
|
|
58
|
+
totalPages: number;
|
|
59
|
+
count: number;
|
|
60
|
+
};
|
|
61
|
+
constructor(data: Array<Item>, pagination: {
|
|
62
|
+
currentPage: number;
|
|
63
|
+
totalPages: number;
|
|
64
|
+
count: number;
|
|
65
|
+
}, pageFetcher: (params: Omit<OffsetLimitPageParams, "limit">) => Promise<OffsetLimitPage<Item>>);
|
|
66
|
+
getPaginatedItems(): Item[];
|
|
67
|
+
hasNextPage(): boolean;
|
|
68
|
+
hasPreviousPage(): boolean;
|
|
69
|
+
getNextPage(): Promise<OffsetLimitPage<Item>>;
|
|
70
|
+
getPreviousPage(): Promise<OffsetLimitPage<Item>>;
|
|
71
|
+
iterPages(): AsyncGenerator<OffsetLimitPage<Item>, void, unknown>;
|
|
72
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<Item>, void, unknown>;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
declare const defaultRetryOptions: {
|
|
76
|
+
maxAttempts: number;
|
|
77
|
+
factor: number;
|
|
78
|
+
minTimeoutInMs: number;
|
|
79
|
+
maxTimeoutInMs: number;
|
|
80
|
+
randomize: false;
|
|
81
|
+
};
|
|
82
|
+
type ZodFetchOptions = {
|
|
83
|
+
retry?: RetryOptions;
|
|
84
|
+
};
|
|
85
|
+
interface FetchCursorPageParams extends CursorPageParams {
|
|
86
|
+
query?: URLSearchParams;
|
|
87
|
+
}
|
|
88
|
+
interface FetchOffsetLimitPageParams extends OffsetLimitPageParams {
|
|
89
|
+
query?: URLSearchParams;
|
|
90
|
+
}
|
|
91
|
+
declare function zodfetch<TResponseBodySchema extends z.ZodTypeAny>(schema: TResponseBodySchema, url: string, requestInit?: RequestInit, options?: ZodFetchOptions): ApiPromise<z.output<TResponseBodySchema>>;
|
|
92
|
+
declare function zodfetchCursorPage<TItemSchema extends z.ZodTypeAny>(schema: TItemSchema, url: string, params: FetchCursorPageParams, requestInit?: RequestInit, options?: ZodFetchOptions): CursorPagePromise<TItemSchema>;
|
|
93
|
+
declare function zodfetchOffsetLimitPage<TItemSchema extends z.ZodTypeAny>(schema: TItemSchema, url: string, params: FetchOffsetLimitPageParams, requestInit?: RequestInit, options?: ZodFetchOptions): OffsetLimitPagePromise<TItemSchema>;
|
|
94
|
+
type ZodFetchResult<T> = {
|
|
95
|
+
data: T;
|
|
96
|
+
response: Response;
|
|
97
|
+
};
|
|
98
|
+
/**
|
|
99
|
+
* A subclass of `Promise` providing additional helper methods
|
|
100
|
+
* for interacting with the SDK.
|
|
101
|
+
*/
|
|
102
|
+
declare class ApiPromise<T> extends Promise<T> {
|
|
103
|
+
private responsePromise;
|
|
104
|
+
constructor(responsePromise: Promise<ZodFetchResult<T>>);
|
|
105
|
+
/**
|
|
106
|
+
* Gets the raw `Response` instance instead of parsing the response
|
|
107
|
+
* data.
|
|
108
|
+
*
|
|
109
|
+
* If you want to parse the response body but still get the `Response`
|
|
110
|
+
* instance, you can use {@link withResponse()}.
|
|
111
|
+
*/
|
|
112
|
+
asResponse(): Promise<Response>;
|
|
113
|
+
/**
|
|
114
|
+
* Gets the parsed response data and the raw `Response` instance.
|
|
115
|
+
*
|
|
116
|
+
* If you just want to get the raw `Response` instance without parsing it,
|
|
117
|
+
* you can use {@link asResponse()}.
|
|
118
|
+
*/
|
|
119
|
+
withResponse(): Promise<{
|
|
120
|
+
data: T;
|
|
121
|
+
response: Response;
|
|
122
|
+
}>;
|
|
123
|
+
private parse;
|
|
124
|
+
then<TResult1 = T, TResult2 = never>(onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | undefined | null, onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null): Promise<TResult1 | TResult2>;
|
|
125
|
+
catch<TResult = never>(onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | undefined | null): Promise<T | TResult>;
|
|
126
|
+
finally(onfinally?: (() => void) | undefined | null): Promise<T>;
|
|
127
|
+
}
|
|
128
|
+
declare class CursorPagePromise<TItemSchema extends z.ZodTypeAny> extends ApiPromise<CursorPage<z.output<TItemSchema>>> implements AsyncIterable<z.output<TItemSchema>> {
|
|
129
|
+
#private;
|
|
130
|
+
private schema;
|
|
131
|
+
private url;
|
|
132
|
+
private params;
|
|
133
|
+
private requestInit?;
|
|
134
|
+
private options?;
|
|
135
|
+
constructor(result: Promise<ZodFetchResult<CursorPageResponse<z.output<TItemSchema>>>>, schema: TItemSchema, url: string, params: FetchCursorPageParams, requestInit?: RequestInit | undefined, options?: ZodFetchOptions | undefined);
|
|
136
|
+
/**
|
|
137
|
+
* Allow auto-paginating iteration on an unawaited list call, eg:
|
|
138
|
+
*
|
|
139
|
+
* for await (const item of client.items.list()) {
|
|
140
|
+
* console.log(item)
|
|
141
|
+
* }
|
|
142
|
+
*/
|
|
143
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<z.output<TItemSchema>>, void, unknown>;
|
|
144
|
+
}
|
|
145
|
+
declare class OffsetLimitPagePromise<TItemSchema extends z.ZodTypeAny> extends ApiPromise<OffsetLimitPage<z.output<TItemSchema>>> implements AsyncIterable<z.output<TItemSchema>> {
|
|
146
|
+
#private;
|
|
147
|
+
private schema;
|
|
148
|
+
private url;
|
|
149
|
+
private params;
|
|
150
|
+
private requestInit?;
|
|
151
|
+
private options?;
|
|
152
|
+
constructor(result: Promise<ZodFetchResult<OffsetLimitPageResponse<z.output<TItemSchema>>>>, schema: TItemSchema, url: string, params: FetchOffsetLimitPageParams, requestInit?: RequestInit | undefined, options?: ZodFetchOptions | undefined);
|
|
153
|
+
/**
|
|
154
|
+
* Allow auto-paginating iteration on an unawaited list call, eg:
|
|
155
|
+
*
|
|
156
|
+
* for await (const item of client.items.list()) {
|
|
157
|
+
* console.log(item)
|
|
158
|
+
* }
|
|
159
|
+
*/
|
|
160
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<z.output<TItemSchema>>, void, unknown>;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
type APIHeaders = Record<string, string | null | undefined>;
|
|
164
|
+
declare class ApiError extends Error {
|
|
165
|
+
readonly status: number | undefined;
|
|
166
|
+
readonly headers: APIHeaders | undefined;
|
|
167
|
+
readonly error: Object | undefined;
|
|
168
|
+
readonly code: string | null | undefined;
|
|
169
|
+
readonly param: string | null | undefined;
|
|
170
|
+
readonly type: string | undefined;
|
|
171
|
+
constructor(status: number | undefined, error: Object | undefined, message: string | undefined, headers: APIHeaders | undefined);
|
|
172
|
+
private static makeMessage;
|
|
173
|
+
static generate(status: number | undefined, errorResponse: Object | undefined, message: string | undefined, headers: APIHeaders | undefined): ApiError;
|
|
174
|
+
}
|
|
175
|
+
declare class ApiConnectionError extends ApiError {
|
|
176
|
+
readonly status: undefined;
|
|
177
|
+
constructor({ message, cause }: {
|
|
178
|
+
message?: string;
|
|
179
|
+
cause?: Error | undefined;
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
declare class BadRequestError extends ApiError {
|
|
183
|
+
readonly status: 400;
|
|
184
|
+
}
|
|
185
|
+
declare class AuthenticationError extends ApiError {
|
|
186
|
+
readonly status: 401;
|
|
187
|
+
}
|
|
188
|
+
declare class PermissionDeniedError extends ApiError {
|
|
189
|
+
readonly status: 403;
|
|
190
|
+
}
|
|
191
|
+
declare class NotFoundError extends ApiError {
|
|
192
|
+
readonly status: 404;
|
|
193
|
+
}
|
|
194
|
+
declare class ConflictError extends ApiError {
|
|
195
|
+
readonly status: 409;
|
|
196
|
+
}
|
|
197
|
+
declare class UnprocessableEntityError extends ApiError {
|
|
198
|
+
readonly status: 422;
|
|
199
|
+
}
|
|
200
|
+
declare class RateLimitError extends ApiError {
|
|
201
|
+
readonly status: 429;
|
|
202
|
+
}
|
|
203
|
+
declare class InternalServerError extends ApiError {
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
export { type APIHeaders, ApiConnectionError, ApiError, ApiPromise, AuthenticationError, BadRequestError, ConflictError, CursorPage, type CursorPageParams, CursorPagePromise, type CursorPageResponse, InternalServerError, NotFoundError, OffsetLimitPage, type OffsetLimitPageParams, OffsetLimitPagePromise, type OffsetLimitPageResponse, type Page, type PageResponse, PermissionDeniedError, RateLimitError, UnprocessableEntityError, type ZodFetchOptions, defaultRetryOptions, zodfetch, zodfetchCursorPage, zodfetchOffsetLimitPage };
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { R as RetryOptions } from '../schemas-Sb0sJcEt.js';
|
|
3
|
+
|
|
4
|
+
interface CursorPageParams {
|
|
5
|
+
limit?: number;
|
|
6
|
+
after?: string;
|
|
7
|
+
before?: string;
|
|
8
|
+
}
|
|
9
|
+
interface OffsetLimitPageParams {
|
|
10
|
+
limit?: number;
|
|
11
|
+
page?: number;
|
|
12
|
+
}
|
|
13
|
+
interface PageResponse<Item> {
|
|
14
|
+
data: Array<Item>;
|
|
15
|
+
}
|
|
16
|
+
interface CursorPageResponse<Item> extends PageResponse<Item> {
|
|
17
|
+
pagination: {
|
|
18
|
+
next?: string;
|
|
19
|
+
previous?: string;
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
interface OffsetLimitPageResponse<Item> extends PageResponse<Item> {
|
|
23
|
+
pagination: {
|
|
24
|
+
currentPage: number;
|
|
25
|
+
totalPages: number;
|
|
26
|
+
count: number;
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
interface Page<Item> {
|
|
30
|
+
getPaginatedItems(): Item[];
|
|
31
|
+
hasNextPage(): boolean;
|
|
32
|
+
hasPreviousPage(): boolean;
|
|
33
|
+
}
|
|
34
|
+
declare class CursorPage<Item> implements CursorPageResponse<Item>, Page<Item>, AsyncIterable<Item> {
|
|
35
|
+
private pageFetcher;
|
|
36
|
+
data: Array<Item>;
|
|
37
|
+
pagination: {
|
|
38
|
+
next?: string;
|
|
39
|
+
previous?: string;
|
|
40
|
+
};
|
|
41
|
+
constructor(data: Array<Item>, pagination: {
|
|
42
|
+
next?: string;
|
|
43
|
+
previous?: string;
|
|
44
|
+
}, pageFetcher: (params: Omit<CursorPageParams, "limit">) => Promise<CursorPage<Item>>);
|
|
45
|
+
getPaginatedItems(): Item[];
|
|
46
|
+
hasNextPage(): boolean;
|
|
47
|
+
hasPreviousPage(): boolean;
|
|
48
|
+
getNextPage(): Promise<CursorPage<Item>>;
|
|
49
|
+
getPreviousPage(): Promise<CursorPage<Item>>;
|
|
50
|
+
iterPages(): AsyncGenerator<CursorPage<Item>, void, unknown>;
|
|
51
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<Item>, void, unknown>;
|
|
52
|
+
}
|
|
53
|
+
declare class OffsetLimitPage<Item> implements OffsetLimitPageResponse<Item>, Page<Item>, AsyncIterable<Item> {
|
|
54
|
+
private pageFetcher;
|
|
55
|
+
data: Array<Item>;
|
|
56
|
+
pagination: {
|
|
57
|
+
currentPage: number;
|
|
58
|
+
totalPages: number;
|
|
59
|
+
count: number;
|
|
60
|
+
};
|
|
61
|
+
constructor(data: Array<Item>, pagination: {
|
|
62
|
+
currentPage: number;
|
|
63
|
+
totalPages: number;
|
|
64
|
+
count: number;
|
|
65
|
+
}, pageFetcher: (params: Omit<OffsetLimitPageParams, "limit">) => Promise<OffsetLimitPage<Item>>);
|
|
66
|
+
getPaginatedItems(): Item[];
|
|
67
|
+
hasNextPage(): boolean;
|
|
68
|
+
hasPreviousPage(): boolean;
|
|
69
|
+
getNextPage(): Promise<OffsetLimitPage<Item>>;
|
|
70
|
+
getPreviousPage(): Promise<OffsetLimitPage<Item>>;
|
|
71
|
+
iterPages(): AsyncGenerator<OffsetLimitPage<Item>, void, unknown>;
|
|
72
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<Item>, void, unknown>;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
declare const defaultRetryOptions: {
|
|
76
|
+
maxAttempts: number;
|
|
77
|
+
factor: number;
|
|
78
|
+
minTimeoutInMs: number;
|
|
79
|
+
maxTimeoutInMs: number;
|
|
80
|
+
randomize: false;
|
|
81
|
+
};
|
|
82
|
+
type ZodFetchOptions = {
|
|
83
|
+
retry?: RetryOptions;
|
|
84
|
+
};
|
|
85
|
+
interface FetchCursorPageParams extends CursorPageParams {
|
|
86
|
+
query?: URLSearchParams;
|
|
87
|
+
}
|
|
88
|
+
interface FetchOffsetLimitPageParams extends OffsetLimitPageParams {
|
|
89
|
+
query?: URLSearchParams;
|
|
90
|
+
}
|
|
91
|
+
declare function zodfetch<TResponseBodySchema extends z.ZodTypeAny>(schema: TResponseBodySchema, url: string, requestInit?: RequestInit, options?: ZodFetchOptions): ApiPromise<z.output<TResponseBodySchema>>;
|
|
92
|
+
declare function zodfetchCursorPage<TItemSchema extends z.ZodTypeAny>(schema: TItemSchema, url: string, params: FetchCursorPageParams, requestInit?: RequestInit, options?: ZodFetchOptions): CursorPagePromise<TItemSchema>;
|
|
93
|
+
declare function zodfetchOffsetLimitPage<TItemSchema extends z.ZodTypeAny>(schema: TItemSchema, url: string, params: FetchOffsetLimitPageParams, requestInit?: RequestInit, options?: ZodFetchOptions): OffsetLimitPagePromise<TItemSchema>;
|
|
94
|
+
type ZodFetchResult<T> = {
|
|
95
|
+
data: T;
|
|
96
|
+
response: Response;
|
|
97
|
+
};
|
|
98
|
+
/**
|
|
99
|
+
* A subclass of `Promise` providing additional helper methods
|
|
100
|
+
* for interacting with the SDK.
|
|
101
|
+
*/
|
|
102
|
+
declare class ApiPromise<T> extends Promise<T> {
|
|
103
|
+
private responsePromise;
|
|
104
|
+
constructor(responsePromise: Promise<ZodFetchResult<T>>);
|
|
105
|
+
/**
|
|
106
|
+
* Gets the raw `Response` instance instead of parsing the response
|
|
107
|
+
* data.
|
|
108
|
+
*
|
|
109
|
+
* If you want to parse the response body but still get the `Response`
|
|
110
|
+
* instance, you can use {@link withResponse()}.
|
|
111
|
+
*/
|
|
112
|
+
asResponse(): Promise<Response>;
|
|
113
|
+
/**
|
|
114
|
+
* Gets the parsed response data and the raw `Response` instance.
|
|
115
|
+
*
|
|
116
|
+
* If you just want to get the raw `Response` instance without parsing it,
|
|
117
|
+
* you can use {@link asResponse()}.
|
|
118
|
+
*/
|
|
119
|
+
withResponse(): Promise<{
|
|
120
|
+
data: T;
|
|
121
|
+
response: Response;
|
|
122
|
+
}>;
|
|
123
|
+
private parse;
|
|
124
|
+
then<TResult1 = T, TResult2 = never>(onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | undefined | null, onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null): Promise<TResult1 | TResult2>;
|
|
125
|
+
catch<TResult = never>(onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | undefined | null): Promise<T | TResult>;
|
|
126
|
+
finally(onfinally?: (() => void) | undefined | null): Promise<T>;
|
|
127
|
+
}
|
|
128
|
+
declare class CursorPagePromise<TItemSchema extends z.ZodTypeAny> extends ApiPromise<CursorPage<z.output<TItemSchema>>> implements AsyncIterable<z.output<TItemSchema>> {
|
|
129
|
+
#private;
|
|
130
|
+
private schema;
|
|
131
|
+
private url;
|
|
132
|
+
private params;
|
|
133
|
+
private requestInit?;
|
|
134
|
+
private options?;
|
|
135
|
+
constructor(result: Promise<ZodFetchResult<CursorPageResponse<z.output<TItemSchema>>>>, schema: TItemSchema, url: string, params: FetchCursorPageParams, requestInit?: RequestInit | undefined, options?: ZodFetchOptions | undefined);
|
|
136
|
+
/**
|
|
137
|
+
* Allow auto-paginating iteration on an unawaited list call, eg:
|
|
138
|
+
*
|
|
139
|
+
* for await (const item of client.items.list()) {
|
|
140
|
+
* console.log(item)
|
|
141
|
+
* }
|
|
142
|
+
*/
|
|
143
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<z.output<TItemSchema>>, void, unknown>;
|
|
144
|
+
}
|
|
145
|
+
declare class OffsetLimitPagePromise<TItemSchema extends z.ZodTypeAny> extends ApiPromise<OffsetLimitPage<z.output<TItemSchema>>> implements AsyncIterable<z.output<TItemSchema>> {
|
|
146
|
+
#private;
|
|
147
|
+
private schema;
|
|
148
|
+
private url;
|
|
149
|
+
private params;
|
|
150
|
+
private requestInit?;
|
|
151
|
+
private options?;
|
|
152
|
+
constructor(result: Promise<ZodFetchResult<OffsetLimitPageResponse<z.output<TItemSchema>>>>, schema: TItemSchema, url: string, params: FetchOffsetLimitPageParams, requestInit?: RequestInit | undefined, options?: ZodFetchOptions | undefined);
|
|
153
|
+
/**
|
|
154
|
+
* Allow auto-paginating iteration on an unawaited list call, eg:
|
|
155
|
+
*
|
|
156
|
+
* for await (const item of client.items.list()) {
|
|
157
|
+
* console.log(item)
|
|
158
|
+
* }
|
|
159
|
+
*/
|
|
160
|
+
[Symbol.asyncIterator](): AsyncGenerator<Awaited<z.output<TItemSchema>>, void, unknown>;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
type APIHeaders = Record<string, string | null | undefined>;
|
|
164
|
+
declare class ApiError extends Error {
|
|
165
|
+
readonly status: number | undefined;
|
|
166
|
+
readonly headers: APIHeaders | undefined;
|
|
167
|
+
readonly error: Object | undefined;
|
|
168
|
+
readonly code: string | null | undefined;
|
|
169
|
+
readonly param: string | null | undefined;
|
|
170
|
+
readonly type: string | undefined;
|
|
171
|
+
constructor(status: number | undefined, error: Object | undefined, message: string | undefined, headers: APIHeaders | undefined);
|
|
172
|
+
private static makeMessage;
|
|
173
|
+
static generate(status: number | undefined, errorResponse: Object | undefined, message: string | undefined, headers: APIHeaders | undefined): ApiError;
|
|
174
|
+
}
|
|
175
|
+
declare class ApiConnectionError extends ApiError {
|
|
176
|
+
readonly status: undefined;
|
|
177
|
+
constructor({ message, cause }: {
|
|
178
|
+
message?: string;
|
|
179
|
+
cause?: Error | undefined;
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
declare class BadRequestError extends ApiError {
|
|
183
|
+
readonly status: 400;
|
|
184
|
+
}
|
|
185
|
+
declare class AuthenticationError extends ApiError {
|
|
186
|
+
readonly status: 401;
|
|
187
|
+
}
|
|
188
|
+
declare class PermissionDeniedError extends ApiError {
|
|
189
|
+
readonly status: 403;
|
|
190
|
+
}
|
|
191
|
+
declare class NotFoundError extends ApiError {
|
|
192
|
+
readonly status: 404;
|
|
193
|
+
}
|
|
194
|
+
declare class ConflictError extends ApiError {
|
|
195
|
+
readonly status: 409;
|
|
196
|
+
}
|
|
197
|
+
declare class UnprocessableEntityError extends ApiError {
|
|
198
|
+
readonly status: 422;
|
|
199
|
+
}
|
|
200
|
+
declare class RateLimitError extends ApiError {
|
|
201
|
+
readonly status: 429;
|
|
202
|
+
}
|
|
203
|
+
declare class InternalServerError extends ApiError {
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
export { type APIHeaders, ApiConnectionError, ApiError, ApiPromise, AuthenticationError, BadRequestError, ConflictError, CursorPage, type CursorPageParams, CursorPagePromise, type CursorPageResponse, InternalServerError, NotFoundError, OffsetLimitPage, type OffsetLimitPageParams, OffsetLimitPagePromise, type OffsetLimitPageResponse, type Page, type PageResponse, PermissionDeniedError, RateLimitError, UnprocessableEntityError, type ZodFetchOptions, defaultRetryOptions, zodfetch, zodfetchCursorPage, zodfetchOffsetLimitPage };
|