@codyswann/lisa 2.147.5 → 2.147.7
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/package.json +1 -1
- package/plugins/lisa/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa/skills/repair-intake/SKILL.md +37 -14
- package/plugins/lisa-agy/plugin.json +1 -1
- package/plugins/lisa-agy/skills/repair-intake/SKILL.md +37 -14
- package/plugins/lisa-cdk/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-cdk/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-cdk-agy/plugin.json +1 -1
- package/plugins/lisa-cdk-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-cdk-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-copilot/skills/repair-intake/SKILL.md +37 -14
- package/plugins/lisa-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-cursor/skills/repair-intake/SKILL.md +37 -14
- package/plugins/lisa-expo/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-expo/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-expo-agy/plugin.json +1 -1
- package/plugins/lisa-expo-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-expo-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-harper-fabric/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-harper-fabric/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-harper-fabric-agy/plugin.json +1 -1
- package/plugins/lisa-harper-fabric-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-harper-fabric-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-nestjs/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-nestjs/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-nestjs-agy/plugin.json +1 -1
- package/plugins/lisa-nestjs-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-nestjs-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-openclaw/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-openclaw/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-openclaw/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
- package/plugins/lisa-openclaw/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
- package/plugins/lisa-openclaw/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
- package/plugins/lisa-openclaw/skills/lisa-openclaw-setup/SKILL.md +3 -0
- package/plugins/lisa-openclaw-agy/plugin.json +1 -1
- package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
- package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
- package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
- package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-setup/SKILL.md +3 -0
- package/plugins/lisa-openclaw-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
- package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
- package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
- package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-setup/SKILL.md +3 -0
- package/plugins/lisa-openclaw-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
- package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
- package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
- package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-setup/SKILL.md +3 -0
- package/plugins/lisa-rails/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-rails/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-rails-agy/plugin.json +1 -1
- package/plugins/lisa-rails-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-rails-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-typescript/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-typescript/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-typescript-agy/plugin.json +1 -1
- package/plugins/lisa-typescript-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-typescript-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-wiki/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-wiki/.codex-plugin/plugin.json +1 -1
- package/plugins/lisa-wiki/scripts/ingest_slack_channel.py +2 -2
- package/plugins/lisa-wiki-agy/plugin.json +1 -1
- package/plugins/lisa-wiki-agy/scripts/ingest_slack_channel.py +2 -2
- package/plugins/lisa-wiki-copilot/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-wiki-copilot/scripts/ingest_slack_channel.py +2 -2
- package/plugins/lisa-wiki-cursor/.claude-plugin/plugin.json +1 -1
- package/plugins/lisa-wiki-cursor/scripts/ingest_slack_channel.py +2 -2
- package/plugins/src/base/skills/repair-intake/SKILL.md +37 -14
- package/plugins/src/openclaw/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
- package/plugins/src/openclaw/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
- package/plugins/src/openclaw/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
- package/plugins/src/openclaw/skills/lisa-openclaw-setup/SKILL.md +3 -0
- package/plugins/src/wiki/scripts/ingest_slack_channel.py +2 -2
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "lisa-openclaw",
|
|
3
|
-
"version": "2.147.
|
|
3
|
+
"version": "2.147.7",
|
|
4
4
|
"description": "Connect staff roles to Telegram or Slack via OpenClaw — facilitator/specialist hub-and-spoke routing and repo-coding topics, for Claude Code and Codex",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Cody Swann"
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "lisa-openclaw",
|
|
3
|
-
"version": "2.147.
|
|
3
|
+
"version": "2.147.7",
|
|
4
4
|
"description": "Connect staff roles to Telegram or Slack via OpenClaw — facilitator/specialist hub-and-spoke routing and repo-coding topics, across Claude and Codex.",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Cody Swann"
|
|
@@ -110,6 +110,11 @@ root-only route can validate while the actual bot still ignores the topic-level
|
|
|
110
110
|
`agentId`, and prompt. When in doubt, mirror the route under the owning account and keep any existing
|
|
111
111
|
root group route only as a fallback/documentation shape.
|
|
112
112
|
|
|
113
|
+
Account-scoped topic `agentId` routes also require an OpenClaw runtime that treats the topic agent as
|
|
114
|
+
an explicit group route for non-default Telegram accounts. If the self-test logs
|
|
115
|
+
`drop non-default account requires explicit binding`, update or rebuild OpenClaw before adding config
|
|
116
|
+
workarounds; do not create persistent ACP bindings solely to bypass that guard.
|
|
117
|
+
|
|
113
118
|
Keep allowlist policy, and add `allowFrom` only when membership must be narrower than the group.
|
|
114
119
|
Leave the topic-level `requireMention = false` (the default) so the agent activates on any message —
|
|
115
120
|
the topic is bound 1:1 to this dispatcher, so an @mention carries no routing information and is pure
|
|
@@ -137,11 +142,14 @@ Then from the target topic, send a plain message with **no** @mention (the defau
|
|
|
137
142
|
`requireMention = false` means the agent must activate without one) asking for an exact-token reply
|
|
138
143
|
with **no** file changes, commits, PRs, or merges, e.g. `reply with exactly TELEGRAM-ROUTE-OK`.
|
|
139
144
|
Confirm the visible reply, that the dispatcher spawned the worker, and that the worker ran in the
|
|
140
|
-
intended repo. If
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
+
intended repo. If there is no dispatcher session, inspect `/tmp/openclaw/openclaw-YYYY-MM-DD.log`;
|
|
146
|
+
`drop non-default account requires explicit binding` means the OpenClaw runtime is too old for
|
|
147
|
+
account-scoped topic-agent routing. If the topic was deliberately left at `requireMention = true`,
|
|
148
|
+
mention the bot instead (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally
|
|
149
|
+
confirm that an un-mentioned message is **ignored**. For folder-scoped topics, also send a request
|
|
150
|
+
that implies but doesn't name a repo and confirm the dispatcher asks for confirmation before
|
|
151
|
+
proceeding. Do **not** treat `openclaw agent --agent <id> ...` as proof a topic route works — use the
|
|
152
|
+
visible topic reply.
|
|
145
153
|
|
|
146
154
|
## Output standard
|
|
147
155
|
|
|
@@ -75,6 +75,12 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If
|
|
|
75
75
|
`channels.telegram.accounts.<account-id>.groups.<group-id>`. Account-scoped Telegram configs do not
|
|
76
76
|
inherit root `channels.telegram.groups` routes.
|
|
77
77
|
|
|
78
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
79
|
+
explicit group route for non-default Telegram accounts. If a real topic self-test is delivered to the
|
|
80
|
+
bot but the logs show `drop non-default account requires explicit binding`, update or rebuild
|
|
81
|
+
OpenClaw. Do not add a persistent ACP binding as a workaround; the configured topic `agentId` is the
|
|
82
|
+
intended route.
|
|
83
|
+
|
|
78
84
|
### Single-account route
|
|
79
85
|
|
|
80
86
|
```json5
|
package/plugins/lisa-openclaw/skills/lisa-openclaw-connect-staff/references/platform-routing.md
CHANGED
|
@@ -19,6 +19,11 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If the OpenC
|
|
|
19
19
|
`channels.telegram.accounts.<account-id>.groups.<telegram-supergroup-id>`; account-scoped Telegram
|
|
20
20
|
configs do not inherit root group routes.
|
|
21
21
|
|
|
22
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
23
|
+
explicit group route for non-default Telegram accounts. If a real Telegram topic test reaches the bot
|
|
24
|
+
but logs `drop non-default account requires explicit binding`, update or rebuild OpenClaw before
|
|
25
|
+
adding config workarounds; the topic `agentId` is the intended route.
|
|
26
|
+
|
|
22
27
|
### Single-account route
|
|
23
28
|
|
|
24
29
|
```json5
|
|
@@ -83,6 +83,9 @@ loudly, do not silently proceed) if any is missing:
|
|
|
83
83
|
root (Slack channel + root `thread_ts`; Telegram supergroup + forum topic + root `message_id`), and
|
|
84
84
|
replies in that thread continue the same session, so concurrent threads don't share short-term
|
|
85
85
|
context.
|
|
86
|
+
- **Account-scoped Telegram topic agents** — in multi-account Telegram configs,
|
|
87
|
+
`channels.telegram.accounts.<account-id>.groups.<group-id>.topics.<topic-id>.agentId` routes group
|
|
88
|
+
messages as an explicit topic route instead of dropping them as a non-default account fallback.
|
|
86
89
|
- **`NO_REPLY` sentinel** — after an agent sends a message with the platform message tool, returning
|
|
87
90
|
exactly `NO_REPLY` as its assistant final prevents the gateway from posting a duplicate loose
|
|
88
91
|
message.
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "lisa-openclaw",
|
|
3
|
-
"version": "2.147.
|
|
3
|
+
"version": "2.147.7",
|
|
4
4
|
"description": "Connect staff roles to Telegram or Slack via OpenClaw — facilitator/specialist hub-and-spoke routing and repo-coding topics, for Claude Code and Codex",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Cody Swann"
|
|
@@ -110,6 +110,11 @@ root-only route can validate while the actual bot still ignores the topic-level
|
|
|
110
110
|
`agentId`, and prompt. When in doubt, mirror the route under the owning account and keep any existing
|
|
111
111
|
root group route only as a fallback/documentation shape.
|
|
112
112
|
|
|
113
|
+
Account-scoped topic `agentId` routes also require an OpenClaw runtime that treats the topic agent as
|
|
114
|
+
an explicit group route for non-default Telegram accounts. If the self-test logs
|
|
115
|
+
`drop non-default account requires explicit binding`, update or rebuild OpenClaw before adding config
|
|
116
|
+
workarounds; do not create persistent ACP bindings solely to bypass that guard.
|
|
117
|
+
|
|
113
118
|
Keep allowlist policy, and add `allowFrom` only when membership must be narrower than the group.
|
|
114
119
|
Leave the topic-level `requireMention = false` (the default) so the agent activates on any message —
|
|
115
120
|
the topic is bound 1:1 to this dispatcher, so an @mention carries no routing information and is pure
|
|
@@ -137,11 +142,14 @@ Then from the target topic, send a plain message with **no** @mention (the defau
|
|
|
137
142
|
`requireMention = false` means the agent must activate without one) asking for an exact-token reply
|
|
138
143
|
with **no** file changes, commits, PRs, or merges, e.g. `reply with exactly TELEGRAM-ROUTE-OK`.
|
|
139
144
|
Confirm the visible reply, that the dispatcher spawned the worker, and that the worker ran in the
|
|
140
|
-
intended repo. If
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
+
intended repo. If there is no dispatcher session, inspect `/tmp/openclaw/openclaw-YYYY-MM-DD.log`;
|
|
146
|
+
`drop non-default account requires explicit binding` means the OpenClaw runtime is too old for
|
|
147
|
+
account-scoped topic-agent routing. If the topic was deliberately left at `requireMention = true`,
|
|
148
|
+
mention the bot instead (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally
|
|
149
|
+
confirm that an un-mentioned message is **ignored**. For folder-scoped topics, also send a request
|
|
150
|
+
that implies but doesn't name a repo and confirm the dispatcher asks for confirmation before
|
|
151
|
+
proceeding. Do **not** treat `openclaw agent --agent <id> ...` as proof a topic route works — use the
|
|
152
|
+
visible topic reply.
|
|
145
153
|
|
|
146
154
|
## Output standard
|
|
147
155
|
|
|
@@ -75,6 +75,12 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If
|
|
|
75
75
|
`channels.telegram.accounts.<account-id>.groups.<group-id>`. Account-scoped Telegram configs do not
|
|
76
76
|
inherit root `channels.telegram.groups` routes.
|
|
77
77
|
|
|
78
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
79
|
+
explicit group route for non-default Telegram accounts. If a real topic self-test is delivered to the
|
|
80
|
+
bot but the logs show `drop non-default account requires explicit binding`, update or rebuild
|
|
81
|
+
OpenClaw. Do not add a persistent ACP binding as a workaround; the configured topic `agentId` is the
|
|
82
|
+
intended route.
|
|
83
|
+
|
|
78
84
|
### Single-account route
|
|
79
85
|
|
|
80
86
|
```json5
|
package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-connect-staff/references/platform-routing.md
CHANGED
|
@@ -19,6 +19,11 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If the OpenC
|
|
|
19
19
|
`channels.telegram.accounts.<account-id>.groups.<telegram-supergroup-id>`; account-scoped Telegram
|
|
20
20
|
configs do not inherit root group routes.
|
|
21
21
|
|
|
22
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
23
|
+
explicit group route for non-default Telegram accounts. If a real Telegram topic test reaches the bot
|
|
24
|
+
but logs `drop non-default account requires explicit binding`, update or rebuild OpenClaw before
|
|
25
|
+
adding config workarounds; the topic `agentId` is the intended route.
|
|
26
|
+
|
|
22
27
|
### Single-account route
|
|
23
28
|
|
|
24
29
|
```json5
|
|
@@ -83,6 +83,9 @@ loudly, do not silently proceed) if any is missing:
|
|
|
83
83
|
root (Slack channel + root `thread_ts`; Telegram supergroup + forum topic + root `message_id`), and
|
|
84
84
|
replies in that thread continue the same session, so concurrent threads don't share short-term
|
|
85
85
|
context.
|
|
86
|
+
- **Account-scoped Telegram topic agents** — in multi-account Telegram configs,
|
|
87
|
+
`channels.telegram.accounts.<account-id>.groups.<group-id>.topics.<topic-id>.agentId` routes group
|
|
88
|
+
messages as an explicit topic route instead of dropping them as a non-default account fallback.
|
|
86
89
|
- **`NO_REPLY` sentinel** — after an agent sends a message with the platform message tool, returning
|
|
87
90
|
exactly `NO_REPLY` as its assistant final prevents the gateway from posting a duplicate loose
|
|
88
91
|
message.
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "lisa-openclaw",
|
|
3
|
-
"version": "2.147.
|
|
3
|
+
"version": "2.147.7",
|
|
4
4
|
"description": "Connect staff roles to Telegram or Slack via OpenClaw — facilitator/specialist hub-and-spoke routing and repo-coding topics, for Claude Code and Codex",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Cody Swann"
|
|
@@ -110,6 +110,11 @@ root-only route can validate while the actual bot still ignores the topic-level
|
|
|
110
110
|
`agentId`, and prompt. When in doubt, mirror the route under the owning account and keep any existing
|
|
111
111
|
root group route only as a fallback/documentation shape.
|
|
112
112
|
|
|
113
|
+
Account-scoped topic `agentId` routes also require an OpenClaw runtime that treats the topic agent as
|
|
114
|
+
an explicit group route for non-default Telegram accounts. If the self-test logs
|
|
115
|
+
`drop non-default account requires explicit binding`, update or rebuild OpenClaw before adding config
|
|
116
|
+
workarounds; do not create persistent ACP bindings solely to bypass that guard.
|
|
117
|
+
|
|
113
118
|
Keep allowlist policy, and add `allowFrom` only when membership must be narrower than the group.
|
|
114
119
|
Leave the topic-level `requireMention = false` (the default) so the agent activates on any message —
|
|
115
120
|
the topic is bound 1:1 to this dispatcher, so an @mention carries no routing information and is pure
|
|
@@ -137,11 +142,14 @@ Then from the target topic, send a plain message with **no** @mention (the defau
|
|
|
137
142
|
`requireMention = false` means the agent must activate without one) asking for an exact-token reply
|
|
138
143
|
with **no** file changes, commits, PRs, or merges, e.g. `reply with exactly TELEGRAM-ROUTE-OK`.
|
|
139
144
|
Confirm the visible reply, that the dispatcher spawned the worker, and that the worker ran in the
|
|
140
|
-
intended repo. If
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
+
intended repo. If there is no dispatcher session, inspect `/tmp/openclaw/openclaw-YYYY-MM-DD.log`;
|
|
146
|
+
`drop non-default account requires explicit binding` means the OpenClaw runtime is too old for
|
|
147
|
+
account-scoped topic-agent routing. If the topic was deliberately left at `requireMention = true`,
|
|
148
|
+
mention the bot instead (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally
|
|
149
|
+
confirm that an un-mentioned message is **ignored**. For folder-scoped topics, also send a request
|
|
150
|
+
that implies but doesn't name a repo and confirm the dispatcher asks for confirmation before
|
|
151
|
+
proceeding. Do **not** treat `openclaw agent --agent <id> ...` as proof a topic route works — use the
|
|
152
|
+
visible topic reply.
|
|
145
153
|
|
|
146
154
|
## Output standard
|
|
147
155
|
|
|
@@ -75,6 +75,12 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If
|
|
|
75
75
|
`channels.telegram.accounts.<account-id>.groups.<group-id>`. Account-scoped Telegram configs do not
|
|
76
76
|
inherit root `channels.telegram.groups` routes.
|
|
77
77
|
|
|
78
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
79
|
+
explicit group route for non-default Telegram accounts. If a real topic self-test is delivered to the
|
|
80
|
+
bot but the logs show `drop non-default account requires explicit binding`, update or rebuild
|
|
81
|
+
OpenClaw. Do not add a persistent ACP binding as a workaround; the configured topic `agentId` is the
|
|
82
|
+
intended route.
|
|
83
|
+
|
|
78
84
|
### Single-account route
|
|
79
85
|
|
|
80
86
|
```json5
|
|
@@ -19,6 +19,11 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If the OpenC
|
|
|
19
19
|
`channels.telegram.accounts.<account-id>.groups.<telegram-supergroup-id>`; account-scoped Telegram
|
|
20
20
|
configs do not inherit root group routes.
|
|
21
21
|
|
|
22
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
23
|
+
explicit group route for non-default Telegram accounts. If a real Telegram topic test reaches the bot
|
|
24
|
+
but logs `drop non-default account requires explicit binding`, update or rebuild OpenClaw before
|
|
25
|
+
adding config workarounds; the topic `agentId` is the intended route.
|
|
26
|
+
|
|
22
27
|
### Single-account route
|
|
23
28
|
|
|
24
29
|
```json5
|
|
@@ -83,6 +83,9 @@ loudly, do not silently proceed) if any is missing:
|
|
|
83
83
|
root (Slack channel + root `thread_ts`; Telegram supergroup + forum topic + root `message_id`), and
|
|
84
84
|
replies in that thread continue the same session, so concurrent threads don't share short-term
|
|
85
85
|
context.
|
|
86
|
+
- **Account-scoped Telegram topic agents** — in multi-account Telegram configs,
|
|
87
|
+
`channels.telegram.accounts.<account-id>.groups.<group-id>.topics.<topic-id>.agentId` routes group
|
|
88
|
+
messages as an explicit topic route instead of dropping them as a non-default account fallback.
|
|
86
89
|
- **`NO_REPLY` sentinel** — after an agent sends a message with the platform message tool, returning
|
|
87
90
|
exactly `NO_REPLY` as its assistant final prevents the gateway from posting a duplicate loose
|
|
88
91
|
message.
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "lisa-openclaw",
|
|
3
|
-
"version": "2.147.
|
|
3
|
+
"version": "2.147.7",
|
|
4
4
|
"description": "Connect staff roles to Telegram or Slack via OpenClaw — facilitator/specialist hub-and-spoke routing and repo-coding topics, for Claude Code and Codex",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Cody Swann"
|
|
@@ -110,6 +110,11 @@ root-only route can validate while the actual bot still ignores the topic-level
|
|
|
110
110
|
`agentId`, and prompt. When in doubt, mirror the route under the owning account and keep any existing
|
|
111
111
|
root group route only as a fallback/documentation shape.
|
|
112
112
|
|
|
113
|
+
Account-scoped topic `agentId` routes also require an OpenClaw runtime that treats the topic agent as
|
|
114
|
+
an explicit group route for non-default Telegram accounts. If the self-test logs
|
|
115
|
+
`drop non-default account requires explicit binding`, update or rebuild OpenClaw before adding config
|
|
116
|
+
workarounds; do not create persistent ACP bindings solely to bypass that guard.
|
|
117
|
+
|
|
113
118
|
Keep allowlist policy, and add `allowFrom` only when membership must be narrower than the group.
|
|
114
119
|
Leave the topic-level `requireMention = false` (the default) so the agent activates on any message —
|
|
115
120
|
the topic is bound 1:1 to this dispatcher, so an @mention carries no routing information and is pure
|
|
@@ -137,11 +142,14 @@ Then from the target topic, send a plain message with **no** @mention (the defau
|
|
|
137
142
|
`requireMention = false` means the agent must activate without one) asking for an exact-token reply
|
|
138
143
|
with **no** file changes, commits, PRs, or merges, e.g. `reply with exactly TELEGRAM-ROUTE-OK`.
|
|
139
144
|
Confirm the visible reply, that the dispatcher spawned the worker, and that the worker ran in the
|
|
140
|
-
intended repo. If
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
+
intended repo. If there is no dispatcher session, inspect `/tmp/openclaw/openclaw-YYYY-MM-DD.log`;
|
|
146
|
+
`drop non-default account requires explicit binding` means the OpenClaw runtime is too old for
|
|
147
|
+
account-scoped topic-agent routing. If the topic was deliberately left at `requireMention = true`,
|
|
148
|
+
mention the bot instead (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally
|
|
149
|
+
confirm that an un-mentioned message is **ignored**. For folder-scoped topics, also send a request
|
|
150
|
+
that implies but doesn't name a repo and confirm the dispatcher asks for confirmation before
|
|
151
|
+
proceeding. Do **not** treat `openclaw agent --agent <id> ...` as proof a topic route works — use the
|
|
152
|
+
visible topic reply.
|
|
145
153
|
|
|
146
154
|
## Output standard
|
|
147
155
|
|
|
@@ -75,6 +75,12 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If
|
|
|
75
75
|
`channels.telegram.accounts.<account-id>.groups.<group-id>`. Account-scoped Telegram configs do not
|
|
76
76
|
inherit root `channels.telegram.groups` routes.
|
|
77
77
|
|
|
78
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
79
|
+
explicit group route for non-default Telegram accounts. If a real topic self-test is delivered to the
|
|
80
|
+
bot but the logs show `drop non-default account requires explicit binding`, update or rebuild
|
|
81
|
+
OpenClaw. Do not add a persistent ACP binding as a workaround; the configured topic `agentId` is the
|
|
82
|
+
intended route.
|
|
83
|
+
|
|
78
84
|
### Single-account route
|
|
79
85
|
|
|
80
86
|
```json5
|
|
@@ -19,6 +19,11 @@ Use `channels.telegram.groups` for a single-account Telegram setup. If the OpenC
|
|
|
19
19
|
`channels.telegram.accounts.<account-id>.groups.<telegram-supergroup-id>`; account-scoped Telegram
|
|
20
20
|
configs do not inherit root group routes.
|
|
21
21
|
|
|
22
|
+
Account-scoped topic `agentId` routes require an OpenClaw runtime that treats the topic agent as an
|
|
23
|
+
explicit group route for non-default Telegram accounts. If a real Telegram topic test reaches the bot
|
|
24
|
+
but logs `drop non-default account requires explicit binding`, update or rebuild OpenClaw before
|
|
25
|
+
adding config workarounds; the topic `agentId` is the intended route.
|
|
26
|
+
|
|
22
27
|
### Single-account route
|
|
23
28
|
|
|
24
29
|
```json5
|
|
@@ -83,6 +83,9 @@ loudly, do not silently proceed) if any is missing:
|
|
|
83
83
|
root (Slack channel + root `thread_ts`; Telegram supergroup + forum topic + root `message_id`), and
|
|
84
84
|
replies in that thread continue the same session, so concurrent threads don't share short-term
|
|
85
85
|
context.
|
|
86
|
+
- **Account-scoped Telegram topic agents** — in multi-account Telegram configs,
|
|
87
|
+
`channels.telegram.accounts.<account-id>.groups.<group-id>.topics.<topic-id>.agentId` routes group
|
|
88
|
+
messages as an explicit topic route instead of dropping them as a non-default account fallback.
|
|
86
89
|
- **`NO_REPLY` sentinel** — after an agent sends a message with the platform message tool, returning
|
|
87
90
|
exactly `NO_REPLY` as its assistant final prevents the gateway from posting a duplicate loose
|
|
88
91
|
message.
|
|
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
|
|
|
57
57
|
|
|
58
58
|
|
|
59
59
|
def utc_now() -> dt.datetime:
|
|
60
|
-
return dt.datetime.now(dt.
|
|
60
|
+
return dt.datetime.now(dt.timezone.utc).replace(microsecond=0)
|
|
61
61
|
|
|
62
62
|
|
|
63
63
|
def iso_from_ts(ts: str) -> str:
|
|
64
64
|
seconds = float(ts)
|
|
65
|
-
return dt.datetime.fromtimestamp(seconds, dt.
|
|
65
|
+
return dt.datetime.fromtimestamp(seconds, dt.timezone.utc).replace(microsecond=0).isoformat().replace("+00:00", "Z")
|
|
66
66
|
|
|
67
67
|
|
|
68
68
|
def ts_from_input(value: str | None) -> str | None:
|
|
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
|
|
|
57
57
|
|
|
58
58
|
|
|
59
59
|
def utc_now() -> dt.datetime:
|
|
60
|
-
return dt.datetime.now(dt.
|
|
60
|
+
return dt.datetime.now(dt.timezone.utc).replace(microsecond=0)
|
|
61
61
|
|
|
62
62
|
|
|
63
63
|
def iso_from_ts(ts: str) -> str:
|
|
64
64
|
seconds = float(ts)
|
|
65
|
-
return dt.datetime.fromtimestamp(seconds, dt.
|
|
65
|
+
return dt.datetime.fromtimestamp(seconds, dt.timezone.utc).replace(microsecond=0).isoformat().replace("+00:00", "Z")
|
|
66
66
|
|
|
67
67
|
|
|
68
68
|
def ts_from_input(value: str | None) -> str | None:
|
|
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
|
|
|
57
57
|
|
|
58
58
|
|
|
59
59
|
def utc_now() -> dt.datetime:
|
|
60
|
-
return dt.datetime.now(dt.
|
|
60
|
+
return dt.datetime.now(dt.timezone.utc).replace(microsecond=0)
|
|
61
61
|
|
|
62
62
|
|
|
63
63
|
def iso_from_ts(ts: str) -> str:
|
|
64
64
|
seconds = float(ts)
|
|
65
|
-
return dt.datetime.fromtimestamp(seconds, dt.
|
|
65
|
+
return dt.datetime.fromtimestamp(seconds, dt.timezone.utc).replace(microsecond=0).isoformat().replace("+00:00", "Z")
|
|
66
66
|
|
|
67
67
|
|
|
68
68
|
def ts_from_input(value: str | None) -> str | None:
|
|
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
|
|
|
57
57
|
|
|
58
58
|
|
|
59
59
|
def utc_now() -> dt.datetime:
|
|
60
|
-
return dt.datetime.now(dt.
|
|
60
|
+
return dt.datetime.now(dt.timezone.utc).replace(microsecond=0)
|
|
61
61
|
|
|
62
62
|
|
|
63
63
|
def iso_from_ts(ts: str) -> str:
|
|
64
64
|
seconds = float(ts)
|
|
65
|
-
return dt.datetime.fromtimestamp(seconds, dt.
|
|
65
|
+
return dt.datetime.fromtimestamp(seconds, dt.timezone.utc).replace(microsecond=0).isoformat().replace("+00:00", "Z")
|
|
66
66
|
|
|
67
67
|
|
|
68
68
|
def ts_from_input(value: str | None) -> str | None:
|