2025-03-02 14:36:53 +03:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
lib,
|
2025-06-07 21:29:52 +03:00
|
|
|
pkgs,
|
2025-06-07 17:46:05 +03:00
|
|
|
inputs,
|
2025-03-02 14:36:53 +03:00
|
|
|
...
|
|
|
|
}:
|
|
|
|
let
|
|
|
|
inherit (lib)
|
2025-03-10 18:29:45 +03:00
|
|
|
mkDefault
|
2025-03-02 14:36:53 +03:00
|
|
|
mkIf
|
|
|
|
mkMerge
|
|
|
|
mkOption
|
2025-03-10 18:29:45 +03:00
|
|
|
recursiveUpdate
|
2025-03-02 14:36:53 +03:00
|
|
|
types
|
|
|
|
;
|
2025-03-10 18:29:45 +03:00
|
|
|
|
2025-06-07 17:50:08 +03:00
|
|
|
defaultUser = config.ataraxia.defaults.users.defaultUser;
|
2025-03-10 18:43:40 +03:00
|
|
|
fs = config.ataraxia.filesystems;
|
|
|
|
fsCompression = fs.zfs.enable || fs.btrfs.enable;
|
2025-03-02 14:36:53 +03:00
|
|
|
role = config.ataraxia.defaults.role;
|
|
|
|
in
|
|
|
|
{
|
|
|
|
options.ataraxia.defaults = {
|
|
|
|
role = mkOption {
|
|
|
|
type = types.enum [
|
|
|
|
"none"
|
|
|
|
"base"
|
|
|
|
"server"
|
|
|
|
"desktop"
|
2025-07-08 15:40:31 +03:00
|
|
|
"laptop"
|
2025-03-02 14:36:53 +03:00
|
|
|
];
|
|
|
|
default = "none";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2025-06-07 17:46:05 +03:00
|
|
|
imports = [ inputs.nix-index-database.nixosModules.nix-index ];
|
|
|
|
|
2025-03-10 18:29:45 +03:00
|
|
|
config =
|
|
|
|
let
|
|
|
|
baseRole = {
|
2025-06-07 17:43:36 +03:00
|
|
|
ataraxia.defaults.boot.enable = mkDefault true;
|
2025-06-07 17:33:23 +03:00
|
|
|
ataraxia.defaults.hardware.enable = mkDefault true;
|
2025-03-10 18:35:29 +03:00
|
|
|
ataraxia.defaults.locale.enable = mkDefault true;
|
2025-03-10 18:29:45 +03:00
|
|
|
ataraxia.defaults.lix.enable = mkDefault true;
|
|
|
|
ataraxia.defaults.nix.enable = mkDefault true;
|
2025-03-10 18:30:20 +03:00
|
|
|
ataraxia.defaults.ssh.enable = mkDefault true;
|
2025-03-10 18:31:24 +03:00
|
|
|
ataraxia.defaults.users.enable = mkDefault true;
|
2025-03-10 18:29:45 +03:00
|
|
|
|
2025-06-07 17:46:05 +03:00
|
|
|
programs.nix-index.enable = mkDefault true;
|
|
|
|
programs.nix-index-database.comma.enable = mkDefault true;
|
|
|
|
|
2025-03-10 18:29:45 +03:00
|
|
|
persist.enable = mkDefault true;
|
2025-06-07 17:35:07 +03:00
|
|
|
persist.cache.clean.enable = mkDefault true;
|
2025-03-10 18:29:45 +03:00
|
|
|
|
2025-03-10 18:43:40 +03:00
|
|
|
# Do not compress journal logs if using native fs compression
|
|
|
|
services.journald.extraConfig = mkIf fsCompression (mkDefault "Compress=false");
|
2025-06-07 17:50:08 +03:00
|
|
|
services.speechd.enable = false;
|
2025-03-10 18:43:40 +03:00
|
|
|
|
2025-03-10 18:29:45 +03:00
|
|
|
boot.initrd.systemd.enable = mkDefault true;
|
|
|
|
services.userborn.enable = mkDefault true;
|
|
|
|
system.rebuild.enableNg = mkDefault true;
|
|
|
|
system.switch.enableNg = mkDefault true;
|
2025-07-04 18:17:48 +03:00
|
|
|
system.etc.overlay.enable = mkDefault false;
|
2025-03-10 18:29:45 +03:00
|
|
|
system.etc.overlay.mutable = mkDefault true;
|
|
|
|
|
2025-06-07 17:50:08 +03:00
|
|
|
systemd.services.systemd-timesyncd.wantedBy = [
|
|
|
|
"multi-user.target"
|
|
|
|
];
|
|
|
|
systemd.timers.systemd-timesyncd = {
|
|
|
|
timerConfig.OnCalendar = "hourly";
|
|
|
|
};
|
|
|
|
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
git
|
|
|
|
];
|
|
|
|
|
2025-03-10 18:29:45 +03:00
|
|
|
zramSwap = {
|
|
|
|
enable = true;
|
|
|
|
algorithm = "zstd";
|
2025-06-07 17:35:07 +03:00
|
|
|
priority = mkDefault 100;
|
|
|
|
memoryPercent = mkDefault 50;
|
2025-03-10 18:29:45 +03:00
|
|
|
};
|
|
|
|
};
|
|
|
|
serverRole = recursiveUpdate baseRole {
|
2025-03-10 18:34:03 +03:00
|
|
|
ataraxia.profiles.hardened = mkDefault true;
|
2025-03-10 18:32:18 +03:00
|
|
|
ataraxia.profiles.minimal = mkDefault true;
|
2025-07-04 15:06:12 +03:00
|
|
|
ataraxia.virtualisation.podman = mkDefault true;
|
|
|
|
ataraxia.virtualisation.libvirt = mkDefault true;
|
2025-07-08 20:12:36 +03:00
|
|
|
virtualisation.quadlet.enable = mkDefault true;
|
2025-03-10 18:32:18 +03:00
|
|
|
|
2025-07-04 15:07:56 +03:00
|
|
|
boot.supportedFilesystems = [ "nfs" ];
|
|
|
|
|
2025-03-10 18:29:45 +03:00
|
|
|
time.timeZone = "Etc/UTC";
|
2025-06-07 17:50:08 +03:00
|
|
|
zramSwap.memoryPercent = 100;
|
2025-03-10 18:29:45 +03:00
|
|
|
};
|
|
|
|
desktopRole = recursiveUpdate baseRole {
|
2025-06-07 17:33:23 +03:00
|
|
|
ataraxia.defaults.hardware.graphics = mkDefault true;
|
2025-06-07 17:31:28 +03:00
|
|
|
ataraxia.defaults.sound.enable = mkDefault true;
|
2025-06-07 21:06:41 +03:00
|
|
|
ataraxia.wayland.enable = mkDefault true;
|
|
|
|
ataraxia.wayland.hyprland.enable = mkDefault true;
|
|
|
|
|
2025-07-04 15:06:12 +03:00
|
|
|
programs.virt-manager.enable = config.ataraxia.virtualisation.libvirt;
|
|
|
|
|
2025-07-04 15:07:56 +03:00
|
|
|
boot.supportedFilesystems = [ "nfs" ];
|
|
|
|
|
2025-07-04 15:10:49 +03:00
|
|
|
# Fix some icon cache problems
|
|
|
|
programs.gdk-pixbuf.modulePackages = with pkgs; [ librsvg ];
|
2025-06-07 21:29:52 +03:00
|
|
|
services.gvfs.enable = mkDefault true;
|
2025-06-07 17:50:08 +03:00
|
|
|
services.getty.autologinUser = mkDefault defaultUser;
|
|
|
|
|
2025-03-10 18:29:45 +03:00
|
|
|
location = {
|
|
|
|
provider = "manual";
|
|
|
|
latitude = 48;
|
|
|
|
longitude = 44;
|
|
|
|
};
|
2025-06-07 17:50:08 +03:00
|
|
|
|
|
|
|
zramSwap.memoryPercent = 150;
|
2025-03-10 18:29:45 +03:00
|
|
|
};
|
2025-07-08 15:40:31 +03:00
|
|
|
laptopRole = recursiveUpdate desktopRole {
|
|
|
|
programs.light = {
|
|
|
|
enable = true;
|
|
|
|
brightnessKeys.enable = true;
|
|
|
|
# Allow dark screen
|
|
|
|
brightnessKeys.minBrightness = 0;
|
|
|
|
brightnessKeys.step = 10;
|
|
|
|
};
|
|
|
|
};
|
2025-03-10 18:29:45 +03:00
|
|
|
in
|
|
|
|
mkMerge [
|
|
|
|
(mkIf (role == "base") baseRole)
|
|
|
|
(mkIf (role == "server") serverRole)
|
|
|
|
(mkIf (role == "desktop") desktopRole)
|
2025-07-08 15:40:31 +03:00
|
|
|
(mkIf (role == "laptop") laptopRole)
|
2025-03-10 18:29:45 +03:00
|
|
|
];
|
2025-03-02 14:36:53 +03:00
|
|
|
}
|