{ config, lib, pkgs, ... }: with lib; { imports = attrValues (modulesIn ./.); nixfiles.modules = { ark.enable = true; wireguard.client.enable = true; wireguard-ng.client.enable = false; syncthing.enable = true; openssh.server = { enable = true; port = 22; }; android.enable = true; beets.enable = true; bluetooth.enable = true; libvirtd.enable = true; mpd.enable = true; qutebrowser.enable = true; hyprland.enable = true; }; hm = { home.packages = with pkgs; [ calibre inkscape krita paper-plane qolibri radeontop rocmPackages.rocm-smi vial wacomtablet ]; programs = { beets.settings.directory = mkForce "/mnt/udata/music"; mpv = { profiles = let mapShaders = map (args: toString (pkgs.fetchurl args)); cfl-prediction = mapShaders [ { url = "https://raw.githubusercontent.com/Artoriuz/glsl-chroma-from-luma-prediction/9fdd0bc68cd8ae42a8072a7d5d098f118daa4293/CfL_Prediction.glsl"; sha256 = "sha256-RK3baWkL0mZwcx+utsHfiiX1mY1jxEOg7/kNsNJvEPc="; } ]; ravu-lite-ar-r4 = mapShaders [ { url = "https://raw.githubusercontent.com/bjin/mpv-prescalers/b3f0a59d68f33b7162051ea5970a5169558f0ea2/compute/ravu-lite-ar-r4.hook"; sha256 = "sha256-gyBAv/Sf75CobVUugeTOhy54B9z8iIoJSJgnLopfMsY="; } ]; ssimdownscaler = mapShaders [ { url = "https://gist.githubusercontent.com/igv/36508af3ffc84410fe39761d6969be10/raw/38992bce7f9ff844f800820df0908692b65bb74a/SSimDownscaler.glsl"; sha256 = "sha256-9G9HEKFi0XBYudgu2GEFiLDATXvgfO9r8qjEB3go+AQ="; } ]; in { # TODO Fix profile conditionals. "qhd-downscale" = { dscale = "lanczos"; linear-downscaling = false; glsl-shaders-append = ssimdownscaler; }; "qhd-upscale" = { glsl-shaders-append = cfl-prediction ++ ravu-lite-ar-r4; }; }; config = { profile = "gpu-hq"; vo = "gpu-next"; gpu-api = "vulkan"; hwdec = "auto"; deband = true; deband-iterations = 4; deband-threshold = 35; deband-range = 16; deband-grain = 5; temporal-dither = true; dither-depth = "auto"; dither = "fruit"; interpolation = true; video-sync = "display-resample"; tscale = "oversample"; target-prim = "auto"; target-trc = "auto"; vf = "format=colorlevels=full:colormatrix=auto"; video-output-levels = "full"; glsl-shaders-append = map (text: toString (pkgs.writeText "shader.hook" text)) [ '' //!HOOK LUMA //!BIND HOOKED #define STRENGTH 48.0 float mod289(float x) { return x - floor(x / 289.0) * 289.0; } float permute(float x) { return mod289((34.0*x + 1.0) * x); } float rand(float x) { return fract(x / 41.0); } vec4 hook() { vec3 _m = vec3(HOOKED_pos, 1.0) + vec3(1.0); float h = permute(permute(permute(_m.x)+_m.y)+_m.z); vec4 noise; noise.x = rand(h); return HOOKED_tex(HOOKED_pos) + vec4(STRENGTH/8192.0) * (noise - 0.5); } '' '' //!HOOK CHROMA //!BIND HOOKED #define STRENGTH 48.0 float mod289(float x) { return x - floor(x / 289.0) * 289.0; } float permute(float x) { return mod289((34.0*x + 1.0) * x); } float rand(float x) { return fract(x / 41.0); } vec4 hook() { vec3 _m = vec3(HOOKED_pos, 0.5) + vec3(1.0); float h = permute(permute(permute(_m.x)+_m.y)+_m.z); vec4 noise; noise.x = rand(h); h = permute(h); noise.y = rand(h); return HOOKED_tex(HOOKED_pos) + vec4(STRENGTH/8192.0) * (noise - 0.5); } '' ]; }; }; }; services = { mpd.musicDirectory = mkForce "/mnt/udata/music"; xsettingsd.settings."Xft/DPI" = "93"; }; }; programs.corectrl.enable = true; services = { displayManager = { sddm.enable = lib.mkForce false; ly = { enable = true; settings.animation = "matrix"; }; }; smartd = { enable = true; notifications.mail = { enable = true; sender = "admin+smartd@${my.domain.shire}"; recipient = "admin+smartd@${my.domain.shire}"; }; }; openssh.settings = { KbdInteractiveAuthentication = mkForce true; PasswordAuthentication = mkForce true; }; udev.packages = with pkgs; [ vial ]; xserver.wacom.enable = true; }; nix.settings = { max-jobs = 8; cores = 30; }; boot = { # The boot drive is Samsung SSD 980 PRO 2TB. initrd.kernelModules = [ "nvme" ]; # These pools were configured manually with a specific mountpoint. zfs.extraPools = [ "udata" "vdata" ]; }; # Filesystem creation: # ``` # mkfs.vfat -F 32 -l nixos-boot /dev/nvmeXnYpZ # # zpool create # -o ashift=12 # -o autotrim=on # -O acltype=posixacl # -O xattr=sa # -O compression=zstd # -O mountpoint=none # nixos # /dev/nvmeXnYpZ # # zfs create # nixos/root # # zfs create # -o encryption=aes-256-gcm # -o keyformat=passphrase # -o mountpoint=legacy # nixos/root/ark # # zfs create # -o mountpoint=legacy # nixos/root/nix # ``` # # physical structure (backside): # [ 1 ] [ 2 ] [ 3 ] # 1: disk/by-id/ata-WDC_WD20SPZX-22UA7T0_WD-WXP2E3163YW6 # 2: disk/by-id/ata-WDC_WD20SPZX-22UA7T0_WD-WXN2E312R5HP # 3: disk/by-id/ata-WDC_WD20SPZX-22UA7T0_WD-WXP2E311E6P2 # # physical structure (mobo M.2): # [ 1 ] # [ 2 ] # 1: disk/by-id/nvme-Samsung_SSD_980_PRO_2TB_S69ENF0R872526A # 2: disk/by-id/nvme-Samsung_SSD_980_PRO_2TB_S69ENX0T807723X fileSystems = { "/" = { device = "none"; fsType = "tmpfs"; options = [ "size=8G" "mode=755" ]; }; "/boot" = { device = "/dev/disk/by-uuid/1363-02E6"; fsType = "vfat"; }; "/nix" = { device = "nixos/root/nix"; fsType = "zfs"; options = [ "noatime" ]; }; ${config.ark.path} = { device = "nixos/root/ark"; fsType = "zfs"; neededForBoot = true; # Required by impermanence. }; # Required[1] when using impermanence with agenix. Filesystem itself is # defined as an `ark.directory` in `nixos/common/users.nix`. # # [1]: https://github.com/ryantm/agenix/issues/45#issuecomment-847852593 # [1]: https://github.com/nix-community/impermanence/issues/22 # [1]: https://github.com/NixOS/nixpkgs/pull/86967#pullrequestreview-667929259 "/home/${my.username}".neededForBoot = true; "/mnt/ydata/music" = { device = "yavanna.shire.net:/export/music"; fsType = "nfs"; options = [ "ro" "noauto" "x-systemd.automount" "x-systemd.idle-timeout=${5 * 60 |> toString}" ]; }; "/mnt/ydata/rtorrent" = { device = "yavanna.shire.net:/export/rtorrent"; fsType = "nfs"; options = [ "ro" "noauto" "x-systemd.automount" "x-systemd.idle-timeout=${5 * 60 |> toString}" ]; }; }; zramSwap = { enable = true; memoryPercent = 50; }; my.extraGroups = [ "corectrl" config.nixfiles.modules.piracy.group ]; users = { users.builder = { isSystemUser = true; group = "builder"; openssh.authorizedKeys.keys = [ "ssh-ed25519 @PUBLIC_KEY@ root@ilmare" ]; useDefaultShell = true; }; groups = { builder = { }; piracy = { inherit (config.nixfiles.modules.piracy) gid; }; }; }; nix.settings.trusted-users = [ "builder" ]; # https://cl.tvl.fyi/c/depot/+/12961 systemd.services = let override.environment.SYSTEMD_SLEEP_FREEZE_USER_SESSIONS = "false"; in { systemd-suspend = override; systemd-hibernate = override; systemd-hybrid-sleep = override; systemd-suspend-then-hibernate = override; }; }