Built-in Roles & permissions admin screen (todo §5); /admin/roles list (search/sort/paginate) + create/delete + assign-to-users/groups + "effective access" (Keto expand → transitive members), writing only to Keto — gated admin-only + CSRF-guarded like Users/Groups (Kratos read only to label members). A role = Keto subject set Role:<name>#members; reuses the Groups membership helpers (now-exported pagedTuples/memberCandidates/safeDecode); added a Roles nav entry (i-shield) + a .plain-list CSS rule. Stability-reviewer run as a local PR: APPROVE, no Critical/High; addressed its explicit-expand-depth nit. Live boot-verify caught a real bug the tests missed — Keto v26.2.0 nests the expand subject under tuple (not node top-level as the §4 ExpandTree type guessed), so expandToEffectiveUsers returned []; fixed type+walker+fixtures, re-verified a group-only member surfaces in effective access. 237→243 units + typecheck green; expand chain boot-verified live then torn down.
This commit is contained in:
@@ -677,6 +677,7 @@ th[aria-sort="descending"] .sort-ico { transform: rotate(180deg); }
|
||||
.inline-form { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
|
||||
.admin-actions { flex-flow: row wrap; gap: 10px; align-items: center; }
|
||||
.admin-actions form { margin: 0; }
|
||||
.plain-list { display: flex; flex-direction: column; gap: 6px; }
|
||||
.btn-danger { color: var(--neg); border-color: var(--neg-bd); }
|
||||
.btn-danger:hover { background: var(--neg-bg); }
|
||||
.recovery-link { word-break: break-all; }
|
||||
|
||||
Reference in New Issue
Block a user