TenantAtlas/specs/055-ops-ux-rollout
Ahmed Darrazi 222a7e0a97 feat(104): implement Provider Permission Posture
- T001-T014: Foundation - StoredReport model/migration, Finding resolved
  lifecycle, badge mappings (resolved status, permission_posture type),
  OperationCatalog + AlertRule constants
- T015-T022: US1 - PermissionPostureFindingGenerator with fingerprint-based
  idempotent upsert, severity from feature-impact count, auto-resolve on
  grant, auto-reopen on revoke, error findings (FR-015), stale finding
  cleanup; GeneratePermissionPostureFindingsJob dispatched from health check;
  PostureResult VO + PostureScoreCalculator
- T023-T026: US2+US4 - Stored report payload validation, temporal ordering,
  polymorphic reusability, score accuracy acceptance tests
- T027-T029: US3 - EvaluateAlertsJob.permissionMissingEvents() wired into
  alert pipeline, AlertRuleResource event type option, cooldown/dedupe tests
- T030-T034: Polish - PruneStoredReportsCommand with config retention,
  scheduled daily, end-to-end integration test, Pint clean

UI bug fixes found during testing:
- FindingResource: hide Diff section for non-drift findings
- TenantRequiredPermissions: fix re-run verification link
- tenant-required-permissions.blade.php: preserve details open state

70 tests (50 PermissionPosture + 20 FindingResolved/Badge/Alert), 216 assertions
2026-02-21 23:31:03 +01:00
..
checklists 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00
contracts 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00
data-model.md 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00
plan.md 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00
quickstart.md 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00
research.md 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00
spec.md feat(104): implement Provider Permission Posture 2026-02-21 23:31:03 +01:00
tasks.md 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00