@dexto/server 1.6.20 → 1.6.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/a2a/jsonrpc/methods.cjs +1 -1
- package/dist/a2a/jsonrpc/methods.d.ts +14 -4
- package/dist/a2a/jsonrpc/methods.d.ts.map +1 -1
- package/dist/a2a/jsonrpc/methods.js +1 -1
- package/dist/approval/wire-approval-events.cjs +44 -0
- package/dist/approval/wire-approval-events.d.ts +4 -0
- package/dist/approval/wire-approval-events.d.ts.map +1 -0
- package/dist/approval/wire-approval-events.js +20 -0
- package/dist/events/session-sse-subscriber.cjs +167 -0
- package/dist/events/session-sse-subscriber.d.ts +13 -0
- package/dist/events/session-sse-subscriber.d.ts.map +1 -0
- package/dist/events/session-sse-subscriber.js +143 -0
- package/dist/hono/__tests__/test-fixtures.cjs +8 -0
- package/dist/hono/__tests__/test-fixtures.d.ts +1 -0
- package/dist/hono/__tests__/test-fixtures.d.ts.map +1 -1
- package/dist/hono/__tests__/test-fixtures.js +8 -0
- package/dist/hono/index.cjs +40 -8
- package/dist/hono/index.d.ts +45 -4531
- package/dist/hono/index.d.ts.map +1 -1
- package/dist/hono/index.js +43 -9
- package/dist/hono/node/index.cjs +51 -6
- package/dist/hono/node/index.d.ts.map +1 -1
- package/dist/hono/node/index.js +51 -6
- package/dist/hono/routes/a2a-jsonrpc.d.ts.map +1 -1
- package/dist/hono/routes/a2a-tasks.cjs +158 -32
- package/dist/hono/routes/a2a-tasks.d.ts +1 -502
- package/dist/hono/routes/a2a-tasks.d.ts.map +1 -1
- package/dist/hono/routes/a2a-tasks.js +162 -32
- package/dist/hono/routes/a2a.d.ts.map +1 -1
- package/dist/hono/routes/agents.cjs +410 -329
- package/dist/hono/routes/agents.d.ts +16043 -68
- package/dist/hono/routes/agents.d.ts.map +1 -1
- package/dist/hono/routes/agents.js +418 -330
- package/dist/hono/routes/approvals.cjs +102 -88
- package/dist/hono/routes/approvals.d.ts +2089 -142
- package/dist/hono/routes/approvals.d.ts.map +1 -1
- package/dist/hono/routes/approvals.js +108 -89
- package/dist/hono/routes/dexto-auth.cjs +40 -33
- package/dist/hono/routes/dexto-auth.d.ts +401 -2
- package/dist/hono/routes/dexto-auth.d.ts.map +1 -1
- package/dist/hono/routes/dexto-auth.js +40 -33
- package/dist/hono/routes/discovery.cjs +16 -14
- package/dist/hono/routes/discovery.d.ts +586 -1
- package/dist/hono/routes/discovery.d.ts.map +1 -1
- package/dist/hono/routes/discovery.js +16 -14
- package/dist/hono/routes/greeting.cjs +26 -22
- package/dist/hono/routes/greeting.d.ts +787 -3
- package/dist/hono/routes/greeting.d.ts.map +1 -1
- package/dist/hono/routes/greeting.js +26 -22
- package/dist/hono/routes/health.d.ts +1 -1
- package/dist/hono/routes/key.cjs +60 -52
- package/dist/hono/routes/key.d.ts +1597 -1
- package/dist/hono/routes/key.d.ts.map +1 -1
- package/dist/hono/routes/key.js +60 -52
- package/dist/hono/routes/llm.cjs +382 -349
- package/dist/hono/routes/llm.d.ts +12148 -98
- package/dist/hono/routes/llm.d.ts.map +1 -1
- package/dist/hono/routes/llm.js +386 -349
- package/dist/hono/routes/mcp.cjs +257 -226
- package/dist/hono/routes/mcp.d.ts +6605 -309
- package/dist/hono/routes/mcp.d.ts.map +1 -1
- package/dist/hono/routes/mcp.js +263 -225
- package/dist/hono/routes/memory.cjs +102 -89
- package/dist/hono/routes/memory.d.ts +5368 -4
- package/dist/hono/routes/memory.d.ts.map +1 -1
- package/dist/hono/routes/memory.js +108 -90
- package/dist/hono/routes/messages.cjs +189 -191
- package/dist/hono/routes/messages.d.ts +3900 -12
- package/dist/hono/routes/messages.d.ts.map +1 -1
- package/dist/hono/routes/messages.js +192 -191
- package/dist/hono/routes/models.cjs +106 -64
- package/dist/hono/routes/models.d.ts +2875 -2
- package/dist/hono/routes/models.d.ts.map +1 -1
- package/dist/hono/routes/models.js +108 -64
- package/dist/hono/routes/openrouter.cjs +79 -65
- package/dist/hono/routes/openrouter.d.ts +854 -1
- package/dist/hono/routes/openrouter.d.ts.map +1 -1
- package/dist/hono/routes/openrouter.js +79 -65
- package/dist/hono/routes/prompts.cjs +136 -109
- package/dist/hono/routes/prompts.d.ts +2818 -10
- package/dist/hono/routes/prompts.d.ts.map +1 -1
- package/dist/hono/routes/prompts.js +138 -109
- package/dist/hono/routes/queue.cjs +133 -120
- package/dist/hono/routes/queue.d.ts +5240 -11
- package/dist/hono/routes/queue.d.ts.map +1 -1
- package/dist/hono/routes/queue.js +136 -120
- package/dist/hono/routes/resources.cjs +65 -46
- package/dist/hono/routes/resources.d.ts +1983 -5
- package/dist/hono/routes/resources.d.ts.map +1 -1
- package/dist/hono/routes/resources.js +72 -47
- package/dist/hono/routes/schedules.cjs +233 -226
- package/dist/hono/routes/schedules.d.ts +4198 -22
- package/dist/hono/routes/schedules.d.ts.map +1 -1
- package/dist/hono/routes/schedules.js +233 -226
- package/dist/hono/routes/search.cjs +34 -30
- package/dist/hono/routes/search.d.ts +3094 -17
- package/dist/hono/routes/search.d.ts.map +1 -1
- package/dist/hono/routes/search.js +40 -31
- package/dist/hono/routes/sessions.cjs +491 -393
- package/dist/hono/routes/sessions.d.ts +18263 -65
- package/dist/hono/routes/sessions.d.ts.map +1 -1
- package/dist/hono/routes/sessions.js +497 -395
- package/dist/hono/routes/static.d.ts.map +1 -1
- package/dist/hono/routes/system-prompt.cjs +57 -61
- package/dist/hono/routes/system-prompt.d.ts +1228 -2
- package/dist/hono/routes/system-prompt.d.ts.map +1 -1
- package/dist/hono/routes/system-prompt.js +58 -62
- package/dist/hono/routes/tools.cjs +29 -34
- package/dist/hono/routes/tools.d.ts +1755 -6
- package/dist/hono/routes/tools.d.ts.map +1 -1
- package/dist/hono/routes/tools.js +33 -33
- package/dist/hono/routes/webhooks.cjs +115 -123
- package/dist/hono/routes/webhooks.d.ts +2501 -11
- package/dist/hono/routes/webhooks.d.ts.map +1 -1
- package/dist/hono/routes/webhooks.js +120 -124
- package/dist/hono/routes/workspaces.cjs +84 -79
- package/dist/hono/routes/workspaces.d.ts +2093 -2
- package/dist/hono/routes/workspaces.d.ts.map +1 -1
- package/dist/hono/routes/workspaces.js +89 -80
- package/dist/hono/schemas/responses.cjs +463 -260
- package/dist/hono/schemas/responses.d.ts +1893 -209
- package/dist/hono/schemas/responses.d.ts.map +1 -1
- package/dist/hono/schemas/responses.js +203 -14
- package/dist/hono/start-server.cjs +9 -0
- package/dist/hono/start-server.d.ts.map +1 -1
- package/dist/hono/start-server.js +9 -0
- package/dist/hono/types.d.ts +11 -0
- package/dist/hono/types.d.ts.map +1 -1
- package/dist/index.cjs +5 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/package.json +7 -7
|
@@ -25,6 +25,7 @@ var import_zod_openapi = require("@hono/zod-openapi");
|
|
|
25
25
|
var import_fs = require("fs");
|
|
26
26
|
var import_core = require("@dexto/core");
|
|
27
27
|
var import_agent_management = require("@dexto/agent-management");
|
|
28
|
+
var import_responses = require("../schemas/responses.js");
|
|
28
29
|
const LocalModelSchema = import_zod_openapi.z.object({
|
|
29
30
|
id: import_zod_openapi.z.string().describe("Model identifier"),
|
|
30
31
|
displayName: import_zod_openapi.z.string().describe("Human-readable model name"),
|
|
@@ -63,7 +64,8 @@ const listLocalModelsRoute = (0, import_zod_openapi.createRoute)({
|
|
|
63
64
|
})
|
|
64
65
|
}
|
|
65
66
|
}
|
|
66
|
-
}
|
|
67
|
+
},
|
|
68
|
+
500: import_responses.InternalErrorResponse
|
|
67
69
|
}
|
|
68
70
|
});
|
|
69
71
|
const listOllamaModelsRoute = (0, import_zod_openapi.createRoute)({
|
|
@@ -90,7 +92,9 @@ const listOllamaModelsRoute = (0, import_zod_openapi.createRoute)({
|
|
|
90
92
|
})
|
|
91
93
|
}
|
|
92
94
|
}
|
|
93
|
-
}
|
|
95
|
+
},
|
|
96
|
+
400: import_responses.BadRequestErrorResponse,
|
|
97
|
+
500: import_responses.InternalErrorResponse
|
|
94
98
|
}
|
|
95
99
|
});
|
|
96
100
|
const validateLocalFileRoute = (0, import_zod_openapi.createRoute)({
|
|
@@ -116,7 +120,9 @@ const validateLocalFileRoute = (0, import_zod_openapi.createRoute)({
|
|
|
116
120
|
schema: ValidateFileResponseSchema
|
|
117
121
|
}
|
|
118
122
|
}
|
|
119
|
-
}
|
|
123
|
+
},
|
|
124
|
+
400: import_responses.BadRequestErrorResponse,
|
|
125
|
+
500: import_responses.InternalErrorResponse
|
|
120
126
|
}
|
|
121
127
|
});
|
|
122
128
|
const DeleteModelRequestSchema = import_zod_openapi.z.object({
|
|
@@ -163,7 +169,9 @@ const deleteLocalModelRoute = (0, import_zod_openapi.createRoute)({
|
|
|
163
169
|
schema: DeleteModelResponseSchema
|
|
164
170
|
}
|
|
165
171
|
}
|
|
166
|
-
}
|
|
172
|
+
},
|
|
173
|
+
400: import_responses.BadRequestErrorResponse,
|
|
174
|
+
500: import_responses.InternalErrorResponse
|
|
167
175
|
}
|
|
168
176
|
});
|
|
169
177
|
function createModelsRouter() {
|
|
@@ -181,82 +189,112 @@ function createModelsRouter() {
|
|
|
181
189
|
source: model.source
|
|
182
190
|
};
|
|
183
191
|
});
|
|
184
|
-
return ctx.json({ models });
|
|
192
|
+
return ctx.json({ models }, 200);
|
|
185
193
|
}).openapi(listOllamaModelsRoute, async (ctx) => {
|
|
186
194
|
const { baseURL } = ctx.req.valid("query");
|
|
187
195
|
const ollamaURL = baseURL || import_core.DEFAULT_OLLAMA_URL;
|
|
188
196
|
try {
|
|
189
197
|
const status = await (0, import_core.checkOllamaStatus)(ollamaURL);
|
|
190
198
|
if (!status.running) {
|
|
191
|
-
return ctx.json(
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
199
|
+
return ctx.json(
|
|
200
|
+
{
|
|
201
|
+
available: false,
|
|
202
|
+
models: [],
|
|
203
|
+
error: "Ollama server is not running"
|
|
204
|
+
},
|
|
205
|
+
200
|
|
206
|
+
);
|
|
196
207
|
}
|
|
197
208
|
const ollamaModels = await (0, import_core.listOllamaModels)(ollamaURL);
|
|
198
|
-
return ctx.json(
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
209
|
+
return ctx.json(
|
|
210
|
+
{
|
|
211
|
+
available: true,
|
|
212
|
+
version: status.version,
|
|
213
|
+
models: ollamaModels.map((m) => ({
|
|
214
|
+
name: m.name,
|
|
215
|
+
size: m.size,
|
|
216
|
+
digest: m.digest,
|
|
217
|
+
modifiedAt: m.modifiedAt
|
|
218
|
+
}))
|
|
219
|
+
},
|
|
220
|
+
200
|
|
221
|
+
);
|
|
208
222
|
} catch (error) {
|
|
209
|
-
return ctx.json(
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
223
|
+
return ctx.json(
|
|
224
|
+
{
|
|
225
|
+
available: false,
|
|
226
|
+
models: [],
|
|
227
|
+
error: error instanceof Error ? error.message : "Failed to connect to Ollama server"
|
|
228
|
+
},
|
|
229
|
+
200
|
|
230
|
+
);
|
|
214
231
|
}
|
|
215
232
|
}).openapi(validateLocalFileRoute, async (ctx) => {
|
|
216
233
|
const { filePath } = ctx.req.valid("json");
|
|
217
234
|
if (!filePath.startsWith("/")) {
|
|
218
|
-
return ctx.json(
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
235
|
+
return ctx.json(
|
|
236
|
+
{
|
|
237
|
+
valid: false,
|
|
238
|
+
error: "File path must be absolute (start with /)"
|
|
239
|
+
},
|
|
240
|
+
200
|
|
241
|
+
);
|
|
222
242
|
}
|
|
223
243
|
if (!filePath.endsWith(".gguf")) {
|
|
224
|
-
return ctx.json(
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
244
|
+
return ctx.json(
|
|
245
|
+
{
|
|
246
|
+
valid: false,
|
|
247
|
+
error: "File must have .gguf extension"
|
|
248
|
+
},
|
|
249
|
+
200
|
|
250
|
+
);
|
|
228
251
|
}
|
|
229
252
|
try {
|
|
230
253
|
const stats = await import_fs.promises.stat(filePath);
|
|
231
254
|
if (!stats.isFile()) {
|
|
232
|
-
return ctx.json(
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
255
|
+
return ctx.json(
|
|
256
|
+
{
|
|
257
|
+
valid: false,
|
|
258
|
+
error: "Path is not a file"
|
|
259
|
+
},
|
|
260
|
+
200
|
|
261
|
+
);
|
|
236
262
|
}
|
|
237
263
|
await import_fs.promises.access(filePath, import_fs.promises.constants.R_OK);
|
|
238
|
-
return ctx.json(
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
264
|
+
return ctx.json(
|
|
265
|
+
{
|
|
266
|
+
valid: true,
|
|
267
|
+
sizeBytes: stats.size
|
|
268
|
+
},
|
|
269
|
+
200
|
|
270
|
+
);
|
|
242
271
|
} catch (error) {
|
|
243
272
|
const nodeError = error;
|
|
244
273
|
if (nodeError.code === "ENOENT") {
|
|
245
|
-
return ctx.json(
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
274
|
+
return ctx.json(
|
|
275
|
+
{
|
|
276
|
+
valid: false,
|
|
277
|
+
error: "File not found"
|
|
278
|
+
},
|
|
279
|
+
200
|
|
280
|
+
);
|
|
249
281
|
}
|
|
250
282
|
if (nodeError.code === "EACCES") {
|
|
251
|
-
return ctx.json(
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
283
|
+
return ctx.json(
|
|
284
|
+
{
|
|
285
|
+
valid: false,
|
|
286
|
+
error: "File is not readable (permission denied)"
|
|
287
|
+
},
|
|
288
|
+
200
|
|
289
|
+
);
|
|
255
290
|
}
|
|
256
|
-
return ctx.json(
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
291
|
+
return ctx.json(
|
|
292
|
+
{
|
|
293
|
+
valid: false,
|
|
294
|
+
error: error instanceof Error ? error.message : "Failed to access file"
|
|
295
|
+
},
|
|
296
|
+
200
|
|
297
|
+
);
|
|
260
298
|
}
|
|
261
299
|
}).openapi(deleteLocalModelRoute, async (ctx) => {
|
|
262
300
|
const { modelId } = ctx.req.valid("param");
|
|
@@ -299,18 +337,22 @@ function createModelsRouter() {
|
|
|
299
337
|
}
|
|
300
338
|
const removed = await (0, import_agent_management.removeInstalledModel)(modelId);
|
|
301
339
|
if (!removed) {
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
340
|
+
throw new import_core.DextoRuntimeError(
|
|
341
|
+
"model_state_remove_failed",
|
|
342
|
+
"model",
|
|
343
|
+
import_core.ErrorType.SYSTEM,
|
|
344
|
+
"Failed to remove model from state",
|
|
345
|
+
{ modelId, fileDeleted }
|
|
346
|
+
);
|
|
308
347
|
}
|
|
309
|
-
return ctx.json(
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
348
|
+
return ctx.json(
|
|
349
|
+
{
|
|
350
|
+
success: true,
|
|
351
|
+
modelId,
|
|
352
|
+
fileDeleted
|
|
353
|
+
},
|
|
354
|
+
200
|
|
355
|
+
);
|
|
314
356
|
});
|
|
315
357
|
}
|
|
316
358
|
// Annotate the CommonJS export names for ESM import in node:
|