@insta-dev01/insta-plugin-openclaw 1.0.0 → 1.0.2
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/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +171 -0
- package/dist/index.js.map +1 -0
- package/dist/src/channel/config.d.ts +9 -0
- package/dist/src/channel/config.d.ts.map +1 -0
- package/dist/src/channel/config.js +10 -0
- package/dist/src/channel/config.js.map +1 -0
- package/dist/src/channel/connection.d.ts +34 -0
- package/dist/src/channel/connection.d.ts.map +1 -0
- package/dist/src/channel/connection.js +281 -0
- package/dist/src/channel/connection.js.map +1 -0
- package/dist/src/channel/dispatcher.d.ts +43 -0
- package/dist/src/channel/dispatcher.d.ts.map +1 -0
- package/dist/src/channel/dispatcher.js +324 -0
- package/dist/src/channel/dispatcher.js.map +1 -0
- package/dist/src/channel/index.d.ts +5 -0
- package/dist/src/channel/index.d.ts.map +1 -0
- package/dist/src/channel/index.js +135 -0
- package/dist/src/channel/index.js.map +1 -0
- package/dist/src/channel/logger.d.ts +10 -0
- package/dist/src/channel/logger.d.ts.map +1 -0
- package/dist/src/channel/logger.js +30 -0
- package/dist/src/channel/logger.js.map +1 -0
- package/dist/src/channel/protocol.d.ts +15 -0
- package/dist/src/channel/protocol.d.ts.map +1 -0
- package/dist/src/channel/protocol.js +204 -0
- package/dist/src/channel/protocol.js.map +1 -0
- package/dist/src/channel/registrar.d.ts +21 -0
- package/dist/src/channel/registrar.d.ts.map +1 -0
- package/dist/src/channel/registrar.js +115 -0
- package/dist/src/channel/registrar.js.map +1 -0
- package/dist/src/channel/registration-store.d.ts +21 -0
- package/dist/src/channel/registration-store.d.ts.map +1 -0
- package/{src/channel/registration-store.ts → dist/src/channel/registration-store.js} +21 -46
- package/dist/src/channel/registration-store.js.map +1 -0
- package/dist/src/channel/types.d.ts +80 -0
- package/dist/src/channel/types.d.ts.map +1 -0
- package/dist/src/channel/types.js +3 -0
- package/dist/src/channel/types.js.map +1 -0
- package/dist/src/core/index.d.ts +5 -0
- package/dist/src/core/index.d.ts.map +1 -0
- package/dist/src/core/index.js +3 -0
- package/dist/src/core/index.js.map +1 -0
- package/dist/src/core/register-identity.d.ts +58 -0
- package/dist/src/core/register-identity.d.ts.map +1 -0
- package/dist/src/core/register-identity.js +251 -0
- package/dist/src/core/register-identity.js.map +1 -0
- package/dist/src/core/task-api.d.ts +31 -0
- package/dist/src/core/task-api.d.ts.map +1 -0
- package/dist/src/core/task-api.js +116 -0
- package/dist/src/core/task-api.js.map +1 -0
- package/dist/src/core/urls.d.ts +33 -0
- package/dist/src/core/urls.d.ts.map +1 -0
- package/dist/src/core/urls.js +40 -0
- package/dist/src/core/urls.js.map +1 -0
- package/dist/src/tools/get-plugin-profile.d.ts +7 -0
- package/dist/src/tools/get-plugin-profile.d.ts.map +1 -0
- package/dist/src/tools/get-plugin-profile.js +132 -0
- package/dist/src/tools/get-plugin-profile.js.map +1 -0
- package/dist/src/tools/grab-task.d.ts +7 -0
- package/dist/src/tools/grab-task.d.ts.map +1 -0
- package/dist/src/tools/grab-task.js +100 -0
- package/dist/src/tools/grab-task.js.map +1 -0
- package/dist/src/tools/list-tasks.d.ts +7 -0
- package/dist/src/tools/list-tasks.d.ts.map +1 -0
- package/dist/src/tools/list-tasks.js +92 -0
- package/dist/src/tools/list-tasks.js.map +1 -0
- package/dist/src/tools/propose-registration.d.ts +14 -0
- package/dist/src/tools/propose-registration.d.ts.map +1 -0
- package/dist/src/tools/propose-registration.js +103 -0
- package/dist/src/tools/propose-registration.js.map +1 -0
- package/dist/src/tools/register-identity.d.ts +11 -0
- package/dist/src/tools/register-identity.d.ts.map +1 -0
- package/dist/src/tools/register-identity.js +101 -0
- package/dist/src/tools/register-identity.js.map +1 -0
- package/dist/src/tools/submit-deliverable.d.ts +17 -0
- package/dist/src/tools/submit-deliverable.d.ts.map +1 -0
- package/dist/src/tools/submit-deliverable.js +215 -0
- package/dist/src/tools/submit-deliverable.js.map +1 -0
- package/dist/src/tools/upload-artifact.d.ts +14 -0
- package/dist/src/tools/upload-artifact.d.ts.map +1 -0
- package/dist/src/tools/upload-artifact.js +166 -0
- package/dist/src/tools/upload-artifact.js.map +1 -0
- package/dist/src/utils/file-lock.d.ts +4 -0
- package/dist/src/utils/file-lock.d.ts.map +1 -0
- package/dist/src/utils/file-lock.js +43 -0
- package/dist/src/utils/file-lock.js.map +1 -0
- package/dist/src/utils/profile.d.ts +17 -0
- package/dist/src/utils/profile.d.ts.map +1 -0
- package/dist/src/utils/profile.js +26 -0
- package/dist/src/utils/profile.js.map +1 -0
- package/dist/src/utils/session.d.ts +3 -0
- package/dist/src/utils/session.d.ts.map +1 -0
- package/dist/src/utils/session.js +26 -0
- package/dist/src/utils/session.js.map +1 -0
- package/package.json +17 -5
- package/.env.example +0 -23
- package/channel/346/265/201/347/250/213/345/233/276.md +0 -477
- package/index.ts +0 -198
- package/src/channel/config.ts +0 -27
- package/src/channel/connection.ts +0 -341
- package/src/channel/dispatcher.ts +0 -374
- package/src/channel/index.ts +0 -173
- package/src/channel/logger.ts +0 -36
- package/src/channel/protocol.ts +0 -265
- package/src/channel/registrar.ts +0 -172
- package/src/channel/types.ts +0 -102
- package/src/core/index.ts +0 -13
- package/src/core/register-identity.ts +0 -326
- package/src/core/task-api.ts +0 -168
- package/src/core/urls.ts +0 -52
- package/src/prompt/job.md +0 -21
- package/src/tools/get-plugin-profile.ts +0 -152
- package/src/tools/grab-task.ts +0 -133
- package/src/tools/list-tasks.ts +0 -135
- package/src/tools/propose-registration.ts +0 -116
- package/src/tools/register-identity.ts +0 -121
- package/src/tools/submit-deliverable.ts +0 -268
- package/src/tools/upload-artifact.ts +0 -222
- package/src/utils/file-lock.ts +0 -43
- package/src/utils/profile.ts +0 -45
- package/src/utils/session.ts +0 -30
- package/tests/profile.test.ts +0 -70
- package/tests/session.test.ts +0 -53
- package/tsconfig.json +0 -49
- package/vitest.config.ts +0 -26
|
@@ -0,0 +1,324 @@
|
|
|
1
|
+
import { createInProgressEvent, createOutputItemAddedEvent, createOutputTextDeltaEvent, createContentPartDoneEvent, createCompletedEvent, createFailedEvent, createEnvelope, } from "./protocol.js";
|
|
2
|
+
// ── SDKDispatcher ─────────────────────────────────────────────────────────────
|
|
3
|
+
export class SDKDispatcher {
|
|
4
|
+
config;
|
|
5
|
+
logger;
|
|
6
|
+
accountId;
|
|
7
|
+
channelRuntime;
|
|
8
|
+
contexts = new Map();
|
|
9
|
+
constructor(config, logger, accountId, channelRuntime) {
|
|
10
|
+
this.config = config;
|
|
11
|
+
this.logger = logger;
|
|
12
|
+
this.accountId = accountId;
|
|
13
|
+
this.channelRuntime = channelRuntime;
|
|
14
|
+
this.logger.info("SDKDispatcher initialized", {
|
|
15
|
+
requestTimeout: config.requestTimeout,
|
|
16
|
+
maxConcurrentRequests: config.maxConcurrentRequests,
|
|
17
|
+
hasChannelRuntime: !!channelRuntime,
|
|
18
|
+
accountId,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
async dispatchRequest(request, ws) {
|
|
22
|
+
const sessionId = request.sessionId ?? "";
|
|
23
|
+
if (!request.content?.trim()) {
|
|
24
|
+
const responseId = this.newId("resp");
|
|
25
|
+
await this.sendFailedEvent(ws, responseId, "INVALID_REQUEST", "Request content must be non-empty", sessionId);
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
if (this.activeCount() >= this.config.maxConcurrentRequests) {
|
|
29
|
+
const responseId = this.newId("resp");
|
|
30
|
+
await this.sendFailedEvent(ws, responseId, "RATE_LIMIT", "Maximum concurrent requests exceeded", sessionId);
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const responseId = this.newId("resp");
|
|
34
|
+
const itemId = this.newId("item");
|
|
35
|
+
const abortController = new AbortController();
|
|
36
|
+
const ctx = {
|
|
37
|
+
messageId: request.messageId,
|
|
38
|
+
responseId,
|
|
39
|
+
itemId,
|
|
40
|
+
content: request.content,
|
|
41
|
+
requestTimestamp: Date.now(),
|
|
42
|
+
responseBuffer: "",
|
|
43
|
+
firstChunkReceived: false,
|
|
44
|
+
timeoutTimer: null,
|
|
45
|
+
abortController,
|
|
46
|
+
status: "pending",
|
|
47
|
+
ws,
|
|
48
|
+
sessionId,
|
|
49
|
+
};
|
|
50
|
+
this.contexts.set(request.messageId, ctx);
|
|
51
|
+
this.logger.info("Dispatching request", {
|
|
52
|
+
messageId: request.messageId,
|
|
53
|
+
responseId,
|
|
54
|
+
sessionId,
|
|
55
|
+
contentLength: request.content.length,
|
|
56
|
+
});
|
|
57
|
+
ctx.timeoutTimer = setTimeout(() => this.handleTimeout(request.messageId), this.config.requestTimeout);
|
|
58
|
+
ctx.status = "processing";
|
|
59
|
+
try {
|
|
60
|
+
await this.realSDKDispatch(request.content, this.createCallback(request.messageId), abortController.signal, sessionId);
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
if (err instanceof Error && err.name === "AbortError")
|
|
64
|
+
return;
|
|
65
|
+
await this.handleError(ctx, err instanceof Error ? err : new Error(String(err)));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
activeCount() {
|
|
69
|
+
let n = 0;
|
|
70
|
+
for (const c of this.contexts.values()) {
|
|
71
|
+
if (c.status === "pending" || c.status === "processing")
|
|
72
|
+
n++;
|
|
73
|
+
}
|
|
74
|
+
return n;
|
|
75
|
+
}
|
|
76
|
+
// ── Private ─────────────────────────────────────────────────────────────────
|
|
77
|
+
newId(prefix) {
|
|
78
|
+
return `${prefix}_${Date.now()}_${Math.random().toString(36).substring(2, 11)}`;
|
|
79
|
+
}
|
|
80
|
+
buildSessionKey(sessionId) {
|
|
81
|
+
const account = this.accountId ?? "default";
|
|
82
|
+
return sessionId ? `instaclaw:${account}:${sessionId}` : `instaclaw:${account}`;
|
|
83
|
+
}
|
|
84
|
+
async sendFailedEvent(ws, responseId, code, message, sessionId) {
|
|
85
|
+
try {
|
|
86
|
+
if (ws.readyState === 1) {
|
|
87
|
+
ws.send(createEnvelope(createFailedEvent(responseId, code, message, null, sessionId)));
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
catch (err) {
|
|
91
|
+
this.logger.error("Failed to send failed event", err);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
async realSDKDispatch(content, callback, signal, sessionId) {
|
|
95
|
+
const runtime = this.channelRuntime;
|
|
96
|
+
if (!runtime?.reply?.dispatchReplyWithBufferedBlockDispatcher) {
|
|
97
|
+
this.logger.warn("channelRuntime not available — falling back to echo");
|
|
98
|
+
await new Promise((resolve) => {
|
|
99
|
+
setTimeout(() => {
|
|
100
|
+
if (!signal?.aborted)
|
|
101
|
+
callback("[no AI runtime] echo: " + content.substring(0, 50), null, false);
|
|
102
|
+
setTimeout(() => {
|
|
103
|
+
if (!signal?.aborted)
|
|
104
|
+
callback(null, null, true);
|
|
105
|
+
resolve();
|
|
106
|
+
}, 50);
|
|
107
|
+
}, 50);
|
|
108
|
+
});
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
const baseSystemPrompt = (this.config.systemPrompt ?? "");
|
|
112
|
+
const sessionInstruction = sessionId
|
|
113
|
+
? `\n\n【当前会话信息】\n当前雇佣会话 sessionId 为:${sessionId}\n当你调用 insta_upload_artifact 上传文件时,必须将此 sessionId 作为参数传入,以便系统自动将产物与本次雇佣会话关联。`
|
|
114
|
+
: "";
|
|
115
|
+
const resolvedSystemPrompt = (baseSystemPrompt + sessionInstruction).trim() || undefined;
|
|
116
|
+
const msgCtx = {
|
|
117
|
+
Body: content,
|
|
118
|
+
AccountId: this.accountId,
|
|
119
|
+
SessionKey: this.buildSessionKey(sessionId),
|
|
120
|
+
...(resolvedSystemPrompt ? { SystemPrompt: resolvedSystemPrompt } : {}),
|
|
121
|
+
};
|
|
122
|
+
let alreadyCompleted = false;
|
|
123
|
+
const safeComplete = () => {
|
|
124
|
+
if (alreadyCompleted || signal?.aborted)
|
|
125
|
+
return;
|
|
126
|
+
alreadyCompleted = true;
|
|
127
|
+
callback(null, null, true);
|
|
128
|
+
};
|
|
129
|
+
let streamedAnyChunks = false;
|
|
130
|
+
let previousAccumulatedText = "";
|
|
131
|
+
await runtime.reply.dispatchReplyWithBufferedBlockDispatcher({
|
|
132
|
+
ctx: msgCtx,
|
|
133
|
+
cfg: this.config.cfg,
|
|
134
|
+
replyOptions: {
|
|
135
|
+
abortSignal: signal,
|
|
136
|
+
onPartialReply: (payload) => {
|
|
137
|
+
if (signal?.aborted)
|
|
138
|
+
return;
|
|
139
|
+
if (payload.text && payload.text.length > previousAccumulatedText.length) {
|
|
140
|
+
const delta = payload.text.substring(previousAccumulatedText.length);
|
|
141
|
+
previousAccumulatedText = payload.text;
|
|
142
|
+
if (delta) {
|
|
143
|
+
streamedAnyChunks = true;
|
|
144
|
+
callback(delta, null, false);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
},
|
|
148
|
+
},
|
|
149
|
+
dispatcherOptions: {
|
|
150
|
+
deliver: async (payload) => {
|
|
151
|
+
if (signal?.aborted)
|
|
152
|
+
return;
|
|
153
|
+
if (!streamedAnyChunks && payload.text) {
|
|
154
|
+
callback(payload.text, null, false);
|
|
155
|
+
}
|
|
156
|
+
safeComplete();
|
|
157
|
+
},
|
|
158
|
+
onError: (err) => {
|
|
159
|
+
callback(null, err instanceof Error ? err : new Error(String(err)), false);
|
|
160
|
+
},
|
|
161
|
+
},
|
|
162
|
+
});
|
|
163
|
+
safeComplete();
|
|
164
|
+
}
|
|
165
|
+
createCallback(messageId) {
|
|
166
|
+
return (chunk, error, isComplete) => {
|
|
167
|
+
try {
|
|
168
|
+
const ctx = this.contexts.get(messageId);
|
|
169
|
+
if (!ctx) {
|
|
170
|
+
this.logger.warn("Callback for unknown messageId", { messageId });
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
if (error) {
|
|
174
|
+
this.handleError(ctx, error).catch((e) => this.logger.error("Error in handleError", e));
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
if (isComplete) {
|
|
178
|
+
this.handleCompletion(ctx).catch((e) => this.logger.error("Error in handleCompletion", e));
|
|
179
|
+
return;
|
|
180
|
+
}
|
|
181
|
+
if (chunk) {
|
|
182
|
+
this.handleChunk(ctx, chunk).catch((e) => this.logger.error("Error in handleChunk", e));
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
catch (e) {
|
|
186
|
+
this.logger.error("Callback threw", e);
|
|
187
|
+
}
|
|
188
|
+
};
|
|
189
|
+
}
|
|
190
|
+
handleTimeout(messageId) {
|
|
191
|
+
const ctx = this.contexts.get(messageId);
|
|
192
|
+
if (!ctx)
|
|
193
|
+
return;
|
|
194
|
+
this.logger.warn("Request timeout", { messageId, responseId: ctx.responseId });
|
|
195
|
+
ctx.status = "timeout";
|
|
196
|
+
this.generateFailedEvent(ctx, "TIMEOUT", `Request timed out after ${this.config.requestTimeout}ms`, {
|
|
197
|
+
timeoutDuration: this.config.requestTimeout,
|
|
198
|
+
}).catch((e) => this.logger.error("Failed to generate timeout event", e));
|
|
199
|
+
ctx.abortController?.abort();
|
|
200
|
+
this.cleanupContext(messageId);
|
|
201
|
+
}
|
|
202
|
+
sendWs(ctx, data) {
|
|
203
|
+
if (ctx.ws.readyState === 1) {
|
|
204
|
+
ctx.ws.send(data);
|
|
205
|
+
}
|
|
206
|
+
else {
|
|
207
|
+
this.logger.warn("WebSocket not open, dropping event", { responseId: ctx.responseId, readyState: ctx.ws.readyState });
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
async generateInProgressEvent(ctx) {
|
|
211
|
+
try {
|
|
212
|
+
this.sendWs(ctx, createEnvelope(createInProgressEvent(ctx.responseId, ctx.sessionId)));
|
|
213
|
+
}
|
|
214
|
+
catch (e) {
|
|
215
|
+
this.logger.error("Failed to send in_progress", e);
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
async generateItemAddedEvent(ctx) {
|
|
219
|
+
try {
|
|
220
|
+
this.sendWs(ctx, createEnvelope(createOutputItemAddedEvent(ctx.responseId, ctx.itemId, 0)));
|
|
221
|
+
}
|
|
222
|
+
catch (e) {
|
|
223
|
+
this.logger.error("Failed to send item_added", e);
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
async generateDeltaEvent(ctx, text) {
|
|
227
|
+
try {
|
|
228
|
+
this.sendWs(ctx, createEnvelope(createOutputTextDeltaEvent(ctx.responseId, ctx.itemId, 0, text)));
|
|
229
|
+
}
|
|
230
|
+
catch (e) {
|
|
231
|
+
this.logger.error("Failed to send delta", e);
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
async generateContentPartDoneEvent(ctx) {
|
|
235
|
+
try {
|
|
236
|
+
this.sendWs(ctx, createEnvelope(createContentPartDoneEvent(ctx.responseId, ctx.itemId, 0)));
|
|
237
|
+
}
|
|
238
|
+
catch (e) {
|
|
239
|
+
this.logger.error("Failed to send content_part.done", e);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
async generateCompletedEvent(ctx) {
|
|
243
|
+
try {
|
|
244
|
+
this.sendWs(ctx, createEnvelope(createCompletedEvent(ctx.responseId, ctx.sessionId)));
|
|
245
|
+
}
|
|
246
|
+
catch (e) {
|
|
247
|
+
this.logger.error("Failed to send completed", e);
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
async generateFailedEvent(ctx, code, message, details) {
|
|
251
|
+
try {
|
|
252
|
+
this.sendWs(ctx, createEnvelope(createFailedEvent(ctx.responseId, code, message, details, ctx.sessionId)));
|
|
253
|
+
}
|
|
254
|
+
catch (e) {
|
|
255
|
+
this.logger.error("Failed to send failed event", e);
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
async handleChunk(ctx, chunk) {
|
|
259
|
+
try {
|
|
260
|
+
if (!ctx.firstChunkReceived) {
|
|
261
|
+
ctx.firstChunkReceived = true;
|
|
262
|
+
await this.generateInProgressEvent(ctx);
|
|
263
|
+
await this.generateItemAddedEvent(ctx);
|
|
264
|
+
}
|
|
265
|
+
ctx.responseBuffer += chunk;
|
|
266
|
+
await this.generateDeltaEvent(ctx, chunk);
|
|
267
|
+
}
|
|
268
|
+
catch (e) {
|
|
269
|
+
this.logger.error("Error handling chunk", e);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
async handleCompletion(ctx) {
|
|
273
|
+
try {
|
|
274
|
+
// If the SDK produced no chunks at all (e.g. empty reply), still emit
|
|
275
|
+
// the protocol preamble so the client sees a well-formed response.
|
|
276
|
+
if (!ctx.firstChunkReceived) {
|
|
277
|
+
ctx.firstChunkReceived = true;
|
|
278
|
+
await this.generateInProgressEvent(ctx);
|
|
279
|
+
await this.generateItemAddedEvent(ctx);
|
|
280
|
+
}
|
|
281
|
+
await this.generateContentPartDoneEvent(ctx);
|
|
282
|
+
await this.generateCompletedEvent(ctx);
|
|
283
|
+
ctx.status = "completed";
|
|
284
|
+
this.logger.info("Request completed", {
|
|
285
|
+
messageId: ctx.messageId,
|
|
286
|
+
responseId: ctx.responseId,
|
|
287
|
+
duration: Date.now() - ctx.requestTimestamp,
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
catch (e) {
|
|
291
|
+
this.logger.error("Error in handleCompletion", e);
|
|
292
|
+
}
|
|
293
|
+
finally {
|
|
294
|
+
this.cleanupContext(ctx.messageId);
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
async handleError(ctx, error) {
|
|
298
|
+
try {
|
|
299
|
+
let code = "SDK_ERROR";
|
|
300
|
+
if (error.message.includes("timeout"))
|
|
301
|
+
code = "TIMEOUT";
|
|
302
|
+
await this.generateFailedEvent(ctx, code, error.message, { stack: error.stack });
|
|
303
|
+
ctx.status = "failed";
|
|
304
|
+
}
|
|
305
|
+
catch (e) {
|
|
306
|
+
this.logger.error("Error in handleError", e);
|
|
307
|
+
}
|
|
308
|
+
finally {
|
|
309
|
+
this.cleanupContext(ctx.messageId);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
cleanupContext(messageId) {
|
|
313
|
+
const ctx = this.contexts.get(messageId);
|
|
314
|
+
if (!ctx)
|
|
315
|
+
return;
|
|
316
|
+
if (ctx.timeoutTimer) {
|
|
317
|
+
clearTimeout(ctx.timeoutTimer);
|
|
318
|
+
ctx.timeoutTimer = null;
|
|
319
|
+
}
|
|
320
|
+
ctx.abortController = null;
|
|
321
|
+
this.contexts.delete(messageId);
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
//# sourceMappingURL=dispatcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dispatcher.js","sourceRoot":"","sources":["../../../src/channel/dispatcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ChannelPlugin } from "openclaw/plugin-sdk";
|
|
2
|
+
export declare function registerConnection(accountId: string, ws: import("ws").WebSocket): void;
|
|
3
|
+
export declare function unregisterConnection(accountId: string): void;
|
|
4
|
+
export declare const plugin: ChannelPlugin;
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/channel/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAczD,wBAAgB,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,EAAE,EAAE,OAAO,IAAI,EAAE,SAAS,GAAG,IAAI,CAEtF;AAED,wBAAgB,oBAAoB,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,CAE5D;AAID,eAAO,MAAM,MAAM,EAAE,aAoJpB,CAAC"}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { DEFAULT_ACCOUNT_ID } from "openclaw/plugin-sdk/account-id";
|
|
2
|
+
import { CHANNEL_ID, DEBUG_ENABLED, POLL_INTERVAL_MS } from "./config.js";
|
|
3
|
+
import { monitorProvider } from "./connection.js";
|
|
4
|
+
import { triggerRegistrationAgent } from "./registrar.js";
|
|
5
|
+
import { setBaseDir, isAgentRunning, getPendingRegistration } from "./registration-store.js";
|
|
6
|
+
import { readProfile } from "../utils/profile.js";
|
|
7
|
+
import { createEnvelope, textToEventSequence } from "./protocol.js";
|
|
8
|
+
import { DebugLogger } from "./logger.js";
|
|
9
|
+
// ── Active WS connections (accountId → WebSocket) ─────────────────────────────
|
|
10
|
+
const activeConnections = new Map();
|
|
11
|
+
export function registerConnection(accountId, ws) {
|
|
12
|
+
activeConnections.set(accountId || "default", ws);
|
|
13
|
+
}
|
|
14
|
+
export function unregisterConnection(accountId) {
|
|
15
|
+
activeConnections.delete(accountId || "default");
|
|
16
|
+
}
|
|
17
|
+
// ── Plugin ────────────────────────────────────────────────────────────────────
|
|
18
|
+
export const plugin = {
|
|
19
|
+
id: CHANNEL_ID,
|
|
20
|
+
meta: {
|
|
21
|
+
id: CHANNEL_ID,
|
|
22
|
+
label: "InstaClaw",
|
|
23
|
+
selectionLabel: "InstaClaw",
|
|
24
|
+
docsPath: "/plugins/insta-plugin-openclaw",
|
|
25
|
+
blurb: "Instagram Claw Connector",
|
|
26
|
+
},
|
|
27
|
+
capabilities: {
|
|
28
|
+
chatTypes: ["direct"],
|
|
29
|
+
media: false,
|
|
30
|
+
polls: false,
|
|
31
|
+
threads: false,
|
|
32
|
+
reactions: false,
|
|
33
|
+
edit: false,
|
|
34
|
+
reply: false,
|
|
35
|
+
},
|
|
36
|
+
config: {
|
|
37
|
+
listAccountIds: (_cfg) => [DEFAULT_ACCOUNT_ID],
|
|
38
|
+
resolveAccount: (_cfg, accountId) => ({
|
|
39
|
+
accountId: accountId ?? DEFAULT_ACCOUNT_ID,
|
|
40
|
+
}),
|
|
41
|
+
defaultAccountId: () => DEFAULT_ACCOUNT_ID,
|
|
42
|
+
isConfigured: (_account) => true,
|
|
43
|
+
describeAccount: (account) => ({
|
|
44
|
+
accountId: account.accountId,
|
|
45
|
+
}),
|
|
46
|
+
},
|
|
47
|
+
gateway: {
|
|
48
|
+
startAccount: async (ctx) => {
|
|
49
|
+
const { cfg, accountId, abortSignal } = ctx;
|
|
50
|
+
const resolvedAccountId = accountId ?? DEFAULT_ACCOUNT_ID;
|
|
51
|
+
// Resolve base directory for local profile storage
|
|
52
|
+
const cfgAny = cfg;
|
|
53
|
+
const baseDir = cfgAny["agentDir"] ??
|
|
54
|
+
cfgAny["workspaceDir"] ??
|
|
55
|
+
process.env["INSTA_BASE_DIR"] ??
|
|
56
|
+
process.cwd();
|
|
57
|
+
const logger = new DebugLogger(DEBUG_ENABLED, `[InstaPlugin:${resolvedAccountId}:startup]`);
|
|
58
|
+
// Bug 1 fix: cache the resolved baseDir so the gateway method
|
|
59
|
+
// (instaclaw.registration.submit) writes profile.json to the same path
|
|
60
|
+
// that this polling loop reads from.
|
|
61
|
+
setBaseDir(baseDir);
|
|
62
|
+
// Abort-aware sleep helper
|
|
63
|
+
const sleep = (ms) => new Promise((resolve) => {
|
|
64
|
+
if (abortSignal.aborted) {
|
|
65
|
+
resolve();
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
const t = setTimeout(resolve, ms);
|
|
69
|
+
abortSignal.addEventListener("abort", () => { clearTimeout(t); resolve(); }, { once: true });
|
|
70
|
+
});
|
|
71
|
+
logger.info("Gateway startup — entering credential polling loop", { baseDir, pollIntervalMs: POLL_INTERVAL_MS });
|
|
72
|
+
while (!abortSignal.aborted) {
|
|
73
|
+
const profile = await readProfile(baseDir).catch((err) => {
|
|
74
|
+
logger.error("Failed to read profile", err);
|
|
75
|
+
return null;
|
|
76
|
+
});
|
|
77
|
+
const hasCredentials = !!(profile?.app_key && profile?.app_secret);
|
|
78
|
+
if (hasCredentials) {
|
|
79
|
+
logger.info("Credentials found, establishing WebSocket connection");
|
|
80
|
+
await monitorProvider({ clientId: profile.app_key, clientSecret: profile.app_secret }, resolvedAccountId, abortSignal, ctx.channelRuntime);
|
|
81
|
+
// monitorProvider resolves when the connection is cleanly shut down (abort).
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
// ── No credentials yet ────────────────────────────────────────────────
|
|
85
|
+
//
|
|
86
|
+
// Bug 2 fix: use store-based flags instead of a local boolean so the
|
|
87
|
+
// loop can recover if the agent completes without creating a proposal.
|
|
88
|
+
//
|
|
89
|
+
// isAgentRunning() → dispatch is in-flight, skip
|
|
90
|
+
// getPendingRegistration() → proposal exists, wait for user, skip
|
|
91
|
+
// neither → safe to trigger (first run OR recovery)
|
|
92
|
+
const agentRunning = isAgentRunning();
|
|
93
|
+
const hasPending = !!getPendingRegistration();
|
|
94
|
+
logger.info("No credentials in profile — waiting for registration", {
|
|
95
|
+
profileExists: !!profile,
|
|
96
|
+
agentRunning,
|
|
97
|
+
hasPending,
|
|
98
|
+
});
|
|
99
|
+
if (!agentRunning && !hasPending) {
|
|
100
|
+
const result = await triggerRegistrationAgent(ctx.channelRuntime, cfg, logger, resolvedAccountId);
|
|
101
|
+
logger.info("Registration agent trigger result", { status: result.status, error: result.error });
|
|
102
|
+
}
|
|
103
|
+
await sleep(POLL_INTERVAL_MS);
|
|
104
|
+
}
|
|
105
|
+
},
|
|
106
|
+
},
|
|
107
|
+
outbound: {
|
|
108
|
+
deliveryMode: "gateway",
|
|
109
|
+
sendText: async (ctx) => {
|
|
110
|
+
const { cfg, to, text, accountId } = ctx;
|
|
111
|
+
void cfg; // credentials are managed via gateway; cfg not needed here
|
|
112
|
+
if (!text?.trim()) {
|
|
113
|
+
throw new Error("Cannot send empty message");
|
|
114
|
+
}
|
|
115
|
+
const wsKey = accountId ?? DEFAULT_ACCOUNT_ID;
|
|
116
|
+
const ws = activeConnections.get(wsKey);
|
|
117
|
+
if (!ws) {
|
|
118
|
+
throw new Error(`WebSocket not found for account "${wsKey}". Gateway may not be connected.`);
|
|
119
|
+
}
|
|
120
|
+
if (ws.readyState !== 1 /* OPEN */) {
|
|
121
|
+
throw new Error(`WebSocket not open (state: ${ws.readyState}) for account "${wsKey}"`);
|
|
122
|
+
}
|
|
123
|
+
const events = textToEventSequence(text);
|
|
124
|
+
for (const event of events) {
|
|
125
|
+
ws.send(createEnvelope(event));
|
|
126
|
+
}
|
|
127
|
+
return {
|
|
128
|
+
channel: CHANNEL_ID,
|
|
129
|
+
messageId: `msg_${Date.now()}_${Math.random().toString(36).substring(2, 9)}`,
|
|
130
|
+
to,
|
|
131
|
+
};
|
|
132
|
+
},
|
|
133
|
+
},
|
|
134
|
+
};
|
|
135
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/channel/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare class DebugLogger {
|
|
2
|
+
private enabled;
|
|
3
|
+
private prefix;
|
|
4
|
+
constructor(enabled: boolean, prefix?: string);
|
|
5
|
+
info(message: string, ...args: unknown[]): void;
|
|
6
|
+
debug(message: string, ...args: unknown[]): void;
|
|
7
|
+
warn(message: string, ...args: unknown[]): void;
|
|
8
|
+
error(message: string, errorOrContext?: unknown, ...args: unknown[]): void;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/channel/logger.ts"],"names":[],"mappings":"AAAA,qBAAa,WAAW;IAEpB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,MAAM;gBADN,OAAO,EAAE,OAAO,EAChB,MAAM,GAAE,MAAwB;IAG1C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAI/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAMhD,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAI/C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;CAe3E"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export class DebugLogger {
|
|
2
|
+
enabled;
|
|
3
|
+
prefix;
|
|
4
|
+
constructor(enabled, prefix = "[InstaPlugin]") {
|
|
5
|
+
this.enabled = enabled;
|
|
6
|
+
this.prefix = prefix;
|
|
7
|
+
}
|
|
8
|
+
info(message, ...args) {
|
|
9
|
+
console.log(`${new Date().toISOString()} [INFO] ${this.prefix}`, message, ...args);
|
|
10
|
+
}
|
|
11
|
+
debug(message, ...args) {
|
|
12
|
+
if (this.enabled) {
|
|
13
|
+
console.log(`${new Date().toISOString()} [DEBUG] ${this.prefix}`, message, ...args);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
warn(message, ...args) {
|
|
17
|
+
console.warn(`${new Date().toISOString()} [WARN] ${this.prefix}`, message, ...args);
|
|
18
|
+
}
|
|
19
|
+
error(message, errorOrContext, ...args) {
|
|
20
|
+
const ts = new Date().toISOString();
|
|
21
|
+
if (errorOrContext instanceof Error) {
|
|
22
|
+
console.error(`${ts} [ERROR] ${this.prefix}`, message, "\nError:", errorOrContext.message, "\nStack:", errorOrContext.stack, ...args);
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
const tail = errorOrContext === undefined ? args : [errorOrContext, ...args];
|
|
26
|
+
console.error(`${ts} [ERROR] ${this.prefix}`, message, ...tail);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/channel/logger.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,WAAW;IAEZ;IACA;IAFV,YACU,OAAgB,EAChB,SAAiB,eAAe;QADhC,YAAO,GAAP,OAAO,CAAS;QAChB,WAAM,GAAN,MAAM,CAA0B;IACvC,CAAC;IAEJ,IAAI,CAAC,OAAe,EAAE,GAAG,IAAe;QACtC,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,WAAW,IAAI,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACrF,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,GAAG,IAAe;QACvC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,YAAY,IAAI,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;QACtF,CAAC;IACH,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,GAAG,IAAe;QACtC,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,WAAW,IAAI,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;IACtF,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,cAAwB,EAAE,GAAG,IAAe;QACjE,MAAM,EAAE,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QACpC,IAAI,cAAc,YAAY,KAAK,EAAE,CAAC;YACpC,OAAO,CAAC,KAAK,CACX,GAAG,EAAE,YAAY,IAAI,CAAC,MAAM,EAAE,EAC9B,OAAO,EACP,UAAU,EAAE,cAAc,CAAC,OAAO,EAClC,UAAU,EAAE,cAAc,CAAC,KAAK,EAChC,GAAG,IAAI,CACR,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,GAAG,cAAc,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,cAAc,EAAE,GAAG,IAAI,CAAC,CAAC;YAC7E,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,YAAY,IAAI,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;QAClE,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { OpenResponsesEvent, ResponseInProgressEvent, OutputItemAddedEvent, OutputTextDeltaEvent, ContentPartDoneEvent, ResponseCompletedEvent, ResponseFailedEvent, RequestContent } from "./types.js";
|
|
2
|
+
export declare const TOPIC_BOT_MESSAGES = "/v1.0/im/bot/messages";
|
|
3
|
+
export declare const TOPIC_USER_MESSAGES = "/v1.0/im/user/messages";
|
|
4
|
+
export declare function extractContentFromInput(input: unknown[]): string;
|
|
5
|
+
export declare function parseRequest(rawMessage: string): RequestContent;
|
|
6
|
+
export declare function parseEnvelope(rawMessage: string): OpenResponsesEvent;
|
|
7
|
+
export declare function createEnvelope(event: OpenResponsesEvent): string;
|
|
8
|
+
export declare function createInProgressEvent(responseId: string, sessionId?: string): ResponseInProgressEvent;
|
|
9
|
+
export declare function createOutputItemAddedEvent(responseId: string, itemId: string, index?: number): OutputItemAddedEvent;
|
|
10
|
+
export declare function createOutputTextDeltaEvent(responseId: string, itemId: string, contentIndex: number, text: string): OutputTextDeltaEvent;
|
|
11
|
+
export declare function createContentPartDoneEvent(responseId: string, itemId: string, contentIndex: number): ContentPartDoneEvent;
|
|
12
|
+
export declare function createCompletedEvent(responseId: string, sessionId?: string): ResponseCompletedEvent;
|
|
13
|
+
export declare function createFailedEvent(responseId: string, code: string, message: string, details?: unknown, sessionId?: string): ResponseFailedEvent;
|
|
14
|
+
export declare function textToEventSequence(text: string, responseId?: string): OpenResponsesEvent[];
|
|
15
|
+
//# sourceMappingURL=protocol.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol.d.ts","sourceRoot":"","sources":["../../../src/channel/protocol.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EAClB,uBAAuB,EACvB,oBAAoB,EACpB,oBAAoB,EACpB,oBAAoB,EACpB,sBAAsB,EACtB,mBAAmB,EACnB,cAAc,EACf,MAAM,YAAY,CAAC;AAKpB,eAAO,MAAM,kBAAkB,0BAA0B,CAAC;AAC1D,eAAO,MAAM,mBAAmB,2BAA2B,CAAC;AAc5D,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,MAAM,CAkDhE;AAED,wBAAgB,YAAY,CAAC,UAAU,EAAE,MAAM,GAAG,cAAc,CAoC/D;AAID,wBAAgB,aAAa,CAAC,UAAU,EAAE,MAAM,GAAG,kBAAkB,CAuBpE;AAID,wBAAgB,cAAc,CAAC,KAAK,EAAE,kBAAkB,GAAG,MAAM,CAEhE;AAID,wBAAgB,qBAAqB,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,uBAAuB,CASrG;AAED,wBAAgB,0BAA0B,CACxC,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,KAAK,SAAI,GACR,oBAAoB,CActB;AAED,wBAAgB,0BAA0B,CACxC,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM,EACpB,IAAI,EAAE,MAAM,GACX,oBAAoB,CAStB;AAED,wBAAgB,0BAA0B,CACxC,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM,GACnB,oBAAoB,CAStB;AAED,wBAAgB,oBAAoB,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,sBAAsB,CASnG;AAED,wBAAgB,iBAAiB,CAC/B,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,EACf,OAAO,GAAE,OAAc,EACvB,SAAS,CAAC,EAAE,MAAM,GACjB,mBAAmB,CAUrB;AAID,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,kBAAkB,EAAE,CAiB3F"}
|