mirror of
https://github.com/SebastianStork/nixos-config.git
synced 2026-01-21 12:51:34 +01:00
Refactor user configuration
This commit is contained in:
parent
4785c99ea4
commit
9ecc4cf9ea
15 changed files with 72 additions and 75 deletions
|
|
@ -15,12 +15,21 @@ let
|
||||||
"${self}/hosts/${hostName}"
|
"${self}/hosts/${hostName}"
|
||||||
|> lib.filesystem.listFilesRecursive
|
|> lib.filesystem.listFilesRecursive
|
||||||
|> lib.filter (lib.hasSuffix ".nix");
|
|> lib.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
|
in
|
||||||
[
|
[
|
||||||
{ networking = { inherit hostName; }; }
|
{ networking = { inherit hostName; }; }
|
||||||
"${self}/hosts/shared.nix"
|
"${self}/hosts/shared.nix"
|
||||||
]
|
]
|
||||||
++ hostFiles;
|
++ hostFiles
|
||||||
|
++ userFiles;
|
||||||
};
|
};
|
||||||
|
|
||||||
mkDeployNode = hostname: {
|
mkDeployNode = hostname: {
|
||||||
|
|
|
||||||
|
|
@ -8,15 +8,11 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
agePublicKey = "age18x6herevmcuhcmeh47ll6p9ck9zk4ga6gfxwlc8yl49rwjxm7qusylwfgc";
|
agePublicKey = "age18x6herevmcuhcmeh47ll6p9ck9zk4ga6gfxwlc8yl49rwjxm7qusylwfgc";
|
||||||
};
|
};
|
||||||
|
|
||||||
boot = {
|
boot = {
|
||||||
loader.systemd-boot.enable = true;
|
loader.systemd-boot.enable = true;
|
||||||
silent = true;
|
silent = true;
|
||||||
};
|
};
|
||||||
users.seb = {
|
|
||||||
enable = true;
|
|
||||||
zsh.enable = true;
|
|
||||||
homeManager.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
dm.tuigreet = {
|
dm.tuigreet = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
|
||||||
|
|
@ -8,15 +8,11 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
agePublicKey = "age1sywwrwse76x8yskrsfpwk38fu2cmyx5s9qkf2pgc68cta0vj9psql7dp6e";
|
agePublicKey = "age1sywwrwse76x8yskrsfpwk38fu2cmyx5s9qkf2pgc68cta0vj9psql7dp6e";
|
||||||
};
|
};
|
||||||
|
|
||||||
boot = {
|
boot = {
|
||||||
loader.systemd-boot.enable = true;
|
loader.systemd-boot.enable = true;
|
||||||
silent = true;
|
silent = true;
|
||||||
};
|
};
|
||||||
users.seb = {
|
|
||||||
enable = true;
|
|
||||||
zsh.enable = true;
|
|
||||||
homeManager.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
dm.tuigreet = {
|
dm.tuigreet = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
|
||||||
|
|
@ -12,8 +12,8 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
agePublicKey = "age1dnpwfwh0h95r63e5qfjc2gvffw2tr2tx4new7sq2h3qs90kx9fmq322mx4";
|
agePublicKey = "age1dnpwfwh0h95r63e5qfjc2gvffw2tr2tx4new7sq2h3qs90kx9fmq322mx4";
|
||||||
};
|
};
|
||||||
|
|
||||||
boot.loader.grub.enable = true;
|
boot.loader.grub.enable = true;
|
||||||
users.seb.enable = true;
|
|
||||||
|
|
||||||
services = {
|
services = {
|
||||||
resolved.enable = true;
|
resolved.enable = true;
|
||||||
|
|
|
||||||
|
|
@ -12,8 +12,8 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
agePublicKey = "age1qz04yg4h4g22wxqca2pd5k0z574223f6m5c9jy5ny37nlgcd6u4styf06t";
|
agePublicKey = "age1qz04yg4h4g22wxqca2pd5k0z574223f6m5c9jy5ny37nlgcd6u4styf06t";
|
||||||
};
|
};
|
||||||
|
|
||||||
boot.loader.systemd-boot.enable = true;
|
boot.loader.systemd-boot.enable = true;
|
||||||
users.seb.enable = true;
|
|
||||||
|
|
||||||
services = {
|
services = {
|
||||||
resolved.enable = true;
|
resolved.enable = true;
|
||||||
|
|
|
||||||
|
|
@ -17,8 +17,8 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
agePublicKey = "age1dnru7l0agvnw3t9kmx60u4vh5u4tyd49xdve53zspxkznnp9f34qtec9dl";
|
agePublicKey = "age1dnru7l0agvnw3t9kmx60u4vh5u4tyd49xdve53zspxkznnp9f34qtec9dl";
|
||||||
};
|
};
|
||||||
|
|
||||||
boot.loader.grub.enable = true;
|
boot.loader.grub.enable = true;
|
||||||
users.seb.enable = true;
|
|
||||||
|
|
||||||
services = {
|
services = {
|
||||||
resolved.enable = true;
|
resolved.enable = true;
|
||||||
|
|
|
||||||
|
|
@ -1,61 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
inputs,
|
|
||||||
self,
|
|
||||||
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 "";
|
|
||||||
configPaths = 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.configPaths;
|
|
||||||
};
|
|
||||||
})
|
|
||||||
]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
17
users/home-manager.nix
Normal file
17
users/home-manager.nix
Normal file
|
|
@ -0,0 +1,17 @@
|
||||||
|
{
|
||||||
|
inputs,
|
||||||
|
self,
|
||||||
|
pkgs-unstable,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
imports = [ inputs.home-manager.nixosModules.home-manager ];
|
||||||
|
|
||||||
|
home-manager = {
|
||||||
|
useGlobalPkgs = true;
|
||||||
|
useUserPackages = true;
|
||||||
|
extraSpecialArgs = {
|
||||||
|
inherit inputs self pkgs-unstable;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
12
users/seb/@desktop/default.nix
Normal file
12
users/seb/@desktop/default.nix
Normal file
|
|
@ -0,0 +1,12 @@
|
||||||
|
{ self, pkgs, ... }:
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
../user.nix
|
||||||
|
"${self}/users/home-manager.nix"
|
||||||
|
];
|
||||||
|
|
||||||
|
users.users.seb.shell = pkgs.zsh;
|
||||||
|
programs.zsh.enable = true;
|
||||||
|
|
||||||
|
home-manager.users.seb = ./home.nix;
|
||||||
|
}
|
||||||
12
users/seb/@laptop/default.nix
Normal file
12
users/seb/@laptop/default.nix
Normal file
|
|
@ -0,0 +1,12 @@
|
||||||
|
{ self, pkgs, ... }:
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
../user.nix
|
||||||
|
"${self}/users/home-manager.nix"
|
||||||
|
];
|
||||||
|
|
||||||
|
users.users.seb.shell = pkgs.zsh;
|
||||||
|
programs.zsh.enable = true;
|
||||||
|
|
||||||
|
home-manager.users.seb = ./home.nix;
|
||||||
|
}
|
||||||
1
users/seb/@srv-external/default.nix
Normal file
1
users/seb/@srv-external/default.nix
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
_: { imports = [ ../user.nix ]; }
|
||||||
1
users/seb/@srv-internal/default.nix
Normal file
1
users/seb/@srv-internal/default.nix
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
_: { imports = [ ../user.nix ]; }
|
||||||
1
users/seb/@srv-monitor/default.nix
Normal file
1
users/seb/@srv-monitor/default.nix
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
_: { imports = [ ../user.nix ]; }
|
||||||
|
|
@ -1,5 +1,7 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, ... }:
|
||||||
{
|
{
|
||||||
|
imports = [ ../shared-home.nix ];
|
||||||
|
|
||||||
home.sessionVariables.NH_FLAKE = "~/Projects/nixos-config";
|
home.sessionVariables.NH_FLAKE = "~/Projects/nixos-config";
|
||||||
|
|
||||||
custom = {
|
custom = {
|
||||||
|
|
|
||||||
11
users/seb/user.nix
Normal file
11
users/seb/user.nix
Normal file
|
|
@ -0,0 +1,11 @@
|
||||||
|
{ 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