kernl 0.2.1 → 0.6.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/.turbo/turbo-build.log +5 -4
- package/.turbo/turbo-check-types.log +4 -0
- package/CHANGELOG.md +147 -0
- package/LICENSE +1 -1
- package/dist/agent/__tests__/concurrency.test.d.ts +2 -0
- package/dist/agent/__tests__/concurrency.test.d.ts.map +1 -0
- package/dist/agent/__tests__/concurrency.test.js +152 -0
- package/dist/agent/__tests__/run.test.d.ts +2 -0
- package/dist/agent/__tests__/run.test.d.ts.map +1 -0
- package/dist/agent/__tests__/run.test.js +357 -0
- package/dist/agent/index.d.ts +1 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent.d.ts +35 -12
- package/dist/agent.d.ts.map +1 -1
- package/dist/agent.js +102 -15
- package/dist/api/__tests__/cursor-page.test.d.ts +2 -0
- package/dist/api/__tests__/cursor-page.test.d.ts.map +1 -0
- package/dist/api/__tests__/cursor-page.test.js +414 -0
- package/dist/api/__tests__/offset-page.test.d.ts +2 -0
- package/dist/api/__tests__/offset-page.test.d.ts.map +1 -0
- package/dist/api/__tests__/offset-page.test.js +510 -0
- package/dist/api/__tests__/threads.test.d.ts +2 -0
- package/dist/api/__tests__/threads.test.d.ts.map +1 -0
- package/dist/api/__tests__/threads.test.js +338 -0
- package/dist/api/models/index.d.ts +2 -0
- package/dist/api/models/index.d.ts.map +1 -0
- package/dist/api/models/thread.d.ts +120 -0
- package/dist/api/models/thread.d.ts.map +1 -0
- package/dist/api/pagination/base.d.ts +48 -0
- package/dist/api/pagination/base.d.ts.map +1 -0
- package/dist/api/pagination/base.js +45 -0
- package/dist/api/pagination/cursor.d.ts +44 -0
- package/dist/api/pagination/cursor.d.ts.map +1 -0
- package/dist/api/pagination/cursor.js +52 -0
- package/dist/api/pagination/offset.d.ts +42 -0
- package/dist/api/pagination/offset.d.ts.map +1 -0
- package/dist/api/pagination/offset.js +55 -0
- package/dist/api/resources/threads/events.d.ts +21 -0
- package/dist/api/resources/threads/events.d.ts.map +1 -0
- package/dist/api/resources/threads/events.js +24 -0
- package/dist/api/resources/threads/index.d.ts +4 -0
- package/dist/api/resources/threads/index.d.ts.map +1 -0
- package/dist/api/resources/threads/index.js +2 -0
- package/dist/api/resources/threads/threads.d.ts +57 -0
- package/dist/api/resources/threads/threads.d.ts.map +1 -0
- package/dist/api/resources/threads/threads.js +199 -0
- package/dist/api/resources/threads/types.d.ts +123 -0
- package/dist/api/resources/threads/types.d.ts.map +1 -0
- package/dist/api/resources/threads/utils.d.ts +18 -0
- package/dist/api/resources/threads/utils.d.ts.map +1 -0
- package/dist/api/resources/threads/utils.js +78 -0
- package/dist/context.d.ts +5 -1
- package/dist/context.d.ts.map +1 -1
- package/dist/context.js +6 -1
- package/dist/guardrail.d.ts +4 -4
- package/dist/index.d.ts +12 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +10 -3
- package/dist/internal.d.ts +4 -0
- package/dist/internal.d.ts.map +1 -0
- package/dist/internal.js +2 -0
- package/dist/kernl/index.d.ts +3 -0
- package/dist/kernl/index.d.ts.map +1 -0
- package/dist/kernl/index.js +2 -0
- package/dist/kernl/kernl.d.ts +64 -0
- package/dist/kernl/kernl.d.ts.map +1 -0
- package/dist/kernl/kernl.js +116 -0
- package/dist/kernl/threads.d.ts +110 -0
- package/dist/kernl/threads.d.ts.map +1 -0
- package/dist/kernl/threads.js +126 -0
- package/dist/kernl.d.ts +27 -11
- package/dist/kernl.d.ts.map +1 -1
- package/dist/kernl.js +74 -11
- package/dist/lib/env.d.ts +3 -3
- package/dist/lib/env.js +1 -1
- package/dist/lib/error.d.ts +3 -3
- package/dist/lib/logger.js +1 -1
- package/dist/lifecycle.d.ts +5 -5
- package/dist/mcp/__tests__/base.test.js +2 -2
- package/dist/mcp/__tests__/fixtures/utils.d.ts +1 -1
- package/dist/mcp/__tests__/fixtures/utils.js +1 -1
- package/dist/mcp/__tests__/integration.test.js +16 -16
- package/dist/mcp/__tests__/stdio.test.js +2 -2
- package/dist/mcp/__tests__/utils.test.js +8 -8
- package/dist/mcp/base.d.ts +2 -2
- package/dist/mcp/http.d.ts +3 -3
- package/dist/mcp/http.d.ts.map +1 -1
- package/dist/mcp/http.js +11 -11
- package/dist/mcp/sse.d.ts +3 -3
- package/dist/mcp/sse.d.ts.map +1 -1
- package/dist/mcp/sse.js +9 -9
- package/dist/mcp/stdio.d.ts +2 -2
- package/dist/mcp/stdio.js +2 -2
- package/dist/mcp/types.d.ts +3 -3
- package/dist/mcp/utils.d.ts +4 -4
- package/dist/mcp/utils.d.ts.map +1 -1
- package/dist/mcp/utils.js +5 -6
- package/dist/storage/__tests__/in-memory.test.d.ts +2 -0
- package/dist/storage/__tests__/in-memory.test.d.ts.map +1 -0
- package/dist/storage/__tests__/in-memory.test.js +455 -0
- package/dist/storage/base.d.ts +64 -0
- package/dist/storage/base.d.ts.map +1 -0
- package/dist/storage/base.js +4 -0
- package/dist/storage/in-memory.d.ts +62 -0
- package/dist/storage/in-memory.d.ts.map +1 -0
- package/dist/storage/in-memory.js +283 -0
- package/dist/storage/index.d.ts +10 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +7 -0
- package/dist/storage/thread.d.ts +123 -0
- package/dist/storage/thread.d.ts.map +1 -0
- package/dist/storage/thread.js +4 -0
- package/dist/task.d.ts +8 -6
- package/dist/task.d.ts.map +1 -1
- package/dist/task.js +10 -8
- package/dist/thread/__tests__/fixtures/mock-model.d.ts +1 -2
- package/dist/thread/__tests__/fixtures/mock-model.d.ts.map +1 -1
- package/dist/thread/__tests__/integration.test.js +10 -10
- package/dist/thread/__tests__/mock.d.ts +1 -1
- package/dist/thread/__tests__/namespace.test.d.ts +2 -0
- package/dist/thread/__tests__/namespace.test.d.ts.map +1 -0
- package/dist/thread/__tests__/namespace.test.js +131 -0
- package/dist/thread/__tests__/thread-persistence.test.d.ts +2 -0
- package/dist/thread/__tests__/thread-persistence.test.d.ts.map +1 -0
- package/dist/thread/__tests__/thread-persistence.test.js +351 -0
- package/dist/thread/__tests__/thread.test.js +55 -57
- package/dist/thread/index.d.ts +1 -1
- package/dist/thread/index.js +1 -1
- package/dist/thread/thread.d.ts +74 -22
- package/dist/thread/thread.d.ts.map +1 -1
- package/dist/thread/thread.js +212 -74
- package/dist/thread/utils.d.ts +38 -10
- package/dist/thread/utils.d.ts.map +1 -1
- package/dist/thread/utils.js +53 -9
- package/dist/tool/__tests__/fixtures.d.ts +8 -8
- package/dist/tool/__tests__/fixtures.js +3 -3
- package/dist/tool/__tests__/tool.test.js +2 -2
- package/dist/tool/__tests__/toolkit.test.js +17 -14
- package/dist/tool/index.d.ts +3 -3
- package/dist/tool/index.js +2 -2
- package/dist/tool/tool.d.ts +2 -2
- package/dist/tool/tool.js +5 -5
- package/dist/tool/toolkit.d.ts +4 -4
- package/dist/tool/toolkit.js +1 -1
- package/dist/tool/types.d.ts +4 -4
- package/dist/trace/traces.js +2 -2
- package/dist/types/agent.d.ts +4 -4
- package/dist/types/kernl.d.ts +42 -0
- package/dist/types/kernl.d.ts.map +1 -0
- package/dist/types/thread.d.ts +110 -24
- package/dist/types/thread.d.ts.map +1 -1
- package/dist/types/thread.js +12 -0
- package/package.json +12 -8
- package/src/agent/__tests__/concurrency.test.ts +194 -0
- package/src/agent/__tests__/run.test.ts +441 -0
- package/src/agent/index.ts +0 -0
- package/src/agent.ts +139 -24
- package/src/api/__tests__/cursor-page.test.ts +512 -0
- package/src/api/__tests__/offset-page.test.ts +624 -0
- package/src/api/__tests__/threads.test.ts +415 -0
- package/src/api/models/index.ts +6 -0
- package/src/api/models/thread.ts +138 -0
- package/src/api/pagination/base.ts +79 -0
- package/src/api/pagination/cursor.ts +86 -0
- package/src/api/pagination/offset.ts +89 -0
- package/src/api/resources/threads/events.ts +26 -0
- package/src/api/resources/threads/index.ts +9 -0
- package/src/api/resources/threads/threads.ts +256 -0
- package/src/api/resources/threads/types.ts +143 -0
- package/src/api/resources/threads/utils.ts +104 -0
- package/src/context.ts +10 -1
- package/src/index.ts +49 -1
- package/src/internal.ts +15 -0
- package/src/kernl.ts +86 -17
- package/src/mcp/__tests__/integration.test.ts +8 -9
- package/src/mcp/__tests__/utils.test.ts +6 -6
- package/src/mcp/http.ts +9 -9
- package/src/mcp/sse.ts +7 -7
- package/src/mcp/utils.ts +6 -5
- package/src/storage/__tests__/in-memory.test.ts +534 -0
- package/src/storage/base.ts +77 -0
- package/src/storage/in-memory.ts +372 -0
- package/src/storage/index.ts +21 -0
- package/src/storage/thread.ts +141 -0
- package/src/task.ts +12 -10
- package/src/thread/__tests__/fixtures/mock-model.ts +2 -4
- package/src/thread/__tests__/integration.test.ts +13 -12
- package/src/thread/__tests__/namespace.test.ts +158 -0
- package/src/thread/__tests__/thread-persistence.test.ts +367 -0
- package/src/thread/__tests__/thread.test.ts +52 -54
- package/src/thread/thread.ts +247 -96
- package/src/thread/utils.ts +76 -13
- package/src/tool/__tests__/fixtures.ts +1 -1
- package/src/tool/__tests__/toolkit.test.ts +15 -12
- package/src/tool/tool.ts +3 -3
- package/src/types/kernl.ts +51 -0
- package/src/types/thread.ts +139 -25
- package/vitest.config.ts +1 -0
- package/dist/env.d.ts +0 -45
- package/dist/env.d.ts.map +0 -1
- package/dist/env.js +0 -31
- package/dist/error.d.ts +0 -1
- package/dist/error.d.ts.map +0 -1
- package/dist/kernel.d.ts +0 -7
- package/dist/kernel.d.ts.map +0 -1
- package/dist/kernel.js +0 -7
- package/dist/lib/serde/__tests__/codec.test.d.ts +0 -2
- package/dist/lib/serde/__tests__/codec.test.d.ts.map +0 -1
- package/dist/lib/serde/__tests__/codec.test.js +0 -75
- package/dist/lib/serde/codec.d.ts +0 -12
- package/dist/lib/serde/codec.d.ts.map +0 -1
- package/dist/lib/serde/codec.js +0 -54
- package/dist/lib/serde/thread.d.ts +0 -1
- package/dist/lib/serde/thread.d.ts.map +0 -1
- package/dist/lib/serde/thread.js +0 -172
- package/dist/lib/serde/tool.d.ts +0 -36
- package/dist/lib/serde/tool.d.ts.map +0 -1
- package/dist/lib/utils.d.ts +0 -19
- package/dist/lib/utils.d.ts.map +0 -1
- package/dist/lib/utils.js +0 -41
- package/dist/logger.d.ts +0 -36
- package/dist/logger.d.ts.map +0 -1
- package/dist/logger.js +0 -43
- package/dist/mcp/__tests__/fixtures/echo-server.d.ts +0 -3
- package/dist/mcp/__tests__/fixtures/echo-server.d.ts.map +0 -1
- package/dist/mcp/__tests__/fixtures/echo-server.js +0 -92
- package/dist/mcp/__tests__/fixtures/math-server.d.ts +0 -3
- package/dist/mcp/__tests__/fixtures/math-server.d.ts.map +0 -1
- package/dist/mcp/__tests__/fixtures/math-server.js +0 -98
- package/dist/mcp/__tests__/fixtures/test-server.d.ts +0 -3
- package/dist/mcp/__tests__/fixtures/test-server.d.ts.map +0 -1
- package/dist/mcp/__tests__/fixtures/test-server.js +0 -163
- package/dist/mcp/__tests__/test-utils.d.ts +0 -17
- package/dist/mcp/__tests__/test-utils.d.ts.map +0 -1
- package/dist/mcp/__tests__/test-utils.js +0 -42
- package/dist/mcp/node.d.ts +0 -60
- package/dist/mcp/node.d.ts.map +0 -1
- package/dist/mcp/node.js +0 -297
- package/dist/model.d.ts +0 -175
- package/dist/model.d.ts.map +0 -1
- package/dist/providers/ai.d.ts +0 -1
- package/dist/providers/ai.d.ts.map +0 -1
- package/dist/providers/ai.js +0 -1
- package/dist/providers/default.d.ts +0 -16
- package/dist/providers/default.d.ts.map +0 -1
- package/dist/providers/default.js +0 -17
- package/dist/providers/registry.d.ts +0 -1
- package/dist/providers/registry.d.ts.map +0 -1
- package/dist/providers/registry.js +0 -1
- package/dist/sched/scheduler.d.ts +0 -20
- package/dist/sched/scheduler.d.ts.map +0 -1
- package/dist/sched/task.d.ts +0 -92
- package/dist/sched/task.d.ts.map +0 -1
- package/dist/sched/task.js +0 -102
- package/dist/serde/__tests__/codec.test.d.ts +0 -2
- package/dist/serde/__tests__/codec.test.d.ts.map +0 -1
- package/dist/serde/__tests__/codec.test.js +0 -75
- package/dist/serde/codec.d.ts +0 -12
- package/dist/serde/codec.d.ts.map +0 -1
- package/dist/serde/codec.js +0 -54
- package/dist/serde/json.d.ts +0 -8
- package/dist/serde/json.d.ts.map +0 -1
- package/dist/serde/json.js +0 -13
- package/dist/serde/thread.d.ts +0 -687
- package/dist/serde/thread.d.ts.map +0 -1
- package/dist/serde/thread.js +0 -158
- package/dist/serde/tool.d.ts +0 -36
- package/dist/serde/tool.d.ts.map +0 -1
- package/dist/session.d.ts +0 -1
- package/dist/session.d.ts.map +0 -1
- package/dist/session.js +0 -1
- package/dist/thread/__tests__/stream.test.d.ts +0 -2
- package/dist/thread/__tests__/stream.test.d.ts.map +0 -1
- package/dist/thread/__tests__/stream.test.js +0 -244
- package/dist/tool/mcp.d.ts +0 -75
- package/dist/tool/mcp.d.ts.map +0 -1
- package/dist/tool/mcp.js +0 -111
- package/dist/tools.d.ts +0 -362
- package/dist/tools.d.ts.map +0 -1
- package/dist/tools.js +0 -220
- package/dist/types/proto.d.ts +0 -1551
- package/dist/types/proto.d.ts.map +0 -1
- package/dist/types/proto.js +0 -531
- package/dist/usage.d.ts +0 -43
- package/dist/usage.d.ts.map +0 -1
- package/dist/usage.js +0 -61
- package/src/lib/serde/thread.ts +0 -188
- /package/dist/{error.js → agent/index.js} +0 -0
- /package/dist/{lib/serde/tool.js → api/models/index.js} +0 -0
- /package/dist/{model.js → api/models/thread.js} +0 -0
- /package/dist/{sched/scheduler.js → api/resources/threads/types.js} +0 -0
- /package/dist/{serde/tool.js → types/kernl.js} +0 -0
package/dist/model.d.ts
DELETED
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
import { Usage } from "./usage";
|
|
2
|
-
import { SerializedTool } from "./lib/serde/tool";
|
|
3
|
-
import { ThreadEvent, ThreadStreamEvent } from "./types/thread";
|
|
4
|
-
export type ModelTracing = boolean | "enabled_without_data";
|
|
5
|
-
/**
|
|
6
|
-
* The base interface for calling an LLM.
|
|
7
|
-
*/
|
|
8
|
-
export interface LanguageModel {
|
|
9
|
-
/**
|
|
10
|
-
* Get a response from the model.
|
|
11
|
-
*
|
|
12
|
-
* @param request - The request to get a response for.
|
|
13
|
-
*/
|
|
14
|
-
generate(request: LanguageModelRequest): Promise<LanguageModelResponse>;
|
|
15
|
-
/**
|
|
16
|
-
* Get a streamed response from the model.
|
|
17
|
-
*
|
|
18
|
-
* @param request - The request to get a response for.
|
|
19
|
-
*/
|
|
20
|
-
stream(request: LanguageModelRequest): AsyncIterable<ThreadStreamEvent>;
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* A request to a large language model.
|
|
24
|
-
*/
|
|
25
|
-
export type LanguageModelRequest = {
|
|
26
|
-
/**
|
|
27
|
-
* The system instructions to use for the model.
|
|
28
|
-
*/
|
|
29
|
-
system?: string;
|
|
30
|
-
/**
|
|
31
|
-
* The input to the model.
|
|
32
|
-
*/
|
|
33
|
-
input: ThreadEvent[] | string;
|
|
34
|
-
/**
|
|
35
|
-
* The ID of stored conversation to use for the model.
|
|
36
|
-
*/
|
|
37
|
-
conversationId?: string;
|
|
38
|
-
/**
|
|
39
|
-
* The model settings to use for the model.
|
|
40
|
-
*/
|
|
41
|
-
modelSettings: LanguageModelSettings;
|
|
42
|
-
/**
|
|
43
|
-
* The tools to use for the model.
|
|
44
|
-
*/
|
|
45
|
-
tools: SerializedTool[];
|
|
46
|
-
/**
|
|
47
|
-
* Whether to enable tracing for the model.
|
|
48
|
-
*/
|
|
49
|
-
tracing: ModelTracing;
|
|
50
|
-
/**
|
|
51
|
-
* An optional signal to abort the model request.
|
|
52
|
-
*/
|
|
53
|
-
abort?: AbortSignal;
|
|
54
|
-
};
|
|
55
|
-
/**
|
|
56
|
-
* The base response type
|
|
57
|
-
*/
|
|
58
|
-
export type LanguageModelResponse = {
|
|
59
|
-
/**
|
|
60
|
-
* The usage information for response.
|
|
61
|
-
*/
|
|
62
|
-
usage: Usage;
|
|
63
|
-
/**
|
|
64
|
-
* A list of events (messages, tool calls, etc.) generated by the model.
|
|
65
|
-
*/
|
|
66
|
-
events: ThreadEvent[];
|
|
67
|
-
/**
|
|
68
|
-
* An ID for the response which can be used to refer to the response in subsequent calls to the
|
|
69
|
-
* model. Not supported by all model providers.
|
|
70
|
-
*/
|
|
71
|
-
responseId?: string;
|
|
72
|
-
/**
|
|
73
|
-
* Raw response data from the underlying model provider.
|
|
74
|
-
*/
|
|
75
|
-
providerData?: Record<string, any>;
|
|
76
|
-
};
|
|
77
|
-
/**
|
|
78
|
-
* Settings to use when calling an LLM.
|
|
79
|
-
*
|
|
80
|
-
* This class holds optional model configuration parameters (e.g. temperature,
|
|
81
|
-
* topP, penalties, truncation, etc.).
|
|
82
|
-
*
|
|
83
|
-
* Not all models/providers support all of these parameters, so please check the API documentation
|
|
84
|
-
* for the specific model and provider you are using.
|
|
85
|
-
*/
|
|
86
|
-
export type LanguageModelSettings = {
|
|
87
|
-
/**
|
|
88
|
-
* The temperature to use when calling the model.
|
|
89
|
-
*/
|
|
90
|
-
temperature?: number;
|
|
91
|
-
/**
|
|
92
|
-
* The topP to use when calling the model.
|
|
93
|
-
*/
|
|
94
|
-
topP?: number;
|
|
95
|
-
/**
|
|
96
|
-
* The frequency penalty to use when calling the model.
|
|
97
|
-
*/
|
|
98
|
-
frequencyPenalty?: number;
|
|
99
|
-
/**
|
|
100
|
-
* The presence penalty to use when calling the model.
|
|
101
|
-
*/
|
|
102
|
-
presencePenalty?: number;
|
|
103
|
-
/**
|
|
104
|
-
* The tool choice to use when calling the model.
|
|
105
|
-
*/
|
|
106
|
-
toolChoice?: ModelSettingsToolChoice;
|
|
107
|
-
/**
|
|
108
|
-
* Whether to use parallel tool calls when calling the model.
|
|
109
|
-
* Defaults to false if not provided.
|
|
110
|
-
*/
|
|
111
|
-
parallelToolCalls?: boolean;
|
|
112
|
-
/**
|
|
113
|
-
* The truncation strategy to use when calling the model.
|
|
114
|
-
*/
|
|
115
|
-
truncation?: "auto" | "disabled";
|
|
116
|
-
/**
|
|
117
|
-
* The maximum number of output tokens to generate.
|
|
118
|
-
*/
|
|
119
|
-
maxTokens?: number;
|
|
120
|
-
/**
|
|
121
|
-
* Whether to store the generated model response for later retrieval.
|
|
122
|
-
* Defaults to true if not provided.
|
|
123
|
-
*/
|
|
124
|
-
store?: boolean;
|
|
125
|
-
/**
|
|
126
|
-
* The reasoning settings to use when calling the model.
|
|
127
|
-
*/
|
|
128
|
-
reasoning?: ModelSettingsReasoning;
|
|
129
|
-
/**
|
|
130
|
-
* The text settings to use when calling the model.
|
|
131
|
-
*/
|
|
132
|
-
text?: ModelSettingsText;
|
|
133
|
-
/**
|
|
134
|
-
* Additional provider specific settings to be passed directly to the model
|
|
135
|
-
* request.
|
|
136
|
-
*/
|
|
137
|
-
providerData?: Record<string, any>;
|
|
138
|
-
};
|
|
139
|
-
export type ModelSettingsToolChoice = "auto" | "required" | "none";
|
|
140
|
-
/**
|
|
141
|
-
* Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning).
|
|
142
|
-
*
|
|
143
|
-
* Supported for providers:
|
|
144
|
-
*
|
|
145
|
-
* - OpenAI
|
|
146
|
-
* - ... ?
|
|
147
|
-
*/
|
|
148
|
-
export type ModelSettingsReasoningEffort = "minimal" | "low" | "medium" | "high" | null;
|
|
149
|
-
/**
|
|
150
|
-
* Configuration options for [reasoning models](https://platform.openai.com/docs/guides/reasoning).
|
|
151
|
-
*/
|
|
152
|
-
export type ModelSettingsReasoning = {
|
|
153
|
-
/**
|
|
154
|
-
* Constrains effort on reasoning for [reasoning models](https://platform.openai.com/docs/guides/reasoning).
|
|
155
|
-
*/
|
|
156
|
-
effort?: ModelSettingsReasoningEffort | null;
|
|
157
|
-
/**
|
|
158
|
-
* A summary of the reasoning performed by the model.
|
|
159
|
-
* This can be useful for debugging and understanding the model's reasoning process.
|
|
160
|
-
* One of `auto`, `concise`, or `detailed`.
|
|
161
|
-
*/
|
|
162
|
-
summary?: "auto" | "concise" | "detailed" | null;
|
|
163
|
-
};
|
|
164
|
-
export interface ModelSettingsText {
|
|
165
|
-
/**
|
|
166
|
-
* Constrains the verbosity of the model's response.
|
|
167
|
-
*
|
|
168
|
-
* Supported for providers:
|
|
169
|
-
*
|
|
170
|
-
* - OpenAI
|
|
171
|
-
* - ... ?
|
|
172
|
-
*/
|
|
173
|
-
verbosity?: "low" | "medium" | "high" | null;
|
|
174
|
-
}
|
|
175
|
-
//# sourceMappingURL=model.d.ts.map
|
package/dist/model.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../src/model.ts"],"names":[],"mappings":"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"}
|
package/dist/providers/ai.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=ai.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ai.d.ts","sourceRoot":"","sources":["../../src/providers/ai.ts"],"names":[],"mappings":""}
|
package/dist/providers/ai.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import type { LanguageModel, LanguageModelRequest, LanguageModelResponse } from "../model";
|
|
2
|
-
import type { ThreadStreamEvent } from "../types/thread";
|
|
3
|
-
/**
|
|
4
|
-
* Default language model that throws an error when used.
|
|
5
|
-
* This is used as a fallback when no model is provided to an Agent.
|
|
6
|
-
*/
|
|
7
|
-
declare class DefaultLanguageModel implements LanguageModel {
|
|
8
|
-
generate(request: LanguageModelRequest): Promise<LanguageModelResponse>;
|
|
9
|
-
stream(request: LanguageModelRequest): AsyncIterable<ThreadStreamEvent>;
|
|
10
|
-
}
|
|
11
|
-
/**
|
|
12
|
-
* Singleton instance of the default language model
|
|
13
|
-
*/
|
|
14
|
-
export declare const DEFAULT_LANGUAGE_MODEL: DefaultLanguageModel;
|
|
15
|
-
export {};
|
|
16
|
-
//# sourceMappingURL=default.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"default.d.ts","sourceRoot":"","sources":["../../src/providers/default.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EACb,oBAAoB,EACpB,qBAAqB,EACtB,MAAM,SAAS,CAAC;AACjB,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAIxD;;;GAGG;AACH,cAAM,oBAAqB,YAAW,aAAa;IAC3C,QAAQ,CACZ,OAAO,EAAE,oBAAoB,GAC5B,OAAO,CAAC,qBAAqB,CAAC;IAM1B,MAAM,CACX,OAAO,EAAE,oBAAoB,GAC5B,aAAa,CAAC,iBAAiB,CAAC;CAKpC;AAED;;GAEG;AACH,eAAO,MAAM,sBAAsB,sBAA6B,CAAC"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
// (TEMPORARY)
|
|
2
|
-
/**
|
|
3
|
-
* Default language model that throws an error when used.
|
|
4
|
-
* This is used as a fallback when no model is provided to an Agent.
|
|
5
|
-
*/
|
|
6
|
-
class DefaultLanguageModel {
|
|
7
|
-
async generate(request) {
|
|
8
|
-
throw new Error("No language model configured. Please provide a model to the Agent.");
|
|
9
|
-
}
|
|
10
|
-
async *stream(request) {
|
|
11
|
-
throw new Error("No language model configured. Please provide a model to the Agent.");
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Singleton instance of the default language model
|
|
16
|
-
*/
|
|
17
|
-
export const DEFAULT_LANGUAGE_MODEL = new DefaultLanguageModel();
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/providers/registry.ts"],"names":[],"mappings":""}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import type { Task } from "./task";
|
|
2
|
-
/**
|
|
3
|
-
* Per-agent run queue.
|
|
4
|
-
* Each agent has one run queue tracking its tasks.
|
|
5
|
-
*
|
|
6
|
-
* Simplified for hello world - defers clock, load, stats, and CFS priority logic.
|
|
7
|
-
*/
|
|
8
|
-
export interface RunQueue {
|
|
9
|
-
agentId: string;
|
|
10
|
-
curr: Task[];
|
|
11
|
-
nrunning: number;
|
|
12
|
-
tasks: Task[];
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Configuration for the Scheduler.
|
|
16
|
-
*/
|
|
17
|
-
export interface SchedulerConfig {
|
|
18
|
-
defaultMaxConcurrent?: number;
|
|
19
|
-
}
|
|
20
|
-
//# sourceMappingURL=scheduler.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"scheduler.d.ts","sourceRoot":"","sources":["../../src/sched/scheduler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEnC;;;;;GAKG;AACH,MAAM,WAAW,QAAQ;IACvB,OAAO,EAAE,MAAM,CAAmC;IAClD,IAAI,EAAE,IAAI,EAAE,CAAiC;IAC7C,QAAQ,EAAE,MAAM,CAAgC;IAChD,KAAK,EAAE,IAAI,EAAE,CAA0C;CAOxD;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,oBAAoB,CAAC,EAAE,MAAM,CAAkD;CAChF"}
|
package/dist/sched/task.d.ts
DELETED
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import type { Agent } from "../agent";
|
|
2
|
-
import type { Context, UnknownContext } from "../context";
|
|
3
|
-
import type { Thread } from "../thread";
|
|
4
|
-
/**
|
|
5
|
-
* A Task represents a unit of work scheduled by the kernl.
|
|
6
|
-
* Analogous to task_struct in the Linux kernel.
|
|
7
|
-
*/
|
|
8
|
-
export declare class Task<TContext = UnknownContext, TResult = unknown> {
|
|
9
|
-
pid: string;
|
|
10
|
-
instructions: string | ((context: Context<TContext>) => string);
|
|
11
|
-
state: TaskState;
|
|
12
|
-
owner: Agent<TContext>;
|
|
13
|
-
context: Context<TContext>;
|
|
14
|
-
/**
|
|
15
|
-
* Might want the ability to pick up a new thread of execution from a compressed task checkpoint instead of including
|
|
16
|
-
* all of the events from the old threads (which may no longer be useful if they completed with good artifacts + reasoning / action summaries).
|
|
17
|
-
* At that point its really more about tracing.
|
|
18
|
-
*/
|
|
19
|
-
threads: Thread<TContext>[];
|
|
20
|
-
current: Thread<TContext> | null;
|
|
21
|
-
result: TResult | null;
|
|
22
|
-
constructor(init: {
|
|
23
|
-
pid: string;
|
|
24
|
-
instructions: string | ((context: Context<TContext>) => string);
|
|
25
|
-
state: TaskState;
|
|
26
|
-
owner: Agent<TContext>;
|
|
27
|
-
context: Context<TContext>;
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* The various states that a task may be in.
|
|
32
|
-
*/
|
|
33
|
-
export declare enum TaskState {
|
|
34
|
-
/**
|
|
35
|
-
* Task is either:
|
|
36
|
-
* - Currently executing
|
|
37
|
-
* - In run queue waiting to be scheduled (might want to differentiate between running + queued here)
|
|
38
|
-
*/
|
|
39
|
-
RUNNING = "running",
|
|
40
|
-
/**
|
|
41
|
-
* Task is sleeping/blocked, waiting for a condition.
|
|
42
|
-
* Can be woken up by:
|
|
43
|
-
* - The condition being met (e.g., approval granted)
|
|
44
|
-
* - A signal (e.g., user cancellation)
|
|
45
|
-
*
|
|
46
|
-
* Examples:
|
|
47
|
-
* - Waiting for tool approval
|
|
48
|
-
* - Waiting for user input
|
|
49
|
-
* - Sleeping on a timer
|
|
50
|
-
*/
|
|
51
|
-
INTERRUPTIBLE = "interruptible",
|
|
52
|
-
/**
|
|
53
|
-
* Task is sleeping/blocked and CANNOT be interrupted by signals.
|
|
54
|
-
* Only wakes when the condition is met.
|
|
55
|
-
*
|
|
56
|
-
* Examples:
|
|
57
|
-
* - Waiting for critical I/O (model API call)
|
|
58
|
-
* - Waiting for resource that MUST complete
|
|
59
|
-
*
|
|
60
|
-
* Use sparingly - these tasks can't be cancelled!
|
|
61
|
-
*/
|
|
62
|
-
UNINTERRUPTIBLE = "uninterruptible",
|
|
63
|
-
/**
|
|
64
|
-
* Task has been stopped by a signal (SIGSTOP).
|
|
65
|
-
* Will remain stopped until explicitly continued (SIGCONT).
|
|
66
|
-
*
|
|
67
|
-
* Examples:
|
|
68
|
-
* - User explicitly paused the agent
|
|
69
|
-
* - Debugger attached
|
|
70
|
-
*/
|
|
71
|
-
STOPPED = "stopped",
|
|
72
|
-
/**
|
|
73
|
-
* Task is being traced by a debugger.
|
|
74
|
-
* Similar to STOPPED but for debugging.
|
|
75
|
-
*/
|
|
76
|
-
TRACED = "traced",
|
|
77
|
-
/**
|
|
78
|
-
* Task has finished execution but hasn't been cleaned up yet.
|
|
79
|
-
* Waiting for parent to read exit status (wait/waitpid).
|
|
80
|
-
*
|
|
81
|
-
* Examples:
|
|
82
|
-
* - Agent completed but result not yet retrieved
|
|
83
|
-
* - Child agent finished, parent needs to collect result
|
|
84
|
-
*/
|
|
85
|
-
ZOMBIE = "zombie",
|
|
86
|
-
/**
|
|
87
|
-
* Task is being removed from the system.
|
|
88
|
-
* Final cleanup in progress, about to be fully deleted.
|
|
89
|
-
*/
|
|
90
|
-
DEAD = "dead"
|
|
91
|
-
}
|
|
92
|
-
//# sourceMappingURL=task.d.ts.map
|
package/dist/sched/task.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"task.d.ts","sourceRoot":"","sources":["../../src/sched/task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAEzD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAEvC;;;GAGG;AACH,qBAAa,IAAI,CAAC,QAAQ,GAAG,cAAc,EAAE,OAAO,GAAG,OAAO;IAC5D,GAAG,EAAE,MAAM,CAAoD;IAG/D,YAAY,EACR,MAAM,GACN,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,KAAK,MAAM,CAAC,CAA4B;IAExE,KAAK,EAAE,SAAS,CAAiC;IACjD,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,CAA2C;IAEjE,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,CAA0D;IAIpF;;;;OAIG;IACH,OAAO,EAAE,MAAM,CAAC,QAAQ,CAAC,EAAE,CAA6C;IACxE,OAAO,EAAE,MAAM,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAyC;IACzE,MAAM,EAAE,OAAO,GAAG,IAAI,CAAgC;gBAQ1C,IAAI,EAAE;QAChB,GAAG,EAAE,MAAM,CAAC;QACZ,YAAY,EAAE,MAAM,GAAG,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,KAAK,MAAM,CAAC,CAAC;QAChE,KAAK,EAAE,SAAS,CAAC;QACjB,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;QACvB,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;KAC5B;CAUF;AAED;;GAEG;AACH,oBAAY,SAAS;IACnB;;;;OAIG;IACH,OAAO,YAAY;IAEnB;;;;;;;;;;OAUG;IACH,aAAa,kBAAkB;IAE/B;;;;;;;;;OASG;IACH,eAAe,oBAAoB;IAEnC;;;;;;;OAOG;IACH,OAAO,YAAY;IAEnB;;;OAGG;IACH,MAAM,WAAW;IAEjB;;;;;;;OAOG;IACH,MAAM,WAAW;IAEjB;;;OAGG;IACH,IAAI,SAAS;CACd"}
|
package/dist/sched/task.js
DELETED
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* A Task represents a unit of work scheduled by the kernl.
|
|
3
|
-
* Analogous to task_struct in the Linux kernel.
|
|
4
|
-
*/
|
|
5
|
-
export class Task {
|
|
6
|
-
pid;
|
|
7
|
-
// tgid: string | null; /* task groupid */
|
|
8
|
-
// prio: TaskPriority;
|
|
9
|
-
instructions;
|
|
10
|
-
// sched: TaskSched; /* scheduling (timers, timeouts, deadlines) */
|
|
11
|
-
state;
|
|
12
|
-
owner;
|
|
13
|
-
context;
|
|
14
|
-
// cred: Credentials; /* Effective (overridable) subjective task credentials (COW): */
|
|
15
|
-
// realcred: Credentials; /* Objective and real subjective task credentials (COW): */
|
|
16
|
-
/**
|
|
17
|
-
* Might want the ability to pick up a new thread of execution from a compressed task checkpoint instead of including
|
|
18
|
-
* all of the events from the old threads (which may no longer be useful if they completed with good artifacts + reasoning / action summaries).
|
|
19
|
-
* At that point its really more about tracing.
|
|
20
|
-
*/
|
|
21
|
-
threads;
|
|
22
|
-
current;
|
|
23
|
-
result;
|
|
24
|
-
// checkpoints: TaskCheckpoint<TContext>[]; /* checkpoints for resuming execution */
|
|
25
|
-
// TODO: Deferred fields for later implementation
|
|
26
|
-
// tgid: string; // Thread group ID
|
|
27
|
-
// limits: TaskLimits; // Resource limits (max ticks, tokens, timeout)
|
|
28
|
-
// nsproxy: NamespaceProxy; // Namespace isolation
|
|
29
|
-
constructor(init) {
|
|
30
|
-
this.pid = init.pid;
|
|
31
|
-
this.instructions = init.instructions;
|
|
32
|
-
this.state = init.state;
|
|
33
|
-
this.owner = init.owner;
|
|
34
|
-
this.context = init.context;
|
|
35
|
-
this.threads = [];
|
|
36
|
-
this.current = null;
|
|
37
|
-
this.result = null;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* The various states that a task may be in.
|
|
42
|
-
*/
|
|
43
|
-
export var TaskState;
|
|
44
|
-
(function (TaskState) {
|
|
45
|
-
/**
|
|
46
|
-
* Task is either:
|
|
47
|
-
* - Currently executing
|
|
48
|
-
* - In run queue waiting to be scheduled (might want to differentiate between running + queued here)
|
|
49
|
-
*/
|
|
50
|
-
TaskState["RUNNING"] = "running";
|
|
51
|
-
/**
|
|
52
|
-
* Task is sleeping/blocked, waiting for a condition.
|
|
53
|
-
* Can be woken up by:
|
|
54
|
-
* - The condition being met (e.g., approval granted)
|
|
55
|
-
* - A signal (e.g., user cancellation)
|
|
56
|
-
*
|
|
57
|
-
* Examples:
|
|
58
|
-
* - Waiting for tool approval
|
|
59
|
-
* - Waiting for user input
|
|
60
|
-
* - Sleeping on a timer
|
|
61
|
-
*/
|
|
62
|
-
TaskState["INTERRUPTIBLE"] = "interruptible";
|
|
63
|
-
/**
|
|
64
|
-
* Task is sleeping/blocked and CANNOT be interrupted by signals.
|
|
65
|
-
* Only wakes when the condition is met.
|
|
66
|
-
*
|
|
67
|
-
* Examples:
|
|
68
|
-
* - Waiting for critical I/O (model API call)
|
|
69
|
-
* - Waiting for resource that MUST complete
|
|
70
|
-
*
|
|
71
|
-
* Use sparingly - these tasks can't be cancelled!
|
|
72
|
-
*/
|
|
73
|
-
TaskState["UNINTERRUPTIBLE"] = "uninterruptible";
|
|
74
|
-
/**
|
|
75
|
-
* Task has been stopped by a signal (SIGSTOP).
|
|
76
|
-
* Will remain stopped until explicitly continued (SIGCONT).
|
|
77
|
-
*
|
|
78
|
-
* Examples:
|
|
79
|
-
* - User explicitly paused the agent
|
|
80
|
-
* - Debugger attached
|
|
81
|
-
*/
|
|
82
|
-
TaskState["STOPPED"] = "stopped";
|
|
83
|
-
/**
|
|
84
|
-
* Task is being traced by a debugger.
|
|
85
|
-
* Similar to STOPPED but for debugging.
|
|
86
|
-
*/
|
|
87
|
-
TaskState["TRACED"] = "traced";
|
|
88
|
-
/**
|
|
89
|
-
* Task has finished execution but hasn't been cleaned up yet.
|
|
90
|
-
* Waiting for parent to read exit status (wait/waitpid).
|
|
91
|
-
*
|
|
92
|
-
* Examples:
|
|
93
|
-
* - Agent completed but result not yet retrieved
|
|
94
|
-
* - Child agent finished, parent needs to collect result
|
|
95
|
-
*/
|
|
96
|
-
TaskState["ZOMBIE"] = "zombie";
|
|
97
|
-
/**
|
|
98
|
-
* Task is being removed from the system.
|
|
99
|
-
* Final cleanup in progress, about to be fully deleted.
|
|
100
|
-
*/
|
|
101
|
-
TaskState["DEAD"] = "dead";
|
|
102
|
-
})(TaskState || (TaskState = {}));
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"codec.test.d.ts","sourceRoot":"","sources":["../../../src/serde/__tests__/codec.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from "vitest";
|
|
2
|
-
import { z } from "zod";
|
|
3
|
-
import { json } from "../codec";
|
|
4
|
-
describe("json codec", () => {
|
|
5
|
-
it("should parse valid JSON and validate against schema", () => {
|
|
6
|
-
const schema = z.object({
|
|
7
|
-
name: z.string(),
|
|
8
|
-
age: z.number(),
|
|
9
|
-
});
|
|
10
|
-
const codec = json(schema);
|
|
11
|
-
const result = codec.decode('{"name": "Alice", "age": 30}');
|
|
12
|
-
expect(result).toEqual({ name: "Alice", age: 30 });
|
|
13
|
-
});
|
|
14
|
-
it("should reject invalid JSON syntax", () => {
|
|
15
|
-
const schema = z.object({
|
|
16
|
-
name: z.string(),
|
|
17
|
-
});
|
|
18
|
-
const codec = json(schema);
|
|
19
|
-
expect(() => {
|
|
20
|
-
codec.decode('{"name": "Alice"');
|
|
21
|
-
}).toThrow();
|
|
22
|
-
});
|
|
23
|
-
it("should reject valid JSON that doesn't match schema", () => {
|
|
24
|
-
const schema = z.object({
|
|
25
|
-
name: z.string(),
|
|
26
|
-
age: z.number(),
|
|
27
|
-
});
|
|
28
|
-
const codec = json(schema);
|
|
29
|
-
// Valid JSON but age is a string, not a number
|
|
30
|
-
expect(() => {
|
|
31
|
-
codec.decode('{"name": "Alice", "age": "30"}');
|
|
32
|
-
}).toThrow();
|
|
33
|
-
});
|
|
34
|
-
it("should reject JSON missing required fields", () => {
|
|
35
|
-
const schema = z.object({
|
|
36
|
-
name: z.string(),
|
|
37
|
-
age: z.number(),
|
|
38
|
-
});
|
|
39
|
-
const codec = json(schema);
|
|
40
|
-
// Valid JSON but missing age field
|
|
41
|
-
expect(() => {
|
|
42
|
-
codec.decode('{"name": "Alice"}');
|
|
43
|
-
}).toThrow();
|
|
44
|
-
});
|
|
45
|
-
it("should handle nested objects", () => {
|
|
46
|
-
const schema = z.object({
|
|
47
|
-
user: z.object({
|
|
48
|
-
name: z.string(),
|
|
49
|
-
email: z.string().email(),
|
|
50
|
-
}),
|
|
51
|
-
metadata: z.object({
|
|
52
|
-
createdAt: z.string(),
|
|
53
|
-
}),
|
|
54
|
-
});
|
|
55
|
-
const codec = json(schema);
|
|
56
|
-
const result = codec.decode('{"user": {"name": "Bob", "email": "bob@example.com"}, "metadata": {"createdAt": "2024-01-01"}}');
|
|
57
|
-
expect(result).toEqual({
|
|
58
|
-
user: { name: "Bob", email: "bob@example.com" },
|
|
59
|
-
metadata: { createdAt: "2024-01-01" },
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
it("should reject nested objects that don't match schema", () => {
|
|
63
|
-
const schema = z.object({
|
|
64
|
-
user: z.object({
|
|
65
|
-
name: z.string(),
|
|
66
|
-
email: z.string().email(),
|
|
67
|
-
}),
|
|
68
|
-
});
|
|
69
|
-
const codec = json(schema);
|
|
70
|
-
// Invalid email format
|
|
71
|
-
expect(() => {
|
|
72
|
-
codec.decode('{"user": {"name": "Bob", "email": "not-an-email"}}');
|
|
73
|
-
}).toThrow();
|
|
74
|
-
});
|
|
75
|
-
});
|
package/dist/serde/codec.d.ts
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { z } from "zod";
|
|
2
|
-
export declare const stringToNumber: z.ZodCodec<z.ZodString, z.ZodNumber>;
|
|
3
|
-
export declare const stringToInt: z.ZodCodec<z.ZodString, z.ZodInt>;
|
|
4
|
-
export declare const isotime: z.ZodCodec<z.ZodISODateTime, z.ZodDate>;
|
|
5
|
-
export declare const epochsec: z.ZodCodec<z.ZodInt, z.ZodDate>;
|
|
6
|
-
export declare const epochms: z.ZodCodec<z.ZodInt, z.ZodDate>;
|
|
7
|
-
export declare const json: <T extends z.core.$ZodType>(schema: T) => z.ZodCodec<z.ZodString, T>;
|
|
8
|
-
export declare const stringToURL: z.ZodCodec<z.ZodURL, z.ZodCustom<import("url").URL, import("url").URL>>;
|
|
9
|
-
export declare const stringToHttpURL: z.ZodCodec<z.ZodURL, z.ZodCustom<import("url").URL, import("url").URL>>;
|
|
10
|
-
export declare const base64ToBytes: z.ZodCodec<z.ZodBase64, z.ZodCustom<Uint8Array<ArrayBuffer>, Uint8Array<ArrayBuffer>>>;
|
|
11
|
-
export declare const base64urlToBytes: z.ZodCodec<z.ZodBase64URL, z.ZodCustom<Uint8Array<ArrayBuffer>, Uint8Array<ArrayBuffer>>>;
|
|
12
|
-
//# sourceMappingURL=codec.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"codec.d.ts","sourceRoot":"","sources":["../../src/serde/codec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,cAAc,sCAO1B,CAAC;AAEF,eAAO,MAAM,WAAW,mCAOvB,CAAC;AAEF,eAAO,MAAM,OAAO,yCAGlB,CAAC;AAEH,eAAO,MAAM,QAAQ,iCAGnB,CAAC;AAEH,eAAO,MAAM,OAAO,iCAGlB,CAAC;AAEH,eAAO,MAAM,IAAI,GAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,+BAgBrD,CAAC;AAEL,eAAO,MAAM,WAAW,yEAGtB,CAAC;AAEH,eAAO,MAAM,eAAe,yEAG1B,CAAC;AAEH,eAAO,MAAM,aAAa,wFAGxB,CAAC;AAEH,eAAO,MAAM,gBAAgB,2FAO5B,CAAC"}
|
package/dist/serde/codec.js
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { z } from "zod";
|
|
2
|
-
export const stringToNumber = z.codec(z.string().regex(z.regexes.number), z.number(), {
|
|
3
|
-
decode: (str) => Number.parseFloat(str),
|
|
4
|
-
encode: (num) => num.toString(),
|
|
5
|
-
});
|
|
6
|
-
export const stringToInt = z.codec(z.string().regex(z.regexes.integer), z.int(), {
|
|
7
|
-
decode: (str) => Number.parseInt(str, 10),
|
|
8
|
-
encode: (num) => num.toString(),
|
|
9
|
-
});
|
|
10
|
-
export const isotime = z.codec(z.iso.datetime(), z.date(), {
|
|
11
|
-
decode: (isoString) => new Date(isoString),
|
|
12
|
-
encode: (date) => date.toISOString(),
|
|
13
|
-
});
|
|
14
|
-
export const epochsec = z.codec(z.int().min(0), z.date(), {
|
|
15
|
-
decode: (seconds) => new Date(seconds * 1000),
|
|
16
|
-
encode: (date) => Math.floor(date.getTime() / 1000),
|
|
17
|
-
});
|
|
18
|
-
export const epochms = z.codec(z.int().min(0), z.date(), {
|
|
19
|
-
decode: (millis) => new Date(millis),
|
|
20
|
-
encode: (date) => date.getTime(),
|
|
21
|
-
});
|
|
22
|
-
export const json = (schema) => z.codec(z.string(), schema, {
|
|
23
|
-
decode: (jsonString, ctx) => {
|
|
24
|
-
try {
|
|
25
|
-
return JSON.parse(jsonString);
|
|
26
|
-
}
|
|
27
|
-
catch (err) {
|
|
28
|
-
ctx.issues.push({
|
|
29
|
-
code: "invalid_format",
|
|
30
|
-
format: "json",
|
|
31
|
-
input: jsonString,
|
|
32
|
-
message: err.message,
|
|
33
|
-
});
|
|
34
|
-
return z.NEVER;
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
encode: (value) => JSON.stringify(value),
|
|
38
|
-
});
|
|
39
|
-
export const stringToURL = z.codec(z.url(), z.instanceof(URL), {
|
|
40
|
-
decode: (urlString) => new URL(urlString),
|
|
41
|
-
encode: (url) => url.href,
|
|
42
|
-
});
|
|
43
|
-
export const stringToHttpURL = z.codec(z.httpUrl(), z.instanceof(URL), {
|
|
44
|
-
decode: (urlString) => new URL(urlString),
|
|
45
|
-
encode: (url) => url.href,
|
|
46
|
-
});
|
|
47
|
-
export const base64ToBytes = z.codec(z.base64(), z.instanceof(Uint8Array), {
|
|
48
|
-
decode: (base64String) => z.util.base64ToUint8Array(base64String),
|
|
49
|
-
encode: (bytes) => z.util.uint8ArrayToBase64(bytes),
|
|
50
|
-
});
|
|
51
|
-
export const base64urlToBytes = z.codec(z.base64url(), z.instanceof(Uint8Array), {
|
|
52
|
-
decode: (base64urlString) => z.util.base64urlToUint8Array(base64urlString),
|
|
53
|
-
encode: (bytes) => z.util.uint8ArrayToBase64url(bytes),
|
|
54
|
-
});
|
package/dist/serde/json.d.ts
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { z } from "zod";
|
|
2
|
-
/**
|
|
3
|
-
* Represents a JSON-serializable value that can be safely stringified and sent to the model.
|
|
4
|
-
* Recursive type that allows nested structures.
|
|
5
|
-
*/
|
|
6
|
-
export declare const JSONValue: z.ZodType<unknown>;
|
|
7
|
-
export type JSONValue = z.infer<typeof JSONValue>;
|
|
8
|
-
//# sourceMappingURL=json.d.ts.map
|
package/dist/serde/json.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json.d.ts","sourceRoot":"","sources":["../../src/serde/json.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB;;;GAGG;AACH,eAAO,MAAM,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,CASxC,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,SAAS,CAAC,CAAC"}
|
package/dist/serde/json.js
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { z } from "zod";
|
|
2
|
-
/**
|
|
3
|
-
* Represents a JSON-serializable value that can be safely stringified and sent to the model.
|
|
4
|
-
* Recursive type that allows nested structures.
|
|
5
|
-
*/
|
|
6
|
-
export const JSONValue = z.lazy(() => z.union([
|
|
7
|
-
z.string(),
|
|
8
|
-
z.number(),
|
|
9
|
-
z.boolean(),
|
|
10
|
-
z.null(),
|
|
11
|
-
z.array(JSONValue),
|
|
12
|
-
z.record(z.string(), JSONValue),
|
|
13
|
-
]));
|