feat(phase-2): workstream 5 — OPA Policy Engine
- policies/authz.rego: Rego policy with path normalisation and scope enforcement - policies/data/scopes.json: all 13 endpoint → scope mappings - src/middleware/opa.ts: OpaMiddleware with Wasm primary path + scopes.json fallback; exports createOpaMiddleware() and reloadOpaPolicy() for SIGHUP hot-reload - All four route files: opaMiddleware wired after authMiddleware - AuditController, OAuth2Service: manual scope checks removed (now centralised in OPA) - src/server.ts: SIGHUP handler calls reloadOpaPolicy() - docs/devops/environment-variables.md: POLICY_DIR documented - 38 new tests; 302/302 passing; opa.ts coverage 98.66% statements Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -68,13 +68,13 @@
|
||||
|
||||
## Workstream 5: OPA Policy Engine
|
||||
|
||||
- [ ] 5.1 Write `policies/authz.rego` — allow/deny rules matching all current scope checks
|
||||
- [ ] 5.2 Write `policies/data/scopes.json` — scope to endpoint permission mapping
|
||||
- [ ] 5.3 Write `src/middleware/opa.ts` — OpaMiddleware: loads Wasm, evaluates input, returns allow/deny
|
||||
- [ ] 5.4 Replace static scope check in `src/middleware/auth.ts` with OpaMiddleware
|
||||
- [ ] 5.5 Add SIGHUP handler in `src/server.ts` to hot-reload policy files
|
||||
- [ ] 5.6 Update `docs/devops/environment-variables.md` — add POLICY_DIR
|
||||
- [ ] 5.7 QA: all existing auth tests pass unchanged, new OPA unit tests, hot-reload verified
|
||||
- [x] 5.1 Write `policies/authz.rego` — allow/deny rules matching all current scope checks
|
||||
- [x] 5.2 Write `policies/data/scopes.json` — scope to endpoint permission mapping
|
||||
- [x] 5.3 Write `src/middleware/opa.ts` — OpaMiddleware: loads Wasm, evaluates input, returns allow/deny
|
||||
- [x] 5.4 Replace static scope check in `src/middleware/auth.ts` with OpaMiddleware
|
||||
- [x] 5.5 Add SIGHUP handler in `src/server.ts` to hot-reload policy files
|
||||
- [x] 5.6 Update `docs/devops/environment-variables.md` — add POLICY_DIR
|
||||
- [x] 5.7 QA: all existing auth tests pass unchanged, new OPA unit tests, hot-reload verified
|
||||
|
||||
## Workstream 6: Web Dashboard UI
|
||||
|
||||
|
||||
Reference in New Issue
Block a user