97 lines
1.7 KiB
Nix
97 lines
1.7 KiB
Nix
{
|
|
config,
|
|
home-manager,
|
|
nh,
|
|
nix-melt,
|
|
nur,
|
|
nurl,
|
|
pkgs,
|
|
...
|
|
} @ inputs: {
|
|
imports = [
|
|
./vars
|
|
|
|
./modules
|
|
./pkgs
|
|
|
|
nur.nixosModules.nur
|
|
nh.nixosModules.default
|
|
home-manager.nixosModules.home-manager
|
|
];
|
|
|
|
nixpkgs = {
|
|
config.allowUnfree = true;
|
|
overlays = import ./overlays inputs;
|
|
};
|
|
boot.tmp.cleanOnBoot = true;
|
|
|
|
nix = {
|
|
# Edit nix.conf
|
|
settings = {
|
|
experimental-features = ["nix-command" "flakes"];
|
|
keep-outputs = true;
|
|
keep-derivations = true;
|
|
auto-optimise-store = true;
|
|
warn-dirty = false;
|
|
|
|
# remote building
|
|
trusted-users = ["matt" "nixremote"];
|
|
};
|
|
};
|
|
|
|
nh = {
|
|
enable = true;
|
|
# weekly cleanup
|
|
clean = {
|
|
enable = true;
|
|
extraArgs = "--keep-since 30d";
|
|
};
|
|
};
|
|
environment.variables.FLAKE = "/home/matt/.nix";
|
|
|
|
services = {
|
|
fwupd.enable = true;
|
|
|
|
xserver = {
|
|
layout = "ca";
|
|
xkbVariant = "multix";
|
|
};
|
|
};
|
|
|
|
home-manager.users = let
|
|
inherit (config.vars) mainUser;
|
|
mainUserConf = config.home-manager.users.${mainUser};
|
|
|
|
default = {
|
|
imports = [
|
|
# Make the vars be the same on Nix and HM
|
|
./vars
|
|
{vars = config.vars;}
|
|
|
|
nur.hmModules.nur
|
|
|
|
./home
|
|
./home/trash-d
|
|
./pkgs
|
|
];
|
|
|
|
home.packages =
|
|
[
|
|
nix-melt.packages.${pkgs.system}.default
|
|
nurl.packages.${pkgs.system}.default
|
|
]
|
|
++ (with config.nur.repos.rycee; [
|
|
mozilla-addons-to-nix
|
|
]);
|
|
};
|
|
in {
|
|
root =
|
|
default
|
|
// {
|
|
home.stateVersion = mainUserConf.home.stateVersion;
|
|
};
|
|
|
|
# TODO: make user an array?
|
|
${mainUser} = default;
|
|
};
|
|
}
|