@codyswann/lisa 2.147.6 → 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.
Files changed (71) hide show
  1. package/package.json +1 -1
  2. package/plugins/lisa/.claude-plugin/plugin.json +1 -1
  3. package/plugins/lisa/.codex-plugin/plugin.json +1 -1
  4. package/plugins/lisa-agy/plugin.json +1 -1
  5. package/plugins/lisa-cdk/.claude-plugin/plugin.json +1 -1
  6. package/plugins/lisa-cdk/.codex-plugin/plugin.json +1 -1
  7. package/plugins/lisa-cdk-agy/plugin.json +1 -1
  8. package/plugins/lisa-cdk-copilot/.claude-plugin/plugin.json +1 -1
  9. package/plugins/lisa-cdk-cursor/.claude-plugin/plugin.json +1 -1
  10. package/plugins/lisa-copilot/.claude-plugin/plugin.json +1 -1
  11. package/plugins/lisa-cursor/.claude-plugin/plugin.json +1 -1
  12. package/plugins/lisa-expo/.claude-plugin/plugin.json +1 -1
  13. package/plugins/lisa-expo/.codex-plugin/plugin.json +1 -1
  14. package/plugins/lisa-expo-agy/plugin.json +1 -1
  15. package/plugins/lisa-expo-copilot/.claude-plugin/plugin.json +1 -1
  16. package/plugins/lisa-expo-cursor/.claude-plugin/plugin.json +1 -1
  17. package/plugins/lisa-harper-fabric/.claude-plugin/plugin.json +1 -1
  18. package/plugins/lisa-harper-fabric/.codex-plugin/plugin.json +1 -1
  19. package/plugins/lisa-harper-fabric-agy/plugin.json +1 -1
  20. package/plugins/lisa-harper-fabric-copilot/.claude-plugin/plugin.json +1 -1
  21. package/plugins/lisa-harper-fabric-cursor/.claude-plugin/plugin.json +1 -1
  22. package/plugins/lisa-nestjs/.claude-plugin/plugin.json +1 -1
  23. package/plugins/lisa-nestjs/.codex-plugin/plugin.json +1 -1
  24. package/plugins/lisa-nestjs-agy/plugin.json +1 -1
  25. package/plugins/lisa-nestjs-copilot/.claude-plugin/plugin.json +1 -1
  26. package/plugins/lisa-nestjs-cursor/.claude-plugin/plugin.json +1 -1
  27. package/plugins/lisa-openclaw/.claude-plugin/plugin.json +1 -1
  28. package/plugins/lisa-openclaw/.codex-plugin/plugin.json +1 -1
  29. package/plugins/lisa-openclaw/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
  30. package/plugins/lisa-openclaw/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
  31. package/plugins/lisa-openclaw/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
  32. package/plugins/lisa-openclaw/skills/lisa-openclaw-setup/SKILL.md +3 -0
  33. package/plugins/lisa-openclaw-agy/plugin.json +1 -1
  34. package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
  35. package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
  36. package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
  37. package/plugins/lisa-openclaw-agy/skills/lisa-openclaw-setup/SKILL.md +3 -0
  38. package/plugins/lisa-openclaw-copilot/.claude-plugin/plugin.json +1 -1
  39. package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
  40. package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
  41. package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
  42. package/plugins/lisa-openclaw-copilot/skills/lisa-openclaw-setup/SKILL.md +3 -0
  43. package/plugins/lisa-openclaw-cursor/.claude-plugin/plugin.json +1 -1
  44. package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
  45. package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
  46. package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
  47. package/plugins/lisa-openclaw-cursor/skills/lisa-openclaw-setup/SKILL.md +3 -0
  48. package/plugins/lisa-rails/.claude-plugin/plugin.json +1 -1
  49. package/plugins/lisa-rails/.codex-plugin/plugin.json +1 -1
  50. package/plugins/lisa-rails-agy/plugin.json +1 -1
  51. package/plugins/lisa-rails-copilot/.claude-plugin/plugin.json +1 -1
  52. package/plugins/lisa-rails-cursor/.claude-plugin/plugin.json +1 -1
  53. package/plugins/lisa-typescript/.claude-plugin/plugin.json +1 -1
  54. package/plugins/lisa-typescript/.codex-plugin/plugin.json +1 -1
  55. package/plugins/lisa-typescript-agy/plugin.json +1 -1
  56. package/plugins/lisa-typescript-copilot/.claude-plugin/plugin.json +1 -1
  57. package/plugins/lisa-typescript-cursor/.claude-plugin/plugin.json +1 -1
  58. package/plugins/lisa-wiki/.claude-plugin/plugin.json +1 -1
  59. package/plugins/lisa-wiki/.codex-plugin/plugin.json +1 -1
  60. package/plugins/lisa-wiki/scripts/ingest_slack_channel.py +2 -2
  61. package/plugins/lisa-wiki-agy/plugin.json +1 -1
  62. package/plugins/lisa-wiki-agy/scripts/ingest_slack_channel.py +2 -2
  63. package/plugins/lisa-wiki-copilot/.claude-plugin/plugin.json +1 -1
  64. package/plugins/lisa-wiki-copilot/scripts/ingest_slack_channel.py +2 -2
  65. package/plugins/lisa-wiki-cursor/.claude-plugin/plugin.json +1 -1
  66. package/plugins/lisa-wiki-cursor/scripts/ingest_slack_channel.py +2 -2
  67. package/plugins/src/openclaw/skills/lisa-openclaw-connect-repo-topic/SKILL.md +13 -5
  68. package/plugins/src/openclaw/skills/lisa-openclaw-connect-repo-topic/references/repo-topic-config.md +6 -0
  69. package/plugins/src/openclaw/skills/lisa-openclaw-connect-staff/references/platform-routing.md +5 -0
  70. package/plugins/src/openclaw/skills/lisa-openclaw-setup/SKILL.md +3 -0
  71. package/plugins/src/wiki/scripts/ingest_slack_channel.py +2 -2
package/package.json CHANGED
@@ -84,7 +84,7 @@
84
84
  "lodash": ">=4.18.1"
85
85
  },
86
86
  "name": "@codyswann/lisa",
87
- "version": "2.147.6",
87
+ "version": "2.147.7",
88
88
  "description": "Claude Code governance framework that applies guardrails, guidance, and automated enforcement to projects",
89
89
  "main": "dist/index.js",
90
90
  "exports": {
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Universal governance — agents, skills, commands, hooks, and rules for all projects",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Universal governance: agents, skills, commands, hooks, and rules for all projects.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Universal governance — agents, skills, commands, hooks, and rules for all projects",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-cdk",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "AWS CDK-specific plugin",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-cdk",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "AWS CDK-specific Lisa plugin.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-cdk",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "AWS CDK-specific plugin",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-cdk",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "AWS CDK-specific plugin",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-cdk",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "AWS CDK-specific plugin",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Universal governance — agents, skills, commands, hooks, and rules for all projects",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Universal governance — agents, skills, commands, hooks, and rules for all projects",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-expo",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Expo/React Native-specific skills, agents, rules, and MCP servers",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-expo",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Expo and React Native-specific skills, agents, rules, and MCP servers.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-expo",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Expo/React Native-specific skills, agents, rules, and MCP servers",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-expo",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Expo/React Native-specific skills, agents, rules, and MCP servers",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-expo",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Expo/React Native-specific skills, agents, rules, and MCP servers",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-harper-fabric",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Harper/Fabric-specific rules for TypeScript component apps",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-harper-fabric",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Harper/Fabric-specific Lisa rules for TypeScript component apps.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-harper-fabric",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Harper/Fabric-specific rules for TypeScript component apps",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-harper-fabric",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Harper/Fabric-specific rules for TypeScript component apps",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-harper-fabric",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Harper/Fabric-specific rules for TypeScript component apps",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-nestjs",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "NestJS-specific skills (GraphQL, TypeORM) and hooks (migration write-protection)",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-nestjs",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "NestJS-specific skills and migration write-protection hooks.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-nestjs",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "NestJS-specific skills (GraphQL, TypeORM) and hooks (migration write-protection)",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-nestjs",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "NestJS-specific skills (GraphQL, TypeORM) and hooks (migration write-protection)",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-nestjs",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "NestJS-specific skills (GraphQL, TypeORM) and hooks (migration write-protection)",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-openclaw",
3
- "version": "2.147.6",
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.6",
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 the topic was deliberately left at `requireMention = true`, mention the bot instead
141
- (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally confirm that an un-mentioned
142
- message is **ignored**. For folder-scoped topics, also send a request that implies but doesn't name a
143
- repo and confirm the dispatcher asks for confirmation before proceeding. Do **not** treat `openclaw agent --agent
144
- <id> ...` as proof a topic route works use the visible topic reply.
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.6",
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 the topic was deliberately left at `requireMention = true`, mention the bot instead
141
- (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally confirm that an un-mentioned
142
- message is **ignored**. For folder-scoped topics, also send a request that implies but doesn't name a
143
- repo and confirm the dispatcher asks for confirmation before proceeding. Do **not** treat `openclaw agent --agent
144
- <id> ...` as proof a topic route works use the visible topic reply.
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.6",
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 the topic was deliberately left at `requireMention = true`, mention the bot instead
141
- (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally confirm that an un-mentioned
142
- message is **ignored**. For folder-scoped topics, also send a request that implies but doesn't name a
143
- repo and confirm the dispatcher asks for confirmation before proceeding. Do **not** treat `openclaw agent --agent
144
- <id> ...` as proof a topic route works use the visible topic reply.
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.6",
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 the topic was deliberately left at `requireMention = true`, mention the bot instead
141
- (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally confirm that an un-mentioned
142
- message is **ignored**. For folder-scoped topics, also send a request that implies but doesn't name a
143
- repo and confirm the dispatcher asks for confirmation before proceeding. Do **not** treat `openclaw agent --agent
144
- <id> ...` as proof a topic route works use the visible topic reply.
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-rails",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Ruby on Rails-specific hooks — RuboCop linting/formatting and ast-grep scanning on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-rails",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Ruby on Rails-specific skills and hooks for RuboCop and ast-grep scanning on edit.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-rails",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Ruby on Rails-specific hooks — RuboCop linting/formatting and ast-grep scanning on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-rails",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Ruby on Rails-specific hooks — RuboCop linting/formatting and ast-grep scanning on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-rails",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Ruby on Rails-specific hooks — RuboCop linting/formatting and ast-grep scanning on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-typescript",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "TypeScript-specific hooks — Prettier formatting, ESLint linting, ast-grep scanning, and error-suppression blocking on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-typescript",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "TypeScript-specific hooks for formatting, linting, and ast-grep scanning on edit.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-typescript",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "TypeScript-specific hooks — Prettier formatting, ESLint linting, ast-grep scanning, and error-suppression blocking on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-typescript",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "TypeScript-specific hooks — Prettier formatting, ESLint linting, ast-grep scanning, and error-suppression blocking on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-typescript",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "TypeScript-specific hooks — Prettier formatting, ESLint linting, ast-grep scanning, and error-suppression blocking on edit",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-wiki",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "LLM Wiki — a distributable, git-native markdown knowledge base for Claude Code and Codex",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-wiki",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "Distributable LLM Wiki kernel — ingest, query, lint, and maintain a git-native markdown knowledge base across Claude and Codex.",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
57
57
 
58
58
 
59
59
  def utc_now() -> dt.datetime:
60
- return dt.datetime.now(dt.UTC).replace(microsecond=0)
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.UTC).replace(microsecond=0).isoformat().replace("+00:00", "Z")
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:
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-wiki",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "LLM Wiki — a distributable, git-native markdown knowledge base for Claude Code and Codex",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
57
57
 
58
58
 
59
59
  def utc_now() -> dt.datetime:
60
- return dt.datetime.now(dt.UTC).replace(microsecond=0)
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.UTC).replace(microsecond=0).isoformat().replace("+00:00", "Z")
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:
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-wiki",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "LLM Wiki — a distributable, git-native markdown knowledge base for Claude Code and Codex",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
57
57
 
58
58
 
59
59
  def utc_now() -> dt.datetime:
60
- return dt.datetime.now(dt.UTC).replace(microsecond=0)
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.UTC).replace(microsecond=0).isoformat().replace("+00:00", "Z")
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:
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "lisa-wiki",
3
- "version": "2.147.6",
3
+ "version": "2.147.7",
4
4
  "description": "LLM Wiki — a distributable, git-native markdown knowledge base for Claude Code and Codex",
5
5
  "author": {
6
6
  "name": "Cody Swann"
@@ -57,12 +57,12 @@ TOKEN_PATTERNS = [
57
57
 
58
58
 
59
59
  def utc_now() -> dt.datetime:
60
- return dt.datetime.now(dt.UTC).replace(microsecond=0)
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.UTC).replace(microsecond=0).isoformat().replace("+00:00", "Z")
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:
@@ -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 the topic was deliberately left at `requireMention = true`, mention the bot instead
141
- (`<bot-handle> reply with exactly TELEGRAM-ROUTE-OK`) and additionally confirm that an un-mentioned
142
- message is **ignored**. For folder-scoped topics, also send a request that implies but doesn't name a
143
- repo and confirm the dispatcher asks for confirmation before proceeding. Do **not** treat `openclaw agent --agent
144
- <id> ...` as proof a topic route works use the visible topic reply.
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.UTC).replace(microsecond=0)
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.UTC).replace(microsecond=0).isoformat().replace("+00:00", "Z")
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: