kernl 0.2.0 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (267) hide show
  1. package/.turbo/turbo-build.log +4 -5
  2. package/.turbo/turbo-check-types.log +4 -0
  3. package/CHANGELOG.md +147 -0
  4. package/LICENSE +1 -1
  5. package/dist/agent/__tests__/concurrency.test.d.ts +2 -0
  6. package/dist/agent/__tests__/concurrency.test.d.ts.map +1 -0
  7. package/dist/agent/__tests__/concurrency.test.js +152 -0
  8. package/dist/agent/__tests__/run.test.d.ts +2 -0
  9. package/dist/agent/__tests__/run.test.d.ts.map +1 -0
  10. package/dist/agent/__tests__/run.test.js +357 -0
  11. package/dist/agent/index.d.ts +1 -0
  12. package/dist/agent/index.d.ts.map +1 -0
  13. package/dist/agent.d.ts +32 -9
  14. package/dist/agent.d.ts.map +1 -1
  15. package/dist/agent.js +102 -14
  16. package/dist/api/__tests__/cursor-page.test.d.ts +2 -0
  17. package/dist/api/__tests__/cursor-page.test.d.ts.map +1 -0
  18. package/dist/api/__tests__/cursor-page.test.js +414 -0
  19. package/dist/api/__tests__/offset-page.test.d.ts +2 -0
  20. package/dist/api/__tests__/offset-page.test.d.ts.map +1 -0
  21. package/dist/api/__tests__/offset-page.test.js +510 -0
  22. package/dist/api/__tests__/threads.test.d.ts +2 -0
  23. package/dist/api/__tests__/threads.test.d.ts.map +1 -0
  24. package/dist/api/__tests__/threads.test.js +338 -0
  25. package/dist/api/models/index.d.ts +2 -0
  26. package/dist/api/models/index.d.ts.map +1 -0
  27. package/dist/api/models/thread.d.ts +120 -0
  28. package/dist/api/models/thread.d.ts.map +1 -0
  29. package/dist/api/pagination/base.d.ts +48 -0
  30. package/dist/api/pagination/base.d.ts.map +1 -0
  31. package/dist/api/pagination/base.js +45 -0
  32. package/dist/api/pagination/cursor.d.ts +44 -0
  33. package/dist/api/pagination/cursor.d.ts.map +1 -0
  34. package/dist/api/pagination/cursor.js +52 -0
  35. package/dist/api/pagination/offset.d.ts +42 -0
  36. package/dist/api/pagination/offset.d.ts.map +1 -0
  37. package/dist/api/pagination/offset.js +55 -0
  38. package/dist/api/resources/threads/events.d.ts +21 -0
  39. package/dist/api/resources/threads/events.d.ts.map +1 -0
  40. package/dist/api/resources/threads/events.js +24 -0
  41. package/dist/api/resources/threads/index.d.ts +4 -0
  42. package/dist/api/resources/threads/index.d.ts.map +1 -0
  43. package/dist/api/resources/threads/index.js +2 -0
  44. package/dist/api/resources/threads/threads.d.ts +57 -0
  45. package/dist/api/resources/threads/threads.d.ts.map +1 -0
  46. package/dist/api/resources/threads/threads.js +199 -0
  47. package/dist/api/resources/threads/types.d.ts +123 -0
  48. package/dist/api/resources/threads/types.d.ts.map +1 -0
  49. package/dist/api/resources/threads/utils.d.ts +18 -0
  50. package/dist/api/resources/threads/utils.d.ts.map +1 -0
  51. package/dist/api/resources/threads/utils.js +78 -0
  52. package/dist/context.d.ts +5 -1
  53. package/dist/context.d.ts.map +1 -1
  54. package/dist/context.js +6 -1
  55. package/dist/index.d.ts +9 -1
  56. package/dist/index.d.ts.map +1 -1
  57. package/dist/index.js +7 -0
  58. package/dist/internal.d.ts +4 -0
  59. package/dist/internal.d.ts.map +1 -0
  60. package/dist/internal.js +2 -0
  61. package/dist/kernl/index.d.ts +3 -0
  62. package/dist/kernl/index.d.ts.map +1 -0
  63. package/dist/kernl/index.js +2 -0
  64. package/dist/kernl/kernl.d.ts +64 -0
  65. package/dist/kernl/kernl.d.ts.map +1 -0
  66. package/dist/kernl/kernl.js +116 -0
  67. package/dist/kernl/threads.d.ts +110 -0
  68. package/dist/kernl/threads.d.ts.map +1 -0
  69. package/dist/kernl/threads.js +126 -0
  70. package/dist/kernl.d.ts +22 -6
  71. package/dist/kernl.d.ts.map +1 -1
  72. package/dist/kernl.js +73 -10
  73. package/dist/lib/env.d.ts +3 -3
  74. package/dist/lib/env.js +1 -1
  75. package/dist/mcp/__tests__/integration.test.js +8 -8
  76. package/dist/mcp/__tests__/utils.test.js +6 -6
  77. package/dist/mcp/http.d.ts +1 -1
  78. package/dist/mcp/http.d.ts.map +1 -1
  79. package/dist/mcp/http.js +9 -9
  80. package/dist/mcp/sse.d.ts +1 -1
  81. package/dist/mcp/sse.d.ts.map +1 -1
  82. package/dist/mcp/sse.js +7 -7
  83. package/dist/mcp/utils.d.ts +1 -1
  84. package/dist/mcp/utils.d.ts.map +1 -1
  85. package/dist/mcp/utils.js +4 -5
  86. package/dist/storage/__tests__/in-memory.test.d.ts +2 -0
  87. package/dist/storage/__tests__/in-memory.test.d.ts.map +1 -0
  88. package/dist/storage/__tests__/in-memory.test.js +455 -0
  89. package/dist/storage/base.d.ts +64 -0
  90. package/dist/storage/base.d.ts.map +1 -0
  91. package/dist/storage/base.js +4 -0
  92. package/dist/storage/in-memory.d.ts +62 -0
  93. package/dist/storage/in-memory.d.ts.map +1 -0
  94. package/dist/storage/in-memory.js +283 -0
  95. package/dist/storage/index.d.ts +10 -0
  96. package/dist/storage/index.d.ts.map +1 -0
  97. package/dist/storage/index.js +7 -0
  98. package/dist/storage/thread.d.ts +123 -0
  99. package/dist/storage/thread.d.ts.map +1 -0
  100. package/dist/storage/thread.js +4 -0
  101. package/dist/task.d.ts +5 -3
  102. package/dist/task.d.ts.map +1 -1
  103. package/dist/task.js +10 -8
  104. package/dist/thread/__tests__/fixtures/mock-model.d.ts +1 -2
  105. package/dist/thread/__tests__/fixtures/mock-model.d.ts.map +1 -1
  106. package/dist/thread/__tests__/integration.test.js +73 -5
  107. package/dist/thread/__tests__/namespace.test.d.ts +2 -0
  108. package/dist/thread/__tests__/namespace.test.d.ts.map +1 -0
  109. package/dist/thread/__tests__/namespace.test.js +131 -0
  110. package/dist/thread/__tests__/thread-persistence.test.d.ts +2 -0
  111. package/dist/thread/__tests__/thread-persistence.test.d.ts.map +1 -0
  112. package/dist/thread/__tests__/thread-persistence.test.js +351 -0
  113. package/dist/thread/__tests__/thread.test.js +49 -51
  114. package/dist/thread/thread.d.ts +70 -18
  115. package/dist/thread/thread.d.ts.map +1 -1
  116. package/dist/thread/thread.js +211 -73
  117. package/dist/thread/utils.d.ts +36 -8
  118. package/dist/thread/utils.d.ts.map +1 -1
  119. package/dist/thread/utils.js +52 -8
  120. package/dist/tool/__tests__/fixtures.js +1 -1
  121. package/dist/tool/__tests__/toolkit.test.js +15 -12
  122. package/dist/tool/tool.js +3 -3
  123. package/dist/types/kernl.d.ts +42 -0
  124. package/dist/types/kernl.d.ts.map +1 -0
  125. package/dist/types/thread.d.ts +108 -22
  126. package/dist/types/thread.d.ts.map +1 -1
  127. package/dist/types/thread.js +12 -0
  128. package/package.json +11 -7
  129. package/src/agent/__tests__/concurrency.test.ts +194 -0
  130. package/src/agent/__tests__/run.test.ts +441 -0
  131. package/src/agent/index.ts +0 -0
  132. package/src/agent.ts +141 -24
  133. package/src/api/__tests__/cursor-page.test.ts +512 -0
  134. package/src/api/__tests__/offset-page.test.ts +624 -0
  135. package/src/api/__tests__/threads.test.ts +415 -0
  136. package/src/api/models/index.ts +6 -0
  137. package/src/api/models/thread.ts +138 -0
  138. package/src/api/pagination/base.ts +79 -0
  139. package/src/api/pagination/cursor.ts +86 -0
  140. package/src/api/pagination/offset.ts +89 -0
  141. package/src/api/resources/threads/events.ts +26 -0
  142. package/src/api/resources/threads/index.ts +9 -0
  143. package/src/api/resources/threads/threads.ts +256 -0
  144. package/src/api/resources/threads/types.ts +143 -0
  145. package/src/api/resources/threads/utils.ts +104 -0
  146. package/src/context.ts +10 -1
  147. package/src/index.ts +49 -1
  148. package/src/internal.ts +15 -0
  149. package/src/kernl.ts +86 -17
  150. package/src/mcp/__tests__/integration.test.ts +8 -9
  151. package/src/mcp/__tests__/utils.test.ts +6 -6
  152. package/src/mcp/http.ts +9 -9
  153. package/src/mcp/sse.ts +7 -7
  154. package/src/mcp/utils.ts +6 -5
  155. package/src/storage/__tests__/in-memory.test.ts +534 -0
  156. package/src/storage/base.ts +77 -0
  157. package/src/storage/in-memory.ts +372 -0
  158. package/src/storage/index.ts +21 -0
  159. package/src/storage/thread.ts +141 -0
  160. package/src/task.ts +12 -10
  161. package/src/thread/__tests__/fixtures/mock-model.ts +2 -4
  162. package/src/thread/__tests__/integration.test.ts +111 -10
  163. package/src/thread/__tests__/namespace.test.ts +158 -0
  164. package/src/thread/__tests__/thread-persistence.test.ts +367 -0
  165. package/src/thread/__tests__/thread.test.ts +52 -54
  166. package/src/thread/thread.ts +247 -96
  167. package/src/thread/utils.ts +76 -13
  168. package/src/tool/__tests__/fixtures.ts +1 -1
  169. package/src/tool/__tests__/toolkit.test.ts +15 -12
  170. package/src/tool/tool.ts +3 -3
  171. package/src/types/kernl.ts +51 -0
  172. package/src/types/thread.ts +139 -25
  173. package/vitest.config.ts +1 -0
  174. package/dist/env.d.ts +0 -45
  175. package/dist/env.d.ts.map +0 -1
  176. package/dist/env.js +0 -31
  177. package/dist/error.d.ts +0 -1
  178. package/dist/error.d.ts.map +0 -1
  179. package/dist/kernel.d.ts +0 -7
  180. package/dist/kernel.d.ts.map +0 -1
  181. package/dist/kernel.js +0 -7
  182. package/dist/lib/serde/__tests__/codec.test.d.ts +0 -2
  183. package/dist/lib/serde/__tests__/codec.test.d.ts.map +0 -1
  184. package/dist/lib/serde/__tests__/codec.test.js +0 -75
  185. package/dist/lib/serde/codec.d.ts +0 -12
  186. package/dist/lib/serde/codec.d.ts.map +0 -1
  187. package/dist/lib/serde/codec.js +0 -54
  188. package/dist/lib/serde/thread.d.ts +0 -1
  189. package/dist/lib/serde/thread.d.ts.map +0 -1
  190. package/dist/lib/serde/thread.js +0 -172
  191. package/dist/lib/serde/tool.d.ts +0 -36
  192. package/dist/lib/serde/tool.d.ts.map +0 -1
  193. package/dist/lib/utils.d.ts +0 -19
  194. package/dist/lib/utils.d.ts.map +0 -1
  195. package/dist/lib/utils.js +0 -41
  196. package/dist/logger.d.ts +0 -36
  197. package/dist/logger.d.ts.map +0 -1
  198. package/dist/logger.js +0 -43
  199. package/dist/mcp/__tests__/fixtures/echo-server.d.ts +0 -3
  200. package/dist/mcp/__tests__/fixtures/echo-server.d.ts.map +0 -1
  201. package/dist/mcp/__tests__/fixtures/echo-server.js +0 -92
  202. package/dist/mcp/__tests__/fixtures/math-server.d.ts +0 -3
  203. package/dist/mcp/__tests__/fixtures/math-server.d.ts.map +0 -1
  204. package/dist/mcp/__tests__/fixtures/math-server.js +0 -98
  205. package/dist/mcp/__tests__/fixtures/test-server.d.ts +0 -3
  206. package/dist/mcp/__tests__/fixtures/test-server.d.ts.map +0 -1
  207. package/dist/mcp/__tests__/fixtures/test-server.js +0 -163
  208. package/dist/mcp/__tests__/test-utils.d.ts +0 -17
  209. package/dist/mcp/__tests__/test-utils.d.ts.map +0 -1
  210. package/dist/mcp/__tests__/test-utils.js +0 -42
  211. package/dist/mcp/node.d.ts +0 -60
  212. package/dist/mcp/node.d.ts.map +0 -1
  213. package/dist/mcp/node.js +0 -297
  214. package/dist/model.d.ts +0 -175
  215. package/dist/model.d.ts.map +0 -1
  216. package/dist/providers/ai.d.ts +0 -1
  217. package/dist/providers/ai.d.ts.map +0 -1
  218. package/dist/providers/ai.js +0 -1
  219. package/dist/providers/default.d.ts +0 -16
  220. package/dist/providers/default.d.ts.map +0 -1
  221. package/dist/providers/default.js +0 -17
  222. package/dist/providers/registry.d.ts +0 -1
  223. package/dist/providers/registry.d.ts.map +0 -1
  224. package/dist/providers/registry.js +0 -1
  225. package/dist/sched/scheduler.d.ts +0 -20
  226. package/dist/sched/scheduler.d.ts.map +0 -1
  227. package/dist/sched/task.d.ts +0 -92
  228. package/dist/sched/task.d.ts.map +0 -1
  229. package/dist/sched/task.js +0 -102
  230. package/dist/serde/__tests__/codec.test.d.ts +0 -2
  231. package/dist/serde/__tests__/codec.test.d.ts.map +0 -1
  232. package/dist/serde/__tests__/codec.test.js +0 -75
  233. package/dist/serde/codec.d.ts +0 -12
  234. package/dist/serde/codec.d.ts.map +0 -1
  235. package/dist/serde/codec.js +0 -54
  236. package/dist/serde/json.d.ts +0 -8
  237. package/dist/serde/json.d.ts.map +0 -1
  238. package/dist/serde/json.js +0 -13
  239. package/dist/serde/thread.d.ts +0 -687
  240. package/dist/serde/thread.d.ts.map +0 -1
  241. package/dist/serde/thread.js +0 -158
  242. package/dist/serde/tool.d.ts +0 -36
  243. package/dist/serde/tool.d.ts.map +0 -1
  244. package/dist/session.d.ts +0 -1
  245. package/dist/session.d.ts.map +0 -1
  246. package/dist/session.js +0 -1
  247. package/dist/thread/__tests__/stream.test.d.ts +0 -2
  248. package/dist/thread/__tests__/stream.test.d.ts.map +0 -1
  249. package/dist/thread/__tests__/stream.test.js +0 -244
  250. package/dist/tool/mcp.d.ts +0 -75
  251. package/dist/tool/mcp.d.ts.map +0 -1
  252. package/dist/tool/mcp.js +0 -111
  253. package/dist/tools.d.ts +0 -362
  254. package/dist/tools.d.ts.map +0 -1
  255. package/dist/tools.js +0 -220
  256. package/dist/types/proto.d.ts +0 -1551
  257. package/dist/types/proto.d.ts.map +0 -1
  258. package/dist/types/proto.js +0 -531
  259. package/dist/usage.d.ts +0 -43
  260. package/dist/usage.d.ts.map +0 -1
  261. package/dist/usage.js +0 -61
  262. package/src/lib/serde/thread.ts +0 -188
  263. /package/dist/{error.js → agent/index.js} +0 -0
  264. /package/dist/{lib/serde/tool.js → api/models/index.js} +0 -0
  265. /package/dist/{model.js → api/models/thread.js} +0 -0
  266. /package/dist/{sched/scheduler.js → api/resources/threads/types.js} +0 -0
  267. /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
@@ -1 +0,0 @@
1
- {"version":3,"file":"model.d.ts","sourceRoot":"","sources":["../src/model.ts"],"names":[],"mappings":"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"}
@@ -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":""}
@@ -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"}
@@ -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
@@ -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"}
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=codec.test.d.ts.map
@@ -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
- });
@@ -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"}
@@ -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
- });
@@ -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
@@ -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"}
@@ -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
- ]));