2024-11-22 23:15:13 -05:00
|
|
|
self: {
|
|
|
|
config,
|
|
|
|
lib,
|
|
|
|
pkgs,
|
|
|
|
...
|
|
|
|
}: let
|
|
|
|
inherit (lib) attrValues filter findFirst isAttrs hasAttr mkDefault mkIf mkOption types;
|
|
|
|
inherit (self.inputs) home-manager nh nixd;
|
|
|
|
|
|
|
|
cfg = config.roles.base;
|
|
|
|
in {
|
|
|
|
imports = [
|
|
|
|
./locale
|
|
|
|
./locate
|
|
|
|
./substituters
|
|
|
|
(import ./common-nix self)
|
|
|
|
(import ./packages self)
|
|
|
|
|
|
|
|
self.nixosModules.borgbackup
|
|
|
|
self.nixosModules.tmux
|
|
|
|
|
|
|
|
home-manager.nixosModules.home-manager
|
|
|
|
];
|
|
|
|
|
|
|
|
options.roles.base = {
|
|
|
|
enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
user = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-11-23 04:53:02 -05:00
|
|
|
config = mkIf cfg.enable {
|
2024-11-22 23:15:13 -05:00
|
|
|
environment.variables.FLAKE = mkDefault "/home/${cfg.user}/.nix";
|
|
|
|
|
|
|
|
programs.tmux.enableCustomConf = true;
|
|
|
|
|
|
|
|
boot.tmp.useTmpfs = true;
|
|
|
|
|
|
|
|
systemd.services.nix-daemon = {
|
|
|
|
environment.TMPDIR = "/home/nix-cache";
|
|
|
|
preStart = ''
|
|
|
|
mkdir -p ${config.systemd.services.nix-daemon.environment.TMPDIR}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
nix = {
|
|
|
|
package = let
|
|
|
|
nixdInput =
|
|
|
|
findFirst
|
|
|
|
(x: x.pname == "nix") {}
|
|
|
|
nixd.packages.${pkgs.system}.nixd.buildInputs;
|
|
|
|
|
|
|
|
throws = x: !(builtins.tryEval x).success;
|
|
|
|
hasVersion = x: isAttrs x && hasAttr "version" x;
|
|
|
|
|
|
|
|
nixVersions = filter (x: ! throws x && hasVersion x) (attrValues pkgs.nixVersions);
|
|
|
|
in
|
|
|
|
findFirst (x: x.version == nixdInput.version) {} nixVersions;
|
|
|
|
|
|
|
|
# Edit nix.conf
|
|
|
|
settings = {
|
|
|
|
# Store
|
|
|
|
keep-outputs = true;
|
|
|
|
keep-derivations = true;
|
|
|
|
auto-optimise-store = true;
|
|
|
|
|
|
|
|
# Commands
|
|
|
|
experimental-features = ["nix-command" "flakes"];
|
|
|
|
http-connections = 0; # unlimited for local cache
|
|
|
|
warn-dirty = false;
|
|
|
|
show-trace = true;
|
|
|
|
allow-import-from-derivation = true;
|
|
|
|
|
|
|
|
# remote building
|
|
|
|
trusted-users = ["matt" "nixremote"];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
programs.nh = {
|
|
|
|
enable = true;
|
|
|
|
package = nh.packages.${pkgs.system}.default;
|
|
|
|
|
|
|
|
# weekly cleanup
|
|
|
|
clean = {
|
|
|
|
enable = true;
|
|
|
|
extraArgs = "--keep-since 30d";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services = {
|
|
|
|
fwupd.enable = true;
|
|
|
|
|
|
|
|
xserver.xkb = {
|
|
|
|
layout = "ca";
|
|
|
|
variant = "multix";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
boot.supportedFilesystems = ["ext4" "xfs" "btrfs" "vfat" "ntfs"];
|
|
|
|
system.fsPackages = attrValues {
|
|
|
|
inherit
|
|
|
|
(pkgs)
|
|
|
|
btrfs-progs
|
|
|
|
nfs-utils
|
|
|
|
ntfs3g
|
|
|
|
xfsprogs
|
|
|
|
;
|
|
|
|
};
|
|
|
|
|
|
|
|
environment.variables.NPM_CONFIG_GLOBALCONFIG = "/etc/npmrc";
|
|
|
|
environment.etc.npmrc.text = ''
|
|
|
|
fund = false
|
|
|
|
update-notifier = false
|
|
|
|
'';
|
|
|
|
|
|
|
|
environment.systemPackages = attrValues {
|
|
|
|
# Peripherals
|
|
|
|
inherit
|
|
|
|
(pkgs)
|
|
|
|
hdparm
|
|
|
|
pciutils
|
|
|
|
usbutils
|
|
|
|
rar
|
|
|
|
;
|
|
|
|
};
|
|
|
|
|
|
|
|
home-manager.users = let
|
|
|
|
default = {
|
|
|
|
imports = [
|
|
|
|
{
|
|
|
|
programs.bash = {
|
|
|
|
sessionVariables = rec {
|
|
|
|
FLAKE = config.environment.variables.FLAKE;
|
|
|
|
NH_FLAKE = FLAKE;
|
|
|
|
};
|
|
|
|
shellAliases.nh = "env -u FLAKE nh";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
home.stateVersion = config.system.stateVersion;
|
|
|
|
};
|
|
|
|
in {
|
|
|
|
greeter = mkIf (config.services.greetd.enable) default;
|
|
|
|
${cfg.user} = default;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# For accurate stack trace
|
|
|
|
_file = ./default.nix;
|
|
|
|
}
|