better flake, add user

This commit is contained in:
Mohamed Chrayed 2024-08-16 14:11:10 +02:00
parent 05ceeee504
commit 4fbc1b8c68
5 changed files with 57 additions and 78 deletions

128
flake.nix
View File

@ -3,96 +3,68 @@
inputs = { inputs = {
nixpkgs.url = "nixpkgs/nixos-unstable"; nixpkgs.url = "nixpkgs/nixos-unstable";
jovian.url = "github:Jovian-Experiments/Jovian-NixOS/development";
home-manager = { home-manager = {
url = "github:nix-community/home-manager/master"; url = "github:nix-community/home-manager/master";
inputs.nixpkgs.follows = "nixpkgs"; inputs.nixpkgs.follows = "nixpkgs";
}; };
jovian.url = "github:Jovian-Experiments/Jovian-NixOS/development";
plasma-manager = { plasma-manager = {
url = "github:nix-community/plasma-manager/trunk"; url = "github:nix-community/plasma-manager/trunk";
inputs.nixpkgs.follows = "nixpkgs"; inputs.nixpkgs.follows = "nixpkgs";
inputs.home-manager.follows = "home-manager"; inputs.home-manager.follows = "home-manager";
}; };
}; };
outputs = { nixpkgs, home-manager, jovian, plasma-manager, ...}:
let
system = "x86_64-linux";
pkgs = import nixpkgs { inherit system;};
lib = nixpkgs.lib;
in
{
systemModules = [
home-manager.nixosModules.home-manager
./modules/system/apps-shell
./modules/system/boot
./modules/system/devices
./modules/system/locale
./modules/system/networking
./modules/system/nixsettings
./modules/system/shell
./modules/system/systemversion
./modules/system/upgrades
./modules/system/users
];
outputs = { self, nixpkgs, home-manager, jovian, plasma-manager, ... }: userModules = [
let ./modules/user/git
lib = nixpkgs.lib; ./modules/user/homeversion
system = "x86_64-linux"; ];
pkgs = import nixpkgs { inherit system; };
commonModules = [ nixosConfigurations = {
home-manager.nixosModules.home-manager computer-mo = nixpkgs.lib.nixosSystem {
jovian.nixosModules.jovian hostName = "computer-mo";
./modules/apps.misc user = "mo";
./modules/apps.shell system = system;
./modules/boot modules = systemModules ++ [
./modules/browser jovian.nixosModules.jovian
./modules/controller ./hosts/${hostName}
./modules/devices ./modules/system/apps-misc
./modules/jovian.desktop ./modules/system/browser
./modules/lact ./modules/system/controller
./modules/locale ./modules/system/jovian-desktop
./modules/networking ./modules/system/lact
./modules/nixsettings ./modules/system/plasma
./modules/plasma ./modules/system/steam
./modules/shell {
./modules/steam home-manager.useGlobalPkgs = true;
./modules/systemversion home-manager.useUserPackages = true;
./modules/upgrade home-manager.users.${user} = import ./modules/user/plasma;
]; home-manager.backupFileExtension = "backup";
home-manager.extraSpecialArgs = { inherit pkgs; };
homeManagerConfig = { home-manager.sharedModules = [ plasma-manager.homeManagerModules.plasma-manager ];
home-manager.useGlobalPkgs = true; }
home-manager.useUserPackages = true; ];
home-manager.backupFileExtension = "backup";
home-manager.extraSpecialArgs = { inherit pkgs; };
home-manager.sharedModules = [ plasma-manager.homeManagerModules.plasma-manager ];
}; };
# Host-specific configurations
hosts = {
computer-mo = {
user = "mo";
extraModules = [];
userConfig = {
isNormalUser = true;
home = "/home/mo";
shell = pkgs.zsh;
extraGroups = [ "wheel" "networkmanager" ];
};
};
steamdeck = {
user = "deck";
extraModules = [];
userConfig = {
isNormalUser = true;
home = "/home/deck";
shell = pkgs.zsh;
extraGroups = [ "wheel" "networkmanager" ];
};
};
};
in {
nixosConfigurations = lib.mapAttrs (hostName: hostConfig:
lib.nixosSystem {
specialArgs = {};
modules = commonModules ++ hostConfig.extraModules ++ [
# Users configuration
{ users.users.${hostConfig.user} = hostConfig.userConfig; }
# Home Manager user imports
{ home-manager.users.${hostConfig.user}.imports = [
./modules/git
./modules/homeversion
./modules/plasma
];
}
homeManagerConfig
];
}
) hosts;
}; };
};
} }

View File

@ -0,0 +1,7 @@
{ user, ... }:
{
users.users.${user} = {
isNormalUser = true;
extraGroups = [ "wheel" "Networkmanager" ];
};
}