@langchain/langgraph-sdk 1.8.10 → 1.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +90 -43
- package/dist/client/assistants/index.cjs +180 -0
- package/dist/client/assistants/index.cjs.map +1 -0
- package/dist/client/assistants/index.d.cts +155 -0
- package/dist/client/assistants/index.d.cts.map +1 -0
- package/dist/client/assistants/index.d.ts +155 -0
- package/dist/client/assistants/index.d.ts.map +1 -0
- package/dist/client/assistants/index.js +180 -0
- package/dist/client/assistants/index.js.map +1 -0
- package/dist/client/base.cjs +190 -0
- package/dist/client/base.cjs.map +1 -0
- package/dist/client/base.d.cts +84 -0
- package/dist/client/base.d.cts.map +1 -0
- package/dist/client/base.d.ts +84 -0
- package/dist/client/base.d.ts.map +1 -0
- package/dist/client/base.js +188 -0
- package/dist/client/base.js.map +1 -0
- package/dist/client/crons/index.cjs +159 -0
- package/dist/client/crons/index.cjs.map +1 -0
- package/dist/client/crons/index.d.cts +71 -0
- package/dist/client/crons/index.d.cts.map +1 -0
- package/dist/client/crons/index.d.ts +71 -0
- package/dist/client/crons/index.d.ts.map +1 -0
- package/dist/client/crons/index.js +159 -0
- package/dist/client/crons/index.js.map +1 -0
- package/dist/client/index.cjs +84 -0
- package/dist/client/index.cjs.map +1 -0
- package/dist/client/index.d.cts +63 -0
- package/dist/client/index.d.cts.map +1 -0
- package/dist/client/index.d.ts +63 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +83 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/runs/index.cjs +275 -0
- package/dist/client/runs/index.cjs.map +1 -0
- package/dist/client/runs/index.d.cts +123 -0
- package/dist/client/runs/index.d.cts.map +1 -0
- package/dist/client/runs/index.d.ts +123 -0
- package/dist/client/runs/index.d.ts.map +1 -0
- package/dist/client/runs/index.js +275 -0
- package/dist/client/runs/index.js.map +1 -0
- package/dist/client/store/index.cjs +128 -0
- package/dist/client/store/index.cjs.map +1 -0
- package/dist/client/store/index.d.cts +75 -0
- package/dist/client/store/index.d.cts.map +1 -0
- package/dist/client/store/index.d.ts +75 -0
- package/dist/client/store/index.d.ts.map +1 -0
- package/dist/client/store/index.js +128 -0
- package/dist/client/store/index.js.map +1 -0
- package/dist/client/stream/error.cjs +18 -0
- package/dist/client/stream/error.cjs.map +1 -0
- package/dist/client/stream/error.d.cts +14 -0
- package/dist/client/stream/error.d.cts.map +1 -0
- package/dist/client/stream/error.d.ts +14 -0
- package/dist/client/stream/error.d.ts.map +1 -0
- package/dist/client/stream/error.js +18 -0
- package/dist/client/stream/error.js.map +1 -0
- package/dist/client/stream/handles/index.cjs +3 -0
- package/dist/client/stream/handles/index.d.ts +3 -0
- package/dist/client/stream/handles/index.js +4 -0
- package/dist/client/stream/handles/subagents.cjs +263 -0
- package/dist/client/stream/handles/subagents.cjs.map +1 -0
- package/dist/client/stream/handles/subagents.d.cts +45 -0
- package/dist/client/stream/handles/subagents.d.cts.map +1 -0
- package/dist/client/stream/handles/subagents.d.ts +45 -0
- package/dist/client/stream/handles/subagents.d.ts.map +1 -0
- package/dist/client/stream/handles/subagents.js +262 -0
- package/dist/client/stream/handles/subagents.js.map +1 -0
- package/dist/client/stream/handles/subgraphs.cjs +352 -0
- package/dist/client/stream/handles/subgraphs.cjs.map +1 -0
- package/dist/client/stream/handles/subgraphs.d.cts +82 -0
- package/dist/client/stream/handles/subgraphs.d.cts.map +1 -0
- package/dist/client/stream/handles/subgraphs.d.ts +82 -0
- package/dist/client/stream/handles/subgraphs.d.ts.map +1 -0
- package/dist/client/stream/handles/subgraphs.js +351 -0
- package/dist/client/stream/handles/subgraphs.js.map +1 -0
- package/dist/client/stream/handles/tools.cjs +92 -0
- package/dist/client/stream/handles/tools.cjs.map +1 -0
- package/dist/client/stream/handles/tools.d.cts +26 -0
- package/dist/client/stream/handles/tools.d.cts.map +1 -0
- package/dist/client/stream/handles/tools.d.ts +26 -0
- package/dist/client/stream/handles/tools.d.ts.map +1 -0
- package/dist/client/stream/handles/tools.js +92 -0
- package/dist/client/stream/handles/tools.js.map +1 -0
- package/dist/client/stream/index.cjs +1368 -0
- package/dist/client/stream/index.cjs.map +1 -0
- package/dist/client/stream/index.d.cts +238 -0
- package/dist/client/stream/index.d.cts.map +1 -0
- package/dist/client/stream/index.d.ts +238 -0
- package/dist/client/stream/index.d.ts.map +1 -0
- package/dist/client/stream/index.js +1367 -0
- package/dist/client/stream/index.js.map +1 -0
- package/dist/client/stream/media.cjs +506 -0
- package/dist/client/stream/media.cjs.map +1 -0
- package/dist/client/stream/media.d.cts +164 -0
- package/dist/client/stream/media.d.cts.map +1 -0
- package/dist/client/stream/media.d.ts +164 -0
- package/dist/client/stream/media.d.ts.map +1 -0
- package/dist/client/stream/media.js +505 -0
- package/dist/client/stream/media.js.map +1 -0
- package/dist/client/stream/messages.cjs +635 -0
- package/dist/client/stream/messages.cjs.map +1 -0
- package/dist/client/stream/messages.d.cts +139 -0
- package/dist/client/stream/messages.d.cts.map +1 -0
- package/dist/client/stream/messages.d.ts +139 -0
- package/dist/client/stream/messages.d.ts.map +1 -0
- package/dist/client/stream/messages.js +631 -0
- package/dist/client/stream/messages.js.map +1 -0
- package/dist/client/stream/multi-cursor-buffer.cjs +55 -0
- package/dist/client/stream/multi-cursor-buffer.cjs.map +1 -0
- package/dist/client/stream/multi-cursor-buffer.js +55 -0
- package/dist/client/stream/multi-cursor-buffer.js.map +1 -0
- package/dist/client/stream/subscription.cjs +85 -0
- package/dist/client/stream/subscription.cjs.map +1 -0
- package/dist/client/stream/subscription.d.cts +22 -0
- package/dist/client/stream/subscription.d.cts.map +1 -0
- package/dist/client/stream/subscription.d.ts +22 -0
- package/dist/client/stream/subscription.d.ts.map +1 -0
- package/dist/client/stream/subscription.js +84 -0
- package/dist/client/stream/subscription.js.map +1 -0
- package/dist/client/stream/transport/agent-server.cjs +45 -0
- package/dist/client/stream/transport/agent-server.cjs.map +1 -0
- package/dist/client/stream/transport/agent-server.d.cts +39 -0
- package/dist/client/stream/transport/agent-server.d.cts.map +1 -0
- package/dist/client/stream/transport/agent-server.d.ts +39 -0
- package/dist/client/stream/transport/agent-server.d.ts.map +1 -0
- package/dist/client/stream/transport/agent-server.js +45 -0
- package/dist/client/stream/transport/agent-server.js.map +1 -0
- package/dist/client/stream/transport/constants.cjs +10 -0
- package/dist/client/stream/transport/constants.cjs.map +1 -0
- package/dist/client/stream/transport/constants.js +10 -0
- package/dist/client/stream/transport/constants.js.map +1 -0
- package/dist/client/stream/transport/decoder.cjs +115 -0
- package/dist/client/stream/transport/decoder.cjs.map +1 -0
- package/dist/client/stream/transport/decoder.js +114 -0
- package/dist/client/stream/transport/decoder.js.map +1 -0
- package/dist/client/stream/transport/http.cjs +183 -0
- package/dist/client/stream/transport/http.cjs.map +1 -0
- package/dist/client/stream/transport/http.d.cts +45 -0
- package/dist/client/stream/transport/http.d.cts.map +1 -0
- package/dist/client/stream/transport/http.d.ts +45 -0
- package/dist/client/stream/transport/http.d.ts.map +1 -0
- package/dist/client/stream/transport/http.js +183 -0
- package/dist/client/stream/transport/http.js.map +1 -0
- package/dist/client/stream/transport/index.cjs +3 -0
- package/dist/client/stream/transport/index.js +4 -0
- package/dist/client/stream/transport/queue.cjs +55 -0
- package/dist/client/stream/transport/queue.cjs.map +1 -0
- package/dist/client/stream/transport/queue.js +55 -0
- package/dist/client/stream/transport/queue.js.map +1 -0
- package/dist/client/stream/transport/stream.cjs +79 -0
- package/dist/client/stream/transport/stream.cjs.map +1 -0
- package/dist/client/stream/transport/stream.js +79 -0
- package/dist/client/stream/transport/stream.js.map +1 -0
- package/dist/client/stream/transport/types.d.cts +29 -0
- package/dist/client/stream/transport/types.d.cts.map +1 -0
- package/dist/client/stream/transport/types.d.ts +29 -0
- package/dist/client/stream/transport/types.d.ts.map +1 -0
- package/dist/client/stream/transport/utils.cjs +45 -0
- package/dist/client/stream/transport/utils.cjs.map +1 -0
- package/dist/client/stream/transport/utils.js +39 -0
- package/dist/client/stream/transport/utils.js.map +1 -0
- package/dist/client/stream/transport/websocket.cjs +155 -0
- package/dist/client/stream/transport/websocket.cjs.map +1 -0
- package/dist/client/stream/transport/websocket.d.cts +36 -0
- package/dist/client/stream/transport/websocket.d.cts.map +1 -0
- package/dist/client/stream/transport/websocket.d.ts +36 -0
- package/dist/client/stream/transport/websocket.d.ts.map +1 -0
- package/dist/client/stream/transport/websocket.js +155 -0
- package/dist/client/stream/transport/websocket.js.map +1 -0
- package/dist/client/stream/transport.d.cts +104 -0
- package/dist/client/stream/transport.d.cts.map +1 -0
- package/dist/client/stream/transport.d.ts +104 -0
- package/dist/client/stream/transport.d.ts.map +1 -0
- package/dist/client/stream/types.d.cts +208 -0
- package/dist/client/stream/types.d.cts.map +1 -0
- package/dist/client/stream/types.d.ts +208 -0
- package/dist/client/stream/types.d.ts.map +1 -0
- package/dist/client/threads/index.cjs +271 -0
- package/dist/client/threads/index.cjs.map +1 -0
- package/dist/client/threads/index.d.cts +235 -0
- package/dist/client/threads/index.d.cts.map +1 -0
- package/dist/client/threads/index.d.ts +235 -0
- package/dist/client/threads/index.d.ts.map +1 -0
- package/dist/client/threads/index.js +270 -0
- package/dist/client/threads/index.js.map +1 -0
- package/dist/client/ui-internal/index.cjs +29 -0
- package/dist/client/ui-internal/index.cjs.map +1 -0
- package/dist/client/ui-internal/index.d.cts +11 -0
- package/dist/client/ui-internal/index.d.cts.map +1 -0
- package/dist/client/ui-internal/index.d.ts +11 -0
- package/dist/client/ui-internal/index.d.ts.map +1 -0
- package/dist/client/ui-internal/index.js +29 -0
- package/dist/client/ui-internal/index.js.map +1 -0
- package/dist/client.cjs +35 -1308
- package/dist/client.d.cts +19 -857
- package/dist/client.d.ts +19 -857
- package/dist/client.js +16 -1301
- package/dist/index.cjs +25 -4
- package/dist/index.d.cts +15 -3
- package/dist/index.d.ts +15 -3
- package/dist/index.js +14 -3
- package/dist/react/stream.cjs.map +1 -1
- package/dist/react/stream.custom.cjs +1 -1
- package/dist/react/stream.custom.js +1 -1
- package/dist/react/stream.d.cts +2 -1
- package/dist/react/stream.d.cts.map +1 -1
- package/dist/react/stream.d.ts +2 -1
- package/dist/react/stream.d.ts.map +1 -1
- package/dist/react/stream.js.map +1 -1
- package/dist/react/stream.lgp.cjs +6 -5
- package/dist/react/stream.lgp.cjs.map +1 -1
- package/dist/react/stream.lgp.js +4 -3
- package/dist/react/stream.lgp.js.map +1 -1
- package/dist/react/types.d.cts +1 -1
- package/dist/react/types.d.ts +1 -1
- package/dist/react/types.d.ts.map +1 -1
- package/dist/react-ui/server/server.cjs +1 -1
- package/dist/react-ui/server/server.cjs.map +1 -1
- package/dist/react-ui/server/server.js +1 -1
- package/dist/react-ui/server/server.js.map +1 -1
- package/dist/react-ui/types.cjs.map +1 -1
- package/dist/react-ui/types.d.cts +1 -1
- package/dist/react-ui/types.d.cts.map +1 -1
- package/dist/react-ui/types.d.ts +1 -1
- package/dist/react-ui/types.d.ts.map +1 -1
- package/dist/react-ui/types.js.map +1 -1
- package/dist/stream/assembled-to-message.cjs +121 -0
- package/dist/stream/assembled-to-message.cjs.map +1 -0
- package/dist/stream/assembled-to-message.d.cts +35 -0
- package/dist/stream/assembled-to-message.d.cts.map +1 -0
- package/dist/stream/assembled-to-message.d.ts +35 -0
- package/dist/stream/assembled-to-message.d.ts.map +1 -0
- package/dist/stream/assembled-to-message.js +119 -0
- package/dist/stream/assembled-to-message.js.map +1 -0
- package/dist/stream/channel-registry.cjs +224 -0
- package/dist/stream/channel-registry.cjs.map +1 -0
- package/dist/stream/channel-registry.d.cts +102 -0
- package/dist/stream/channel-registry.d.cts.map +1 -0
- package/dist/stream/channel-registry.d.ts +102 -0
- package/dist/stream/channel-registry.d.ts.map +1 -0
- package/dist/stream/channel-registry.js +224 -0
- package/dist/stream/channel-registry.js.map +1 -0
- package/dist/stream/constants.cjs +11 -0
- package/dist/stream/constants.cjs.map +1 -0
- package/dist/stream/constants.d.cts +10 -0
- package/dist/stream/constants.d.cts.map +1 -0
- package/dist/stream/constants.d.ts +10 -0
- package/dist/stream/constants.d.ts.map +1 -0
- package/dist/stream/constants.js +11 -0
- package/dist/stream/constants.js.map +1 -0
- package/dist/stream/controller.cjs +933 -0
- package/dist/stream/controller.cjs.map +1 -0
- package/dist/stream/controller.d.cts +135 -0
- package/dist/stream/controller.d.cts.map +1 -0
- package/dist/stream/controller.d.ts +135 -0
- package/dist/stream/controller.d.ts.map +1 -0
- package/dist/stream/controller.js +910 -0
- package/dist/stream/controller.js.map +1 -0
- package/dist/stream/discovery/index.d.ts +2 -0
- package/dist/stream/discovery/subagents.cjs +235 -0
- package/dist/stream/discovery/subagents.cjs.map +1 -0
- package/dist/stream/discovery/subagents.d.cts +18 -0
- package/dist/stream/discovery/subagents.d.cts.map +1 -0
- package/dist/stream/discovery/subagents.d.ts +18 -0
- package/dist/stream/discovery/subagents.d.ts.map +1 -0
- package/dist/stream/discovery/subagents.js +235 -0
- package/dist/stream/discovery/subagents.js.map +1 -0
- package/dist/stream/discovery/subgraphs.cjs +153 -0
- package/dist/stream/discovery/subgraphs.cjs.map +1 -0
- package/dist/stream/discovery/subgraphs.d.cts +19 -0
- package/dist/stream/discovery/subgraphs.d.cts.map +1 -0
- package/dist/stream/discovery/subgraphs.d.ts +19 -0
- package/dist/stream/discovery/subgraphs.d.ts.map +1 -0
- package/dist/stream/discovery/subgraphs.js +153 -0
- package/dist/stream/discovery/subgraphs.js.map +1 -0
- package/dist/stream/index.cjs +36 -0
- package/dist/stream/index.d.cts +25 -0
- package/dist/stream/index.d.ts +25 -0
- package/dist/stream/index.js +16 -0
- package/dist/stream/lifecycle-loading-tracker.cjs +83 -0
- package/dist/stream/lifecycle-loading-tracker.cjs.map +1 -0
- package/dist/stream/lifecycle-loading-tracker.js +83 -0
- package/dist/stream/lifecycle-loading-tracker.js.map +1 -0
- package/dist/stream/message-metadata-tracker.cjs +165 -0
- package/dist/stream/message-metadata-tracker.cjs.map +1 -0
- package/dist/stream/message-metadata-tracker.d.cts +24 -0
- package/dist/stream/message-metadata-tracker.d.cts.map +1 -0
- package/dist/stream/message-metadata-tracker.d.ts +24 -0
- package/dist/stream/message-metadata-tracker.d.ts.map +1 -0
- package/dist/stream/message-metadata-tracker.js +165 -0
- package/dist/stream/message-metadata-tracker.js.map +1 -0
- package/dist/stream/message-reconciliation.cjs +118 -0
- package/dist/stream/message-reconciliation.cjs.map +1 -0
- package/dist/stream/message-reconciliation.js +115 -0
- package/dist/stream/message-reconciliation.js.map +1 -0
- package/dist/stream/namespace.cjs +54 -0
- package/dist/stream/namespace.cjs.map +1 -0
- package/dist/stream/namespace.js +49 -0
- package/dist/stream/namespace.js.map +1 -0
- package/dist/stream/projections/channel.cjs +53 -0
- package/dist/stream/projections/channel.cjs.map +1 -0
- package/dist/stream/projections/channel.d.cts +22 -0
- package/dist/stream/projections/channel.d.cts.map +1 -0
- package/dist/stream/projections/channel.d.ts +22 -0
- package/dist/stream/projections/channel.d.ts.map +1 -0
- package/dist/stream/projections/channel.js +53 -0
- package/dist/stream/projections/channel.js.map +1 -0
- package/dist/stream/projections/extension.cjs +29 -0
- package/dist/stream/projections/extension.cjs.map +1 -0
- package/dist/stream/projections/extension.d.cts +7 -0
- package/dist/stream/projections/extension.d.cts.map +1 -0
- package/dist/stream/projections/extension.d.ts +7 -0
- package/dist/stream/projections/extension.d.ts.map +1 -0
- package/dist/stream/projections/extension.js +29 -0
- package/dist/stream/projections/extension.js.map +1 -0
- package/dist/stream/projections/index.cjs +6 -0
- package/dist/stream/projections/index.d.ts +6 -0
- package/dist/stream/projections/index.js +7 -0
- package/dist/stream/projections/media.cjs +81 -0
- package/dist/stream/projections/media.cjs.map +1 -0
- package/dist/stream/projections/media.d.cts +18 -0
- package/dist/stream/projections/media.d.cts.map +1 -0
- package/dist/stream/projections/media.d.ts +18 -0
- package/dist/stream/projections/media.d.ts.map +1 -0
- package/dist/stream/projections/media.js +78 -0
- package/dist/stream/projections/media.js.map +1 -0
- package/dist/stream/projections/messages.cjs +121 -0
- package/dist/stream/projections/messages.cjs.map +1 -0
- package/dist/stream/projections/messages.d.cts +8 -0
- package/dist/stream/projections/messages.d.cts.map +1 -0
- package/dist/stream/projections/messages.d.ts +8 -0
- package/dist/stream/projections/messages.d.ts.map +1 -0
- package/dist/stream/projections/messages.js +121 -0
- package/dist/stream/projections/messages.js.map +1 -0
- package/dist/stream/projections/runtime.cjs +44 -0
- package/dist/stream/projections/runtime.cjs.map +1 -0
- package/dist/stream/projections/runtime.js +44 -0
- package/dist/stream/projections/runtime.js.map +1 -0
- package/dist/stream/projections/tool-calls.cjs +50 -0
- package/dist/stream/projections/tool-calls.cjs.map +1 -0
- package/dist/stream/projections/tool-calls.d.cts +8 -0
- package/dist/stream/projections/tool-calls.d.cts.map +1 -0
- package/dist/stream/projections/tool-calls.d.ts +8 -0
- package/dist/stream/projections/tool-calls.d.ts.map +1 -0
- package/dist/stream/projections/tool-calls.js +50 -0
- package/dist/stream/projections/tool-calls.js.map +1 -0
- package/dist/stream/projections/values.cjs +52 -0
- package/dist/stream/projections/values.cjs.map +1 -0
- package/dist/stream/projections/values.d.cts +7 -0
- package/dist/stream/projections/values.d.cts.map +1 -0
- package/dist/stream/projections/values.d.ts +6 -0
- package/dist/stream/projections/values.d.ts.map +1 -0
- package/dist/stream/projections/values.js +52 -0
- package/dist/stream/projections/values.js.map +1 -0
- package/dist/stream/root-message-projection.cjs +256 -0
- package/dist/stream/root-message-projection.cjs.map +1 -0
- package/dist/stream/root-message-projection.js +256 -0
- package/dist/stream/root-message-projection.js.map +1 -0
- package/dist/stream/store.cjs +32 -0
- package/dist/stream/store.cjs.map +1 -0
- package/dist/stream/store.d.cts +37 -0
- package/dist/stream/store.d.cts.map +1 -0
- package/dist/stream/store.d.ts +37 -0
- package/dist/stream/store.d.ts.map +1 -0
- package/dist/stream/store.js +32 -0
- package/dist/stream/store.js.map +1 -0
- package/dist/stream/submit-coordinator.cjs +399 -0
- package/dist/stream/submit-coordinator.cjs.map +1 -0
- package/dist/stream/submit-coordinator.d.cts +27 -0
- package/dist/stream/submit-coordinator.d.cts.map +1 -0
- package/dist/stream/submit-coordinator.d.ts +27 -0
- package/dist/stream/submit-coordinator.d.ts.map +1 -0
- package/dist/stream/submit-coordinator.js +397 -0
- package/dist/stream/submit-coordinator.js.map +1 -0
- package/dist/stream/tool-calls.cjs +15 -0
- package/dist/stream/tool-calls.cjs.map +1 -0
- package/dist/stream/tool-calls.js +15 -0
- package/dist/stream/tool-calls.js.map +1 -0
- package/dist/stream/types-inference.d.cts +43 -0
- package/dist/stream/types-inference.d.cts.map +1 -0
- package/dist/stream/types-inference.d.ts +43 -0
- package/dist/stream/types-inference.d.ts.map +1 -0
- package/dist/stream/types.d.cts +354 -0
- package/dist/stream/types.d.cts.map +1 -0
- package/dist/stream/types.d.ts +354 -0
- package/dist/stream/types.d.ts.map +1 -0
- package/dist/types.d.cts +2 -1
- package/dist/types.d.cts.map +1 -1
- package/dist/types.d.ts +2 -1
- package/dist/types.d.ts.map +1 -1
- package/dist/ui/index.cjs +1 -1
- package/dist/ui/index.d.cts +3 -3
- package/dist/ui/index.d.ts +3 -3
- package/dist/ui/index.js +1 -1
- package/dist/ui/manager.cjs +1 -1
- package/dist/ui/manager.js +1 -1
- package/dist/ui/messages.cjs +50 -7
- package/dist/ui/messages.cjs.map +1 -1
- package/dist/ui/messages.d.cts.map +1 -1
- package/dist/ui/messages.d.ts.map +1 -1
- package/dist/ui/messages.js +51 -9
- package/dist/ui/messages.js.map +1 -1
- package/dist/ui/orchestrator-custom.cjs +1 -1
- package/dist/ui/orchestrator-custom.js +1 -1
- package/dist/ui/orchestrator.cjs +2 -2
- package/dist/ui/orchestrator.d.cts +1 -1
- package/dist/ui/orchestrator.d.ts +1 -1
- package/dist/ui/orchestrator.d.ts.map +1 -1
- package/dist/ui/orchestrator.js +2 -2
- package/dist/ui/stream/agent.d.cts +1 -1
- package/dist/ui/stream/agent.d.cts.map +1 -1
- package/dist/ui/stream/agent.d.ts +1 -1
- package/dist/ui/stream/agent.d.ts.map +1 -1
- package/dist/ui/stream/base.d.cts +7 -6
- package/dist/ui/stream/base.d.cts.map +1 -1
- package/dist/ui/stream/base.d.ts +7 -6
- package/dist/ui/stream/base.d.ts.map +1 -1
- package/dist/ui/stream/deep-agent.d.cts +1 -1
- package/dist/ui/stream/deep-agent.d.cts.map +1 -1
- package/dist/ui/stream/deep-agent.d.ts +1 -1
- package/dist/ui/stream/deep-agent.d.ts.map +1 -1
- package/dist/ui/stream/index.d.cts +4 -4
- package/dist/ui/stream/index.d.cts.map +1 -1
- package/dist/ui/stream/index.d.ts +4 -4
- package/dist/ui/stream/index.d.ts.map +1 -1
- package/dist/ui/types.d.cts +3 -2
- package/dist/ui/types.d.cts.map +1 -1
- package/dist/ui/types.d.ts +2 -1
- package/dist/ui/types.d.ts.map +1 -1
- package/package.json +18 -8
- package/dist/client.cjs.map +0 -1
- package/dist/client.d.cts.map +0 -1
- package/dist/client.d.ts.map +0 -1
- package/dist/client.js.map +0 -1
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
import { BaseClient, getRunMetadataFromResponse } from "../base.js";
|
|
2
|
+
//#region src/client/runs/index.ts
|
|
3
|
+
var RunsClient = class extends BaseClient {
|
|
4
|
+
/**
|
|
5
|
+
* Create a run and stream the results.
|
|
6
|
+
*
|
|
7
|
+
* @param threadId The ID of the thread.
|
|
8
|
+
* @param assistantId Assistant ID to use for this run.
|
|
9
|
+
* @param payload Payload for creating a run.
|
|
10
|
+
*/
|
|
11
|
+
async *stream(threadId, assistantId, payload) {
|
|
12
|
+
const json = {
|
|
13
|
+
input: payload?.input,
|
|
14
|
+
command: payload?.command,
|
|
15
|
+
config: payload?.config,
|
|
16
|
+
context: payload?.context,
|
|
17
|
+
metadata: payload?.metadata,
|
|
18
|
+
stream_mode: payload?.streamMode,
|
|
19
|
+
stream_subgraphs: payload?.streamSubgraphs,
|
|
20
|
+
stream_resumable: payload?.streamResumable,
|
|
21
|
+
feedback_keys: payload?.feedbackKeys,
|
|
22
|
+
assistant_id: assistantId,
|
|
23
|
+
interrupt_before: payload?.interruptBefore,
|
|
24
|
+
interrupt_after: payload?.interruptAfter,
|
|
25
|
+
checkpoint: payload?.checkpoint,
|
|
26
|
+
webhook: payload?.webhook,
|
|
27
|
+
multitask_strategy: payload?.multitaskStrategy,
|
|
28
|
+
on_completion: payload?.onCompletion,
|
|
29
|
+
on_disconnect: payload?.onDisconnect,
|
|
30
|
+
after_seconds: payload?.afterSeconds,
|
|
31
|
+
if_not_exists: payload?.ifNotExists,
|
|
32
|
+
checkpoint_during: payload?.checkpointDuring,
|
|
33
|
+
durability: payload?.durability
|
|
34
|
+
};
|
|
35
|
+
yield* this.streamWithRetry({
|
|
36
|
+
endpoint: threadId == null ? `/runs/stream` : `/threads/${threadId}/runs/stream`,
|
|
37
|
+
method: "POST",
|
|
38
|
+
json,
|
|
39
|
+
signal: payload?.signal,
|
|
40
|
+
onInitialResponse: (response) => {
|
|
41
|
+
const runMetadata = getRunMetadataFromResponse(response);
|
|
42
|
+
if (runMetadata) payload?.onRunCreated?.(runMetadata);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Create a run.
|
|
48
|
+
*
|
|
49
|
+
* @param threadId The ID of the thread.
|
|
50
|
+
* @param assistantId Assistant ID to use for this run.
|
|
51
|
+
* @param payload Payload for creating a run.
|
|
52
|
+
* @returns The created run.
|
|
53
|
+
*/
|
|
54
|
+
async create(threadId, assistantId, payload) {
|
|
55
|
+
const json = {
|
|
56
|
+
input: payload?.input,
|
|
57
|
+
command: payload?.command,
|
|
58
|
+
config: payload?.config,
|
|
59
|
+
context: payload?.context,
|
|
60
|
+
metadata: payload?.metadata,
|
|
61
|
+
stream_mode: payload?.streamMode,
|
|
62
|
+
stream_subgraphs: payload?.streamSubgraphs,
|
|
63
|
+
stream_resumable: payload?.streamResumable,
|
|
64
|
+
feedback_keys: payload?.feedbackKeys,
|
|
65
|
+
assistant_id: assistantId,
|
|
66
|
+
interrupt_before: payload?.interruptBefore,
|
|
67
|
+
interrupt_after: payload?.interruptAfter,
|
|
68
|
+
webhook: payload?.webhook,
|
|
69
|
+
checkpoint: payload?.checkpoint,
|
|
70
|
+
checkpoint_id: payload?.checkpointId,
|
|
71
|
+
multitask_strategy: payload?.multitaskStrategy,
|
|
72
|
+
after_seconds: payload?.afterSeconds,
|
|
73
|
+
if_not_exists: payload?.ifNotExists,
|
|
74
|
+
checkpoint_during: payload?.checkpointDuring,
|
|
75
|
+
durability: payload?.durability,
|
|
76
|
+
on_completion: payload?.onCompletion,
|
|
77
|
+
langsmith_tracer: payload?._langsmithTracer ? {
|
|
78
|
+
project_name: payload?._langsmithTracer?.projectName,
|
|
79
|
+
example_id: payload?._langsmithTracer?.exampleId
|
|
80
|
+
} : void 0
|
|
81
|
+
};
|
|
82
|
+
const endpoint = threadId === null ? "/runs" : `/threads/${threadId}/runs`;
|
|
83
|
+
const [run, response] = await this.fetch(endpoint, {
|
|
84
|
+
method: "POST",
|
|
85
|
+
json,
|
|
86
|
+
signal: payload?.signal,
|
|
87
|
+
withResponse: true
|
|
88
|
+
});
|
|
89
|
+
const runMetadata = getRunMetadataFromResponse(response);
|
|
90
|
+
if (runMetadata) payload?.onRunCreated?.(runMetadata);
|
|
91
|
+
return run;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Create a batch of stateless background runs.
|
|
95
|
+
*
|
|
96
|
+
* @param payloads An array of payloads for creating runs.
|
|
97
|
+
* @returns An array of created runs.
|
|
98
|
+
*/
|
|
99
|
+
async createBatch(payloads, options) {
|
|
100
|
+
const filteredPayloads = payloads.map((payload) => ({
|
|
101
|
+
...payload,
|
|
102
|
+
assistant_id: payload.assistantId
|
|
103
|
+
})).map((payload) => {
|
|
104
|
+
return Object.fromEntries(Object.entries(payload).filter(([_, v]) => v !== void 0));
|
|
105
|
+
});
|
|
106
|
+
return this.fetch("/runs/batch", {
|
|
107
|
+
method: "POST",
|
|
108
|
+
json: filteredPayloads,
|
|
109
|
+
signal: options?.signal
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Create a run and wait for it to complete.
|
|
114
|
+
*
|
|
115
|
+
* @param threadId The ID of the thread.
|
|
116
|
+
* @param assistantId Assistant ID to use for this run.
|
|
117
|
+
* @param payload Payload for creating a run.
|
|
118
|
+
* @returns The last values chunk of the thread.
|
|
119
|
+
*/
|
|
120
|
+
async wait(threadId, assistantId, payload) {
|
|
121
|
+
const json = {
|
|
122
|
+
input: payload?.input,
|
|
123
|
+
command: payload?.command,
|
|
124
|
+
config: payload?.config,
|
|
125
|
+
context: payload?.context,
|
|
126
|
+
metadata: payload?.metadata,
|
|
127
|
+
assistant_id: assistantId,
|
|
128
|
+
interrupt_before: payload?.interruptBefore,
|
|
129
|
+
interrupt_after: payload?.interruptAfter,
|
|
130
|
+
checkpoint: payload?.checkpoint,
|
|
131
|
+
checkpoint_id: payload?.checkpointId,
|
|
132
|
+
webhook: payload?.webhook,
|
|
133
|
+
multitask_strategy: payload?.multitaskStrategy,
|
|
134
|
+
on_completion: payload?.onCompletion,
|
|
135
|
+
on_disconnect: payload?.onDisconnect,
|
|
136
|
+
after_seconds: payload?.afterSeconds,
|
|
137
|
+
if_not_exists: payload?.ifNotExists,
|
|
138
|
+
checkpoint_during: payload?.checkpointDuring,
|
|
139
|
+
durability: payload?.durability,
|
|
140
|
+
langsmith_tracer: payload?._langsmithTracer ? {
|
|
141
|
+
project_name: payload?._langsmithTracer?.projectName,
|
|
142
|
+
example_id: payload?._langsmithTracer?.exampleId
|
|
143
|
+
} : void 0
|
|
144
|
+
};
|
|
145
|
+
const endpoint = threadId == null ? `/runs/wait` : `/threads/${threadId}/runs/wait`;
|
|
146
|
+
const [run, response] = await this.fetch(endpoint, {
|
|
147
|
+
method: "POST",
|
|
148
|
+
json,
|
|
149
|
+
timeoutMs: null,
|
|
150
|
+
signal: payload?.signal,
|
|
151
|
+
withResponse: true
|
|
152
|
+
});
|
|
153
|
+
const runMetadata = getRunMetadataFromResponse(response);
|
|
154
|
+
if (runMetadata) payload?.onRunCreated?.(runMetadata);
|
|
155
|
+
if ((payload?.raiseError !== void 0 ? payload.raiseError : true) && "__error__" in run && typeof run.__error__ === "object" && run.__error__ && "error" in run.__error__ && "message" in run.__error__) throw new Error(`${run.__error__?.error}: ${run.__error__?.message}`);
|
|
156
|
+
return run;
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* List all runs for a thread.
|
|
160
|
+
*
|
|
161
|
+
* @param threadId The ID of the thread.
|
|
162
|
+
* @param options Filtering and pagination options.
|
|
163
|
+
* @returns List of runs.
|
|
164
|
+
*/
|
|
165
|
+
async list(threadId, options) {
|
|
166
|
+
return this.fetch(`/threads/${threadId}/runs`, {
|
|
167
|
+
params: {
|
|
168
|
+
limit: options?.limit ?? 10,
|
|
169
|
+
offset: options?.offset ?? 0,
|
|
170
|
+
status: options?.status ?? void 0,
|
|
171
|
+
select: options?.select ?? void 0
|
|
172
|
+
},
|
|
173
|
+
signal: options?.signal
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Get a run by ID.
|
|
178
|
+
*
|
|
179
|
+
* @param threadId The ID of the thread.
|
|
180
|
+
* @param runId The ID of the run.
|
|
181
|
+
* @returns The run.
|
|
182
|
+
*/
|
|
183
|
+
async get(threadId, runId, options) {
|
|
184
|
+
return this.fetch(`/threads/${threadId}/runs/${runId}`, { signal: options?.signal });
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Cancel a run.
|
|
188
|
+
*
|
|
189
|
+
* @param threadId The ID of the thread.
|
|
190
|
+
* @param runId The ID of the run.
|
|
191
|
+
* @param wait Whether to block when canceling
|
|
192
|
+
* @param action Action to take when cancelling the run. Possible values are `interrupt` or `rollback`. Default is `interrupt`.
|
|
193
|
+
* @returns
|
|
194
|
+
*/
|
|
195
|
+
async cancel(threadId, runId, wait = false, action = "interrupt", options = {}) {
|
|
196
|
+
return this.fetch(`/threads/${threadId}/runs/${runId}/cancel`, {
|
|
197
|
+
method: "POST",
|
|
198
|
+
params: {
|
|
199
|
+
wait: wait ? "1" : "0",
|
|
200
|
+
action
|
|
201
|
+
},
|
|
202
|
+
signal: options?.signal
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Cancel one or more runs.
|
|
207
|
+
*
|
|
208
|
+
* @param options Options for cancelling runs.
|
|
209
|
+
* @returns
|
|
210
|
+
*/
|
|
211
|
+
async cancelMany(options) {
|
|
212
|
+
return this.fetch(`/runs/cancel`, {
|
|
213
|
+
method: "POST",
|
|
214
|
+
json: {
|
|
215
|
+
thread_id: options.threadId,
|
|
216
|
+
run_ids: options.runIds,
|
|
217
|
+
status: options.status
|
|
218
|
+
},
|
|
219
|
+
params: { action: options.action },
|
|
220
|
+
signal: options.signal
|
|
221
|
+
});
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Block until a run is done.
|
|
225
|
+
*
|
|
226
|
+
* @param threadId The ID of the thread.
|
|
227
|
+
* @param runId The ID of the run.
|
|
228
|
+
* @returns
|
|
229
|
+
*/
|
|
230
|
+
async join(threadId, runId, options) {
|
|
231
|
+
return this.fetch(`/threads/${threadId}/runs/${runId}/join`, {
|
|
232
|
+
timeoutMs: null,
|
|
233
|
+
params: { cancel_on_disconnect: options?.cancelOnDisconnect ? "1" : "0" },
|
|
234
|
+
signal: options?.signal
|
|
235
|
+
});
|
|
236
|
+
}
|
|
237
|
+
/**
|
|
238
|
+
* Stream output from a run in real-time, until the run is done.
|
|
239
|
+
*
|
|
240
|
+
* @param threadId The ID of the thread.
|
|
241
|
+
* @param runId The ID of the run.
|
|
242
|
+
* @param options Additional options for controlling the stream behavior.
|
|
243
|
+
* @returns An async generator yielding stream parts.
|
|
244
|
+
*/
|
|
245
|
+
async *joinStream(threadId, runId, options) {
|
|
246
|
+
const opts = typeof options === "object" && options != null && options instanceof AbortSignal ? { signal: options } : options;
|
|
247
|
+
yield* this.streamWithRetry({
|
|
248
|
+
endpoint: threadId != null ? `/threads/${threadId}/runs/${runId}/stream` : `/runs/${runId}/stream`,
|
|
249
|
+
method: "GET",
|
|
250
|
+
signal: opts?.signal,
|
|
251
|
+
headers: opts?.lastEventId ? { "Last-Event-ID": opts.lastEventId } : void 0,
|
|
252
|
+
params: {
|
|
253
|
+
cancel_on_disconnect: opts?.cancelOnDisconnect ? "1" : "0",
|
|
254
|
+
stream_mode: opts?.streamMode
|
|
255
|
+
}
|
|
256
|
+
});
|
|
257
|
+
}
|
|
258
|
+
/**
|
|
259
|
+
* Delete a run.
|
|
260
|
+
*
|
|
261
|
+
* @param threadId The ID of the thread.
|
|
262
|
+
* @param runId The ID of the run.
|
|
263
|
+
* @returns
|
|
264
|
+
*/
|
|
265
|
+
async delete(threadId, runId, options) {
|
|
266
|
+
return this.fetch(`/threads/${threadId}/runs/${runId}`, {
|
|
267
|
+
method: "DELETE",
|
|
268
|
+
signal: options?.signal
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
};
|
|
272
|
+
//#endregion
|
|
273
|
+
export { RunsClient };
|
|
274
|
+
|
|
275
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../../src/client/runs/index.ts"],"sourcesContent":["import {\n CancelAction,\n DefaultValues,\n Run,\n RunSelectField,\n RunStatus,\n ThreadState,\n} from \"../../schema.js\";\nimport type {\n RunsCreatePayload,\n RunsStreamPayload,\n RunsWaitPayload,\n StreamEvent,\n} from \"../../types.js\";\nimport type { StreamMode, TypedAsyncGenerator } from \"../../types.stream.js\";\n\nimport { BaseClient, getRunMetadataFromResponse } from \"../base.js\";\n\nexport class RunsClient<\n TStateType = DefaultValues,\n TUpdateType = TStateType,\n TCustomEventType = unknown,\n> extends BaseClient {\n stream<\n TStreamMode extends StreamMode | StreamMode[] = StreamMode,\n TSubgraphs extends boolean = false,\n >(\n threadId: null,\n assistantId: string,\n payload?: Omit<\n RunsStreamPayload<TStreamMode, TSubgraphs>,\n \"multitaskStrategy\" | \"onCompletion\"\n >\n ): TypedAsyncGenerator<\n TStreamMode,\n TSubgraphs,\n TStateType,\n TUpdateType,\n TCustomEventType\n >;\n\n stream<\n TStreamMode extends StreamMode | StreamMode[] = StreamMode,\n TSubgraphs extends boolean = false,\n >(\n threadId: string,\n assistantId: string,\n payload?: RunsStreamPayload<TStreamMode, TSubgraphs>\n ): TypedAsyncGenerator<\n TStreamMode,\n TSubgraphs,\n TStateType,\n TUpdateType,\n TCustomEventType\n >;\n\n /**\n * Create a run and stream the results.\n *\n * @param threadId The ID of the thread.\n * @param assistantId Assistant ID to use for this run.\n * @param payload Payload for creating a run.\n */\n async *stream<\n TStreamMode extends StreamMode | StreamMode[] = StreamMode,\n TSubgraphs extends boolean = false,\n >(\n threadId: string | null,\n assistantId: string,\n payload?: RunsStreamPayload<TStreamMode, TSubgraphs>\n ): TypedAsyncGenerator<\n TStreamMode,\n TSubgraphs,\n TStateType,\n TUpdateType,\n TCustomEventType\n > {\n const json: Record<string, unknown> = {\n input: payload?.input,\n command: payload?.command,\n config: payload?.config,\n context: payload?.context,\n metadata: payload?.metadata,\n stream_mode: payload?.streamMode,\n stream_subgraphs: payload?.streamSubgraphs,\n stream_resumable: payload?.streamResumable,\n feedback_keys: payload?.feedbackKeys,\n assistant_id: assistantId,\n interrupt_before: payload?.interruptBefore,\n interrupt_after: payload?.interruptAfter,\n checkpoint: payload?.checkpoint,\n webhook: payload?.webhook,\n multitask_strategy: payload?.multitaskStrategy,\n on_completion: payload?.onCompletion,\n on_disconnect: payload?.onDisconnect,\n after_seconds: payload?.afterSeconds,\n if_not_exists: payload?.ifNotExists,\n checkpoint_during: payload?.checkpointDuring,\n durability: payload?.durability,\n };\n\n yield* this.streamWithRetry({\n endpoint:\n threadId == null ? `/runs/stream` : `/threads/${threadId}/runs/stream`,\n method: \"POST\",\n json,\n signal: payload?.signal,\n onInitialResponse: (response) => {\n const runMetadata = getRunMetadataFromResponse(response);\n if (runMetadata) payload?.onRunCreated?.(runMetadata);\n },\n }) as TypedAsyncGenerator<\n TStreamMode,\n TSubgraphs,\n TStateType,\n TUpdateType,\n TCustomEventType\n >;\n }\n\n /**\n * Create a run.\n *\n * @param threadId The ID of the thread.\n * @param assistantId Assistant ID to use for this run.\n * @param payload Payload for creating a run.\n * @returns The created run.\n */\n async create(\n threadId: string | null,\n assistantId: string,\n payload?: RunsCreatePayload\n ): Promise<Run> {\n const json: Record<string, unknown> = {\n input: payload?.input,\n command: payload?.command,\n config: payload?.config,\n context: payload?.context,\n metadata: payload?.metadata,\n stream_mode: payload?.streamMode,\n stream_subgraphs: payload?.streamSubgraphs,\n stream_resumable: payload?.streamResumable,\n feedback_keys: payload?.feedbackKeys,\n assistant_id: assistantId,\n interrupt_before: payload?.interruptBefore,\n interrupt_after: payload?.interruptAfter,\n webhook: payload?.webhook,\n checkpoint: payload?.checkpoint,\n checkpoint_id: payload?.checkpointId,\n multitask_strategy: payload?.multitaskStrategy,\n after_seconds: payload?.afterSeconds,\n if_not_exists: payload?.ifNotExists,\n checkpoint_during: payload?.checkpointDuring,\n durability: payload?.durability,\n on_completion: payload?.onCompletion,\n langsmith_tracer: payload?._langsmithTracer\n ? {\n project_name: payload?._langsmithTracer?.projectName,\n example_id: payload?._langsmithTracer?.exampleId,\n }\n : undefined,\n };\n\n const endpoint = threadId === null ? \"/runs\" : `/threads/${threadId}/runs`;\n const [run, response] = await this.fetch<Run>(endpoint, {\n method: \"POST\",\n json,\n signal: payload?.signal,\n withResponse: true,\n });\n\n const runMetadata = getRunMetadataFromResponse(response);\n if (runMetadata) payload?.onRunCreated?.(runMetadata);\n\n return run;\n }\n\n /**\n * Create a batch of stateless background runs.\n *\n * @param payloads An array of payloads for creating runs.\n * @returns An array of created runs.\n */\n async createBatch(\n payloads: (Omit<RunsCreatePayload, \"signal\"> & { assistantId: string })[],\n options?: { signal?: AbortSignal }\n ): Promise<Run[]> {\n const filteredPayloads = payloads\n .map((payload) => ({ ...payload, assistant_id: payload.assistantId }))\n .map((payload) => {\n return Object.fromEntries(\n Object.entries(payload).filter(([_, v]) => v !== undefined)\n );\n });\n\n return this.fetch<Run[]>(\"/runs/batch\", {\n method: \"POST\",\n json: filteredPayloads,\n signal: options?.signal,\n });\n }\n\n async wait(\n threadId: null,\n assistantId: string,\n payload?: Omit<RunsWaitPayload, \"multitaskStrategy\" | \"onCompletion\">\n ): Promise<ThreadState[\"values\"]>;\n\n async wait(\n threadId: string,\n assistantId: string,\n payload?: RunsWaitPayload\n ): Promise<ThreadState[\"values\"]>;\n\n /**\n * Create a run and wait for it to complete.\n *\n * @param threadId The ID of the thread.\n * @param assistantId Assistant ID to use for this run.\n * @param payload Payload for creating a run.\n * @returns The last values chunk of the thread.\n */\n async wait(\n threadId: string | null,\n assistantId: string,\n payload?: RunsWaitPayload\n ): Promise<ThreadState[\"values\"]> {\n const json: Record<string, unknown> = {\n input: payload?.input,\n command: payload?.command,\n config: payload?.config,\n context: payload?.context,\n metadata: payload?.metadata,\n assistant_id: assistantId,\n interrupt_before: payload?.interruptBefore,\n interrupt_after: payload?.interruptAfter,\n checkpoint: payload?.checkpoint,\n checkpoint_id: payload?.checkpointId,\n webhook: payload?.webhook,\n multitask_strategy: payload?.multitaskStrategy,\n on_completion: payload?.onCompletion,\n on_disconnect: payload?.onDisconnect,\n after_seconds: payload?.afterSeconds,\n if_not_exists: payload?.ifNotExists,\n checkpoint_during: payload?.checkpointDuring,\n durability: payload?.durability,\n langsmith_tracer: payload?._langsmithTracer\n ? {\n project_name: payload?._langsmithTracer?.projectName,\n example_id: payload?._langsmithTracer?.exampleId,\n }\n : undefined,\n };\n const endpoint =\n threadId == null ? `/runs/wait` : `/threads/${threadId}/runs/wait`;\n const [run, response] = await this.fetch<ThreadState[\"values\"]>(endpoint, {\n method: \"POST\",\n json,\n timeoutMs: null,\n signal: payload?.signal,\n withResponse: true,\n });\n\n const runMetadata = getRunMetadataFromResponse(response);\n if (runMetadata) payload?.onRunCreated?.(runMetadata);\n\n const raiseError =\n payload?.raiseError !== undefined ? payload.raiseError : true;\n if (\n raiseError &&\n \"__error__\" in run &&\n typeof run.__error__ === \"object\" &&\n run.__error__ &&\n \"error\" in run.__error__ &&\n \"message\" in run.__error__\n ) {\n throw new Error(`${run.__error__?.error}: ${run.__error__?.message}`);\n }\n return run;\n }\n\n /**\n * List all runs for a thread.\n *\n * @param threadId The ID of the thread.\n * @param options Filtering and pagination options.\n * @returns List of runs.\n */\n async list(\n threadId: string,\n options?: {\n limit?: number;\n offset?: number;\n status?: RunStatus;\n select?: RunSelectField[];\n signal?: AbortSignal;\n }\n ): Promise<Run[]> {\n return this.fetch<Run[]>(`/threads/${threadId}/runs`, {\n params: {\n limit: options?.limit ?? 10,\n offset: options?.offset ?? 0,\n status: options?.status ?? undefined,\n select: options?.select ?? undefined,\n },\n signal: options?.signal,\n });\n }\n\n /**\n * Get a run by ID.\n *\n * @param threadId The ID of the thread.\n * @param runId The ID of the run.\n * @returns The run.\n */\n async get(\n threadId: string,\n runId: string,\n options?: { signal?: AbortSignal }\n ): Promise<Run> {\n return this.fetch<Run>(`/threads/${threadId}/runs/${runId}`, {\n signal: options?.signal,\n });\n }\n\n /**\n * Cancel a run.\n *\n * @param threadId The ID of the thread.\n * @param runId The ID of the run.\n * @param wait Whether to block when canceling\n * @param action Action to take when cancelling the run. Possible values are `interrupt` or `rollback`. Default is `interrupt`.\n * @returns\n */\n async cancel(\n threadId: string,\n runId: string,\n wait: boolean = false,\n action: CancelAction = \"interrupt\",\n options: { signal?: AbortSignal } = {}\n ): Promise<void> {\n return this.fetch<void>(`/threads/${threadId}/runs/${runId}/cancel`, {\n method: \"POST\",\n params: { wait: wait ? \"1\" : \"0\", action },\n signal: options?.signal,\n });\n }\n\n /**\n * Cancel one or more runs.\n *\n * @param options Options for cancelling runs.\n * @returns\n */\n async cancelMany(options: {\n threadId?: string;\n runIds?: string[];\n status?: \"pending\" | \"running\" | \"all\";\n action?: CancelAction;\n signal?: AbortSignal;\n }): Promise<void> {\n return this.fetch<void>(`/runs/cancel`, {\n method: \"POST\",\n json: {\n thread_id: options.threadId,\n run_ids: options.runIds,\n status: options.status,\n },\n params: { action: options.action },\n signal: options.signal,\n });\n }\n\n /**\n * Block until a run is done.\n *\n * @param threadId The ID of the thread.\n * @param runId The ID of the run.\n * @returns\n */\n async join(\n threadId: string,\n runId: string,\n options?: { cancelOnDisconnect?: boolean; signal?: AbortSignal }\n ): Promise<TStateType> {\n return this.fetch<TStateType>(`/threads/${threadId}/runs/${runId}/join`, {\n timeoutMs: null,\n params: { cancel_on_disconnect: options?.cancelOnDisconnect ? \"1\" : \"0\" },\n signal: options?.signal,\n });\n }\n\n /**\n * Stream output from a run in real-time, until the run is done.\n *\n * @param threadId The ID of the thread.\n * @param runId The ID of the run.\n * @param options Additional options for controlling the stream behavior.\n * @returns An async generator yielding stream parts.\n */\n async *joinStream(\n threadId: string | undefined | null,\n runId: string,\n options?:\n | {\n signal?: AbortSignal;\n cancelOnDisconnect?: boolean;\n lastEventId?: string;\n streamMode?: StreamMode | StreamMode[];\n }\n | AbortSignal\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): AsyncGenerator<{ id?: string; event: StreamEvent; data: any }> {\n const opts =\n typeof options === \"object\" &&\n options != null &&\n // eslint-disable-next-line no-instanceof/no-instanceof\n options instanceof AbortSignal\n ? { signal: options }\n : options;\n\n yield* this.streamWithRetry({\n endpoint:\n threadId != null\n ? `/threads/${threadId}/runs/${runId}/stream`\n : `/runs/${runId}/stream`,\n method: \"GET\",\n signal: opts?.signal,\n headers: opts?.lastEventId\n ? { \"Last-Event-ID\": opts.lastEventId }\n : undefined,\n params: {\n cancel_on_disconnect: opts?.cancelOnDisconnect ? \"1\" : \"0\",\n stream_mode: opts?.streamMode,\n },\n });\n }\n\n /**\n * Delete a run.\n *\n * @param threadId The ID of the thread.\n * @param runId The ID of the run.\n * @returns\n */\n async delete(\n threadId: string,\n runId: string,\n options?: { signal?: AbortSignal }\n ): Promise<void> {\n return this.fetch<void>(`/threads/${threadId}/runs/${runId}`, {\n method: \"DELETE\",\n signal: options?.signal,\n });\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
const require_base = require("../base.cjs");
|
|
2
|
+
//#region src/client/store/index.ts
|
|
3
|
+
var StoreClient = class extends require_base.BaseClient {
|
|
4
|
+
/**
|
|
5
|
+
* Store or update an item.
|
|
6
|
+
*
|
|
7
|
+
* @param namespace A list of strings representing the namespace path.
|
|
8
|
+
* @param key The unique identifier for the item within the namespace.
|
|
9
|
+
* @param value A dictionary containing the item's data.
|
|
10
|
+
* @param options.index Controls search indexing - null (use defaults), false (disable), or list of field paths to index.
|
|
11
|
+
* @param options.ttl Optional time-to-live in minutes for the item, or null for no expiration.
|
|
12
|
+
* @returns Promise<void>
|
|
13
|
+
*/
|
|
14
|
+
async putItem(namespace, key, value, options) {
|
|
15
|
+
namespace.forEach((label) => {
|
|
16
|
+
if (label.includes(".")) throw new Error(`Invalid namespace label '${label}'. Namespace labels cannot contain periods ('.')`);
|
|
17
|
+
});
|
|
18
|
+
const payload = {
|
|
19
|
+
namespace,
|
|
20
|
+
key,
|
|
21
|
+
value,
|
|
22
|
+
index: options?.index,
|
|
23
|
+
ttl: options?.ttl
|
|
24
|
+
};
|
|
25
|
+
return this.fetch("/store/items", {
|
|
26
|
+
method: "PUT",
|
|
27
|
+
json: payload,
|
|
28
|
+
signal: options?.signal
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Retrieve a single item.
|
|
33
|
+
*
|
|
34
|
+
* @param namespace A list of strings representing the namespace path.
|
|
35
|
+
* @param key The unique identifier for the item.
|
|
36
|
+
* @param options.refreshTtl Whether to refresh the TTL on this read operation.
|
|
37
|
+
* @returns Promise<Item>
|
|
38
|
+
*/
|
|
39
|
+
async getItem(namespace, key, options) {
|
|
40
|
+
namespace.forEach((label) => {
|
|
41
|
+
if (label.includes(".")) throw new Error(`Invalid namespace label '${label}'. Namespace labels cannot contain periods ('.')`);
|
|
42
|
+
});
|
|
43
|
+
const params = {
|
|
44
|
+
namespace: namespace.join("."),
|
|
45
|
+
key
|
|
46
|
+
};
|
|
47
|
+
if (options?.refreshTtl !== void 0) params.refresh_ttl = options.refreshTtl;
|
|
48
|
+
const response = await this.fetch("/store/items", {
|
|
49
|
+
params,
|
|
50
|
+
signal: options?.signal
|
|
51
|
+
});
|
|
52
|
+
return response ? {
|
|
53
|
+
...response,
|
|
54
|
+
createdAt: response.created_at,
|
|
55
|
+
updatedAt: response.updated_at
|
|
56
|
+
} : null;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Delete an item.
|
|
60
|
+
*
|
|
61
|
+
* @param namespace A list of strings representing the namespace path.
|
|
62
|
+
* @param key The unique identifier for the item.
|
|
63
|
+
* @returns Promise<void>
|
|
64
|
+
*/
|
|
65
|
+
async deleteItem(namespace, key, options) {
|
|
66
|
+
namespace.forEach((label) => {
|
|
67
|
+
if (label.includes(".")) throw new Error(`Invalid namespace label '${label}'. Namespace labels cannot contain periods ('.')`);
|
|
68
|
+
});
|
|
69
|
+
return this.fetch("/store/items", {
|
|
70
|
+
method: "DELETE",
|
|
71
|
+
json: {
|
|
72
|
+
namespace,
|
|
73
|
+
key
|
|
74
|
+
},
|
|
75
|
+
signal: options?.signal
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Search for items within a namespace prefix.
|
|
80
|
+
*
|
|
81
|
+
* @param namespacePrefix List of strings representing the namespace prefix.
|
|
82
|
+
* @param options Search options including filter, pagination, and query.
|
|
83
|
+
* @returns Promise<SearchItemsResponse>
|
|
84
|
+
*/
|
|
85
|
+
async searchItems(namespacePrefix, options) {
|
|
86
|
+
const payload = {
|
|
87
|
+
namespace_prefix: namespacePrefix,
|
|
88
|
+
filter: options?.filter,
|
|
89
|
+
limit: options?.limit ?? 10,
|
|
90
|
+
offset: options?.offset ?? 0,
|
|
91
|
+
query: options?.query,
|
|
92
|
+
refresh_ttl: options?.refreshTtl
|
|
93
|
+
};
|
|
94
|
+
return { items: (await this.fetch("/store/items/search", {
|
|
95
|
+
method: "POST",
|
|
96
|
+
json: payload,
|
|
97
|
+
signal: options?.signal
|
|
98
|
+
})).items.map((item) => ({
|
|
99
|
+
...item,
|
|
100
|
+
createdAt: item.created_at,
|
|
101
|
+
updatedAt: item.updated_at
|
|
102
|
+
})) };
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* List namespaces with optional match conditions.
|
|
106
|
+
*
|
|
107
|
+
* @param options Filtering and pagination options for namespaces.
|
|
108
|
+
* @returns Promise<ListNamespaceResponse>
|
|
109
|
+
*/
|
|
110
|
+
async listNamespaces(options) {
|
|
111
|
+
const payload = {
|
|
112
|
+
prefix: options?.prefix,
|
|
113
|
+
suffix: options?.suffix,
|
|
114
|
+
max_depth: options?.maxDepth,
|
|
115
|
+
limit: options?.limit ?? 100,
|
|
116
|
+
offset: options?.offset ?? 0
|
|
117
|
+
};
|
|
118
|
+
return this.fetch("/store/namespaces", {
|
|
119
|
+
method: "POST",
|
|
120
|
+
json: payload,
|
|
121
|
+
signal: options?.signal
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
//#endregion
|
|
126
|
+
exports.StoreClient = StoreClient;
|
|
127
|
+
|
|
128
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs","names":["BaseClient"],"sources":["../../../src/client/store/index.ts"],"sourcesContent":["import {\n Item,\n ListNamespaceResponse,\n SearchItemsResponse,\n} from \"../../schema.js\";\nimport { BaseClient } from \"../base.js\";\n\ninterface APIItem {\n namespace: string[];\n key: string;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n value: Record<string, any>;\n created_at: string;\n updated_at: string;\n}\ninterface APISearchItemsResponse {\n items: APIItem[];\n}\n\nexport class StoreClient extends BaseClient {\n /**\n * Store or update an item.\n *\n * @param namespace A list of strings representing the namespace path.\n * @param key The unique identifier for the item within the namespace.\n * @param value A dictionary containing the item's data.\n * @param options.index Controls search indexing - null (use defaults), false (disable), or list of field paths to index.\n * @param options.ttl Optional time-to-live in minutes for the item, or null for no expiration.\n * @returns Promise<void>\n */\n async putItem(\n namespace: string[],\n key: string,\n value: Record<string, unknown>,\n options?: {\n index?: false | string[] | null;\n ttl?: number | null;\n signal?: AbortSignal;\n }\n ): Promise<void> {\n namespace.forEach((label) => {\n if (label.includes(\".\")) {\n throw new Error(\n `Invalid namespace label '${label}'. Namespace labels cannot contain periods ('.')`\n );\n }\n });\n\n const payload = {\n namespace,\n key,\n value,\n index: options?.index,\n ttl: options?.ttl,\n };\n\n return this.fetch<void>(\"/store/items\", {\n method: \"PUT\",\n json: payload,\n signal: options?.signal,\n });\n }\n\n /**\n * Retrieve a single item.\n *\n * @param namespace A list of strings representing the namespace path.\n * @param key The unique identifier for the item.\n * @param options.refreshTtl Whether to refresh the TTL on this read operation.\n * @returns Promise<Item>\n */\n async getItem(\n namespace: string[],\n key: string,\n options?: {\n refreshTtl?: boolean | null;\n signal?: AbortSignal;\n }\n ): Promise<Item | null> {\n namespace.forEach((label) => {\n if (label.includes(\".\")) {\n throw new Error(\n `Invalid namespace label '${label}'. Namespace labels cannot contain periods ('.')`\n );\n }\n });\n\n const params: Record<string, unknown> = {\n namespace: namespace.join(\".\"),\n key,\n };\n\n if (options?.refreshTtl !== undefined) {\n params.refresh_ttl = options.refreshTtl;\n }\n\n const response = await this.fetch<APIItem>(\"/store/items\", {\n params,\n signal: options?.signal,\n });\n\n return response\n ? {\n ...response,\n createdAt: response.created_at,\n updatedAt: response.updated_at,\n }\n : null;\n }\n\n /**\n * Delete an item.\n *\n * @param namespace A list of strings representing the namespace path.\n * @param key The unique identifier for the item.\n * @returns Promise<void>\n */\n async deleteItem(\n namespace: string[],\n key: string,\n options?: { signal?: AbortSignal }\n ): Promise<void> {\n namespace.forEach((label) => {\n if (label.includes(\".\")) {\n throw new Error(\n `Invalid namespace label '${label}'. Namespace labels cannot contain periods ('.')`\n );\n }\n });\n\n return this.fetch<void>(\"/store/items\", {\n method: \"DELETE\",\n json: { namespace, key },\n signal: options?.signal,\n });\n }\n\n /**\n * Search for items within a namespace prefix.\n *\n * @param namespacePrefix List of strings representing the namespace prefix.\n * @param options Search options including filter, pagination, and query.\n * @returns Promise<SearchItemsResponse>\n */\n async searchItems(\n namespacePrefix: string[],\n options?: {\n filter?: Record<string, unknown>;\n limit?: number;\n offset?: number;\n query?: string;\n refreshTtl?: boolean | null;\n signal?: AbortSignal;\n }\n ): Promise<SearchItemsResponse> {\n const payload = {\n namespace_prefix: namespacePrefix,\n filter: options?.filter,\n limit: options?.limit ?? 10,\n offset: options?.offset ?? 0,\n query: options?.query,\n refresh_ttl: options?.refreshTtl,\n };\n\n const response = await this.fetch<APISearchItemsResponse>(\n \"/store/items/search\",\n {\n method: \"POST\",\n json: payload,\n signal: options?.signal,\n }\n );\n return {\n items: response.items.map((item) => ({\n ...item,\n createdAt: item.created_at,\n updatedAt: item.updated_at,\n })),\n };\n }\n\n /**\n * List namespaces with optional match conditions.\n *\n * @param options Filtering and pagination options for namespaces.\n * @returns Promise<ListNamespaceResponse>\n */\n async listNamespaces(options?: {\n prefix?: string[];\n suffix?: string[];\n maxDepth?: number;\n limit?: number;\n offset?: number;\n signal?: AbortSignal;\n }): Promise<ListNamespaceResponse> {\n const payload = {\n prefix: options?.prefix,\n suffix: options?.suffix,\n max_depth: options?.maxDepth,\n limit: options?.limit ?? 100,\n offset: options?.offset ?? 0,\n };\n\n return this.fetch<ListNamespaceResponse>(\"/store/namespaces\", {\n method: \"POST\",\n json: payload,\n signal: options?.signal,\n });\n }\n}\n"],"mappings":";;AAmBA,IAAa,cAAb,cAAiCA,aAAAA,WAAW;;;;;;;;;;;CAW1C,MAAM,QACJ,WACA,KACA,OACA,SAKe;AACf,YAAU,SAAS,UAAU;AAC3B,OAAI,MAAM,SAAS,IAAI,CACrB,OAAM,IAAI,MACR,4BAA4B,MAAM,kDACnC;IAEH;EAEF,MAAM,UAAU;GACd;GACA;GACA;GACA,OAAO,SAAS;GAChB,KAAK,SAAS;GACf;AAED,SAAO,KAAK,MAAY,gBAAgB;GACtC,QAAQ;GACR,MAAM;GACN,QAAQ,SAAS;GAClB,CAAC;;;;;;;;;;CAWJ,MAAM,QACJ,WACA,KACA,SAIsB;AACtB,YAAU,SAAS,UAAU;AAC3B,OAAI,MAAM,SAAS,IAAI,CACrB,OAAM,IAAI,MACR,4BAA4B,MAAM,kDACnC;IAEH;EAEF,MAAM,SAAkC;GACtC,WAAW,UAAU,KAAK,IAAI;GAC9B;GACD;AAED,MAAI,SAAS,eAAe,KAAA,EAC1B,QAAO,cAAc,QAAQ;EAG/B,MAAM,WAAW,MAAM,KAAK,MAAe,gBAAgB;GACzD;GACA,QAAQ,SAAS;GAClB,CAAC;AAEF,SAAO,WACH;GACE,GAAG;GACH,WAAW,SAAS;GACpB,WAAW,SAAS;GACrB,GACD;;;;;;;;;CAUN,MAAM,WACJ,WACA,KACA,SACe;AACf,YAAU,SAAS,UAAU;AAC3B,OAAI,MAAM,SAAS,IAAI,CACrB,OAAM,IAAI,MACR,4BAA4B,MAAM,kDACnC;IAEH;AAEF,SAAO,KAAK,MAAY,gBAAgB;GACtC,QAAQ;GACR,MAAM;IAAE;IAAW;IAAK;GACxB,QAAQ,SAAS;GAClB,CAAC;;;;;;;;;CAUJ,MAAM,YACJ,iBACA,SAQ8B;EAC9B,MAAM,UAAU;GACd,kBAAkB;GAClB,QAAQ,SAAS;GACjB,OAAO,SAAS,SAAS;GACzB,QAAQ,SAAS,UAAU;GAC3B,OAAO,SAAS;GAChB,aAAa,SAAS;GACvB;AAUD,SAAO,EACL,QATe,MAAM,KAAK,MAC1B,uBACA;GACE,QAAQ;GACR,MAAM;GACN,QAAQ,SAAS;GAClB,CACF,EAEiB,MAAM,KAAK,UAAU;GACnC,GAAG;GACH,WAAW,KAAK;GAChB,WAAW,KAAK;GACjB,EAAE,EACJ;;;;;;;;CASH,MAAM,eAAe,SAOc;EACjC,MAAM,UAAU;GACd,QAAQ,SAAS;GACjB,QAAQ,SAAS;GACjB,WAAW,SAAS;GACpB,OAAO,SAAS,SAAS;GACzB,QAAQ,SAAS,UAAU;GAC5B;AAED,SAAO,KAAK,MAA6B,qBAAqB;GAC5D,QAAQ;GACR,MAAM;GACN,QAAQ,SAAS;GAClB,CAAC"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Item, ListNamespaceResponse, SearchItemsResponse } from "../../schema.cjs";
|
|
2
|
+
import { BaseClient } from "../base.cjs";
|
|
3
|
+
|
|
4
|
+
//#region src/client/store/index.d.ts
|
|
5
|
+
declare class StoreClient extends BaseClient {
|
|
6
|
+
/**
|
|
7
|
+
* Store or update an item.
|
|
8
|
+
*
|
|
9
|
+
* @param namespace A list of strings representing the namespace path.
|
|
10
|
+
* @param key The unique identifier for the item within the namespace.
|
|
11
|
+
* @param value A dictionary containing the item's data.
|
|
12
|
+
* @param options.index Controls search indexing - null (use defaults), false (disable), or list of field paths to index.
|
|
13
|
+
* @param options.ttl Optional time-to-live in minutes for the item, or null for no expiration.
|
|
14
|
+
* @returns Promise<void>
|
|
15
|
+
*/
|
|
16
|
+
putItem(namespace: string[], key: string, value: Record<string, unknown>, options?: {
|
|
17
|
+
index?: false | string[] | null;
|
|
18
|
+
ttl?: number | null;
|
|
19
|
+
signal?: AbortSignal;
|
|
20
|
+
}): Promise<void>;
|
|
21
|
+
/**
|
|
22
|
+
* Retrieve a single item.
|
|
23
|
+
*
|
|
24
|
+
* @param namespace A list of strings representing the namespace path.
|
|
25
|
+
* @param key The unique identifier for the item.
|
|
26
|
+
* @param options.refreshTtl Whether to refresh the TTL on this read operation.
|
|
27
|
+
* @returns Promise<Item>
|
|
28
|
+
*/
|
|
29
|
+
getItem(namespace: string[], key: string, options?: {
|
|
30
|
+
refreshTtl?: boolean | null;
|
|
31
|
+
signal?: AbortSignal;
|
|
32
|
+
}): Promise<Item | null>;
|
|
33
|
+
/**
|
|
34
|
+
* Delete an item.
|
|
35
|
+
*
|
|
36
|
+
* @param namespace A list of strings representing the namespace path.
|
|
37
|
+
* @param key The unique identifier for the item.
|
|
38
|
+
* @returns Promise<void>
|
|
39
|
+
*/
|
|
40
|
+
deleteItem(namespace: string[], key: string, options?: {
|
|
41
|
+
signal?: AbortSignal;
|
|
42
|
+
}): Promise<void>;
|
|
43
|
+
/**
|
|
44
|
+
* Search for items within a namespace prefix.
|
|
45
|
+
*
|
|
46
|
+
* @param namespacePrefix List of strings representing the namespace prefix.
|
|
47
|
+
* @param options Search options including filter, pagination, and query.
|
|
48
|
+
* @returns Promise<SearchItemsResponse>
|
|
49
|
+
*/
|
|
50
|
+
searchItems(namespacePrefix: string[], options?: {
|
|
51
|
+
filter?: Record<string, unknown>;
|
|
52
|
+
limit?: number;
|
|
53
|
+
offset?: number;
|
|
54
|
+
query?: string;
|
|
55
|
+
refreshTtl?: boolean | null;
|
|
56
|
+
signal?: AbortSignal;
|
|
57
|
+
}): Promise<SearchItemsResponse>;
|
|
58
|
+
/**
|
|
59
|
+
* List namespaces with optional match conditions.
|
|
60
|
+
*
|
|
61
|
+
* @param options Filtering and pagination options for namespaces.
|
|
62
|
+
* @returns Promise<ListNamespaceResponse>
|
|
63
|
+
*/
|
|
64
|
+
listNamespaces(options?: {
|
|
65
|
+
prefix?: string[];
|
|
66
|
+
suffix?: string[];
|
|
67
|
+
maxDepth?: number;
|
|
68
|
+
limit?: number;
|
|
69
|
+
offset?: number;
|
|
70
|
+
signal?: AbortSignal;
|
|
71
|
+
}): Promise<ListNamespaceResponse>;
|
|
72
|
+
}
|
|
73
|
+
//#endregion
|
|
74
|
+
export { StoreClient };
|
|
75
|
+
//# sourceMappingURL=index.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.cts","names":[],"sources":["../../../src/client/store/index.ts"],"mappings":";;;;cAmBa,WAAA,SAAoB,UAAA;;AAAjC;;;;;;;;;EAWQ,OAAA,CACJ,SAAA,YACA,GAAA,UACA,KAAA,EAAO,MAAA,mBACP,OAAA;IACE,KAAA;IACA,GAAA;IACA,MAAA,GAAS,WAAA;EAAA,IAEV,OAAA;EAmHA;;;;;;;;EAnFG,OAAA,CACJ,SAAA,YACA,GAAA,UACA,OAAA;IACE,UAAA;IACA,MAAA,GAAS,WAAA;EAAA,IAEV,OAAA,CAAQ,IAAA;EA7CT;;;;;;;EAoFI,UAAA,CACJ,SAAA,YACA,GAAA,UACA,OAAA;IAAY,MAAA,GAAS,WAAA;EAAA,IACpB,OAAA;EA9CC;;;;;;;EAqEE,WAAA,CACJ,eAAA,YACA,OAAA;IACE,MAAA,GAAS,MAAA;IACT,KAAA;IACA,MAAA;IACA,KAAA;IACA,UAAA;IACA,MAAA,GAAS,WAAA;EAAA,IAEV,OAAA,CAAQ,mBAAA;EAPP;;;;;;EAwCE,cAAA,CAAe,OAAA;IACnB,MAAA;IACA,MAAA;IACA,QAAA;IACA,KAAA;IACA,MAAA;IACA,MAAA,GAAS,WAAA;EAAA,IACP,OAAA,CAAQ,qBAAA;AAAA"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Item, ListNamespaceResponse, SearchItemsResponse } from "../../schema.js";
|
|
2
|
+
import { BaseClient } from "../base.js";
|
|
3
|
+
|
|
4
|
+
//#region src/client/store/index.d.ts
|
|
5
|
+
declare class StoreClient extends BaseClient {
|
|
6
|
+
/**
|
|
7
|
+
* Store or update an item.
|
|
8
|
+
*
|
|
9
|
+
* @param namespace A list of strings representing the namespace path.
|
|
10
|
+
* @param key The unique identifier for the item within the namespace.
|
|
11
|
+
* @param value A dictionary containing the item's data.
|
|
12
|
+
* @param options.index Controls search indexing - null (use defaults), false (disable), or list of field paths to index.
|
|
13
|
+
* @param options.ttl Optional time-to-live in minutes for the item, or null for no expiration.
|
|
14
|
+
* @returns Promise<void>
|
|
15
|
+
*/
|
|
16
|
+
putItem(namespace: string[], key: string, value: Record<string, unknown>, options?: {
|
|
17
|
+
index?: false | string[] | null;
|
|
18
|
+
ttl?: number | null;
|
|
19
|
+
signal?: AbortSignal;
|
|
20
|
+
}): Promise<void>;
|
|
21
|
+
/**
|
|
22
|
+
* Retrieve a single item.
|
|
23
|
+
*
|
|
24
|
+
* @param namespace A list of strings representing the namespace path.
|
|
25
|
+
* @param key The unique identifier for the item.
|
|
26
|
+
* @param options.refreshTtl Whether to refresh the TTL on this read operation.
|
|
27
|
+
* @returns Promise<Item>
|
|
28
|
+
*/
|
|
29
|
+
getItem(namespace: string[], key: string, options?: {
|
|
30
|
+
refreshTtl?: boolean | null;
|
|
31
|
+
signal?: AbortSignal;
|
|
32
|
+
}): Promise<Item | null>;
|
|
33
|
+
/**
|
|
34
|
+
* Delete an item.
|
|
35
|
+
*
|
|
36
|
+
* @param namespace A list of strings representing the namespace path.
|
|
37
|
+
* @param key The unique identifier for the item.
|
|
38
|
+
* @returns Promise<void>
|
|
39
|
+
*/
|
|
40
|
+
deleteItem(namespace: string[], key: string, options?: {
|
|
41
|
+
signal?: AbortSignal;
|
|
42
|
+
}): Promise<void>;
|
|
43
|
+
/**
|
|
44
|
+
* Search for items within a namespace prefix.
|
|
45
|
+
*
|
|
46
|
+
* @param namespacePrefix List of strings representing the namespace prefix.
|
|
47
|
+
* @param options Search options including filter, pagination, and query.
|
|
48
|
+
* @returns Promise<SearchItemsResponse>
|
|
49
|
+
*/
|
|
50
|
+
searchItems(namespacePrefix: string[], options?: {
|
|
51
|
+
filter?: Record<string, unknown>;
|
|
52
|
+
limit?: number;
|
|
53
|
+
offset?: number;
|
|
54
|
+
query?: string;
|
|
55
|
+
refreshTtl?: boolean | null;
|
|
56
|
+
signal?: AbortSignal;
|
|
57
|
+
}): Promise<SearchItemsResponse>;
|
|
58
|
+
/**
|
|
59
|
+
* List namespaces with optional match conditions.
|
|
60
|
+
*
|
|
61
|
+
* @param options Filtering and pagination options for namespaces.
|
|
62
|
+
* @returns Promise<ListNamespaceResponse>
|
|
63
|
+
*/
|
|
64
|
+
listNamespaces(options?: {
|
|
65
|
+
prefix?: string[];
|
|
66
|
+
suffix?: string[];
|
|
67
|
+
maxDepth?: number;
|
|
68
|
+
limit?: number;
|
|
69
|
+
offset?: number;
|
|
70
|
+
signal?: AbortSignal;
|
|
71
|
+
}): Promise<ListNamespaceResponse>;
|
|
72
|
+
}
|
|
73
|
+
//#endregion
|
|
74
|
+
export { StoreClient };
|
|
75
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","names":[],"sources":["../../../src/client/store/index.ts"],"mappings":";;;;cAmBa,WAAA,SAAoB,UAAA;;AAAjC;;;;;;;;;EAWQ,OAAA,CACJ,SAAA,YACA,GAAA,UACA,KAAA,EAAO,MAAA,mBACP,OAAA;IACE,KAAA;IACA,GAAA;IACA,MAAA,GAAS,WAAA;EAAA,IAEV,OAAA;EAmHA;;;;;;;;EAnFG,OAAA,CACJ,SAAA,YACA,GAAA,UACA,OAAA;IACE,UAAA;IACA,MAAA,GAAS,WAAA;EAAA,IAEV,OAAA,CAAQ,IAAA;EA7CT;;;;;;;EAoFI,UAAA,CACJ,SAAA,YACA,GAAA,UACA,OAAA;IAAY,MAAA,GAAS,WAAA;EAAA,IACpB,OAAA;EA9CC;;;;;;;EAqEE,WAAA,CACJ,eAAA,YACA,OAAA;IACE,MAAA,GAAS,MAAA;IACT,KAAA;IACA,MAAA;IACA,KAAA;IACA,UAAA;IACA,MAAA,GAAS,WAAA;EAAA,IAEV,OAAA,CAAQ,mBAAA;EAPP;;;;;;EAwCE,cAAA,CAAe,OAAA;IACnB,MAAA;IACA,MAAA;IACA,QAAA;IACA,KAAA;IACA,MAAA;IACA,MAAA,GAAS,WAAA;EAAA,IACP,OAAA,CAAQ,qBAAA;AAAA"}
|