feat(users): add disable/enable lockout commands; fix table output

- Add cmd_user_disable: disables Kratos identity (state: inactive) and
  revokes all sessions. Provides emergency lockout — user cannot log in
  again; existing Django app sessions expire within SESSION_COOKIE_AGE (1h).

- Add cmd_user_enable: re-enables a previously disabled identity.

- Wire disable/enable as subcommands of 'sunbeam user'.

- Fix cmd_user_list: table() args were swapped and result was not printed.
This commit is contained in:
2026-03-03 18:07:51 +00:00
parent cb5a290b0c
commit c759f2c014
2 changed files with 53 additions and 2 deletions

View File

@@ -95,6 +95,12 @@ def main() -> None:
p_user_recover = user_sub.add_parser("recover", help="Generate recovery link")
p_user_recover.add_argument("target", help="Email or identity ID")
p_user_disable = user_sub.add_parser("disable", help="Disable identity + revoke sessions (lockout)")
p_user_disable.add_argument("target", help="Email or identity ID")
p_user_enable = user_sub.add_parser("enable", help="Re-enable a disabled identity")
p_user_enable.add_argument("target", help="Email or identity ID")
args = parser.parse_args()
if args.verb is None:
@@ -164,7 +170,8 @@ def main() -> None:
elif args.verb == "user":
from sunbeam.users import (cmd_user_list, cmd_user_get, cmd_user_create,
cmd_user_delete, cmd_user_recover)
cmd_user_delete, cmd_user_recover,
cmd_user_disable, cmd_user_enable)
action = getattr(args, "user_action", None)
if action is None:
p_user.print_help()
@@ -179,6 +186,10 @@ def main() -> None:
cmd_user_delete(args.target)
elif action == "recover":
cmd_user_recover(args.target)
elif action == "disable":
cmd_user_disable(args.target)
elif action == "enable":
cmd_user_enable(args.target)
else:
parser.print_help()