1
0
Fork 0
nix-configuration/modules/system/system.nix

110 lines
3 KiB
Nix
Raw Normal View History

# System options
{
pkgs,
config,
lib,
...
}:
let
cfg = config.aux.system;
in
{
options = {
aux.system = {
packages = lib.mkOption {
description = "Additional system packages to install. This is just a wrapper for environment.systemPackages.";
type = lib.types.listOf lib.types.package;
default = [ ];
example = lib.literalExpression "[ pkgs.firefox pkgs.thunderbird ]";
};
corePackages = lib.mkOption {
description = "Minimum set of packages to install.";
type = lib.types.listOf lib.types.package;
default = with pkgs; [
# Courtesy of https://discourse.nixos.org/t/how-to-use-other-packages-binary-in-systemd-service-configuration/14363
2024-06-24 16:24:21 +00:00
bash
coreutils
dconf
2024-06-24 16:24:21 +00:00
direnv
git
git-crypt # Secrets management
gnutar
gzip
2024-06-24 16:24:21 +00:00
home-manager
2024-10-10 16:16:37 +00:00
openssh
sudo
xz.bin
];
};
powerManagement.enable = lib.mkEnableOption "Enables power management, e.g. for laptops.";
};
};
config = {
# Install base packages
environment.systemPackages = cfg.corePackages ++ cfg.packages;
# Configure power management via auto-cpufreq
# https://github.com/AdnanHodzic/auto-cpufreq
programs.auto-cpufreq.enable = cfg.powerManagement.enable;
services = {
2024-09-08 15:58:56 +00:00
# Automatically set the timezone based on location
2024-08-11 23:08:42 +00:00
automatic-timezoned.enable = true;
geoclue2.enableDemoAgent = lib.mkForce true;
2024-08-11 23:08:42 +00:00
# Enable fwupd (firmware updater)
fwupd.enable = true;
# Allow systemd user services to keep running after the user has logged out
logind.killUserProcesses = false;
# Enable disk monitoring
smartd = {
enable = true;
autodetect = true;
2024-11-22 17:47:18 +00:00
notifications = {
wall.enable = true;
mail = lib.mkIf config.aux.system.services.msmtp.enable {
enable = true;
mailer = "/run/wrappers/bin/sendmail";
sender = "${config.networking.hostName}@${config.secrets.networking.domains.primary}";
recipient = config.secrets.users.aires.email;
};
};
};
};
2024-08-11 23:08:42 +00:00
# Enable visual updates
system.activationScripts.diff = {
supportsDryActivation = true;
text = ''
${pkgs.nvd}/bin/nvd --nix-bin-dir=${pkgs.nix}/bin diff /run/current-system "$systemConfig"
'';
};
# Limit logout stop timer duration to 30 seconds
systemd.user.extraConfig = ''
DefaultTimeoutStopSec=30s
'';
# Select internationalisation properties.
i18n = {
defaultLocale = "en_US.UTF-8";
extraLocaleSettings = {
LC_ADDRESS = "en_US.UTF-8";
LC_IDENTIFICATION = "en_US.UTF-8";
LC_MEASUREMENT = "en_US.UTF-8";
LC_MONETARY = "en_US.UTF-8";
LC_NAME = "en_US.UTF-8";
LC_NUMERIC = "en_US.UTF-8";
LC_PAPER = "en_US.UTF-8";
LC_TELEPHONE = "en_US.UTF-8";
LC_TIME = "en_US.UTF-8";
};
};
};
}