Mason Huang
004835f4c7
fix(plugins): block untrusted workspace setup-only channel loads (#86953)
Summary:
- This PR blocks disabled workspace-origin channel plugins from setup-only scoped imports, rejects their channel registrations at registry assembly, documents the trust rule, and adds regression coverage.
- PR surface: Source +46, Tests +610, Docs +13. Total +669 across 22 files.
- Reproducibility: yes. source inspection gives a high-confidence reproduction path: current main's setup-only ... ce channel plugin can be imported before this PR. I did not run the repro locally in this read-only review.
Automerge notes:
- PR branch already contained follow-up commit before automerge: test(plugins): cover workspace channel registry guard
- PR branch already contained follow-up commit before automerge: fix(plugins): isolate setup channel registration errors
- PR branch already contained follow-up commit before automerge: fix(channels): mark raw catalog listing internal
- PR branch already contained follow-up commit before automerge: test(channels): cover trusted catalog filtering
- PR branch already contained follow-up commit before automerge: test(channels): mock raw catalog helper
- PR branch already contained follow-up commit before automerge: docs(changelog): credit setup channel hardening
Validation:
- ClawSweeper review passed for head 11438bc1a0.
- Required merge gates passed before the squash merge.
Prepared head SHA: 11438bc1a0
Review: https://github.com/openclaw/openclaw/pull/86953#issuecomment-4545730044
Co-authored-by: masonxhuang <masonxhuang@tencent.com>
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
Co-authored-by: Mason Huang <masonxhuang@tencent.com>
Co-authored-by: Sebastien Tardif <sebtardif@ncf.ca>
Co-authored-by: clawsweeper <274271284+clawsweeper[bot]@users.noreply.github.com>
Co-authored-by: clawsweeper[bot] <274271284+clawsweeper[bot]@users.noreply.github.com>
Approved-by: hxy91819
Co-authored-by: hxy91819 <8814856+hxy91819@users.noreply.github.com>
2026-06-01 09:25:56 +00:00
..
2026-05-31 23:06:13 +01:00
2026-06-01 01:12:21 +01:00
2026-06-01 01:12:21 +01:00
2026-06-01 01:12:21 +01:00
2026-05-31 22:40:48 +01:00
2026-06-01 00:30:12 -04:00
2026-05-31 01:33:00 +01:00
2026-05-29 02:22:03 -04:00
2026-05-31 22:40:48 +01:00
2026-05-19 15:10:17 -07:00
2026-05-30 11:07:45 +02:00
2026-05-31 20:51:33 -04:00
2026-05-31 20:51:33 -04:00
2026-05-26 21:08:11 +01:00
2026-05-30 11:07:45 +02:00
2026-06-01 00:30:12 -04:00
2026-06-01 00:30:12 -04:00
2026-06-01 09:25:56 +00:00
2026-05-31 01:33:00 +01:00
2026-05-18 14:56:06 +01:00
2026-05-31 01:33:00 +01:00
2026-05-17 17:03:23 +08:00
2026-05-30 11:07:45 +02:00
2026-05-30 11:07:45 +02:00
2026-05-01 22:05:19 +01:00
2026-05-29 04:06:56 -04:00
2026-05-02 00:55:11 +01:00
2026-05-01 21:37:08 +01:00
2026-05-02 10:55:59 +01:00
2026-05-30 04:54:37 +02:00
2026-05-17 20:08:16 +08:00
2026-05-17 20:08:16 +08:00
2026-05-30 04:54:37 +02:00
2026-05-26 22:24:25 +01:00
2026-05-08 05:28:12 +01:00
2026-05-31 22:32:28 -04:00
2026-05-31 18:59:02 +01:00
2026-05-31 09:32:52 +01:00
2026-05-18 20:35:55 -05:00
2026-05-18 20:35:55 -05:00
2026-05-27 03:54:44 +01:00
2026-05-31 01:33:00 +01:00
2026-05-17 10:42:57 +01:00
2026-05-31 21:02:11 -04:00
2026-05-31 21:02:11 -04:00
2026-05-31 21:02:11 -04:00
2026-05-30 04:54:37 +02:00
2026-05-01 07:49:02 +00:00
2026-05-26 20:40:13 +01:00
2026-05-30 11:07:45 +02:00
2026-05-13 13:33:38 +01:00
2026-05-13 13:33:38 +01:00
2026-05-26 18:08:44 +01:00
2026-05-31 22:32:28 -04:00
2026-05-28 13:20:19 +01:00
2026-06-01 07:11:28 +01:00
2026-05-31 07:17:57 +01:00
2026-05-26 01:13:20 +01:00
2026-05-16 11:09:42 -07:00
2026-05-31 07:17:57 +01:00
2026-05-11 04:46:48 +01:00
2026-05-01 22:05:19 +01:00
2026-05-13 13:33:38 +01:00
2026-05-31 01:33:00 +01:00
2026-05-31 01:37:45 -04:00
2026-05-03 00:59:55 +09:00
2026-05-19 22:09:14 -07:00
2026-05-28 16:29:08 -07:00
2026-05-28 16:29:08 -07:00
2026-05-14 16:02:42 +08:00
2026-05-27 08:57:03 -04:00
2026-05-31 01:33:00 +01:00
2026-05-30 11:07:45 +02:00
2026-05-30 13:00:28 +02:00
2026-05-27 07:35:02 -04:00
2026-05-31 01:33:00 +01:00
2026-05-30 11:07:45 +02:00
2026-05-30 11:07:45 +02:00
2026-05-10 15:37:57 +08:00
2026-05-13 13:33:38 +01:00
2026-05-31 01:33:00 +01:00
2026-05-30 11:07:45 +02:00
2026-05-30 11:07:45 +02:00
2026-05-12 21:54:12 +01:00
2026-05-09 08:05:05 +08:00
2026-05-29 20:52:19 +02:00
2026-05-31 13:56:27 +01:00
2026-05-27 08:57:03 -04:00
2026-05-29 02:23:42 +01:00
2026-05-29 02:23:42 +01:00
2026-05-24 03:55:49 +01:00
2026-05-31 01:33:00 +01:00
2026-05-31 11:14:26 +01:00
2026-05-30 11:07:45 +02:00
2026-05-31 21:24:09 -04:00
2026-05-21 18:05:11 -07:00
2026-05-31 22:32:28 -04:00
2026-05-23 17:54:23 +08:00
2026-05-31 18:59:02 +01:00
2026-05-31 07:38:33 +01:00
2026-05-31 10:06:55 +01:00
2026-05-31 10:06:55 +01:00
2026-05-09 03:57:18 +01:00
2026-05-31 01:33:00 +01:00
2026-05-14 15:48:11 +08:00
2026-05-14 15:48:11 +08:00
2026-05-31 00:29:44 +01:00
2026-05-31 19:01:51 +01:00
2026-05-31 21:24:09 -04:00
2026-05-31 21:24:09 -04:00
2026-05-24 03:55:49 +01:00
2026-06-01 01:12:21 +01:00
2026-05-31 09:32:52 +01:00
2026-05-21 00:35:40 +00:00
2026-05-09 03:54:12 +01:00
2026-05-31 01:33:00 +01:00
2026-05-24 03:55:49 +01:00
2026-05-29 09:42:46 +01:00
2026-05-28 16:29:08 -07:00
2026-05-31 01:33:00 +01:00
2026-05-30 11:07:45 +02:00
2026-06-01 01:12:21 +01:00
2026-05-31 01:33:00 +01:00
2026-05-31 01:33:00 +01:00
2026-05-29 07:52:00 -04:00
2026-05-29 07:52:00 -04:00
2026-05-31 01:33:00 +01:00
2026-05-26 23:51:53 +01:00
2026-05-26 23:51:53 +01:00
2026-05-01 21:32:22 +01:00
2026-05-02 10:55:59 +01:00
2026-05-18 14:56:06 +01:00
2026-05-18 14:56:06 +01:00
2026-05-29 20:52:18 +02:00
2026-05-31 01:33:00 +01:00
2026-05-31 18:59:02 +01:00
2026-05-29 09:42:46 +01:00
2026-05-14 15:57:07 +08:00
2026-05-27 19:24:04 +01:00
2026-05-31 00:29:44 +01:00
2026-05-31 09:32:52 +01:00
2026-05-30 13:00:28 +02:00
2026-05-13 05:35:45 +01:00
2026-05-13 19:34:18 +10:00
2026-05-31 01:33:00 +01:00
2026-05-30 11:07:45 +02:00
2026-05-31 01:33:00 +01:00
2026-05-15 23:04:15 -05:00
2026-05-12 21:54:12 +01:00
2026-05-30 11:07:45 +02:00
2026-05-27 18:05:07 +01:00
2026-05-27 18:05:07 +01:00
2026-05-30 13:00:31 +02:00
2026-05-30 13:00:31 +02:00
2026-05-30 11:07:45 +02:00
2026-05-09 05:31:22 +01:00
2026-05-02 13:30:07 -07:00
2026-05-02 13:19:24 +00:00
2026-05-27 03:34:44 -04:00
2026-05-31 01:33:00 +01:00
2026-05-30 11:07:45 +02:00
2026-05-30 11:07:45 +02:00
2026-05-30 11:07:45 +02:00
2026-05-31 01:37:45 -04:00
2026-05-31 01:37:45 -04:00
2026-05-31 01:33:00 +01:00
2026-05-24 03:55:49 +01:00
2026-05-31 01:33:00 +01:00
2026-05-31 01:37:45 -04:00
2026-05-26 18:08:44 +01:00
2026-05-31 00:00:19 +01:00
2026-05-27 03:52:40 -04:00
2026-05-31 18:59:02 +01:00
2026-05-31 01:37:45 -04:00
2026-05-31 01:37:45 -04:00
2026-05-31 23:06:13 +01:00
2026-05-31 22:32:28 -04:00
2026-05-31 18:59:02 +01:00
2026-05-31 23:06:13 +01:00
2026-05-29 06:34:28 -04:00
2026-05-29 06:34:28 -04:00
2026-05-13 03:20:26 +01:00
2026-05-30 11:07:45 +02:00
2026-05-16 12:11:56 +01:00
2026-05-01 12:31:52 +01:00
2026-05-31 22:32:28 -04:00
2026-05-18 20:35:55 -05:00
2026-05-31 07:17:57 +01:00
2026-05-21 18:01:32 +08:00
2026-05-01 22:08:43 +01:00
2026-05-19 11:37:35 +00:00
2026-05-29 02:12:59 -04:00
2026-05-30 04:54:37 +02:00
2026-04-27 20:51:50 +01:00
2026-05-31 01:33:00 +01:00
2026-05-30 11:07:45 +02:00
2026-04-28 01:59:25 +01:00
2026-05-21 18:01:32 +08:00
2026-05-31 13:56:27 +01:00
2026-05-30 11:07:45 +02:00
2026-05-24 03:55:49 +01:00
2026-05-30 13:00:29 +02:00
2026-05-25 13:39:56 +00:00
2026-06-01 01:12:21 +01:00
2026-05-21 11:21:58 +08:00
2026-05-31 18:59:02 +01:00
2026-05-30 11:07:45 +02:00
2026-05-29 17:35:02 +01:00
2026-05-29 17:35:02 +01:00
2026-05-31 01:33:00 +01:00
2026-05-27 14:23:24 -05:00
2026-05-30 20:04:52 +01:00
2026-05-18 14:56:06 +01:00
2026-05-18 14:56:06 +01:00
2026-05-31 08:16:11 +01:00
2026-05-31 01:33:00 +01:00
2026-05-31 17:59:43 +01:00
2026-05-31 17:59:43 +01:00
2026-05-12 08:15:26 +01:00
2026-05-30 11:07:45 +02:00
2026-05-24 03:55:49 +01:00
2026-05-31 22:40:48 +01:00
2026-05-31 07:17:57 +01:00
2026-05-23 13:36:56 +01:00
2026-05-27 07:35:02 -04:00
2026-05-31 01:33:00 +01:00
2026-05-26 21:31:58 +01:00
2026-05-31 09:32:52 +01:00