openclaw-zulip 0.1.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/LICENSE +21 -0
- package/README.md +129 -0
- package/dist/actions.d.ts +3 -0
- package/dist/actions.d.ts.map +1 -0
- package/dist/actions.js +149 -0
- package/dist/actions.js.map +1 -0
- package/dist/agent-prompt.d.ts +3 -0
- package/dist/agent-prompt.d.ts.map +1 -0
- package/dist/agent-prompt.js +21 -0
- package/dist/agent-prompt.js.map +1 -0
- package/dist/allowlist.d.ts +3 -0
- package/dist/allowlist.d.ts.map +1 -0
- package/dist/allowlist.js +50 -0
- package/dist/allowlist.js.map +1 -0
- package/dist/bindings.d.ts +24 -0
- package/dist/bindings.d.ts.map +1 -0
- package/dist/bindings.js +281 -0
- package/dist/bindings.js.map +1 -0
- package/dist/commands.d.ts +3 -0
- package/dist/commands.d.ts.map +1 -0
- package/dist/commands.js +7 -0
- package/dist/commands.js.map +1 -0
- package/dist/config-schema.d.ts +2 -0
- package/dist/config-schema.d.ts.map +1 -0
- package/dist/config-schema.js +34 -0
- package/dist/config-schema.js.map +1 -0
- package/dist/config.d.ts +5 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +53 -0
- package/dist/config.js.map +1 -0
- package/dist/directory.d.ts +3 -0
- package/dist/directory.d.ts.map +1 -0
- package/dist/directory.js +68 -0
- package/dist/directory.js.map +1 -0
- package/dist/gateway.d.ts +4 -0
- package/dist/gateway.d.ts.map +1 -0
- package/dist/gateway.js +324 -0
- package/dist/gateway.js.map +1 -0
- package/dist/groups.d.ts +3 -0
- package/dist/groups.d.ts.map +1 -0
- package/dist/groups.js +28 -0
- package/dist/groups.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/messaging.d.ts +3 -0
- package/dist/messaging.d.ts.map +1 -0
- package/dist/messaging.js +47 -0
- package/dist/messaging.js.map +1 -0
- package/dist/outbound.d.ts +24 -0
- package/dist/outbound.d.ts.map +1 -0
- package/dist/outbound.js +114 -0
- package/dist/outbound.js.map +1 -0
- package/dist/plugin.d.ts +5 -0
- package/dist/plugin.d.ts.map +1 -0
- package/dist/plugin.js +66 -0
- package/dist/plugin.js.map +1 -0
- package/dist/resolver.d.ts +3 -0
- package/dist/resolver.d.ts.map +1 -0
- package/dist/resolver.js +39 -0
- package/dist/resolver.js.map +1 -0
- package/dist/security.d.ts +4 -0
- package/dist/security.d.ts.map +1 -0
- package/dist/security.js +15 -0
- package/dist/security.js.map +1 -0
- package/dist/setup.d.ts +2 -0
- package/dist/setup.d.ts.map +1 -0
- package/dist/setup.js +25 -0
- package/dist/setup.js.map +1 -0
- package/dist/status.d.ts +14 -0
- package/dist/status.d.ts.map +1 -0
- package/dist/status.js +74 -0
- package/dist/status.js.map +1 -0
- package/dist/threading.d.ts +3 -0
- package/dist/threading.d.ts.map +1 -0
- package/dist/threading.js +25 -0
- package/dist/threading.js.map +1 -0
- package/dist/types.d.ts +42 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +4 -0
- package/dist/types.js.map +1 -0
- package/dist/zulip-client.d.ts +115 -0
- package/dist/zulip-client.d.ts.map +1 -0
- package/dist/zulip-client.js +232 -0
- package/dist/zulip-client.js.map +1 -0
- package/openclaw.plugin.json +33 -0
- package/package.json +53 -0
package/dist/plugin.js
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { createChatChannelPlugin } from "openclaw/plugin-sdk/core";
|
|
2
|
+
import { zulipConfigAdapter } from "./config.js";
|
|
3
|
+
import { zulipConfigSchema } from "./config-schema.js";
|
|
4
|
+
import { zulipSetupAdapter } from "./setup.js";
|
|
5
|
+
import { zulipSecurityAdapter } from "./security.js";
|
|
6
|
+
import { zulipGatewayAdapter } from "./gateway.js";
|
|
7
|
+
import { zulipOutboundAdapter } from "./outbound.js";
|
|
8
|
+
import { zulipThreadingAdapter } from "./threading.js";
|
|
9
|
+
import { zulipMessagingAdapter } from "./messaging.js";
|
|
10
|
+
import { zulipActionsAdapter } from "./actions.js";
|
|
11
|
+
import { zulipBindingsAdapter, zulipConversationBindingsSupport } from "./bindings.js";
|
|
12
|
+
import { zulipStatusAdapter } from "./status.js";
|
|
13
|
+
import { zulipDirectoryAdapter } from "./directory.js";
|
|
14
|
+
import { zulipResolverAdapter } from "./resolver.js";
|
|
15
|
+
import { zulipAgentPromptAdapter } from "./agent-prompt.js";
|
|
16
|
+
import { zulipGroupsAdapter } from "./groups.js";
|
|
17
|
+
import { zulipCommandAdapter } from "./commands.js";
|
|
18
|
+
import { zulipAllowlistAdapter } from "./allowlist.js";
|
|
19
|
+
export const zulipPlugin = createChatChannelPlugin({
|
|
20
|
+
base: {
|
|
21
|
+
id: "zulip",
|
|
22
|
+
meta: {
|
|
23
|
+
id: "zulip",
|
|
24
|
+
label: "Zulip",
|
|
25
|
+
selectionLabel: "Zulip",
|
|
26
|
+
docsPath: "/docs/channels/zulip",
|
|
27
|
+
blurb: "Connect OpenClaw to Zulip for streams, topics, and DMs.",
|
|
28
|
+
},
|
|
29
|
+
capabilities: {
|
|
30
|
+
chatTypes: ["direct", "group", "thread"],
|
|
31
|
+
reactions: true,
|
|
32
|
+
edit: true,
|
|
33
|
+
unsend: true,
|
|
34
|
+
reply: true,
|
|
35
|
+
threads: true,
|
|
36
|
+
media: true,
|
|
37
|
+
nativeCommands: false,
|
|
38
|
+
polls: false,
|
|
39
|
+
effects: false,
|
|
40
|
+
groupManagement: false,
|
|
41
|
+
blockStreaming: false,
|
|
42
|
+
},
|
|
43
|
+
config: zulipConfigAdapter,
|
|
44
|
+
configSchema: zulipConfigSchema,
|
|
45
|
+
setup: zulipSetupAdapter,
|
|
46
|
+
status: zulipStatusAdapter,
|
|
47
|
+
gateway: zulipGatewayAdapter,
|
|
48
|
+
messaging: zulipMessagingAdapter,
|
|
49
|
+
actions: zulipActionsAdapter,
|
|
50
|
+
bindings: zulipBindingsAdapter,
|
|
51
|
+
conversationBindings: zulipConversationBindingsSupport,
|
|
52
|
+
directory: zulipDirectoryAdapter,
|
|
53
|
+
resolver: zulipResolverAdapter,
|
|
54
|
+
agentPrompt: zulipAgentPromptAdapter,
|
|
55
|
+
groups: zulipGroupsAdapter,
|
|
56
|
+
commands: zulipCommandAdapter,
|
|
57
|
+
allowlist: zulipAllowlistAdapter,
|
|
58
|
+
reload: {
|
|
59
|
+
configPrefixes: ["channels.zulip"],
|
|
60
|
+
},
|
|
61
|
+
},
|
|
62
|
+
security: zulipSecurityAdapter,
|
|
63
|
+
threading: zulipThreadingAdapter,
|
|
64
|
+
outbound: zulipOutboundAdapter,
|
|
65
|
+
});
|
|
66
|
+
//# sourceMappingURL=plugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plugin.js","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AAGnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,gCAAgC,EAAE,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAEvD,MAAM,CAAC,MAAM,WAAW,GAAoD,uBAAuB,CAAC;IAClG,IAAI,EAAE;QACJ,EAAE,EAAE,OAAO;QACX,IAAI,EAAE;YACJ,EAAE,EAAE,OAAO;YACX,KAAK,EAAE,OAAO;YACd,cAAc,EAAE,OAAO;YACvB,QAAQ,EAAE,sBAAsB;YAChC,KAAK,EAAE,yDAAyD;SACjE;QACD,YAAY,EAAE;YACZ,SAAS,EAAE,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC;YACxC,SAAS,EAAE,IAAI;YACf,IAAI,EAAE,IAAI;YACV,MAAM,EAAE,IAAI;YACZ,KAAK,EAAE,IAAI;YACX,OAAO,EAAE,IAAI;YACb,KAAK,EAAE,IAAI;YACX,cAAc,EAAE,KAAK;YACrB,KAAK,EAAE,KAAK;YACZ,OAAO,EAAE,KAAK;YACd,eAAe,EAAE,KAAK;YACtB,cAAc,EAAE,KAAK;SACtB;QACD,MAAM,EAAE,kBAAkB;QAC1B,YAAY,EAAE,iBAAiB;QAC/B,KAAK,EAAE,iBAAiB;QACxB,MAAM,EAAE,kBAAkB;QAC1B,OAAO,EAAE,mBAAmB;QAC5B,SAAS,EAAE,qBAAqB;QAChC,OAAO,EAAE,mBAAmB;QAC5B,QAAQ,EAAE,oBAAoB;QAC9B,oBAAoB,EAAE,gCAAgC;QACtD,SAAS,EAAE,qBAAqB;QAChC,QAAQ,EAAE,oBAAoB;QAC9B,WAAW,EAAE,uBAAuB;QACpC,MAAM,EAAE,kBAAkB;QAC1B,QAAQ,EAAE,mBAAmB;QAC7B,SAAS,EAAE,qBAAqB;QAChC,MAAM,EAAE;YACN,cAAc,EAAE,CAAC,gBAAgB,CAAC;SACnC;KACF;IACD,QAAQ,EAAE,oBAAoB;IAC9B,SAAS,EAAE,qBAAqB;IAChC,QAAQ,EAAE,oBAAoB;CAC/B,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolver.d.ts","sourceRoot":"","sources":["../src/resolver.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAS9D,eAAO,MAAM,oBAAoB,EAAE,WAAW,CAAC,aAAa,CAAC,UAAU,CAAC,CAqCvE,CAAC"}
|
package/dist/resolver.js
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { resolveZulipAccount } from "./config.js";
|
|
2
|
+
import { ZulipClient } from "./zulip-client.js";
|
|
3
|
+
// ---------------------------------------------------------------------------
|
|
4
|
+
// Resolver adapter — resolve user/stream names to IDs
|
|
5
|
+
// ---------------------------------------------------------------------------
|
|
6
|
+
export const zulipResolverAdapter = {
|
|
7
|
+
async resolveTargets({ cfg, accountId, inputs, kind }) {
|
|
8
|
+
const account = resolveZulipAccount(cfg, accountId);
|
|
9
|
+
const client = new ZulipClient({
|
|
10
|
+
serverUrl: account.serverUrl,
|
|
11
|
+
email: account.email,
|
|
12
|
+
apiKey: account.apiKey,
|
|
13
|
+
});
|
|
14
|
+
if (kind === "user") {
|
|
15
|
+
const users = await client.getUsers();
|
|
16
|
+
return inputs.map((input) => {
|
|
17
|
+
const q = input.toLowerCase();
|
|
18
|
+
const match = users.find((u) => u.email.toLowerCase() === q || u.full_name.toLowerCase() === q);
|
|
19
|
+
if (match) {
|
|
20
|
+
return { input, resolved: true, id: String(match.user_id), name: match.full_name };
|
|
21
|
+
}
|
|
22
|
+
return { input, resolved: false, note: "No matching Zulip user found" };
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
if (kind === "group") {
|
|
26
|
+
const streams = await client.getStreams();
|
|
27
|
+
return inputs.map((input) => {
|
|
28
|
+
const q = input.toLowerCase().replace(/^#/, "");
|
|
29
|
+
const match = streams.find((s) => s.name.toLowerCase() === q);
|
|
30
|
+
if (match) {
|
|
31
|
+
return { input, resolved: true, id: String(match.stream_id), name: match.name };
|
|
32
|
+
}
|
|
33
|
+
return { input, resolved: false, note: "No matching Zulip stream found" };
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
return inputs.map((input) => ({ input, resolved: false, note: `Unknown kind: ${kind}` }));
|
|
37
|
+
},
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=resolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolver.js","sourceRoot":"","sources":["../src/resolver.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,8EAA8E;AAC9E,sDAAsD;AACtD,8EAA8E;AAE9E,MAAM,CAAC,MAAM,oBAAoB,GAA2C;IAC1E,KAAK,CAAC,cAAc,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE;QACnD,MAAM,OAAO,GAAG,mBAAmB,CAAC,GAAiB,EAAE,SAAS,CAAC,CAAC;QAClE,MAAM,MAAM,GAAG,IAAI,WAAW,CAAC;YAC7B,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,MAAM,EAAE,OAAO,CAAC,MAAM;SACvB,CAAC,CAAC;QAEH,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;YACpB,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;YACtC,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC1B,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;gBAC9B,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CACtB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,WAAW,EAAE,KAAK,CAAC,CACtE,CAAC;gBACF,IAAI,KAAK,EAAE,CAAC;oBACV,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC;gBACrF,CAAC;gBACD,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,8BAA8B,EAAE,CAAC;YAC1E,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,IAAI,KAAK,OAAO,EAAE,CAAC;YACrB,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,UAAU,EAAE,CAAC;YAC1C,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC1B,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBAChD,MAAM,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC;gBAC9D,IAAI,KAAK,EAAE,CAAC;oBACV,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;gBAClF,CAAC;gBACD,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,gCAAgC,EAAE,CAAC;YAC5E,CAAC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,iBAAiB,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IAC5F,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security.d.ts","sourceRoot":"","sources":["../src/security.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAE9D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAEvD,eAAO,MAAM,oBAAoB,EAAE,WAAW,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC,UAAU,CAAC,CAY7F,CAAC"}
|
package/dist/security.js
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { buildAccountScopedDmSecurityPolicy } from "openclaw/plugin-sdk/channel-config-helpers";
|
|
2
|
+
export const zulipSecurityAdapter = {
|
|
3
|
+
resolveDmPolicy({ cfg, accountId, account }) {
|
|
4
|
+
return buildAccountScopedDmSecurityPolicy({
|
|
5
|
+
cfg,
|
|
6
|
+
channelKey: "zulip",
|
|
7
|
+
accountId,
|
|
8
|
+
policy: account.dmPolicy,
|
|
9
|
+
allowFrom: account.allowFrom,
|
|
10
|
+
approveChannelId: "zulip",
|
|
11
|
+
approveHint: "Send a DM to the bot in Zulip.",
|
|
12
|
+
});
|
|
13
|
+
},
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=security.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security.js","sourceRoot":"","sources":["../src/security.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kCAAkC,EAAE,MAAM,4CAA4C,CAAC;AAGhG,MAAM,CAAC,MAAM,oBAAoB,GAAiE;IAChG,eAAe,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,OAAO,EAAE;QACzC,OAAO,kCAAkC,CAAC;YACxC,GAAG;YACH,UAAU,EAAE,OAAO;YACnB,SAAS;YACT,MAAM,EAAE,OAAO,CAAC,QAAQ;YACxB,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,gBAAgB,EAAE,OAAO;YACzB,WAAW,EAAE,gCAAgC;SAC9C,CAAC,CAAC;IACL,CAAC;CACF,CAAC"}
|
package/dist/setup.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../src/setup.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,iBAAiB,yDAoB5B,CAAC"}
|
package/dist/setup.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { createPatchedAccountSetupAdapter } from "openclaw/plugin-sdk/setup";
|
|
2
|
+
const SECTION_KEY = "zulip";
|
|
3
|
+
export const zulipSetupAdapter = createPatchedAccountSetupAdapter({
|
|
4
|
+
channelKey: SECTION_KEY,
|
|
5
|
+
alwaysUseAccounts: true,
|
|
6
|
+
ensureChannelEnabled: true,
|
|
7
|
+
ensureAccountEnabled: true,
|
|
8
|
+
validateInput({ input }) {
|
|
9
|
+
if (!input.url?.trim())
|
|
10
|
+
return "Server URL is required.";
|
|
11
|
+
if (!input.userId?.trim())
|
|
12
|
+
return "Bot email is required.";
|
|
13
|
+
if (!input.token?.trim())
|
|
14
|
+
return "API key is required.";
|
|
15
|
+
return null;
|
|
16
|
+
},
|
|
17
|
+
buildPatch(input) {
|
|
18
|
+
return {
|
|
19
|
+
serverUrl: input.url.trim().replace(/\/+$/, ""),
|
|
20
|
+
email: input.userId.trim(),
|
|
21
|
+
apiKey: input.token.trim(),
|
|
22
|
+
};
|
|
23
|
+
},
|
|
24
|
+
});
|
|
25
|
+
//# sourceMappingURL=setup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../src/setup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gCAAgC,EAAE,MAAM,2BAA2B,CAAC;AAE7E,MAAM,WAAW,GAAG,OAAO,CAAC;AAE5B,MAAM,CAAC,MAAM,iBAAiB,GAAG,gCAAgC,CAAC;IAChE,UAAU,EAAE,WAAW;IACvB,iBAAiB,EAAE,IAAI;IACvB,oBAAoB,EAAE,IAAI;IAC1B,oBAAoB,EAAE,IAAI;IAE1B,aAAa,CAAC,EAAE,KAAK,EAAE;QACrB,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,EAAE;YAAE,OAAO,yBAAyB,CAAC;QACzD,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,EAAE;YAAE,OAAO,wBAAwB,CAAC;QAC3D,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,EAAE;YAAE,OAAO,sBAAsB,CAAC;QACxD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,UAAU,CAAC,KAAK;QACd,OAAO;YACL,SAAS,EAAE,KAAK,CAAC,GAAI,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;YAChD,KAAK,EAAE,KAAK,CAAC,MAAO,CAAC,IAAI,EAAE;YAC3B,MAAM,EAAE,KAAK,CAAC,KAAM,CAAC,IAAI,EAAE;SAC5B,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
package/dist/status.d.ts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { ChannelPlugin } from "openclaw/plugin-sdk/core";
|
|
2
|
+
import type { ZulipResolvedAccount } from "./types.js";
|
|
3
|
+
export type ZulipProbe = {
|
|
4
|
+
ok: boolean;
|
|
5
|
+
error?: string | null;
|
|
6
|
+
elapsedMs: number;
|
|
7
|
+
user?: {
|
|
8
|
+
userId: number;
|
|
9
|
+
email: string;
|
|
10
|
+
fullName: string;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
export declare const zulipStatusAdapter: NonNullable<ChannelPlugin<ZulipResolvedAccount, ZulipProbe>["status"]>;
|
|
14
|
+
//# sourceMappingURL=status.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../src/status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAOvD,MAAM,MAAM,UAAU,GAAG;IACvB,EAAE,EAAE,OAAO,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE;QACL,MAAM,EAAE,MAAM,CAAC;QACf,KAAK,EAAE,MAAM,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;CACH,CAAC;AAMF,eAAO,MAAM,kBAAkB,EAAE,WAAW,CAC1C,aAAa,CAAC,oBAAoB,EAAE,UAAU,CAAC,CAAC,QAAQ,CAAC,CAuE1D,CAAC"}
|
package/dist/status.js
ADDED
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { ZulipClient } from "./zulip-client.js";
|
|
2
|
+
// ---------------------------------------------------------------------------
|
|
3
|
+
// Status adapter
|
|
4
|
+
// ---------------------------------------------------------------------------
|
|
5
|
+
export const zulipStatusAdapter = {
|
|
6
|
+
async probeAccount({ account, timeoutMs }) {
|
|
7
|
+
const start = Date.now();
|
|
8
|
+
try {
|
|
9
|
+
const client = new ZulipClient({
|
|
10
|
+
serverUrl: account.serverUrl,
|
|
11
|
+
email: account.email,
|
|
12
|
+
apiKey: account.apiKey,
|
|
13
|
+
});
|
|
14
|
+
const controller = new AbortController();
|
|
15
|
+
const timer = setTimeout(() => controller.abort(), timeoutMs);
|
|
16
|
+
try {
|
|
17
|
+
const self = await client.getOwnUser();
|
|
18
|
+
return {
|
|
19
|
+
ok: true,
|
|
20
|
+
elapsedMs: Date.now() - start,
|
|
21
|
+
user: {
|
|
22
|
+
userId: self.user_id,
|
|
23
|
+
email: self.email,
|
|
24
|
+
fullName: self.full_name,
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
finally {
|
|
29
|
+
clearTimeout(timer);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
return {
|
|
34
|
+
ok: false,
|
|
35
|
+
error: err instanceof Error ? err.message : String(err),
|
|
36
|
+
elapsedMs: Date.now() - start,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
buildAccountSnapshot({ account, runtime }) {
|
|
41
|
+
return {
|
|
42
|
+
accountId: account.accountId,
|
|
43
|
+
name: `${account.email} (${account.mode})`,
|
|
44
|
+
enabled: account.enabled,
|
|
45
|
+
configured: account.configured,
|
|
46
|
+
running: runtime?.running ?? false,
|
|
47
|
+
connected: runtime?.connected ?? false,
|
|
48
|
+
lastConnectedAt: runtime?.lastConnectedAt ?? null,
|
|
49
|
+
};
|
|
50
|
+
},
|
|
51
|
+
collectStatusIssues(accounts) {
|
|
52
|
+
const issues = [];
|
|
53
|
+
for (const snap of accounts) {
|
|
54
|
+
if (snap.enabled && !snap.configured) {
|
|
55
|
+
issues.push({
|
|
56
|
+
channel: "zulip",
|
|
57
|
+
accountId: snap.accountId,
|
|
58
|
+
kind: "config",
|
|
59
|
+
message: `Account "${snap.accountId}" is enabled but not configured (missing serverUrl, email, or apiKey).`,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
if (snap.enabled && snap.configured && !snap.connected) {
|
|
63
|
+
issues.push({
|
|
64
|
+
channel: "zulip",
|
|
65
|
+
accountId: snap.accountId,
|
|
66
|
+
kind: "runtime",
|
|
67
|
+
message: `Account "${snap.accountId}" is not connected.`,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return issues;
|
|
72
|
+
},
|
|
73
|
+
};
|
|
74
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../src/status.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"threading.d.ts","sourceRoot":"","sources":["../src/threading.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAI9D,eAAO,MAAM,qBAAqB,EAAE,WAAW,CAAC,aAAa,CAAC,WAAW,CAAC,CAsBzE,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { resolveZulipAccount } from "./config.js";
|
|
2
|
+
export const zulipThreadingAdapter = {
|
|
3
|
+
resolveReplyToMode({ cfg, accountId }) {
|
|
4
|
+
const account = resolveZulipAccount(cfg, accountId);
|
|
5
|
+
const mode = account.replyToMode;
|
|
6
|
+
if (mode === "off" || mode === "first" || mode === "all")
|
|
7
|
+
return mode;
|
|
8
|
+
return "all";
|
|
9
|
+
},
|
|
10
|
+
resolveFocusedBinding({ context }) {
|
|
11
|
+
// Zulip: To = stream id, MessageThreadId = topic name
|
|
12
|
+
const streamId = context.To;
|
|
13
|
+
const topic = context.MessageThreadId ?? context.ThreadLabel;
|
|
14
|
+
if (!streamId || !topic)
|
|
15
|
+
return null;
|
|
16
|
+
const conversationId = `${streamId}/${topic}`;
|
|
17
|
+
return {
|
|
18
|
+
conversationId,
|
|
19
|
+
parentConversationId: String(streamId),
|
|
20
|
+
placement: "current",
|
|
21
|
+
labelNoun: "topic",
|
|
22
|
+
};
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=threading.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"threading.js","sourceRoot":"","sources":["../src/threading.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAGlD,MAAM,CAAC,MAAM,qBAAqB,GAA4C;IAC5E,kBAAkB,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE;QACnC,MAAM,OAAO,GAAG,mBAAmB,CAAC,GAAiB,EAAE,SAAS,CAAC,CAAC;QAClE,MAAM,IAAI,GAAG,OAAO,CAAC,WAAW,CAAC;QACjC,IAAI,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,KAAK;YAAE,OAAO,IAAI,CAAC;QACtE,OAAO,KAAK,CAAC;IACf,CAAC;IAED,qBAAqB,CAAC,EAAE,OAAO,EAAE;QAC/B,sDAAsD;QACtD,MAAM,QAAQ,GAAG,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,KAAK,GAAG,OAAO,CAAC,eAAe,IAAI,OAAO,CAAC,WAAW,CAAC;QAC7D,IAAI,CAAC,QAAQ,IAAI,CAAC,KAAK;YAAE,OAAO,IAAI,CAAC;QAErC,MAAM,cAAc,GAAG,GAAG,QAAQ,IAAI,KAAK,EAAE,CAAC;QAC9C,OAAO;YACL,cAAc;YACd,oBAAoB,EAAE,MAAM,CAAC,QAAQ,CAAC;YACtC,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,OAAO;SACnB,CAAC;IACJ,CAAC;CACF,CAAC"}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { OpenClawConfig } from "openclaw/plugin-sdk/core";
|
|
2
|
+
export type ZulipAccountMode = "bot" | "user";
|
|
3
|
+
export type ZulipStreamConfig = {
|
|
4
|
+
requireMention?: boolean;
|
|
5
|
+
enabled?: boolean;
|
|
6
|
+
};
|
|
7
|
+
export type ZulipAccountConfig = {
|
|
8
|
+
name?: string;
|
|
9
|
+
enabled?: boolean;
|
|
10
|
+
mode?: ZulipAccountMode;
|
|
11
|
+
serverUrl?: string;
|
|
12
|
+
email?: string;
|
|
13
|
+
apiKey?: string;
|
|
14
|
+
dmPolicy?: string;
|
|
15
|
+
allowFrom?: Array<string | number>;
|
|
16
|
+
replyToMode?: string;
|
|
17
|
+
streams?: Record<string, ZulipStreamConfig>;
|
|
18
|
+
};
|
|
19
|
+
export type ZulipChannelConfig = ZulipAccountConfig & {
|
|
20
|
+
defaultAccount?: string;
|
|
21
|
+
accounts?: Record<string, ZulipAccountConfig>;
|
|
22
|
+
};
|
|
23
|
+
export type ZulipResolvedAccount = {
|
|
24
|
+
accountId: string;
|
|
25
|
+
mode: ZulipAccountMode;
|
|
26
|
+
serverUrl: string;
|
|
27
|
+
email: string;
|
|
28
|
+
apiKey: string;
|
|
29
|
+
enabled: boolean;
|
|
30
|
+
configured: boolean;
|
|
31
|
+
dmPolicy: string;
|
|
32
|
+
allowFrom: Array<string | number>;
|
|
33
|
+
replyToMode: string;
|
|
34
|
+
streams: Record<string, ZulipStreamConfig>;
|
|
35
|
+
};
|
|
36
|
+
export type CoreConfig = OpenClawConfig & {
|
|
37
|
+
channels?: OpenClawConfig["channels"] & {
|
|
38
|
+
zulip?: ZulipChannelConfig;
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
export declare function getZulipSection(cfg: OpenClawConfig): ZulipChannelConfig | undefined;
|
|
42
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAM/D,MAAM,MAAM,gBAAgB,GAAG,KAAK,GAAG,MAAM,CAAC;AAM9C,MAAM,MAAM,iBAAiB,GAAG;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAMF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE,gBAAgB,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC;IACnC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;CAC7C,CAAC;AAMF,MAAM,MAAM,kBAAkB,GAAG,kBAAkB,GAAG;IACpD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAC;CAC/C,CAAC;AAMF,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,gBAAgB,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,OAAO,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC;IAClC,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;CAC5C,CAAC;AAMF,MAAM,MAAM,UAAU,GAAG,cAAc,GAAG;IACxC,QAAQ,CAAC,EAAE,cAAc,CAAC,UAAU,CAAC,GAAG;QACtC,KAAK,CAAC,EAAE,kBAAkB,CAAC;KAC5B,CAAC;CACH,CAAC;AAEF,wBAAgB,eAAe,CAAC,GAAG,EAAE,cAAc,GAAG,kBAAkB,GAAG,SAAS,CAEnF"}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAuEA,MAAM,UAAU,eAAe,CAAC,GAAmB;IACjD,OAAQ,GAAkB,CAAC,QAAQ,EAAE,KAAK,CAAC;AAC7C,CAAC"}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
export type ZulipClientConfig = {
|
|
2
|
+
serverUrl: string;
|
|
3
|
+
email: string;
|
|
4
|
+
apiKey: string;
|
|
5
|
+
};
|
|
6
|
+
export type ZulipMessage = {
|
|
7
|
+
id: number;
|
|
8
|
+
sender_id: number;
|
|
9
|
+
sender_email: string;
|
|
10
|
+
sender_full_name: string;
|
|
11
|
+
type: "stream" | "private";
|
|
12
|
+
stream_id?: number;
|
|
13
|
+
subject?: string;
|
|
14
|
+
display_recipient: string | Array<{
|
|
15
|
+
id: number;
|
|
16
|
+
email: string;
|
|
17
|
+
full_name: string;
|
|
18
|
+
}>;
|
|
19
|
+
content: string;
|
|
20
|
+
timestamp: number;
|
|
21
|
+
};
|
|
22
|
+
export type ZulipEventQueueRegistration = {
|
|
23
|
+
queue_id: string;
|
|
24
|
+
last_event_id: number;
|
|
25
|
+
};
|
|
26
|
+
export type ZulipEvent = {
|
|
27
|
+
id: number;
|
|
28
|
+
type: string;
|
|
29
|
+
message?: ZulipMessage;
|
|
30
|
+
flags?: string[];
|
|
31
|
+
};
|
|
32
|
+
export type ZulipStream = {
|
|
33
|
+
stream_id: number;
|
|
34
|
+
name: string;
|
|
35
|
+
description: string;
|
|
36
|
+
invite_only: boolean;
|
|
37
|
+
};
|
|
38
|
+
export type ZulipSendMessageResult = {
|
|
39
|
+
id: number;
|
|
40
|
+
};
|
|
41
|
+
export type ZulipUploadResult = {
|
|
42
|
+
uri: string;
|
|
43
|
+
};
|
|
44
|
+
export declare class ZulipClient {
|
|
45
|
+
private readonly baseUrl;
|
|
46
|
+
private readonly authHeader;
|
|
47
|
+
constructor(config: ZulipClientConfig);
|
|
48
|
+
private request;
|
|
49
|
+
private requestMultipart;
|
|
50
|
+
sendMessage(params: {
|
|
51
|
+
type: "stream" | "direct";
|
|
52
|
+
to: string | number[] | string[];
|
|
53
|
+
topic?: string;
|
|
54
|
+
content: string;
|
|
55
|
+
}): Promise<ZulipSendMessageResult>;
|
|
56
|
+
registerEventQueue(params?: {
|
|
57
|
+
eventTypes?: string[];
|
|
58
|
+
allPublicStreams?: boolean;
|
|
59
|
+
}): Promise<ZulipEventQueueRegistration>;
|
|
60
|
+
getEvents(params: {
|
|
61
|
+
queueId: string;
|
|
62
|
+
lastEventId: number;
|
|
63
|
+
dontBlock?: boolean;
|
|
64
|
+
}): Promise<ZulipEvent[]>;
|
|
65
|
+
deleteEventQueue(queueId: string): Promise<void>;
|
|
66
|
+
getStreams(): Promise<ZulipStream[]>;
|
|
67
|
+
getSubscriptions(): Promise<ZulipStream[]>;
|
|
68
|
+
getOwnUser(): Promise<{
|
|
69
|
+
user_id: number;
|
|
70
|
+
email: string;
|
|
71
|
+
full_name: string;
|
|
72
|
+
}>;
|
|
73
|
+
editMessage(messageId: number, content: string): Promise<void>;
|
|
74
|
+
deleteMessage(messageId: number): Promise<void>;
|
|
75
|
+
addReaction(messageId: number, emojiName: string, emojiCode?: string, reactionType?: string): Promise<void>;
|
|
76
|
+
removeReaction(messageId: number, emojiName: string, emojiCode?: string, reactionType?: string): Promise<void>;
|
|
77
|
+
searchMessages(params: {
|
|
78
|
+
anchor: string | number;
|
|
79
|
+
numBefore: number;
|
|
80
|
+
numAfter: number;
|
|
81
|
+
narrow: Array<{
|
|
82
|
+
operator: string;
|
|
83
|
+
operand: string;
|
|
84
|
+
}>;
|
|
85
|
+
}): Promise<ZulipMessage[]>;
|
|
86
|
+
updateMessageTopic(messageId: number, topic: string, propagateMode?: string, streamId?: number): Promise<void>;
|
|
87
|
+
sendTypingNotification(params: {
|
|
88
|
+
op: "start" | "stop";
|
|
89
|
+
type: "direct" | "stream";
|
|
90
|
+
to?: number[];
|
|
91
|
+
streamId?: number;
|
|
92
|
+
topic?: string;
|
|
93
|
+
}): Promise<void>;
|
|
94
|
+
uploadFile(filename: string, buffer: Buffer, mimeType?: string): Promise<ZulipUploadResult>;
|
|
95
|
+
getUsers(): Promise<Array<{
|
|
96
|
+
user_id: number;
|
|
97
|
+
email: string;
|
|
98
|
+
full_name: string;
|
|
99
|
+
is_bot: boolean;
|
|
100
|
+
}>>;
|
|
101
|
+
getUser(userId: number): Promise<{
|
|
102
|
+
user_id: number;
|
|
103
|
+
email: string;
|
|
104
|
+
full_name: string;
|
|
105
|
+
is_bot: boolean;
|
|
106
|
+
avatar_url?: string;
|
|
107
|
+
role: number;
|
|
108
|
+
}>;
|
|
109
|
+
getStreamById(streamId: number): Promise<ZulipStream & {
|
|
110
|
+
rendered_description?: string;
|
|
111
|
+
}>;
|
|
112
|
+
getStreamMembers(streamId: number): Promise<number[]>;
|
|
113
|
+
downloadFile(url: string): Promise<Buffer>;
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=zulip-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zulip-client.d.ts","sourceRoot":"","sources":["../src/zulip-client.ts"],"names":[],"mappings":"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"}
|