Files
infra/users/ai-worker.nix

26 lines
888 B
Nix
Raw Normal View History

{ pkgs, inputs, config, keys, ... }: {
2026-04-04 04:57:47 -04:00
users.users.ai-worker = {
isSystemUser = true;
2026-04-04 04:57:47 -04:00
group = "ai-worker";
home = "/home/ai-worker";
createHome = true;
extraGroups = [ "docker" ];
shell = pkgs.bashInteractive;
openssh.authorizedKeys.keys = [
2026-04-04 04:57:47 -04:00
keys.users.ai-worker.main
];
# No password login - SSH key only
hashedPassword = "!";
};
2026-04-04 04:57:47 -04:00
users.groups.ai-worker = {};
# Enable restricted AI worker access with deployment capabilities
# SECURITY: ai-worker can only:
# - Access /home/ai-worker/infra (bind-mounted to /home/gortium/infra)
# - Run: nh, nixos-rebuild, nixpkgs-fmt, nix (via sudo, no password)
# - Manage docker containers (via docker group)
# - All changes to infra/ are logged via audit subsystem
# WORKFLOW: AI must ask for user confirmation before running nh os switch
services.aiWorkerAccess = true;
}