openalerts 0.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +253 -0
- package/dist/channels/console.d.ts +6 -0
- package/dist/channels/console.d.ts.map +1 -0
- package/dist/channels/console.js +10 -0
- package/dist/channels/console.js.map +1 -0
- package/dist/channels/telegram.d.ts +12 -0
- package/dist/channels/telegram.d.ts.map +1 -0
- package/dist/channels/telegram.js +28 -0
- package/dist/channels/telegram.js.map +1 -0
- package/dist/channels/webhook.d.ts +8 -0
- package/dist/channels/webhook.d.ts.map +1 -0
- package/dist/channels/webhook.js +15 -0
- package/dist/channels/webhook.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +234 -0
- package/dist/cli.js.map +1 -0
- package/dist/config.d.ts +51 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +86 -0
- package/dist/config.js.map +1 -0
- package/dist/core/alert-channel.d.ts +16 -0
- package/dist/core/alert-channel.d.ts.map +1 -0
- package/dist/core/alert-channel.js +23 -0
- package/dist/core/alert-channel.js.map +1 -0
- package/dist/core/bounded-map.d.ts +52 -0
- package/dist/core/bounded-map.d.ts.map +1 -0
- package/dist/core/bounded-map.js +129 -0
- package/dist/core/bounded-map.js.map +1 -0
- package/dist/core/engine.d.ts +36 -0
- package/dist/core/engine.d.ts.map +1 -0
- package/dist/core/engine.js +162 -0
- package/dist/core/engine.js.map +1 -0
- package/dist/core/evaluator.d.ts +19 -0
- package/dist/core/evaluator.d.ts.map +1 -0
- package/dist/core/evaluator.js +168 -0
- package/dist/core/evaluator.js.map +1 -0
- package/dist/core/event-bus.d.ts +18 -0
- package/dist/core/event-bus.d.ts.map +1 -0
- package/dist/core/event-bus.js +32 -0
- package/dist/core/event-bus.js.map +1 -0
- package/dist/core/formatter.d.ts +15 -0
- package/dist/core/formatter.d.ts.map +1 -0
- package/dist/core/formatter.js +125 -0
- package/dist/core/formatter.js.map +1 -0
- package/dist/core/rules.d.ts +3 -0
- package/dist/core/rules.d.ts.map +1 -0
- package/dist/core/rules.js +410 -0
- package/dist/core/rules.js.map +1 -0
- package/dist/core/store.d.ts +9 -0
- package/dist/core/store.d.ts.map +1 -0
- package/dist/core/store.js +72 -0
- package/dist/core/store.js.map +1 -0
- package/dist/core/types.d.ts +158 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +18 -0
- package/dist/core/types.js.map +1 -0
- package/dist/db/index.d.ts +6 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +31 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/queries.d.ts +157 -0
- package/dist/db/queries.d.ts.map +1 -0
- package/dist/db/queries.js +221 -0
- package/dist/db/queries.js.map +1 -0
- package/dist/db/schema.d.ts +5 -0
- package/dist/db/schema.d.ts.map +1 -0
- package/dist/db/schema.js +177 -0
- package/dist/db/schema.js.map +1 -0
- package/dist/readers/openclaw.d.ts +11 -0
- package/dist/readers/openclaw.d.ts.map +1 -0
- package/dist/readers/openclaw.js +267 -0
- package/dist/readers/openclaw.js.map +1 -0
- package/dist/server/dashboard.d.ts +2 -0
- package/dist/server/dashboard.d.ts.map +1 -0
- package/dist/server/dashboard.js +765 -0
- package/dist/server/dashboard.js.map +1 -0
- package/dist/server/index.d.ts +10 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +28 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/routes.d.ts +6 -0
- package/dist/server/routes.d.ts.map +1 -0
- package/dist/server/routes.js +146 -0
- package/dist/server/routes.js.map +1 -0
- package/dist/server/sse.d.ts +21 -0
- package/dist/server/sse.d.ts.map +1 -0
- package/dist/server/sse.js +53 -0
- package/dist/server/sse.js.map +1 -0
- package/dist/watchers/files.d.ts +19 -0
- package/dist/watchers/files.d.ts.map +1 -0
- package/dist/watchers/files.js +105 -0
- package/dist/watchers/files.js.map +1 -0
- package/dist/watchers/gateway-adapter.d.ts +18 -0
- package/dist/watchers/gateway-adapter.d.ts.map +1 -0
- package/dist/watchers/gateway-adapter.js +273 -0
- package/dist/watchers/gateway-adapter.js.map +1 -0
- package/dist/watchers/gateway.d.ts +27 -0
- package/dist/watchers/gateway.d.ts.map +1 -0
- package/dist/watchers/gateway.js +131 -0
- package/dist/watchers/gateway.js.map +1 -0
- package/package.json +48 -0
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
import { upsertSession, upsertAction, insertHeartbeat } from "../db/queries.js";
|
|
2
|
+
// ─── Helpers ─────────────────────────────────────────────────────────────────
|
|
3
|
+
/** Extract text content from a message block (handles string, array, or text field) */
|
|
4
|
+
function extractContent(message) {
|
|
5
|
+
if (!message)
|
|
6
|
+
return "";
|
|
7
|
+
const msg = message;
|
|
8
|
+
if (typeof msg.content === "string")
|
|
9
|
+
return msg.content;
|
|
10
|
+
if (typeof msg.text === "string")
|
|
11
|
+
return msg.text;
|
|
12
|
+
if (Array.isArray(msg.content)) {
|
|
13
|
+
return msg.content
|
|
14
|
+
.filter(b => b.type === "text")
|
|
15
|
+
.map(b => String(b.text || ""))
|
|
16
|
+
.join("");
|
|
17
|
+
}
|
|
18
|
+
return "";
|
|
19
|
+
}
|
|
20
|
+
/** Infer platform label from session key (e.g. "agent:workspace:main" → "webchat") */
|
|
21
|
+
function inferPlatform(sessionKey) {
|
|
22
|
+
if (!sessionKey)
|
|
23
|
+
return undefined;
|
|
24
|
+
const lower = sessionKey.toLowerCase();
|
|
25
|
+
if (lower.includes("telegram"))
|
|
26
|
+
return "telegram";
|
|
27
|
+
if (lower.includes("discord"))
|
|
28
|
+
return "discord";
|
|
29
|
+
if (lower.includes("slack"))
|
|
30
|
+
return "slack";
|
|
31
|
+
if (lower.includes("webchat") || lower.includes("web"))
|
|
32
|
+
return "webchat";
|
|
33
|
+
return undefined;
|
|
34
|
+
}
|
|
35
|
+
export function translateGatewayEvent(eventName, payload, db) {
|
|
36
|
+
const now = Date.now();
|
|
37
|
+
// ── health / tick ─────────────────────────────────────────────────────────
|
|
38
|
+
if (eventName === "health" || eventName === "tick") {
|
|
39
|
+
const h = payload;
|
|
40
|
+
const queueDepth = typeof h?.queue === "number"
|
|
41
|
+
? h.queue
|
|
42
|
+
: (typeof h?.queue === "object" && h?.queue ? h.queue.total ?? 0 : 0);
|
|
43
|
+
const sessions = Array.isArray(h?.sessions) ? h.sessions : [];
|
|
44
|
+
const activeSessions = sessions.length;
|
|
45
|
+
// Upsert all sessions from health payload
|
|
46
|
+
if (db) {
|
|
47
|
+
for (const s of sessions) {
|
|
48
|
+
if (!s.key)
|
|
49
|
+
continue;
|
|
50
|
+
try {
|
|
51
|
+
upsertSession(db, {
|
|
52
|
+
session_key: s.key,
|
|
53
|
+
agent_id: s.agentId,
|
|
54
|
+
last_activity_at: s.lastActivityAt ?? now,
|
|
55
|
+
status: s.status ?? "active",
|
|
56
|
+
updated_at: now,
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
catch { /* ignore */ }
|
|
60
|
+
}
|
|
61
|
+
try {
|
|
62
|
+
insertHeartbeat(db, {
|
|
63
|
+
ts: now, status: "ok",
|
|
64
|
+
gateway_connected: 1,
|
|
65
|
+
queue_depth: queueDepth,
|
|
66
|
+
active_sessions: activeSessions,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
catch { /* ignore */ }
|
|
70
|
+
}
|
|
71
|
+
return {
|
|
72
|
+
event: {
|
|
73
|
+
type: "infra.heartbeat", ts: now,
|
|
74
|
+
outcome: "success", queueDepth,
|
|
75
|
+
},
|
|
76
|
+
sseType: "health",
|
|
77
|
+
ssePayload: { queueDepth, activeSessions, sessions, ts: now },
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
// ── chat ──────────────────────────────────────────────────────────────────
|
|
81
|
+
if (eventName === "chat") {
|
|
82
|
+
const c = payload;
|
|
83
|
+
if (!c?.runId)
|
|
84
|
+
return {};
|
|
85
|
+
const actionId = `${c.runId}-${c.seq}`;
|
|
86
|
+
const platform = inferPlatform(c.sessionKey);
|
|
87
|
+
const msg = c.message;
|
|
88
|
+
const role = typeof msg?.role === "string" ? msg.role : undefined;
|
|
89
|
+
// ── User message (Telegram / webchat / connected app input) ──
|
|
90
|
+
if (role === "user") {
|
|
91
|
+
const content = extractContent(c.message);
|
|
92
|
+
if (db) {
|
|
93
|
+
try {
|
|
94
|
+
upsertSession(db, { session_key: c.sessionKey, last_activity_at: now, status: "active", updated_at: now });
|
|
95
|
+
upsertAction(db, { id: actionId, run_id: c.runId, session_key: c.sessionKey, seq: c.seq, type: "user_message", event_type: "chat", ts: now });
|
|
96
|
+
}
|
|
97
|
+
catch { /* ignore */ }
|
|
98
|
+
}
|
|
99
|
+
return {
|
|
100
|
+
sseType: "action",
|
|
101
|
+
ssePayload: {
|
|
102
|
+
id: actionId, runId: c.runId, sessionKey: c.sessionKey, seq: c.seq,
|
|
103
|
+
type: "user_message", eventType: "chat",
|
|
104
|
+
content: content.substring(0, 300),
|
|
105
|
+
platform,
|
|
106
|
+
ts: now,
|
|
107
|
+
},
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
// ── Assistant response (LLM output) ──
|
|
111
|
+
let type;
|
|
112
|
+
if (c.state === "final")
|
|
113
|
+
type = "complete";
|
|
114
|
+
else if (c.state === "aborted")
|
|
115
|
+
type = "aborted";
|
|
116
|
+
else if (c.state === "error")
|
|
117
|
+
type = "error";
|
|
118
|
+
else
|
|
119
|
+
type = "streaming";
|
|
120
|
+
let content;
|
|
121
|
+
if (c.message)
|
|
122
|
+
content = extractContent(c.message) || undefined;
|
|
123
|
+
if (c.errorMessage)
|
|
124
|
+
content = c.errorMessage;
|
|
125
|
+
if (db) {
|
|
126
|
+
try {
|
|
127
|
+
upsertSession(db, {
|
|
128
|
+
session_key: c.sessionKey,
|
|
129
|
+
last_activity_at: now,
|
|
130
|
+
status: c.state === "delta" ? "thinking" : "active",
|
|
131
|
+
total_input_tokens: c.usage?.inputTokens ?? undefined,
|
|
132
|
+
total_output_tokens: c.usage?.outputTokens ?? undefined,
|
|
133
|
+
updated_at: now,
|
|
134
|
+
});
|
|
135
|
+
upsertAction(db, {
|
|
136
|
+
id: actionId, run_id: c.runId, session_key: c.sessionKey,
|
|
137
|
+
seq: c.seq, type, event_type: "chat", ts: now,
|
|
138
|
+
input_tokens: c.usage?.inputTokens ?? undefined,
|
|
139
|
+
output_tokens: c.usage?.outputTokens ?? undefined,
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
catch { /* ignore */ }
|
|
143
|
+
}
|
|
144
|
+
const alertEvent = c.state === "error"
|
|
145
|
+
? { type: "llm.error", ts: now, sessionKey: c.sessionKey, error: c.errorMessage ?? "chat error", outcome: "error" }
|
|
146
|
+
: c.state === "final" && c.usage
|
|
147
|
+
? { type: "llm.token_usage", ts: now, sessionKey: c.sessionKey, tokenCount: (c.usage.inputTokens ?? 0) + (c.usage.outputTokens ?? 0) }
|
|
148
|
+
: undefined;
|
|
149
|
+
return {
|
|
150
|
+
event: alertEvent,
|
|
151
|
+
sseType: "action",
|
|
152
|
+
ssePayload: {
|
|
153
|
+
id: actionId, runId: c.runId, sessionKey: c.sessionKey, seq: c.seq,
|
|
154
|
+
type, eventType: "chat",
|
|
155
|
+
content: content?.substring(0, 200),
|
|
156
|
+
platform,
|
|
157
|
+
ts: now,
|
|
158
|
+
},
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
// ── agent ─────────────────────────────────────────────────────────────────
|
|
162
|
+
if (eventName === "agent") {
|
|
163
|
+
const a = payload;
|
|
164
|
+
if (!a?.runId)
|
|
165
|
+
return {};
|
|
166
|
+
const actionId = `${a.runId}-${a.seq}`;
|
|
167
|
+
if (a.stream === "lifecycle") {
|
|
168
|
+
const phase = a.data?.phase;
|
|
169
|
+
if (phase === "start") {
|
|
170
|
+
if (db) {
|
|
171
|
+
try {
|
|
172
|
+
if (a.sessionKey)
|
|
173
|
+
upsertSession(db, { session_key: a.sessionKey, last_activity_at: now, status: "thinking", updated_at: now });
|
|
174
|
+
upsertAction(db, { id: actionId, run_id: a.runId, session_key: a.sessionKey, seq: a.seq, type: "start", event_type: "agent", ts: a.data.startedAt ?? now });
|
|
175
|
+
}
|
|
176
|
+
catch { /* ignore */ }
|
|
177
|
+
}
|
|
178
|
+
return {
|
|
179
|
+
event: { type: "agent.start", ts: a.data.startedAt ?? now, sessionKey: a.sessionKey, agentId: a.sessionKey?.split(":")[1], meta: { runId: a.runId } },
|
|
180
|
+
sseType: "action",
|
|
181
|
+
ssePayload: { id: actionId, runId: a.runId, sessionKey: a.sessionKey, type: "start", eventType: "agent", ts: now },
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
if (phase === "end") {
|
|
185
|
+
const startedAt = typeof a.data.startedAt === "number" ? a.data.startedAt : now;
|
|
186
|
+
const endedAt = typeof a.data.endedAt === "number" ? a.data.endedAt : now;
|
|
187
|
+
if (db) {
|
|
188
|
+
try {
|
|
189
|
+
if (a.sessionKey)
|
|
190
|
+
upsertSession(db, { session_key: a.sessionKey, last_activity_at: now, status: "active", updated_at: now });
|
|
191
|
+
upsertAction(db, { id: actionId, run_id: a.runId, session_key: a.sessionKey, seq: a.seq, type: "complete", event_type: "agent", ts: endedAt, duration_ms: endedAt - startedAt });
|
|
192
|
+
}
|
|
193
|
+
catch { /* ignore */ }
|
|
194
|
+
}
|
|
195
|
+
return {
|
|
196
|
+
event: { type: "agent.end", ts: endedAt, sessionKey: a.sessionKey, durationMs: endedAt - startedAt, outcome: "success", meta: { runId: a.runId } },
|
|
197
|
+
sseType: "action",
|
|
198
|
+
ssePayload: { id: actionId, runId: a.runId, sessionKey: a.sessionKey, type: "complete", eventType: "agent", durationMs: endedAt - startedAt, ts: now },
|
|
199
|
+
};
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
// Tool use / tool result
|
|
203
|
+
if (a.data?.type === "tool_use") {
|
|
204
|
+
const toolName = String(a.data.name || "unknown");
|
|
205
|
+
if (db) {
|
|
206
|
+
try {
|
|
207
|
+
upsertAction(db, { id: actionId, run_id: a.runId, session_key: a.sessionKey, seq: a.seq, type: "tool_call", event_type: "agent", ts: now, tool_name: toolName });
|
|
208
|
+
}
|
|
209
|
+
catch { /* ignore */ }
|
|
210
|
+
}
|
|
211
|
+
return {
|
|
212
|
+
event: { type: "tool.call", ts: now, sessionKey: a.sessionKey, meta: { toolName, runId: a.runId } },
|
|
213
|
+
sseType: "action",
|
|
214
|
+
ssePayload: { id: actionId, runId: a.runId, sessionKey: a.sessionKey, type: "tool_call", eventType: "agent", toolName, ts: now },
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
if (a.data?.type === "tool_result") {
|
|
218
|
+
if (db) {
|
|
219
|
+
try {
|
|
220
|
+
upsertAction(db, { id: actionId, run_id: a.runId, session_key: a.sessionKey, seq: a.seq, type: "tool_result", event_type: "agent", ts: now });
|
|
221
|
+
}
|
|
222
|
+
catch { /* ignore */ }
|
|
223
|
+
}
|
|
224
|
+
return {
|
|
225
|
+
sseType: "action",
|
|
226
|
+
ssePayload: { id: actionId, runId: a.runId, sessionKey: a.sessionKey, type: "tool_result", eventType: "agent", ts: now },
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
// Streaming text
|
|
230
|
+
if (a.stream === "assistant" && typeof a.data?.text === "string") {
|
|
231
|
+
if (db) {
|
|
232
|
+
try {
|
|
233
|
+
if (a.sessionKey)
|
|
234
|
+
upsertSession(db, { session_key: a.sessionKey, last_activity_at: now, status: "thinking", updated_at: now });
|
|
235
|
+
}
|
|
236
|
+
catch { /* ignore */ }
|
|
237
|
+
}
|
|
238
|
+
return {
|
|
239
|
+
sseType: "action",
|
|
240
|
+
ssePayload: { id: actionId, runId: a.runId, sessionKey: a.sessionKey, type: "streaming", eventType: "agent", content: a.data.text.substring(0, 200), ts: now },
|
|
241
|
+
};
|
|
242
|
+
}
|
|
243
|
+
return {};
|
|
244
|
+
}
|
|
245
|
+
// ── exec.* ────────────────────────────────────────────────────────────────
|
|
246
|
+
if (eventName === "exec.started") {
|
|
247
|
+
const e = payload;
|
|
248
|
+
return {
|
|
249
|
+
sseType: "exec",
|
|
250
|
+
ssePayload: { type: "started", runId: e.runId, pid: e.pid, command: e.command, sessionId: e.sessionId, ts: now },
|
|
251
|
+
};
|
|
252
|
+
}
|
|
253
|
+
if (eventName === "exec.output") {
|
|
254
|
+
const e = payload;
|
|
255
|
+
return {
|
|
256
|
+
sseType: "exec",
|
|
257
|
+
ssePayload: { type: "output", runId: e.runId, pid: e.pid, stream: e.stream, output: e.output?.substring(0, 500), ts: now },
|
|
258
|
+
};
|
|
259
|
+
}
|
|
260
|
+
if (eventName === "exec.completed") {
|
|
261
|
+
const e = payload;
|
|
262
|
+
const isError = typeof e.exitCode === "number" && e.exitCode !== 0;
|
|
263
|
+
return {
|
|
264
|
+
event: isError
|
|
265
|
+
? { type: "tool.error", ts: now, sessionKey: e.sessionId, error: `exec exit ${e.exitCode}`, meta: { runId: e.runId, pid: e.pid, exitCode: e.exitCode } }
|
|
266
|
+
: undefined,
|
|
267
|
+
sseType: "exec",
|
|
268
|
+
ssePayload: { type: "completed", runId: e.runId, pid: e.pid, exitCode: e.exitCode, durationMs: e.durationMs, ts: now },
|
|
269
|
+
};
|
|
270
|
+
}
|
|
271
|
+
return {};
|
|
272
|
+
}
|
|
273
|
+
//# sourceMappingURL=gateway-adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gateway-adapter.js","sourceRoot":"","sources":["../../src/watchers/gateway-adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { EventEmitter } from "node:events";
|
|
2
|
+
export interface GatewayClientConfig {
|
|
3
|
+
url?: string;
|
|
4
|
+
token?: string;
|
|
5
|
+
reconnectInterval?: number;
|
|
6
|
+
}
|
|
7
|
+
export declare class GatewayClient extends EventEmitter {
|
|
8
|
+
private ws;
|
|
9
|
+
private pending;
|
|
10
|
+
private backoffMs;
|
|
11
|
+
private closed;
|
|
12
|
+
private connectTimer;
|
|
13
|
+
private _ready;
|
|
14
|
+
private readonly url;
|
|
15
|
+
private readonly token;
|
|
16
|
+
private readonly reconnectInterval;
|
|
17
|
+
constructor(config?: GatewayClientConfig);
|
|
18
|
+
get isReady(): boolean;
|
|
19
|
+
start(): void;
|
|
20
|
+
stop(): void;
|
|
21
|
+
request<T = unknown>(method: string, params?: unknown): Promise<T>;
|
|
22
|
+
private connect;
|
|
23
|
+
private handleFrame;
|
|
24
|
+
private sendHandshake;
|
|
25
|
+
private scheduleReconnect;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=gateway.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gateway.d.ts","sourceRoot":"","sources":["../../src/watchers/gateway.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,WAAW,mBAAmB;IAClC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAgBD,qBAAa,aAAc,SAAQ,YAAY;IAC7C,OAAO,CAAC,EAAE,CAA0B;IACpC,OAAO,CAAC,OAAO,CAA8B;IAC7C,OAAO,CAAC,SAAS,CAAQ;IACzB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,YAAY,CAA+B;IACnD,OAAO,CAAC,MAAM,CAAS;IAEvB,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAS;IAC7B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAS;IAC/B,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAS;gBAE/B,MAAM,GAAE,mBAAwB;IAO5C,IAAI,OAAO,IAAI,OAAO,CAAwB;IAE9C,KAAK,IAAI,IAAI;IAIb,IAAI,IAAI,IAAI;IAMZ,OAAO,CAAC,CAAC,GAAG,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC;IAgBlE,OAAO,CAAC,OAAO;IAef,OAAO,CAAC,WAAW;IA0BnB,OAAO,CAAC,aAAa;IAuBrB,OAAO,CAAC,iBAAiB;CAO1B"}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Gateway WebSocket client — connects to OpenClaw gateway as an operator.
|
|
3
|
+
* Adapted from node/src/plugin/gateway-client.ts (same protocol).
|
|
4
|
+
* Emits: ready, disconnected, error, agent, chat, health, cron, tick
|
|
5
|
+
*/
|
|
6
|
+
import { randomUUID } from "node:crypto";
|
|
7
|
+
import { WebSocket } from "ws";
|
|
8
|
+
import { EventEmitter } from "node:events";
|
|
9
|
+
export class GatewayClient extends EventEmitter {
|
|
10
|
+
ws = null;
|
|
11
|
+
pending = new Map();
|
|
12
|
+
backoffMs = 1000;
|
|
13
|
+
closed = false;
|
|
14
|
+
connectTimer = null;
|
|
15
|
+
_ready = false;
|
|
16
|
+
url;
|
|
17
|
+
token;
|
|
18
|
+
reconnectInterval;
|
|
19
|
+
constructor(config = {}) {
|
|
20
|
+
super();
|
|
21
|
+
this.url = config.url ?? "ws://127.0.0.1:18789";
|
|
22
|
+
this.token = config.token ?? "";
|
|
23
|
+
this.reconnectInterval = config.reconnectInterval ?? 1000;
|
|
24
|
+
}
|
|
25
|
+
get isReady() { return this._ready; }
|
|
26
|
+
start() {
|
|
27
|
+
if (!this.closed)
|
|
28
|
+
this.connect();
|
|
29
|
+
}
|
|
30
|
+
stop() {
|
|
31
|
+
this.closed = true;
|
|
32
|
+
if (this.connectTimer) {
|
|
33
|
+
clearTimeout(this.connectTimer);
|
|
34
|
+
this.connectTimer = null;
|
|
35
|
+
}
|
|
36
|
+
if (this.ws) {
|
|
37
|
+
this.ws.close();
|
|
38
|
+
this.ws = null;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
request(method, params) {
|
|
42
|
+
if (!this._ready || !this.ws)
|
|
43
|
+
return Promise.reject(new Error("Gateway not ready"));
|
|
44
|
+
const id = randomUUID();
|
|
45
|
+
return new Promise((resolve, reject) => {
|
|
46
|
+
const timeout = setTimeout(() => {
|
|
47
|
+
this.pending.delete(id);
|
|
48
|
+
reject(new Error(`Timeout: ${method}`));
|
|
49
|
+
}, 10_000);
|
|
50
|
+
this.pending.set(id, {
|
|
51
|
+
resolve: v => { clearTimeout(timeout); resolve(v); },
|
|
52
|
+
reject: e => { clearTimeout(timeout); reject(e); },
|
|
53
|
+
});
|
|
54
|
+
this.ws.send(JSON.stringify({ type: "req", id, method, params }));
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
connect() {
|
|
58
|
+
if (this.closed || this.ws)
|
|
59
|
+
return;
|
|
60
|
+
this.ws = new WebSocket(this.url, { maxPayload: 25 * 1024 * 1024 });
|
|
61
|
+
this.ws.on("open", () => { this.backoffMs = this.reconnectInterval; });
|
|
62
|
+
this.ws.on("message", (data) => this.handleFrame(data.toString()));
|
|
63
|
+
this.ws.on("error", err => this.emit("error", err));
|
|
64
|
+
this.ws.on("close", () => {
|
|
65
|
+
this.ws = null;
|
|
66
|
+
this._ready = false;
|
|
67
|
+
this.emit("disconnected");
|
|
68
|
+
if (!this.closed)
|
|
69
|
+
this.scheduleReconnect();
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
handleFrame(raw) {
|
|
73
|
+
try {
|
|
74
|
+
const frame = JSON.parse(raw);
|
|
75
|
+
if (frame.type === "event" && frame.event === "connect.challenge") {
|
|
76
|
+
this.sendHandshake();
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
if (frame.type === "res") {
|
|
80
|
+
const p = this.pending.get(frame.id);
|
|
81
|
+
if (p) {
|
|
82
|
+
this.pending.delete(frame.id);
|
|
83
|
+
if (frame.error || frame.ok === false) {
|
|
84
|
+
const msg = typeof frame.error === "string" ? frame.error : JSON.stringify(frame.error ?? frame.payload);
|
|
85
|
+
p.reject(new Error(msg));
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
p.resolve(frame.payload ?? frame.result);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (frame.type === "event" && frame.event) {
|
|
94
|
+
this.emit(frame.event, frame.payload);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
catch { /* ignore parse errors */ }
|
|
98
|
+
}
|
|
99
|
+
sendHandshake() {
|
|
100
|
+
if (!this.ws || this.ws.readyState !== WebSocket.OPEN)
|
|
101
|
+
return;
|
|
102
|
+
const id = randomUUID();
|
|
103
|
+
this.pending.set(id, {
|
|
104
|
+
resolve: result => { this._ready = true; this.emit("ready", result); },
|
|
105
|
+
reject: err => this.emit("error", new Error(`Handshake failed: ${err.message}`)),
|
|
106
|
+
});
|
|
107
|
+
const frame = {
|
|
108
|
+
type: "req", id, method: "connect",
|
|
109
|
+
params: {
|
|
110
|
+
minProtocol: 3, maxProtocol: 3,
|
|
111
|
+
client: { id: "cli", displayName: "OpenAlerts", version: "0.1.0", platform: process.platform, mode: "cli" },
|
|
112
|
+
role: "operator",
|
|
113
|
+
scopes: ["operator.read"],
|
|
114
|
+
caps: [], commands: [], permissions: {},
|
|
115
|
+
locale: "en-US",
|
|
116
|
+
userAgent: "openalerts/0.1.0",
|
|
117
|
+
auth: this.token ? { token: this.token } : undefined,
|
|
118
|
+
},
|
|
119
|
+
};
|
|
120
|
+
this.ws.send(JSON.stringify(frame));
|
|
121
|
+
}
|
|
122
|
+
scheduleReconnect() {
|
|
123
|
+
if (this.connectTimer)
|
|
124
|
+
clearTimeout(this.connectTimer);
|
|
125
|
+
this.connectTimer = setTimeout(() => {
|
|
126
|
+
this.backoffMs = Math.min(this.backoffMs * 2, 60_000);
|
|
127
|
+
this.connect();
|
|
128
|
+
}, this.backoffMs);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
//# sourceMappingURL=gateway.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gateway.js","sourceRoot":"","sources":["../../src/watchers/gateway.ts"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "openalerts",
|
|
3
|
+
"version": "0.2.6",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"description": "Standalone monitoring daemon for OpenClaw — live dashboard, alerts via Telegram/webhook, REST API",
|
|
6
|
+
"author": "Nilay",
|
|
7
|
+
"license": "Apache-2.0",
|
|
8
|
+
"keywords": [
|
|
9
|
+
"openclaw",
|
|
10
|
+
"monitoring",
|
|
11
|
+
"alerts",
|
|
12
|
+
"telegram",
|
|
13
|
+
"dashboard",
|
|
14
|
+
"ai-agent",
|
|
15
|
+
"llm"
|
|
16
|
+
],
|
|
17
|
+
"repository": {
|
|
18
|
+
"type": "git",
|
|
19
|
+
"url": "https://github.com/steadwing/openalerts.git",
|
|
20
|
+
"directory": "node"
|
|
21
|
+
},
|
|
22
|
+
"bin": {
|
|
23
|
+
"openalerts": "./bin/openalerts.js"
|
|
24
|
+
},
|
|
25
|
+
"main": "./dist/cli.js",
|
|
26
|
+
"files": [
|
|
27
|
+
"dist",
|
|
28
|
+
"bin",
|
|
29
|
+
"README.md"
|
|
30
|
+
],
|
|
31
|
+
"scripts": {
|
|
32
|
+
"build": "tsc",
|
|
33
|
+
"dev": "node --experimental-sqlite --enable-source-maps dist/cli.js start",
|
|
34
|
+
"start": "node --experimental-sqlite dist/cli.js start",
|
|
35
|
+
"typecheck": "tsc --noEmit",
|
|
36
|
+
"clean": "node -e \"const fs=require('fs');try{fs.rmSync('dist',{recursive:true,force:true})}catch{}\""
|
|
37
|
+
},
|
|
38
|
+
"dependencies": {
|
|
39
|
+
"ws": "^8.18.0"
|
|
40
|
+
},
|
|
41
|
+
"devDependencies": {
|
|
42
|
+
"@types/ws": "^8.5.13",
|
|
43
|
+
"typescript": "^5.9.3"
|
|
44
|
+
},
|
|
45
|
+
"engines": {
|
|
46
|
+
"node": ">=22.5.0"
|
|
47
|
+
}
|
|
48
|
+
}
|