bonecode 1.1.0 → 1.2.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.
- package/bin/bonecode +47 -42
- package/compat/opencode_adapter.ts +188 -17
- package/dist/bone/output/agent/src/algorithms.d.ts +1 -0
- package/dist/bone/output/agent/src/algorithms.js +3 -0
- package/dist/bone/output/agent/src/algorithms.js.map +1 -0
- package/dist/bone/output/agent/src/audit.d.ts +3 -0
- package/dist/bone/output/agent/src/audit.js +40 -0
- package/dist/bone/output/agent/src/audit.js.map +1 -0
- package/dist/bone/output/agent/src/auth.d.ts +8 -0
- package/dist/bone/output/agent/src/auth.js +56 -0
- package/dist/bone/output/agent/src/auth.js.map +1 -0
- package/dist/bone/output/agent/src/db.d.ts +6 -0
- package/dist/bone/output/agent/src/db.js +63 -0
- package/dist/bone/output/agent/src/db.js.map +1 -0
- package/dist/bone/output/agent/src/events.d.ts +25 -0
- package/dist/bone/output/agent/src/events.js +184 -0
- package/dist/bone/output/agent/src/events.js.map +1 -0
- package/dist/bone/output/agent/src/logger.d.ts +28 -0
- package/dist/bone/output/agent/src/logger.js +45 -0
- package/dist/bone/output/agent/src/logger.js.map +1 -0
- package/dist/bone/output/agent/src/metrics.d.ts +5 -0
- package/dist/bone/output/agent/src/metrics.js +60 -0
- package/dist/bone/output/agent/src/metrics.js.map +1 -0
- package/dist/bone/output/agent/src/routes/agent_instance.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/agent_instance.js +253 -0
- package/dist/bone/output/agent/src/routes/agent_instance.js.map +1 -0
- package/dist/bone/output/agent/src/routes/build_step.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/build_step.js +133 -0
- package/dist/bone/output/agent/src/routes/build_step.js.map +1 -0
- package/dist/bone/output/agent/src/routes/plan.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/plan.js +119 -0
- package/dist/bone/output/agent/src/routes/plan.js.map +1 -0
- package/dist/bone/output/agent/src/routes/task.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/task.js +133 -0
- package/dist/bone/output/agent/src/routes/task.js.map +1 -0
- package/dist/bone/output/agent/src/routes/tool_call.d.ts +1 -0
- package/dist/bone/output/agent/src/routes/tool_call.js +190 -0
- package/dist/bone/output/agent/src/routes/tool_call.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/agent_instance.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/agent_instance.js +22 -0
- package/dist/bone/output/agent/src/state_machines/agent_instance.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/build_step.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/build_step.js +20 -0
- package/dist/bone/output/agent/src/state_machines/build_step.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/plan.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/plan.js +20 -0
- package/dist/bone/output/agent/src/state_machines/plan.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/task.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/task.js +20 -0
- package/dist/bone/output/agent/src/state_machines/task.js.map +1 -0
- package/dist/bone/output/agent/src/state_machines/tool_call.d.ts +9 -0
- package/dist/bone/output/agent/src/state_machines/tool_call.js +20 -0
- package/dist/bone/output/agent/src/state_machines/tool_call.js.map +1 -0
- package/dist/bone/output/rag/src/algorithms.d.ts +1 -0
- package/dist/bone/output/rag/src/algorithms.js +3 -0
- package/dist/bone/output/rag/src/algorithms.js.map +1 -0
- package/dist/bone/output/rag/src/auth.d.ts +8 -0
- package/dist/bone/output/rag/src/auth.js +56 -0
- package/dist/bone/output/rag/src/auth.js.map +1 -0
- package/dist/bone/output/rag/src/db.d.ts +6 -0
- package/dist/bone/output/rag/src/db.js +63 -0
- package/dist/bone/output/rag/src/db.js.map +1 -0
- package/dist/bone/output/rag/src/events.d.ts +25 -0
- package/dist/bone/output/rag/src/events.js +184 -0
- package/dist/bone/output/rag/src/events.js.map +1 -0
- package/dist/bone/output/rag/src/extensions.d.ts +83 -0
- package/dist/bone/output/rag/src/extensions.js +329 -0
- package/dist/bone/output/rag/src/extensions.js.map +1 -0
- package/dist/bone/output/rag/src/flows.d.ts +24 -0
- package/dist/bone/output/rag/src/flows.js +236 -0
- package/dist/bone/output/rag/src/flows.js.map +1 -0
- package/dist/bone/output/rag/src/logger.d.ts +28 -0
- package/dist/bone/output/rag/src/logger.js +45 -0
- package/dist/bone/output/rag/src/logger.js.map +1 -0
- package/dist/bone/output/rag/src/metrics.d.ts +5 -0
- package/dist/bone/output/rag/src/metrics.js +60 -0
- package/dist/bone/output/rag/src/metrics.js.map +1 -0
- package/dist/bone/output/rag/src/routes/code_chunk.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/code_chunk.js +100 -0
- package/dist/bone/output/rag/src/routes/code_chunk.js.map +1 -0
- package/dist/bone/output/rag/src/routes/code_file.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/code_file.js +127 -0
- package/dist/bone/output/rag/src/routes/code_file.js.map +1 -0
- package/dist/bone/output/rag/src/routes/indexing_job.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/indexing_job.js +113 -0
- package/dist/bone/output/rag/src/routes/indexing_job.js.map +1 -0
- package/dist/bone/output/rag/src/routes/knowledge_base.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/knowledge_base.js +242 -0
- package/dist/bone/output/rag/src/routes/knowledge_base.js.map +1 -0
- package/dist/bone/output/rag/src/routes/memory_entry.d.ts +1 -0
- package/dist/bone/output/rag/src/routes/memory_entry.js +113 -0
- package/dist/bone/output/rag/src/routes/memory_entry.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/code_file.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/code_file.js +21 -0
- package/dist/bone/output/rag/src/state_machines/code_file.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/indexing_job.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/indexing_job.js +20 -0
- package/dist/bone/output/rag/src/state_machines/indexing_job.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/knowledge_base.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/knowledge_base.js +21 -0
- package/dist/bone/output/rag/src/state_machines/knowledge_base.js.map +1 -0
- package/dist/bone/output/rag/src/state_machines/memory_entry.d.ts +9 -0
- package/dist/bone/output/rag/src/state_machines/memory_entry.js +18 -0
- package/dist/bone/output/rag/src/state_machines/memory_entry.js.map +1 -0
- package/dist/bone/output/session/src/algorithms.d.ts +1 -0
- package/dist/bone/output/session/src/algorithms.js +3 -0
- package/dist/bone/output/session/src/algorithms.js.map +1 -0
- package/dist/bone/output/session/src/audit.d.ts +3 -0
- package/dist/bone/output/session/src/audit.js +40 -0
- package/dist/bone/output/session/src/audit.js.map +1 -0
- package/dist/bone/output/session/src/auth.d.ts +8 -0
- package/dist/bone/output/session/src/auth.js +56 -0
- package/dist/bone/output/session/src/auth.js.map +1 -0
- package/dist/bone/output/session/src/db.d.ts +6 -0
- package/dist/bone/output/session/src/db.js +63 -0
- package/dist/bone/output/session/src/db.js.map +1 -0
- package/dist/bone/output/session/src/events.d.ts +26 -0
- package/dist/bone/output/session/src/events.js +212 -0
- package/dist/bone/output/session/src/events.js.map +1 -0
- package/dist/bone/output/session/src/extensions.d.ts +41 -0
- package/dist/bone/output/session/src/extensions.js +217 -0
- package/dist/bone/output/session/src/extensions.js.map +1 -0
- package/dist/bone/output/session/src/logger.d.ts +28 -0
- package/dist/bone/output/session/src/logger.js +44 -0
- package/dist/bone/output/session/src/logger.js.map +1 -0
- package/dist/bone/output/session/src/metrics.d.ts +5 -0
- package/dist/bone/output/session/src/metrics.js +60 -0
- package/dist/bone/output/session/src/metrics.js.map +1 -0
- package/dist/bone/output/session/src/routes/message.d.ts +1 -0
- package/dist/bone/output/session/src/routes/message.js +120 -0
- package/dist/bone/output/session/src/routes/message.js.map +1 -0
- package/dist/bone/output/session/src/routes/part.d.ts +1 -0
- package/dist/bone/output/session/src/routes/part.js +106 -0
- package/dist/bone/output/session/src/routes/part.js.map +1 -0
- package/dist/bone/output/session/src/routes/permission.d.ts +1 -0
- package/dist/bone/output/session/src/routes/permission.js +106 -0
- package/dist/bone/output/session/src/routes/permission.js.map +1 -0
- package/dist/bone/output/session/src/routes/project.d.ts +1 -0
- package/dist/bone/output/session/src/routes/project.js +106 -0
- package/dist/bone/output/session/src/routes/project.js.map +1 -0
- package/dist/bone/output/session/src/routes/session.d.ts +1 -0
- package/dist/bone/output/session/src/routes/session.js +308 -0
- package/dist/bone/output/session/src/routes/session.js.map +1 -0
- package/dist/bone/output/session/src/state_machines/session.d.ts +9 -0
- package/dist/bone/output/session/src/state_machines/session.js +21 -0
- package/dist/bone/output/session/src/state_machines/session.js.map +1 -0
- package/dist/bone/output/session/src/websocket.d.ts +15 -0
- package/dist/bone/output/session/src/websocket.js +215 -0
- package/dist/bone/output/session/src/websocket.js.map +1 -0
- package/dist/bone/output/workspace/src/algorithms.d.ts +1 -0
- package/dist/bone/output/workspace/src/algorithms.js +3 -0
- package/dist/bone/output/workspace/src/algorithms.js.map +1 -0
- package/dist/bone/output/workspace/src/auth.d.ts +8 -0
- package/dist/bone/output/workspace/src/auth.js +56 -0
- package/dist/bone/output/workspace/src/auth.js.map +1 -0
- package/dist/bone/output/workspace/src/db.d.ts +6 -0
- package/dist/bone/output/workspace/src/db.js +63 -0
- package/dist/bone/output/workspace/src/db.js.map +1 -0
- package/dist/bone/output/workspace/src/events.d.ts +25 -0
- package/dist/bone/output/workspace/src/events.js +184 -0
- package/dist/bone/output/workspace/src/events.js.map +1 -0
- package/dist/bone/output/workspace/src/logger.d.ts +28 -0
- package/dist/bone/output/workspace/src/logger.js +45 -0
- package/dist/bone/output/workspace/src/logger.js.map +1 -0
- package/dist/bone/output/workspace/src/metrics.d.ts +5 -0
- package/dist/bone/output/workspace/src/metrics.js +60 -0
- package/dist/bone/output/workspace/src/metrics.js.map +1 -0
- package/dist/bone/output/workspace/src/routes/codebase.d.ts +1 -0
- package/dist/bone/output/workspace/src/routes/codebase.js +113 -0
- package/dist/bone/output/workspace/src/routes/codebase.js.map +1 -0
- package/dist/bone/output/workspace/src/routes/snapshot.d.ts +1 -0
- package/dist/bone/output/workspace/src/routes/snapshot.js +151 -0
- package/dist/bone/output/workspace/src/routes/snapshot.js.map +1 -0
- package/dist/bone/output/workspace/src/routes/workspace.d.ts +1 -0
- package/dist/bone/output/workspace/src/routes/workspace.js +209 -0
- package/dist/bone/output/workspace/src/routes/workspace.js.map +1 -0
- package/dist/bone/output/workspace/src/state_machines/codebase.d.ts +9 -0
- package/dist/bone/output/workspace/src/state_machines/codebase.js +19 -0
- package/dist/bone/output/workspace/src/state_machines/codebase.js.map +1 -0
- package/dist/bone/output/workspace/src/state_machines/snapshot.d.ts +9 -0
- package/dist/bone/output/workspace/src/state_machines/snapshot.js +18 -0
- package/dist/bone/output/workspace/src/state_machines/snapshot.js.map +1 -0
- package/dist/bone/output/workspace/src/state_machines/workspace.d.ts +9 -0
- package/dist/bone/output/workspace/src/state_machines/workspace.js +19 -0
- package/dist/bone/output/workspace/src/state_machines/workspace.js.map +1 -0
- package/dist/compat/opencode_adapter.d.ts +25 -0
- package/dist/compat/opencode_adapter.js +599 -0
- package/dist/compat/opencode_adapter.js.map +1 -0
- package/dist/extensions/chunker.d.ts +24 -0
- package/dist/extensions/chunker.js +360 -0
- package/dist/extensions/chunker.js.map +1 -0
- package/dist/extensions/embedding_provider.d.ts +18 -0
- package/dist/extensions/embedding_provider.js +150 -0
- package/dist/extensions/embedding_provider.js.map +1 -0
- package/dist/extensions/llm_provider.d.ts +33 -0
- package/dist/extensions/llm_provider.js +338 -0
- package/dist/extensions/llm_provider.js.map +1 -0
- package/dist/extensions/mcp_bridge.d.ts +44 -0
- package/dist/extensions/mcp_bridge.js +151 -0
- package/dist/extensions/mcp_bridge.js.map +1 -0
- package/dist/extensions/rag_search.d.ts +38 -0
- package/dist/extensions/rag_search.js +242 -0
- package/dist/extensions/rag_search.js.map +1 -0
- package/dist/extensions/snapshot.d.ts +14 -0
- package/dist/extensions/snapshot.js +158 -0
- package/dist/extensions/snapshot.js.map +1 -0
- package/dist/extensions/tool_executor.d.ts +28 -0
- package/dist/extensions/tool_executor.js +268 -0
- package/dist/extensions/tool_executor.js.map +1 -0
- package/dist/src/cli.d.ts +15 -0
- package/dist/src/cli.js +687 -0
- package/dist/src/cli.js.map +1 -0
- package/dist/src/config.d.ts +44 -0
- package/dist/src/config.js +165 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/context_builder.d.ts +51 -0
- package/dist/src/context_builder.js +558 -0
- package/dist/src/context_builder.js.map +1 -0
- package/dist/src/db_adapter.d.ts +24 -0
- package/dist/src/db_adapter.js +341 -0
- package/dist/src/db_adapter.js.map +1 -0
- package/dist/src/engine/session/compaction_logic.d.ts +11 -0
- package/dist/src/engine/session/compaction_logic.js +113 -0
- package/dist/src/engine/session/compaction_logic.js.map +1 -0
- package/dist/src/engine/session/instruction_loader.d.ts +5 -0
- package/dist/src/engine/session/instruction_loader.js +78 -0
- package/dist/src/engine/session/instruction_loader.js.map +1 -0
- package/dist/src/engine/session/overflow_check.d.ts +14 -0
- package/dist/src/engine/session/overflow_check.js +45 -0
- package/dist/src/engine/session/overflow_check.js.map +1 -0
- package/dist/src/engine/session/prompt.d.ts +45 -0
- package/dist/src/engine/session/prompt.js +584 -0
- package/dist/src/engine/session/prompt.js.map +1 -0
- package/dist/src/engine/session/provider_transform.d.ts +59 -0
- package/dist/src/engine/session/provider_transform.js +193 -0
- package/dist/src/engine/session/provider_transform.js.map +1 -0
- package/dist/src/engine/session/retry_logic.d.ts +12 -0
- package/dist/src/engine/session/retry_logic.js +72 -0
- package/dist/src/engine/session/retry_logic.js.map +1 -0
- package/dist/src/engine/session/system_prompt.d.ts +9 -0
- package/dist/src/engine/session/system_prompt.js +96 -0
- package/dist/src/engine/session/system_prompt.js.map +1 -0
- package/dist/src/engine/session/tool_registry.d.ts +5 -0
- package/dist/src/engine/session/tool_registry.js +117 -0
- package/dist/src/engine/session/tool_registry.js.map +1 -0
- package/dist/src/export.d.ts +13 -0
- package/dist/src/export.js +103 -0
- package/dist/src/export.js.map +1 -0
- package/dist/src/mdns.d.ts +7 -0
- package/dist/src/mdns.js +60 -0
- package/dist/src/mdns.js.map +1 -0
- package/dist/src/rag_worker.d.ts +38 -0
- package/dist/src/rag_worker.js +435 -0
- package/dist/src/rag_worker.js.map +1 -0
- package/dist/src/server.d.ts +11 -0
- package/dist/src/server.js +214 -0
- package/dist/src/server.js.map +1 -0
- package/dist/src/stats.d.ts +45 -0
- package/dist/src/stats.js +233 -0
- package/dist/src/stats.js.map +1 -0
- package/dist/src/tui.d.ts +29 -0
- package/dist/src/tui.js +1053 -0
- package/dist/src/tui.js.map +1 -0
- package/package.json +7 -4
- package/src/cli.ts +247 -5
- package/src/export.ts +122 -0
- package/src/mdns.ts +53 -0
- package/src/server.ts +32 -0
- package/src/stats.ts +290 -0
- package/src/tui.ts +749 -248
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
3
|
+
// Durable event bus with transactional outbox pattern.
|
|
4
|
+
// Set EVENT_MODE=durable in .env to enable.
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.eventBus = void 0;
|
|
7
|
+
const uuid_1 = require("uuid");
|
|
8
|
+
const db_1 = require("./db");
|
|
9
|
+
const logger_1 = require("./logger");
|
|
10
|
+
const metrics_1 = require("./metrics");
|
|
11
|
+
const MODE = process.env.EVENT_MODE || "in_process";
|
|
12
|
+
// Events requiring exactly_once delivery (deduplicated)
|
|
13
|
+
const EXACTLY_ONCE_EVENTS = new Set(["AgentCompleted"]);
|
|
14
|
+
// Events requiring at_least_once delivery (retried until ack)
|
|
15
|
+
const AT_LEAST_ONCE_EVENTS = new Set(["AgentStarted", "AgentFailed", "ToolCallRequested", "ToolCallCompleted", "PermissionRequired"]);
|
|
16
|
+
// ─── In-Process Bus ──────────────────────────────────────────────────────────
|
|
17
|
+
class InProcessBus {
|
|
18
|
+
constructor() {
|
|
19
|
+
this.handlers = new Map();
|
|
20
|
+
}
|
|
21
|
+
subscribe(type, handler) {
|
|
22
|
+
const existing = this.handlers.get(type) || [];
|
|
23
|
+
existing.push(handler);
|
|
24
|
+
this.handlers.set(type, existing);
|
|
25
|
+
}
|
|
26
|
+
async publish(type, payload, source, correlationId) {
|
|
27
|
+
const event = {
|
|
28
|
+
type,
|
|
29
|
+
payload,
|
|
30
|
+
metadata: {
|
|
31
|
+
source,
|
|
32
|
+
timestamp: new Date(),
|
|
33
|
+
correlation_id: correlationId || (0, uuid_1.v4)(),
|
|
34
|
+
causation_id: (0, uuid_1.v4)(),
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
(0, metrics_1.counter)("event.published", { type, mode: "in_process" });
|
|
38
|
+
const handlers = this.handlers.get(type) || [];
|
|
39
|
+
for (const handler of handlers) {
|
|
40
|
+
try {
|
|
41
|
+
await handler(event);
|
|
42
|
+
(0, metrics_1.counter)("event.delivered", { type, mode: "in_process" });
|
|
43
|
+
}
|
|
44
|
+
catch (e) {
|
|
45
|
+
(0, metrics_1.counter)("event.delivery_failed", { type, mode: "in_process" });
|
|
46
|
+
logger_1.logger.error("event_handler_failed", { event: type, metadata: { error: e.message } });
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// ─── Durable Bus (Transactional Outbox) ──────────────────────────────────────
|
|
52
|
+
class DurableBus {
|
|
53
|
+
constructor() {
|
|
54
|
+
this.handlers = new Map();
|
|
55
|
+
}
|
|
56
|
+
subscribe(type, handler) {
|
|
57
|
+
const existing = this.handlers.get(type) || [];
|
|
58
|
+
existing.push(handler);
|
|
59
|
+
this.handlers.set(type, existing);
|
|
60
|
+
}
|
|
61
|
+
// Write event to outbox within the current transaction (or a new one)
|
|
62
|
+
async publish(type, payload, source, correlationId, client) {
|
|
63
|
+
const eventId = (0, uuid_1.v4)();
|
|
64
|
+
const corrId = correlationId || (0, uuid_1.v4)();
|
|
65
|
+
const sql = `
|
|
66
|
+
INSERT INTO event_outbox (id, event_type, payload, source, correlation_id)
|
|
67
|
+
VALUES ($1, $2, $3, $4, $5)
|
|
68
|
+
`;
|
|
69
|
+
const params = [eventId, type, JSON.stringify({ ...payload, _event_id: eventId }), source, corrId];
|
|
70
|
+
if (client) {
|
|
71
|
+
// Write within caller's transaction — atomicity guaranteed
|
|
72
|
+
await client.query(sql, params);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
await db_1.pool.query(sql, params);
|
|
76
|
+
}
|
|
77
|
+
(0, metrics_1.counter)("event.outboxed", { type });
|
|
78
|
+
}
|
|
79
|
+
// Called by the background worker
|
|
80
|
+
async flush() {
|
|
81
|
+
const client = await db_1.pool.connect();
|
|
82
|
+
try {
|
|
83
|
+
await client.query("BEGIN");
|
|
84
|
+
// Fetch pending events (lock rows to prevent concurrent processing)
|
|
85
|
+
const { rows } = await client.query(`
|
|
86
|
+
SELECT id, event_type, payload, source, correlation_id, attempts
|
|
87
|
+
FROM event_outbox
|
|
88
|
+
WHERE status = 'pending' AND scheduled_at <= NOW()
|
|
89
|
+
ORDER BY scheduled_at ASC
|
|
90
|
+
LIMIT 50
|
|
91
|
+
FOR UPDATE SKIP LOCKED
|
|
92
|
+
`);
|
|
93
|
+
for (const row of rows) {
|
|
94
|
+
try {
|
|
95
|
+
// exactly_once: check deduplication table
|
|
96
|
+
if (EXACTLY_ONCE_EVENTS.has(row.event_type)) {
|
|
97
|
+
const { rows: dup } = await client.query("SELECT 1 FROM event_processed WHERE event_id = $1", [row.payload._event_id || row.id]);
|
|
98
|
+
if (dup.length > 0) {
|
|
99
|
+
await client.query("UPDATE event_outbox SET status = 'delivered', delivered_at = NOW() WHERE id = $1", [row.id]);
|
|
100
|
+
continue;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
const event = {
|
|
104
|
+
type: row.event_type,
|
|
105
|
+
payload: row.payload,
|
|
106
|
+
metadata: {
|
|
107
|
+
source: row.source,
|
|
108
|
+
timestamp: new Date(),
|
|
109
|
+
correlation_id: row.correlation_id,
|
|
110
|
+
causation_id: (0, uuid_1.v4)(),
|
|
111
|
+
},
|
|
112
|
+
};
|
|
113
|
+
const handlers = this.handlers.get(row.event_type) || [];
|
|
114
|
+
for (const handler of handlers) {
|
|
115
|
+
await handler(event);
|
|
116
|
+
}
|
|
117
|
+
// Mark delivered
|
|
118
|
+
await client.query("UPDATE event_outbox SET status = 'delivered', delivered_at = NOW(), attempts = attempts + 1 WHERE id = $1", [row.id]);
|
|
119
|
+
// Record for exactly_once deduplication
|
|
120
|
+
if (EXACTLY_ONCE_EVENTS.has(row.event_type)) {
|
|
121
|
+
await client.query("INSERT INTO event_processed (event_id, event_type) VALUES ($1, $2) ON CONFLICT DO NOTHING", [row.payload._event_id || row.id, row.event_type]);
|
|
122
|
+
}
|
|
123
|
+
(0, metrics_1.counter)("event.delivered", { type: row.event_type, mode: "durable" });
|
|
124
|
+
}
|
|
125
|
+
catch (e) {
|
|
126
|
+
const maxAttempts = AT_LEAST_ONCE_EVENTS.has(row.event_type) ? 10 : 3;
|
|
127
|
+
const newAttempts = row.attempts + 1;
|
|
128
|
+
const status = newAttempts >= maxAttempts ? "dead_letter" : "pending";
|
|
129
|
+
const backoffMs = Math.min(1000 * Math.pow(2, newAttempts), 300000);
|
|
130
|
+
await client.query(`UPDATE event_outbox
|
|
131
|
+
SET attempts = $1, last_error = $2, status = $3,
|
|
132
|
+
scheduled_at = NOW() + ($4 || ' milliseconds')::interval
|
|
133
|
+
WHERE id = $5`, [newAttempts, e.message, status, backoffMs, row.id]);
|
|
134
|
+
(0, metrics_1.counter)("event.delivery_failed", { type: row.event_type, mode: "durable" });
|
|
135
|
+
logger_1.logger.error("event_delivery_failed", { event: row.event_type, metadata: { error: e.message, attempts: newAttempts } });
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
await client.query("COMMIT");
|
|
139
|
+
}
|
|
140
|
+
catch (e) {
|
|
141
|
+
await client.query("ROLLBACK");
|
|
142
|
+
throw e;
|
|
143
|
+
}
|
|
144
|
+
finally {
|
|
145
|
+
client.release();
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
// Start background worker
|
|
149
|
+
startWorker(intervalMs = 1000) {
|
|
150
|
+
logger_1.logger.info("event_worker_started", { event: "startup", metadata: { interval_ms: intervalMs } });
|
|
151
|
+
return setInterval(async () => {
|
|
152
|
+
try {
|
|
153
|
+
await this.flush();
|
|
154
|
+
}
|
|
155
|
+
catch (e) {
|
|
156
|
+
logger_1.logger.error("event_worker_error", { event: "flush_failed", metadata: { error: e.message } });
|
|
157
|
+
}
|
|
158
|
+
}, intervalMs);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
// ─── Unified Interface ────────────────────────────────────────────────────────
|
|
162
|
+
const inProcess = new InProcessBus();
|
|
163
|
+
const durable = new DurableBus();
|
|
164
|
+
exports.eventBus = {
|
|
165
|
+
subscribe(type, handler) {
|
|
166
|
+
inProcess.subscribe(type, handler);
|
|
167
|
+
durable.subscribe(type, handler);
|
|
168
|
+
},
|
|
169
|
+
async publish(type, payload, source, correlationId, client) {
|
|
170
|
+
if (MODE === "durable") {
|
|
171
|
+
await durable.publish(type, payload, source, correlationId, client);
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
await inProcess.publish(type, payload, source, correlationId);
|
|
175
|
+
}
|
|
176
|
+
},
|
|
177
|
+
startWorker(intervalMs) {
|
|
178
|
+
if (MODE === "durable") {
|
|
179
|
+
return durable.startWorker(intervalMs);
|
|
180
|
+
}
|
|
181
|
+
return null;
|
|
182
|
+
},
|
|
183
|
+
};
|
|
184
|
+
//# sourceMappingURL=events.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../../../bone/output/agent/src/events.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export type LogLevel = "debug" | "info" | "warn" | "error" | "fatal";
|
|
2
|
+
export type LogStatus = "success" | "failure" | "timeout" | "rejected";
|
|
3
|
+
export interface LogEntry {
|
|
4
|
+
timestamp: string;
|
|
5
|
+
level: LogLevel;
|
|
6
|
+
service: string;
|
|
7
|
+
trace_id: string;
|
|
8
|
+
span_id: string;
|
|
9
|
+
event: string;
|
|
10
|
+
duration_ms?: number;
|
|
11
|
+
status: LogStatus;
|
|
12
|
+
entity_id?: string;
|
|
13
|
+
actor_id?: string | null;
|
|
14
|
+
error_code?: string | null;
|
|
15
|
+
metadata?: Record<string, unknown>;
|
|
16
|
+
}
|
|
17
|
+
declare class Logger {
|
|
18
|
+
private service;
|
|
19
|
+
constructor(service: string);
|
|
20
|
+
emit(entry: Omit<LogEntry, "timestamp" | "service" | "span_id">): void;
|
|
21
|
+
info(event: string, fields?: Partial<LogEntry>): void;
|
|
22
|
+
warn(event: string, fields?: Partial<LogEntry>): void;
|
|
23
|
+
error(event: string, fields?: Partial<LogEntry>): void;
|
|
24
|
+
debug(event: string, fields?: Partial<LogEntry>): void;
|
|
25
|
+
}
|
|
26
|
+
export declare function createLogger(service: string): Logger;
|
|
27
|
+
export declare const logger: Logger;
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
3
|
+
// Implements spec/10 §3 (Logging Schema)
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.logger = exports.createLogger = void 0;
|
|
6
|
+
const uuid_1 = require("uuid");
|
|
7
|
+
class Logger {
|
|
8
|
+
constructor(service) {
|
|
9
|
+
this.service = service;
|
|
10
|
+
}
|
|
11
|
+
emit(entry) {
|
|
12
|
+
const full = {
|
|
13
|
+
timestamp: new Date().toISOString(),
|
|
14
|
+
service: this.service,
|
|
15
|
+
span_id: (0, uuid_1.v4)(),
|
|
16
|
+
...entry,
|
|
17
|
+
};
|
|
18
|
+
// Suppress all log output in TUI mode
|
|
19
|
+
if (process.env.BONECODE_TUI === "1")
|
|
20
|
+
return;
|
|
21
|
+
// In production: send to log aggregator. In dev: console.
|
|
22
|
+
const fn = entry.level === "error" || entry.level === "fatal" ? console.error : console.log;
|
|
23
|
+
fn(JSON.stringify(full));
|
|
24
|
+
}
|
|
25
|
+
info(event, fields = {}) {
|
|
26
|
+
this.emit({ level: "info", event, status: "success", trace_id: fields.trace_id || "", ...fields });
|
|
27
|
+
}
|
|
28
|
+
warn(event, fields = {}) {
|
|
29
|
+
this.emit({ level: "warn", event, status: "rejected", trace_id: fields.trace_id || "", ...fields });
|
|
30
|
+
}
|
|
31
|
+
error(event, fields = {}) {
|
|
32
|
+
this.emit({ level: "error", event, status: "failure", trace_id: fields.trace_id || "", ...fields });
|
|
33
|
+
}
|
|
34
|
+
debug(event, fields = {}) {
|
|
35
|
+
if (process.env.LOG_LEVEL === "debug") {
|
|
36
|
+
this.emit({ level: "debug", event, status: "success", trace_id: fields.trace_id || "", ...fields });
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
function createLogger(service) {
|
|
41
|
+
return new Logger(service);
|
|
42
|
+
}
|
|
43
|
+
exports.createLogger = createLogger;
|
|
44
|
+
exports.logger = createLogger("AgentDomain");
|
|
45
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../../../bone/output/agent/src/logger.ts"],"names":[],"mappings":";AAAA,iDAAiD;AACjD,0CAA0C;;;AAE1C,+BAAkC;AAoBlC,MAAM,MAAM;IAGV,YAAY,OAAe;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED,IAAI,CAAC,KAA0D;QAC7D,MAAM,IAAI,GAAa;YACrB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,OAAO,EAAE,IAAA,SAAI,GAAE;YACf,GAAG,KAAK;SACT,CAAC;QACF,sCAAsC;QACtC,IAAI,OAAO,CAAC,GAAG,CAAC,YAAY,KAAK,GAAG;YAAE,OAAO;QAC7C,0DAA0D;QAC1D,MAAM,EAAE,GAAG,KAAK,CAAC,KAAK,KAAK,OAAO,IAAI,KAAK,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC;QAC5F,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3B,CAAC;IAED,IAAI,CAAC,KAAa,EAAE,SAA4B,EAAE;QAChD,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,EAAE,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;IACrG,CAAC;IAED,IAAI,CAAC,KAAa,EAAE,SAA4B,EAAE;QAChD,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,EAAE,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;IACtG,CAAC;IAED,KAAK,CAAC,KAAa,EAAE,SAA4B,EAAE;QACjD,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,EAAE,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;IACtG,CAAC;IAED,KAAK,CAAC,KAAa,EAAE,SAA4B,EAAE;QACjD,IAAI,OAAO,CAAC,GAAG,CAAC,SAAS,KAAK,OAAO,EAAE,CAAC;YACtC,IAAI,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,EAAE,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;QACtG,CAAC;IACH,CAAC;CACF;AAED,SAAgB,YAAY,CAAC,OAAe;IAC1C,OAAO,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC;AAC7B,CAAC;AAFD,oCAEC;AAEY,QAAA,MAAM,GAAG,YAAY,CAAC,aAAa,CAAC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare function counter(name: string, labels?: Record<string, string>): void;
|
|
2
|
+
export declare function histogram(name: string, value: number, labels?: Record<string, string>): void;
|
|
3
|
+
export declare function gauge(name: string, value: number, labels?: Record<string, string>): void;
|
|
4
|
+
export declare function dump(): string;
|
|
5
|
+
export declare function reset(): void;
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
3
|
+
// Implements spec/10 §4 (Telemetry Hooks)
|
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
+
exports.reset = exports.dump = exports.gauge = exports.histogram = exports.counter = void 0;
|
|
6
|
+
const metrics = new Map();
|
|
7
|
+
function key(name, labels) {
|
|
8
|
+
const parts = Object.keys(labels).sort().map(k => `${k}="${labels[k]}"`);
|
|
9
|
+
return parts.length > 0 ? `${name}{${parts.join(",")}}` : name;
|
|
10
|
+
}
|
|
11
|
+
function counter(name, labels = {}) {
|
|
12
|
+
const k = key(name, labels);
|
|
13
|
+
const existing = metrics.get(k);
|
|
14
|
+
if (existing && existing.type === "counter") {
|
|
15
|
+
existing.value++;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
metrics.set(k, { type: "counter", value: 1, labels });
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
exports.counter = counter;
|
|
22
|
+
function histogram(name, value, labels = {}) {
|
|
23
|
+
const k = key(name, labels);
|
|
24
|
+
const existing = metrics.get(k);
|
|
25
|
+
if (existing && existing.type === "histogram") {
|
|
26
|
+
existing.values.push(value);
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
metrics.set(k, { type: "histogram", values: [value], labels });
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.histogram = histogram;
|
|
33
|
+
function gauge(name, value, labels = {}) {
|
|
34
|
+
const k = key(name, labels);
|
|
35
|
+
metrics.set(k, { type: "gauge", value, labels });
|
|
36
|
+
}
|
|
37
|
+
exports.gauge = gauge;
|
|
38
|
+
function dump() {
|
|
39
|
+
const lines = [];
|
|
40
|
+
for (const [k, m] of metrics.entries()) {
|
|
41
|
+
if (m.type === "counter" || m.type === "gauge") {
|
|
42
|
+
lines.push(`${k} ${m.value}`);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
const sum = m.values.reduce((a, b) => a + b, 0);
|
|
46
|
+
const count = m.values.length;
|
|
47
|
+
const avg = count > 0 ? sum / count : 0;
|
|
48
|
+
lines.push(`${k}_count ${count}`);
|
|
49
|
+
lines.push(`${k}_sum ${sum}`);
|
|
50
|
+
lines.push(`${k}_avg ${avg.toFixed(2)}`);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return lines.join("\n");
|
|
54
|
+
}
|
|
55
|
+
exports.dump = dump;
|
|
56
|
+
function reset() {
|
|
57
|
+
metrics.clear();
|
|
58
|
+
}
|
|
59
|
+
exports.reset = reset;
|
|
60
|
+
//# sourceMappingURL=metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../../../../bone/output/agent/src/metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const agentInstancesRouter: import("express-serve-static-core").Router;
|
|
@@ -0,0 +1,253 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.agentInstancesRouter = void 0;
|
|
30
|
+
// Generated by BoneScript compiler. DO NOT EDIT.
|
|
31
|
+
// Service: AgentInstanceService
|
|
32
|
+
const express_1 = require("express");
|
|
33
|
+
const uuid_1 = require("uuid");
|
|
34
|
+
const db_1 = require("../db");
|
|
35
|
+
const events_1 = require("../events");
|
|
36
|
+
const auth_1 = require("../auth");
|
|
37
|
+
const express_rate_limit_1 = __importDefault(require("express-rate-limit"));
|
|
38
|
+
const audit_1 = require("../audit");
|
|
39
|
+
const metrics_1 = require("../metrics");
|
|
40
|
+
const __algorithms = __importStar(require("../algorithms"));
|
|
41
|
+
const { shortestPath, topologicalSort, binarySearch, bipartiteMatching, roundRobin, weightedAverage, percentile, rankBy, consistentHash } = __algorithms;
|
|
42
|
+
const agent_instance_1 = require("../state_machines/agent_instance");
|
|
43
|
+
exports.agentInstancesRouter = (0, express_1.Router)();
|
|
44
|
+
// Rate limiter from policy declaration
|
|
45
|
+
const __routeRateLimit = (0, express_rate_limit_1.default)({ windowMs: 60000, max: 200, standardHeaders: true, legacyHeaders: false });
|
|
46
|
+
// CREATE
|
|
47
|
+
exports.agentInstancesRouter.post("/", __routeRateLimit, auth_1.requireAuth, async (req, res) => {
|
|
48
|
+
try {
|
|
49
|
+
const id = (0, uuid_1.v4)();
|
|
50
|
+
const { session_id, model_id, provider_id, system_prompt, temperature, max_tokens, context_window_used, context_window_max, total_cost_usd, total_tokens_in, total_tokens_out, config } = req.body;
|
|
51
|
+
const state = agent_instance_1.AGENTINSTANCE_INITIAL;
|
|
52
|
+
const sql = `INSERT INTO agent_instances (id, session_id, model_id, provider_id, system_prompt, temperature, max_tokens, context_window_used, context_window_max, total_cost_usd, total_tokens_in, total_tokens_out, config, state) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14) RETURNING *`;
|
|
53
|
+
const rows = await (0, db_1.query)(sql, [id, session_id, model_id, provider_id, system_prompt, temperature, max_tokens, context_window_used, context_window_max, total_cost_usd, total_tokens_in, total_tokens_out, config, state]);
|
|
54
|
+
(0, metrics_1.counter)("entity.created", { entity: "AgentInstance" });
|
|
55
|
+
res.status(201).json(rows[0]);
|
|
56
|
+
}
|
|
57
|
+
catch (e) {
|
|
58
|
+
res.status(400).json({ error: { code: "CREATE_FAILED", message: e.message } });
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
// READ
|
|
62
|
+
exports.agentInstancesRouter.get("/:id", __routeRateLimit, auth_1.requireAuth, async (req, res) => {
|
|
63
|
+
try {
|
|
64
|
+
const row = await (0, db_1.queryOne)(`SELECT * FROM agent_instances WHERE id = $1`, [req.params.id]);
|
|
65
|
+
if (!row)
|
|
66
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
67
|
+
res.json(row);
|
|
68
|
+
}
|
|
69
|
+
catch (e) {
|
|
70
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
// LIST
|
|
74
|
+
exports.agentInstancesRouter.get("/", __routeRateLimit, auth_1.requireAuth, async (req, res) => {
|
|
75
|
+
try {
|
|
76
|
+
const page = parseInt(req.query.page) || 1;
|
|
77
|
+
const pageSize = Math.min(parseInt(req.query.page_size) || 50, 100);
|
|
78
|
+
const offset = (page - 1) * pageSize;
|
|
79
|
+
const rows = await (0, db_1.query)(`SELECT * FROM agent_instances ORDER BY created_at DESC LIMIT $1 OFFSET $2`, [pageSize, offset]);
|
|
80
|
+
const [{ count }] = await (0, db_1.query)(`SELECT COUNT(*) as count FROM agent_instances`);
|
|
81
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
82
|
+
}
|
|
83
|
+
catch (e) {
|
|
84
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
// UPDATE
|
|
88
|
+
exports.agentInstancesRouter.put("/:id", __routeRateLimit, auth_1.requireAuth, async (req, res) => {
|
|
89
|
+
const fields = { ...req.body };
|
|
90
|
+
// State machine enforcement
|
|
91
|
+
if (fields.state !== undefined) {
|
|
92
|
+
const current = await (0, db_1.queryOne)(`SELECT state FROM agent_instances WHERE id = $1`, [req.params.id]);
|
|
93
|
+
if (!current)
|
|
94
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
95
|
+
// Find the trigger for this state transition
|
|
96
|
+
const trigger = `${current.state}_to_${fields.state}`;
|
|
97
|
+
const tr = (0, agent_instance_1.transitionAgentInstance)(current.state, trigger);
|
|
98
|
+
if (!tr.ok)
|
|
99
|
+
return res.status(422).json({ error: { code: "INVALID_TRANSITION", message: `Cannot transition from ${current.state} to ${fields.state}` } });
|
|
100
|
+
}
|
|
101
|
+
const sets = Object.keys(fields).map((k, i) => `${k} = $${i + 2}`).join(", ");
|
|
102
|
+
const values = Object.values(fields);
|
|
103
|
+
const sql = `UPDATE agent_instances SET ${sets}, updated_at = NOW() WHERE id = $1 RETURNING *`;
|
|
104
|
+
const rows = await (0, db_1.query)(sql, [req.params.id, ...values]);
|
|
105
|
+
if (rows.length === 0)
|
|
106
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
107
|
+
res.json(rows[0]);
|
|
108
|
+
});
|
|
109
|
+
// DELETE
|
|
110
|
+
exports.agentInstancesRouter.delete("/:id", __routeRateLimit, auth_1.requireAuth, async (req, res) => {
|
|
111
|
+
try {
|
|
112
|
+
const count = await (0, db_1.execute)(`DELETE FROM agent_instances WHERE id = $1`, [req.params.id]);
|
|
113
|
+
if (count === 0)
|
|
114
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "Not found" } });
|
|
115
|
+
res.status(204).send();
|
|
116
|
+
}
|
|
117
|
+
catch (e) {
|
|
118
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
// CAPABILITY: complete_agent [transactional]
|
|
122
|
+
exports.agentInstancesRouter.post("/complete-agent", __routeRateLimit, auth_1.requireAuth, (0, audit_1.auditLog)("complete_agent", "AgentInstance"), async (req, res) => {
|
|
123
|
+
const auth = req.auth;
|
|
124
|
+
const __client = await db_1.pool.connect();
|
|
125
|
+
try {
|
|
126
|
+
await __client.query("BEGIN");
|
|
127
|
+
// Fetch entities
|
|
128
|
+
const agent = await (0, db_1.queryOne)(`SELECT * FROM agent_instances WHERE id = $1`, [req.body.agent_id || req.params.id]);
|
|
129
|
+
if (!agent) {
|
|
130
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "agent not found" } });
|
|
131
|
+
}
|
|
132
|
+
// Preconditions
|
|
133
|
+
if (!([["running", "waiting_for_tool"]].flat().includes(agent?.state))) {
|
|
134
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "agent.state in [\\\"running\\\", \\\"waiting_for_tool\\\"]" } });
|
|
135
|
+
}
|
|
136
|
+
// Effects (applied in declaration order)
|
|
137
|
+
const __effect_0 = await (0, db_1.query)(`UPDATE agents SET state = $1, updated_at = NOW() WHERE id = $2 RETURNING *`, ["done", req.body.agent_id || req.params.id]);
|
|
138
|
+
if (!__effect_0 || __effect_0.length === 0) {
|
|
139
|
+
throw new Error("Effect failed: agent.state = \"done\"");
|
|
140
|
+
}
|
|
141
|
+
// Emit events
|
|
142
|
+
await events_1.eventBus.publish("AgentCompleted", { agent_id: agent?.id, timestamp: new Date().toISOString(), actor_id: auth.actor_id }, "AgentInstanceService", auth.trace_id, __client);
|
|
143
|
+
res.json({ ok: true, action: "complete_agent", entity: agent });
|
|
144
|
+
await __client.query("COMMIT");
|
|
145
|
+
}
|
|
146
|
+
catch (e) {
|
|
147
|
+
await __client.query("ROLLBACK");
|
|
148
|
+
res.status(400).json({ error: { code: "CAPABILITY_FAILED", message: e.message } });
|
|
149
|
+
}
|
|
150
|
+
finally {
|
|
151
|
+
__client.release();
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
// CAPABILITY: fail_agent [transactional]
|
|
155
|
+
exports.agentInstancesRouter.post("/fail-agent", __routeRateLimit, auth_1.requireAuth, (0, audit_1.auditLog)("fail_agent", "AgentInstance"), async (req, res) => {
|
|
156
|
+
const auth = req.auth;
|
|
157
|
+
const __client = await db_1.pool.connect();
|
|
158
|
+
try {
|
|
159
|
+
await __client.query("BEGIN");
|
|
160
|
+
const { error } = req.body;
|
|
161
|
+
// Fetch entities
|
|
162
|
+
const agent = await (0, db_1.queryOne)(`SELECT * FROM agent_instances WHERE id = $1`, [req.body.agent_id || req.params.id]);
|
|
163
|
+
if (!agent) {
|
|
164
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "agent not found" } });
|
|
165
|
+
}
|
|
166
|
+
// Preconditions
|
|
167
|
+
if (!([["running", "waiting_for_tool", "compacting"]].flat().includes(agent?.state))) {
|
|
168
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "agent.state in [\\\"running\\\", \\\"waiting_for_tool\\\", \\\"compacting\\\"]" } });
|
|
169
|
+
}
|
|
170
|
+
// Effects (applied in declaration order)
|
|
171
|
+
const __effect_0 = await (0, db_1.query)(`UPDATE agents SET state = $1, updated_at = NOW() WHERE id = $2 RETURNING *`, ["failed", req.body.agent_id || req.params.id]);
|
|
172
|
+
if (!__effect_0 || __effect_0.length === 0) {
|
|
173
|
+
throw new Error("Effect failed: agent.state = \"failed\"");
|
|
174
|
+
}
|
|
175
|
+
// Emit events
|
|
176
|
+
await events_1.eventBus.publish("AgentFailed", { agent_id: agent?.id, timestamp: new Date().toISOString(), actor_id: auth.actor_id }, "AgentInstanceService", auth.trace_id, __client);
|
|
177
|
+
res.json({ ok: true, action: "fail_agent", entity: agent });
|
|
178
|
+
await __client.query("COMMIT");
|
|
179
|
+
}
|
|
180
|
+
catch (e) {
|
|
181
|
+
await __client.query("ROLLBACK");
|
|
182
|
+
res.status(400).json({ error: { code: "CAPABILITY_FAILED", message: e.message } });
|
|
183
|
+
}
|
|
184
|
+
finally {
|
|
185
|
+
__client.release();
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
// CAPABILITY: request_tool_call [transactional]
|
|
189
|
+
exports.agentInstancesRouter.post("/request-tool-call", __routeRateLimit, auth_1.requireAuth, (0, audit_1.auditLog)("request_tool_call", "AgentInstance"), async (req, res) => {
|
|
190
|
+
const auth = req.auth;
|
|
191
|
+
const __client = await db_1.pool.connect();
|
|
192
|
+
try {
|
|
193
|
+
await __client.query("BEGIN");
|
|
194
|
+
const { tool_name, tool_input } = req.body;
|
|
195
|
+
// Fetch entities
|
|
196
|
+
const agent = await (0, db_1.queryOne)(`SELECT * FROM agent_instances WHERE id = $1`, [req.body.agent_id || req.params.id]);
|
|
197
|
+
if (!agent) {
|
|
198
|
+
return res.status(404).json({ error: { code: "NOT_FOUND", message: "agent not found" } });
|
|
199
|
+
}
|
|
200
|
+
// Preconditions
|
|
201
|
+
if (!(agent?.state === "running")) {
|
|
202
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "agent.state == \\\"running\\\"" } });
|
|
203
|
+
}
|
|
204
|
+
if (!(tool_name?.length >= 1)) {
|
|
205
|
+
return res.status(422).json({ error: { code: "PRECONDITION_FAILED", message: "tool_name.length >= 1" } });
|
|
206
|
+
}
|
|
207
|
+
// Effects (applied in declaration order)
|
|
208
|
+
const __effect_0 = await (0, db_1.query)(`UPDATE agents SET state = $1, updated_at = NOW() WHERE id = $2 RETURNING *`, ["waiting_for_tool", req.body.agent_id || req.params.id]);
|
|
209
|
+
if (!__effect_0 || __effect_0.length === 0) {
|
|
210
|
+
throw new Error("Effect failed: agent.state = \"waiting_for_tool\"");
|
|
211
|
+
}
|
|
212
|
+
// Emit events
|
|
213
|
+
await events_1.eventBus.publish("ToolCallRequested", { agent_id: agent?.id, timestamp: new Date().toISOString(), actor_id: auth.actor_id }, "AgentInstanceService", auth.trace_id, __client);
|
|
214
|
+
res.json({ ok: true, action: "request_tool_call", entity: agent });
|
|
215
|
+
await __client.query("COMMIT");
|
|
216
|
+
}
|
|
217
|
+
catch (e) {
|
|
218
|
+
await __client.query("ROLLBACK");
|
|
219
|
+
res.status(400).json({ error: { code: "CAPABILITY_FAILED", message: e.message } });
|
|
220
|
+
}
|
|
221
|
+
finally {
|
|
222
|
+
__client.release();
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
// RELATION: tasks (has_many Task)
|
|
226
|
+
exports.agentInstancesRouter.get("/:id/tasks", auth_1.requireAuth, async (req, res) => {
|
|
227
|
+
try {
|
|
228
|
+
const page = parseInt(req.query.page) || 1;
|
|
229
|
+
const pageSize = Math.min(parseInt(req.query.page_size) || 50, 100);
|
|
230
|
+
const offset = (page - 1) * pageSize;
|
|
231
|
+
const rows = await (0, db_1.query)(`SELECT * FROM tasks WHERE agent_id = $1 ORDER BY created_at DESC LIMIT $2 OFFSET $3`, [req.params.id, pageSize, offset]);
|
|
232
|
+
const [{ count }] = await (0, db_1.query)(`SELECT COUNT(*) as count FROM tasks WHERE agent_id = $1`, [req.params.id]);
|
|
233
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
234
|
+
}
|
|
235
|
+
catch (e) {
|
|
236
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
237
|
+
}
|
|
238
|
+
});
|
|
239
|
+
// RELATION: tool_calls (has_many ToolCall)
|
|
240
|
+
exports.agentInstancesRouter.get("/:id/tool_calls", auth_1.requireAuth, async (req, res) => {
|
|
241
|
+
try {
|
|
242
|
+
const page = parseInt(req.query.page) || 1;
|
|
243
|
+
const pageSize = Math.min(parseInt(req.query.page_size) || 50, 100);
|
|
244
|
+
const offset = (page - 1) * pageSize;
|
|
245
|
+
const rows = await (0, db_1.query)(`SELECT * FROM tool_calls WHERE agent_id = $1 ORDER BY created_at DESC LIMIT $2 OFFSET $3`, [req.params.id, pageSize, offset]);
|
|
246
|
+
const [{ count }] = await (0, db_1.query)(`SELECT COUNT(*) as count FROM tool_calls WHERE agent_id = $1`, [req.params.id]);
|
|
247
|
+
res.json({ items: rows, total: parseInt(count), page, page_size: pageSize });
|
|
248
|
+
}
|
|
249
|
+
catch (e) {
|
|
250
|
+
res.status(500).json({ error: { code: "DB_ERROR", message: e.message } });
|
|
251
|
+
}
|
|
252
|
+
});
|
|
253
|
+
//# sourceMappingURL=agent_instance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent_instance.js","sourceRoot":"","sources":["../../../../../../bone/output/agent/src/routes/agent_instance.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const buildStepsRouter: import("express-serve-static-core").Router;
|