openclaw/extensions/slack
Agustin Rivera 1c35795fce
fix(slack): align interaction auth with allowlists (#66028)
* fix(slack): align interaction auth with allowlists

* fix(slack): address review followups

* fix(slack): preserve explicit owners with wildcard

* chore: append Claude comments resolution worklog

* fix(slack): harden interaction auth with default-deny, mandatory actor binding, and channel type validation

- Add interactiveEvent flag to authorizeSlackSystemEventSender for stricter
  interactive control authorization
- Default-deny when no allowFrom or channel users are configured for
  interactive events (block actions, modals)
- Require expectedSenderId for all interactive event types; block actions
  pass Slack-verified userId, modals pass metadata-embedded userId
- Reject ambiguous channel types for interactive events to prevent DM
  authorization bypass via channel-type fallback
- Add comprehensive test coverage for all new behaviors

* fix(slack): scope interactive owner/allowFrom enforcement to interactive paths only

* fix(slack): preserve no-channel interactive default

* Update context-engine-maintenance test

* chore: remove USER.md worklog artifact

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>

* changelog: note Slack interactive auth allowlist alignment (#66028)

---------

Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Co-authored-by: Devin Robison <drobison@nvidia.com>
2026-04-13 20:38:11 -06:00
..
src fix(slack): align interaction auth with allowlists (#66028) 2026-04-13 20:38:11 -06:00
api.ts refactor: clean bundled channel bootstrap boundaries 2026-04-05 18:18:59 +01:00
channel-config-api.ts
channel-entry.ts fix: repair bundled channel secret sidecars 2026-04-08 04:56:58 +01:00
channel-plugin-api.ts test: speed up slack setup entry tests 2026-04-07 19:59:46 +01:00
config-api.ts refactor(extensions): add channel-owned config schema seams 2026-04-04 05:31:11 +01:00
configured-state.ts refactor: add metadata-first channel configured-state probes 2026-04-06 01:02:45 +01:00
contract-api.ts tests(contracts): use contract-api for Slack and Discord directories (#65280) 2026-04-12 18:54:58 +08:00
doctor-contract-api.ts fix(slack): isolate doctor contract API (#63192) 2026-04-13 17:33:49 -07:00
index.test.ts test(extensions): dedupe bundled entry smoke tests 2026-04-12 03:09:18 +01:00
index.ts fix: repair bundled channel secret sidecars 2026-04-08 04:56:58 +01:00
interactive-replies-api.ts fix(tests): narrow bundled plugin test seams 2026-04-06 23:35:07 +01:00
openclaw.plugin.json refactor: resolve channel env vars from plugin manifests 2026-04-06 19:53:27 +01:00
package.json chore: bump version to 2026.4.12 2026-04-12 10:37:18 -07:00
runtime-api.ts refactor: clean bundled channel bootstrap boundaries 2026-04-05 18:18:59 +01:00
secret-contract-api.ts fix: repair bundled channel secret sidecars 2026-04-08 04:56:58 +01:00
security-contract-api.ts fix(tests): narrow bundled plugin test seams 2026-04-06 23:35:07 +01:00
setup-entry.ts fix: repair bundled channel secret sidecars 2026-04-08 04:56:58 +01:00
setup-plugin-api.ts test: speed up slack setup entry tests 2026-04-07 19:59:46 +01:00
test-api.ts fix(plugins): keep test helpers out of contract barrels (#63311) 2026-04-08 22:59:05 +01:00
tsconfig.json chore(plugins): bulk add package boundary tsconfig rollout 2026-04-07 08:48:23 +01:00