40 lines
836 B
Nix
40 lines
836 B
Nix
|
{
|
||
|
lib,
|
||
|
config,
|
||
|
pkgs,
|
||
|
...
|
||
|
}:
|
||
|
with lib; let
|
||
|
cfg = config.modules.users;
|
||
|
in {
|
||
|
options.modules.users = {
|
||
|
root.disablePassword = mkEnableOption "Disables root password";
|
||
|
phundrak = mkOption {
|
||
|
type = types.bool;
|
||
|
default = true;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
config = {
|
||
|
users.users = {
|
||
|
root = {
|
||
|
hashedPassword = mkIf cfg.root.disablePassword "*";
|
||
|
shell = pkgs.zsh;
|
||
|
};
|
||
|
phundrak = {
|
||
|
isNormalUser = true;
|
||
|
description = "Lucien Cartier-Tilet";
|
||
|
extraGroups = ["networkmanager" "wheel" "docker" "dialout" "podman"];
|
||
|
shell = pkgs.zsh;
|
||
|
openssh.authorizedKeys.keyFiles = [
|
||
|
./keys/id_gampo.pub
|
||
|
./keys/id_marpa.pub
|
||
|
./keys/id_tilo.pub
|
||
|
./keys/id_opn4.pub
|
||
|
];
|
||
|
};
|
||
|
};
|
||
|
programs.zsh.enable = true;
|
||
|
};
|
||
|
}
|