mirror of
https://github.com/SebastianStork/nixos-config.git
synced 2026-01-21 12:51:34 +01:00
Manage users with the option system
This commit is contained in:
parent
9386dc29d7
commit
d7070b6fb5
15 changed files with 79 additions and 71 deletions
|
|
@ -14,19 +14,11 @@ let
|
|||
"${self}/hosts/${hostName}"
|
||||
|> lib.filesystem.listFilesRecursive
|
||||
|> builtins.filter (lib.hasSuffix ".nix");
|
||||
userFiles =
|
||||
"${self}/users"
|
||||
|> builtins.readDir
|
||||
|> lib.filterAttrs (_: type: type == "directory")
|
||||
|> builtins.attrNames
|
||||
|> map (user: "${self}/users/${user}/@${hostName}")
|
||||
|> builtins.filter (path: builtins.pathExists path);
|
||||
in
|
||||
lib.flatten [
|
||||
{ networking = { inherit hostName; }; }
|
||||
"${self}/hosts/shared.nix"
|
||||
hostFiles
|
||||
userFiles
|
||||
];
|
||||
};
|
||||
};
|
||||
|
|
|
|||
|
|
@ -6,6 +6,8 @@
|
|||
sops.enable = true;
|
||||
boot.loader.systemdBoot.enable = true;
|
||||
|
||||
users.seb.enable = true;
|
||||
|
||||
services = {
|
||||
tailscale = {
|
||||
enable = true;
|
||||
|
|
|
|||
|
|
@ -6,6 +6,8 @@
|
|||
sops.enable = true;
|
||||
boot.loader.grub.enable = true;
|
||||
|
||||
users.seb.enable = true;
|
||||
|
||||
services = {
|
||||
tailscale = {
|
||||
enable = true;
|
||||
|
|
|
|||
|
|
@ -6,6 +6,8 @@
|
|||
sops.enable = true;
|
||||
boot.loader.grub.enable = true;
|
||||
|
||||
users.seb.enable = true;
|
||||
|
||||
services = {
|
||||
tailscale = {
|
||||
enable = true;
|
||||
|
|
|
|||
|
|
@ -10,6 +10,12 @@
|
|||
silent = true;
|
||||
};
|
||||
|
||||
users.seb = {
|
||||
enable = true;
|
||||
zsh.enable = true;
|
||||
homeManager.enable = true;
|
||||
};
|
||||
|
||||
dm.tuigreet.enable = true;
|
||||
de.hyprland.enable = true;
|
||||
|
||||
|
|
|
|||
|
|
@ -10,6 +10,12 @@
|
|||
silent = true;
|
||||
};
|
||||
|
||||
users.seb = {
|
||||
enable = true;
|
||||
zsh.enable = true;
|
||||
homeManager.enable = true;
|
||||
};
|
||||
|
||||
dm.tuigreet.enable = true;
|
||||
de.hyprland.enable = true;
|
||||
|
||||
|
|
|
|||
61
modules/system/users/seb.nix
Normal file
61
modules/system/users/seb.nix
Normal file
|
|
@ -0,0 +1,61 @@
|
|||
{
|
||||
config,
|
||||
self,
|
||||
inputs,
|
||||
pkgs,
|
||||
pkgs-unstable,
|
||||
lib,
|
||||
...
|
||||
}:
|
||||
let
|
||||
cfg = config.custom.users.seb;
|
||||
in
|
||||
{
|
||||
imports = [ inputs.home-manager.nixosModules.home-manager ];
|
||||
|
||||
options.custom.users.seb = {
|
||||
enable = lib.mkEnableOption "";
|
||||
zsh.enable = lib.mkEnableOption "";
|
||||
homeManager = {
|
||||
enable = lib.mkEnableOption "";
|
||||
configPath = lib.mkOption {
|
||||
type = lib.types.listOf lib.types.path;
|
||||
default = [
|
||||
"${self}/users/shared-home.nix"
|
||||
"${self}/users/seb/home.nix"
|
||||
"${self}/users/seb/@${config.networking.hostName}/home.nix"
|
||||
];
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
config = lib.mkIf cfg.enable (
|
||||
lib.mkMerge [
|
||||
{
|
||||
sops.secrets."seb-password".neededForUsers = true;
|
||||
|
||||
users.users.seb = {
|
||||
isNormalUser = true;
|
||||
description = "Sebastian Stork";
|
||||
hashedPasswordFile = config.sops.secrets."seb-password".path;
|
||||
extraGroups = [ "wheel" ];
|
||||
shell = lib.mkIf cfg.zsh.enable pkgs.zsh;
|
||||
};
|
||||
|
||||
programs.zsh.enable = lib.mkIf cfg.zsh.enable true;
|
||||
}
|
||||
|
||||
(lib.mkIf cfg.homeManager.enable {
|
||||
home-manager = {
|
||||
useGlobalPkgs = true;
|
||||
useUserPackages = true;
|
||||
extraSpecialArgs = {
|
||||
inherit inputs self pkgs-unstable;
|
||||
};
|
||||
|
||||
users.seb.imports = cfg.homeManager.configPath;
|
||||
};
|
||||
})
|
||||
]
|
||||
);
|
||||
}
|
||||
|
|
@ -1,17 +0,0 @@
|
|||
{
|
||||
inputs,
|
||||
self,
|
||||
pkgs-unstable,
|
||||
...
|
||||
}:
|
||||
{
|
||||
imports = [ inputs.home-manager.nixosModules.home-manager ];
|
||||
|
||||
home-manager = {
|
||||
useGlobalPkgs = true;
|
||||
useUserPackages = true;
|
||||
extraSpecialArgs = {
|
||||
inherit inputs self pkgs-unstable;
|
||||
};
|
||||
};
|
||||
}
|
||||
|
|
@ -1,3 +0,0 @@
|
|||
_: {
|
||||
imports = [ ../user.nix ];
|
||||
}
|
||||
|
|
@ -1,3 +0,0 @@
|
|||
_: {
|
||||
imports = [ ../user.nix ];
|
||||
}
|
||||
|
|
@ -1,3 +0,0 @@
|
|||
_: {
|
||||
imports = [ ../user.nix ];
|
||||
}
|
||||
|
|
@ -1,12 +0,0 @@
|
|||
{ pkgs, ... }:
|
||||
{
|
||||
imports = [
|
||||
../../home-manager.nix
|
||||
../user.nix
|
||||
];
|
||||
|
||||
users.users.seb.shell = pkgs.zsh;
|
||||
programs.zsh.enable = true;
|
||||
|
||||
home-manager.users.seb = ./home.nix;
|
||||
}
|
||||
|
|
@ -1,12 +0,0 @@
|
|||
{ pkgs, ... }:
|
||||
{
|
||||
imports = [
|
||||
../../home-manager.nix
|
||||
../user.nix
|
||||
];
|
||||
|
||||
users.users.seb.shell = pkgs.zsh;
|
||||
programs.zsh.enable = true;
|
||||
|
||||
home-manager.users.seb = ./home.nix;
|
||||
}
|
||||
|
|
@ -19,8 +19,6 @@ let
|
|||
};
|
||||
in
|
||||
{
|
||||
imports = [ ../shared-home.nix ];
|
||||
|
||||
home.sessionVariables.NH_FLAKE = "~/Projects/nixos-config";
|
||||
|
||||
custom = {
|
||||
|
|
|
|||
|
|
@ -1,11 +0,0 @@
|
|||
{ config, ... }:
|
||||
{
|
||||
sops.secrets."seb-password".neededForUsers = true;
|
||||
|
||||
users.users.seb = {
|
||||
isNormalUser = true;
|
||||
description = "Sebastian Stork";
|
||||
hashedPasswordFile = config.sops.secrets."seb-password".path;
|
||||
extraGroups = [ "wheel" ];
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue