2024-02-05 11:46:52 +01:00
|
|
|
|
{
|
|
|
|
|
nixos-hardware,
|
|
|
|
|
...
|
|
|
|
|
}:
|
2023-08-03 10:38:54 +02:00
|
|
|
|
{ pkgs, config, ... }:
|
2022-11-11 11:54:21 +01:00
|
|
|
|
{
|
2024-02-05 11:46:52 +01:00
|
|
|
|
imports = [
|
|
|
|
|
# Include the results of the hardware scan.
|
|
|
|
|
nixos-hardware.nixosModules.common-cpu-amd
|
|
|
|
|
nixos-hardware.nixosModules.common-cpu-amd-pstate
|
|
|
|
|
nixos-hardware.nixosModules.common-pc-ssd
|
|
|
|
|
|
|
|
|
|
../../users/erwin
|
|
|
|
|
../../users/root
|
|
|
|
|
];
|
2022-11-11 11:54:21 +01:00
|
|
|
|
|
2022-11-11 17:07:24 +01:00
|
|
|
|
# nixpkgs.config.allowUnfree = true;
|
2024-07-28 20:49:24 +02:00
|
|
|
|
nixpkgs.config = {
|
|
|
|
|
cudaSupport = true;
|
|
|
|
|
};
|
2022-11-11 12:51:48 +01:00
|
|
|
|
|
2022-11-11 11:54:21 +01:00
|
|
|
|
eboskma = {
|
2022-11-14 18:49:06 +01:00
|
|
|
|
var.workSystem = true;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
users = {
|
|
|
|
|
erwin = {
|
|
|
|
|
enable = true;
|
|
|
|
|
work = true;
|
2022-11-11 12:51:48 +01:00
|
|
|
|
terminal = "Alacritty";
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
base = {
|
|
|
|
|
plymouth.enable = true;
|
|
|
|
|
work = true;
|
2024-10-16 08:53:46 +02:00
|
|
|
|
udev-rules = {
|
|
|
|
|
nvidia = true;
|
|
|
|
|
};
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
desktop = {
|
|
|
|
|
enable = true;
|
2023-09-29 11:52:45 +02:00
|
|
|
|
wayland = true;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
2023-12-20 11:25:45 +01:00
|
|
|
|
podman = {
|
2022-12-09 10:40:13 +01:00
|
|
|
|
enable = true;
|
|
|
|
|
enableNvidia = true;
|
2023-03-10 12:57:16 +01:00
|
|
|
|
# enableTcpSocket = true;
|
2022-12-09 10:40:13 +01:00
|
|
|
|
};
|
2022-11-11 11:54:21 +01:00
|
|
|
|
fonts.enable = true;
|
|
|
|
|
gnome.enable = true;
|
2023-09-29 11:52:45 +02:00
|
|
|
|
greetd = {
|
2024-06-12 17:00:07 +02:00
|
|
|
|
enable = true;
|
2023-09-29 11:52:45 +02:00
|
|
|
|
sway = true;
|
|
|
|
|
wayvnc = true;
|
2023-10-05 14:58:46 +02:00
|
|
|
|
wallpaper = ../../wallpapers/river-3840.png;
|
2023-11-30 11:50:10 +01:00
|
|
|
|
output = {
|
|
|
|
|
"DP-1" = {
|
|
|
|
|
bg = "${../../wallpapers/river-3840.png} fill";
|
|
|
|
|
mode = "3840x2160@60Hz";
|
|
|
|
|
position = "0 0";
|
|
|
|
|
};
|
|
|
|
|
"DP-3" = {
|
|
|
|
|
bg = "${../../wallpapers/river-3840.png} fill";
|
|
|
|
|
mode = "3840x2160@60Hz";
|
|
|
|
|
position = "3840 0";
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
input = {
|
|
|
|
|
"1241:662:USB-HID_Keyboard" = {
|
2024-04-05 13:15:40 +02:00
|
|
|
|
xkb_layout = "us,us";
|
|
|
|
|
xkb_variant = "colemak,";
|
|
|
|
|
xkb_options = "lv3:ralt_switch,eurosign:5,caps:backspace,ctrl:nocaps,grp:sclk_toggle,grp_led:scroll";
|
2023-11-30 11:50:10 +01:00
|
|
|
|
xkb_numlock = "enabled";
|
|
|
|
|
};
|
|
|
|
|
"1133:49257:Logitech_USB_Laser_Mouse" = {
|
|
|
|
|
natural_scroll = "enabled";
|
|
|
|
|
pointer_accel = "1";
|
|
|
|
|
};
|
|
|
|
|
};
|
2023-09-29 11:52:45 +02:00
|
|
|
|
};
|
2023-05-17 08:06:05 +02:00
|
|
|
|
kanata = {
|
2023-12-08 16:39:57 +01:00
|
|
|
|
enable = true;
|
2024-02-05 11:46:52 +01:00
|
|
|
|
devices = [ "/dev/input/by-id/usb-04d9_USB-HID_Keyboard-event-kbd" ];
|
2023-05-17 08:06:05 +02:00
|
|
|
|
};
|
2023-09-29 11:52:45 +02:00
|
|
|
|
lightdm.enable = false;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
networking.enable = true;
|
2022-12-09 10:40:13 +01:00
|
|
|
|
nix-common = {
|
|
|
|
|
enable = true;
|
|
|
|
|
cross-systems = [ "aarch64-linux" ];
|
2024-07-18 10:47:15 +02:00
|
|
|
|
gc-interval = "weekly";
|
2022-12-09 10:40:13 +01:00
|
|
|
|
};
|
2024-06-08 16:03:24 +02:00
|
|
|
|
regreet = {
|
2024-06-12 17:00:07 +02:00
|
|
|
|
enable = false;
|
2024-06-08 16:03:24 +02:00
|
|
|
|
wallpaper = ../../wallpapers/river-3840.png;
|
|
|
|
|
wayvnc = true;
|
|
|
|
|
};
|
2022-11-11 11:54:21 +01:00
|
|
|
|
sound.enable = true;
|
|
|
|
|
systemd.enable = true;
|
2023-12-20 11:34:47 +01:00
|
|
|
|
tailscale.enable = true;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
fileSystems = {
|
|
|
|
|
"/" = {
|
|
|
|
|
device = "/dev/disk/by-label/nixos";
|
|
|
|
|
fsType = "ext4";
|
|
|
|
|
};
|
2023-08-03 10:38:54 +02:00
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
"/boot" = {
|
|
|
|
|
device = "/dev/disk/by-label/boot";
|
|
|
|
|
fsType = "vfat";
|
|
|
|
|
};
|
2023-08-03 10:38:54 +02:00
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
"/home" = {
|
|
|
|
|
device = "/dev/disk/by-label/home";
|
|
|
|
|
fsType = "ext4";
|
|
|
|
|
};
|
2023-08-03 10:38:54 +02:00
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
"/yocto" = {
|
|
|
|
|
device = "/dev/disk/by-label/yocto";
|
|
|
|
|
fsType = "ext4";
|
|
|
|
|
};
|
2024-12-13 11:12:16 +01:00
|
|
|
|
|
|
|
|
|
"/mnt/horus/Public" = {
|
|
|
|
|
device = "//horusnas1/Horusdata/Public";
|
|
|
|
|
fsType = "cifs";
|
|
|
|
|
options =
|
|
|
|
|
let
|
|
|
|
|
automount_opts = "x-systemd.automount,noauto,x-systemd.idle-timeout=60,x-systemd.device-timeout=5s,x-systemd.mount-timeout=5s";
|
|
|
|
|
in
|
|
|
|
|
[
|
|
|
|
|
"${automount_opts},credentials=/etc/nixos/smb-secrets"
|
|
|
|
|
"uid=1000"
|
|
|
|
|
"gid=500"
|
|
|
|
|
];
|
|
|
|
|
};
|
2023-08-03 10:38:54 +02:00
|
|
|
|
};
|
|
|
|
|
|
2024-02-05 11:46:52 +01:00
|
|
|
|
swapDevices = [ { device = "/dev/disk/by-label/swap"; } ];
|
2023-08-03 10:38:54 +02:00
|
|
|
|
|
|
|
|
|
hardware = {
|
|
|
|
|
enableAllFirmware = true;
|
|
|
|
|
nvidia = {
|
2024-08-28 16:55:35 +02:00
|
|
|
|
open = false;
|
2023-08-03 10:38:54 +02:00
|
|
|
|
modesetting.enable = true;
|
2024-05-17 22:27:46 +02:00
|
|
|
|
powerManagement.enable = true; # Needed to make hibernate work properly
|
|
|
|
|
forceFullCompositionPipeline = true;
|
2023-08-03 10:38:54 +02:00
|
|
|
|
};
|
|
|
|
|
|
2024-06-24 14:26:50 +02:00
|
|
|
|
graphics = {
|
|
|
|
|
enable32Bit = true;
|
2024-05-17 22:27:46 +02:00
|
|
|
|
extraPackages = with pkgs; [
|
|
|
|
|
vaapiVdpau
|
|
|
|
|
vulkan-validation-layers
|
|
|
|
|
];
|
2023-08-03 10:38:54 +02:00
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2022-11-11 11:54:21 +01:00
|
|
|
|
# Use the systemd-boot EFI boot loader.
|
2023-05-25 08:01:53 +02:00
|
|
|
|
boot = {
|
2023-08-03 10:38:54 +02:00
|
|
|
|
initrd = {
|
2024-02-05 11:46:52 +01:00
|
|
|
|
availableKernelModules = [
|
|
|
|
|
"nvme"
|
|
|
|
|
"xhci_pci"
|
|
|
|
|
"ahci"
|
|
|
|
|
"usb_storage"
|
|
|
|
|
"usbhid"
|
|
|
|
|
"sd_mod"
|
|
|
|
|
];
|
2023-08-03 10:38:54 +02:00
|
|
|
|
kernelModules = [ "dm-snapshot" ];
|
|
|
|
|
};
|
2024-10-02 12:12:44 +02:00
|
|
|
|
|
|
|
|
|
# NVIDIA driver is broken with Linux 6.11
|
2024-11-06 09:41:47 +01:00
|
|
|
|
# kernelPackages = pkgs.linuxPackages_latest;
|
2024-02-05 11:46:52 +01:00
|
|
|
|
kernelModules = [
|
|
|
|
|
"kvm-amd"
|
|
|
|
|
"apple-mfi-fastcharge"
|
|
|
|
|
"zenpower"
|
|
|
|
|
];
|
2024-10-02 12:12:44 +02:00
|
|
|
|
blacklistedKernelModules = [
|
|
|
|
|
"k10temp"
|
|
|
|
|
];
|
2024-02-05 11:46:52 +01:00
|
|
|
|
extraModulePackages = with config.boot.kernelPackages; [
|
|
|
|
|
cpupower
|
2024-10-02 12:12:44 +02:00
|
|
|
|
zenpower
|
2024-02-05 11:46:52 +01:00
|
|
|
|
];
|
2024-10-02 12:12:44 +02:00
|
|
|
|
|
2023-05-25 08:01:53 +02:00
|
|
|
|
loader = {
|
|
|
|
|
systemd-boot = {
|
|
|
|
|
enable = true;
|
|
|
|
|
configurationLimit = 15;
|
|
|
|
|
};
|
|
|
|
|
efi.canTouchEfiVariables = true;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
2023-09-29 11:52:45 +02:00
|
|
|
|
# This triggers a warning on stateVersions < 23.11 if set to true
|
|
|
|
|
swraid.enable = false;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
time.timeZone = "Europe/Amsterdam";
|
|
|
|
|
|
2023-09-29 11:52:45 +02:00
|
|
|
|
console = {
|
|
|
|
|
font = "${pkgs.terminus_font}/share/consolefonts/ter-u28n.psf.gz";
|
|
|
|
|
useXkbConfig = true;
|
|
|
|
|
};
|
2022-11-11 17:07:24 +01:00
|
|
|
|
|
2024-09-16 10:36:04 +02:00
|
|
|
|
# Enable new implementation of switch-to-configuration built in Rust
|
|
|
|
|
system = {
|
|
|
|
|
switch = {
|
|
|
|
|
enable = false;
|
|
|
|
|
enableNg = true;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2022-11-11 11:54:21 +01:00
|
|
|
|
networking = {
|
|
|
|
|
hostName = "mimir";
|
|
|
|
|
useDHCP = false;
|
2023-04-21 11:20:56 +02:00
|
|
|
|
networkmanager.enable = false;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
useNetworkd = true;
|
|
|
|
|
|
2023-12-20 11:46:13 +01:00
|
|
|
|
nftables.enable = true;
|
|
|
|
|
|
2022-11-11 11:54:21 +01:00
|
|
|
|
firewall = {
|
2024-02-05 11:46:52 +01:00
|
|
|
|
trustedInterfaces = [
|
|
|
|
|
"tailscale0"
|
2024-10-18 19:41:34 +02:00
|
|
|
|
"enp5s0f1"
|
2024-02-05 11:46:52 +01:00
|
|
|
|
];
|
2022-11-11 11:54:21 +01:00
|
|
|
|
|
|
|
|
|
allowedTCPPorts = [
|
|
|
|
|
# Horus System V2
|
|
|
|
|
12345
|
|
|
|
|
5555
|
|
|
|
|
5556
|
2022-12-09 10:40:13 +01:00
|
|
|
|
|
|
|
|
|
# sccache server
|
|
|
|
|
10501
|
2022-12-22 11:35:17 +01:00
|
|
|
|
|
|
|
|
|
# Celantur
|
|
|
|
|
7000
|
2022-11-11 11:54:21 +01:00
|
|
|
|
];
|
|
|
|
|
};
|
2023-01-27 15:36:05 +01:00
|
|
|
|
|
|
|
|
|
nat = {
|
|
|
|
|
enable = true;
|
|
|
|
|
externalInterface = "enp4s0";
|
|
|
|
|
};
|
2024-02-23 11:33:18 +01:00
|
|
|
|
|
|
|
|
|
wireless.iwd = {
|
|
|
|
|
enable = true;
|
|
|
|
|
settings = {
|
|
|
|
|
General = {
|
|
|
|
|
EnableNetworkConfiguration = true;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
|
|
|
|
|
2023-01-31 17:20:23 +01:00
|
|
|
|
powerManagement = {
|
|
|
|
|
cpuFreqGovernor = "ondemand";
|
|
|
|
|
};
|
|
|
|
|
|
2023-11-20 17:03:05 +01:00
|
|
|
|
security = {
|
|
|
|
|
sudo.enable = false;
|
|
|
|
|
sudo-rs.enable = true;
|
2023-12-20 11:46:59 +01:00
|
|
|
|
|
|
|
|
|
apparmor = {
|
|
|
|
|
enable = true;
|
|
|
|
|
};
|
2024-03-26 15:06:20 +01:00
|
|
|
|
pam.services.swaylock = {
|
|
|
|
|
unixAuth = true;
|
|
|
|
|
setLoginUid = true;
|
|
|
|
|
enableGnomeKeyring = true;
|
|
|
|
|
allowNullPassword = true;
|
|
|
|
|
updateWtmp = true;
|
|
|
|
|
startSession = true;
|
|
|
|
|
};
|
2023-11-20 17:03:05 +01:00
|
|
|
|
};
|
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
systemd = {
|
|
|
|
|
network = {
|
|
|
|
|
enable = true;
|
2022-11-11 17:07:24 +01:00
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
# wait-online.extraArgs = [ "--interface=enp4s0" ];
|
|
|
|
|
wait-online.anyInterface = true;
|
|
|
|
|
|
|
|
|
|
links = {
|
|
|
|
|
"40-enp4s0" = {
|
|
|
|
|
matchConfig = {
|
|
|
|
|
Name = "enp4s0";
|
|
|
|
|
};
|
|
|
|
|
linkConfig = {
|
|
|
|
|
WakeOnLan = "magic";
|
|
|
|
|
};
|
2023-02-13 08:27:46 +01:00
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2024-12-09 09:45:11 +01:00
|
|
|
|
netdevs = {
|
|
|
|
|
"11-horus1" = {
|
|
|
|
|
netdevConfig = {
|
|
|
|
|
Kind = "wireguard";
|
|
|
|
|
MTUBytes = "1420";
|
|
|
|
|
Name = "horus1";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
wireguardConfig = {
|
|
|
|
|
PrivateKeyFile = config.sops.secrets.wireguard-horus1-privkey.path;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
wireguardPeers = [
|
|
|
|
|
{
|
|
|
|
|
PublicKey = "UZGk9xoXhpHwM6jDWQvYDgJKk/OfcX9gw4iM9bPJJ00=";
|
|
|
|
|
AllowedIPs = [
|
|
|
|
|
"10.128.0.0/23"
|
|
|
|
|
];
|
2024-12-06 11:38:52 +01:00
|
|
|
|
Endpoint = "212.45.34.195:51822";
|
2024-12-09 09:45:11 +01:00
|
|
|
|
PersistentKeepalive = 25;
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
networks = {
|
|
|
|
|
"40-enp4s0" = {
|
|
|
|
|
enable = true;
|
|
|
|
|
DHCP = "yes";
|
2022-11-11 23:32:29 +01:00
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
domains = [
|
|
|
|
|
"internal.horus.nu"
|
|
|
|
|
"bedum.horus.nu"
|
|
|
|
|
];
|
2023-05-23 17:12:31 +02:00
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
dhcpV4Config = {
|
|
|
|
|
RouteMetric = 64;
|
|
|
|
|
};
|
2024-03-22 09:42:37 +01:00
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
matchConfig = {
|
|
|
|
|
Name = "enp4s0";
|
|
|
|
|
};
|
2022-11-11 23:32:29 +01:00
|
|
|
|
};
|
2022-11-11 17:07:24 +01:00
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
"40-enp5s0f1" = {
|
|
|
|
|
enable = true;
|
|
|
|
|
linkConfig = {
|
|
|
|
|
RequiredForOnline = "no";
|
|
|
|
|
};
|
|
|
|
|
matchConfig = {
|
|
|
|
|
Name = "enp5s0f1";
|
|
|
|
|
};
|
2023-01-27 15:36:05 +01:00
|
|
|
|
|
2024-12-18 19:29:04 +01:00
|
|
|
|
networkConfig = {
|
|
|
|
|
DHCP = "yes";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
# addresses = [
|
|
|
|
|
# { Address = "192.168.42.10/24"; }
|
|
|
|
|
# ];
|
2024-09-18 16:16:19 +02:00
|
|
|
|
};
|
2024-12-09 09:45:11 +01:00
|
|
|
|
"41-horus1" = {
|
|
|
|
|
matchConfig = {
|
|
|
|
|
Name = "horus1";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
linkConfig = {
|
|
|
|
|
ActivationPolicy = "manual";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
networkConfig = {
|
|
|
|
|
DHCP = "no";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
address = [ "10.128.0.2/23" ];
|
|
|
|
|
};
|
2023-01-27 15:36:05 +01:00
|
|
|
|
};
|
2024-09-18 16:16:19 +02:00
|
|
|
|
};
|
2023-01-27 15:36:05 +01:00
|
|
|
|
|
2024-09-18 16:16:19 +02:00
|
|
|
|
services = {
|
|
|
|
|
ollama = {
|
|
|
|
|
after = [ "tailscaled.service" ];
|
|
|
|
|
preStart = "${pkgs.coreutils}/bin/sleep 10"; # Tailscale reports ready before getting an IP address
|
2023-01-27 15:36:05 +01:00
|
|
|
|
};
|
2022-11-11 11:54:21 +01:00
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2023-06-23 14:15:11 +02:00
|
|
|
|
# programs.ssh.startAgent = true;
|
2023-09-29 11:52:45 +02:00
|
|
|
|
programs = {
|
2024-03-26 15:06:20 +01:00
|
|
|
|
sway = {
|
|
|
|
|
enable = true;
|
|
|
|
|
wrapperFeatures = {
|
|
|
|
|
gtk = true;
|
|
|
|
|
base = true;
|
|
|
|
|
};
|
|
|
|
|
extraPackages = with pkgs; [
|
|
|
|
|
swaylock
|
|
|
|
|
swayidle
|
|
|
|
|
];
|
2024-06-08 16:03:24 +02:00
|
|
|
|
extraOptions = [ "--unsupported-gpu" ];
|
2024-03-26 15:06:20 +01:00
|
|
|
|
};
|
2023-09-29 11:52:45 +02:00
|
|
|
|
gnome-disks.enable = true;
|
2023-12-08 16:39:57 +01:00
|
|
|
|
nix-ld = {
|
|
|
|
|
enable = true;
|
|
|
|
|
libraries = with pkgs; [
|
|
|
|
|
alsa-lib
|
|
|
|
|
at-spi2-atk
|
|
|
|
|
at-spi2-core
|
|
|
|
|
atk
|
|
|
|
|
cairo
|
|
|
|
|
cups
|
|
|
|
|
curl
|
|
|
|
|
dbus
|
|
|
|
|
expat
|
|
|
|
|
fontconfig
|
|
|
|
|
freetype
|
|
|
|
|
fuse3
|
|
|
|
|
gdk-pixbuf
|
|
|
|
|
glib
|
|
|
|
|
gtk3
|
|
|
|
|
icu
|
|
|
|
|
libGL
|
|
|
|
|
libappindicator-gtk3
|
|
|
|
|
libdrm
|
|
|
|
|
libglvnd
|
|
|
|
|
libnotify
|
|
|
|
|
libpulseaudio
|
|
|
|
|
libunwind
|
|
|
|
|
libusb1
|
|
|
|
|
libuuid
|
|
|
|
|
libxkbcommon
|
|
|
|
|
mesa
|
|
|
|
|
nspr
|
|
|
|
|
nss
|
|
|
|
|
openssl
|
|
|
|
|
pango
|
|
|
|
|
pipewire
|
|
|
|
|
stdenv.cc.cc
|
|
|
|
|
systemd
|
|
|
|
|
vulkan-loader
|
|
|
|
|
xorg.libX11
|
|
|
|
|
xorg.libXScrnSaver
|
|
|
|
|
xorg.libXcomposite
|
|
|
|
|
xorg.libXcursor
|
|
|
|
|
xorg.libXdamage
|
|
|
|
|
xorg.libXext
|
|
|
|
|
xorg.libXfixes
|
|
|
|
|
xorg.libXi
|
|
|
|
|
xorg.libXrandr
|
|
|
|
|
xorg.libXrender
|
|
|
|
|
xorg.libXtst
|
|
|
|
|
xorg.libxcb
|
|
|
|
|
xorg.libxkbfile
|
|
|
|
|
xorg.libxshmfence
|
|
|
|
|
zlib
|
|
|
|
|
];
|
|
|
|
|
};
|
2023-09-29 11:52:45 +02:00
|
|
|
|
};
|
2022-11-11 11:54:21 +01:00
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
services = {
|
|
|
|
|
openssh.enable = true;
|
2023-01-26 11:36:08 +01:00
|
|
|
|
|
2024-12-06 11:38:52 +01:00
|
|
|
|
envfs.enable = false;
|
2023-09-13 14:50:03 +02:00
|
|
|
|
cpupower-gui.enable = true;
|
|
|
|
|
flatpak.enable = true;
|
2023-04-13 08:38:40 +02:00
|
|
|
|
|
2023-10-05 14:58:46 +02:00
|
|
|
|
teamviewer.enable = true;
|
2023-08-03 10:38:54 +02:00
|
|
|
|
|
2024-01-18 09:44:48 +01:00
|
|
|
|
ddccontrol.enable = true;
|
|
|
|
|
|
2023-09-29 11:52:45 +02:00
|
|
|
|
udisks2 = {
|
|
|
|
|
enable = true;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
udev = {
|
|
|
|
|
extraRules = ''
|
|
|
|
|
ACTION=="add", ATTRS{idVendor}=="0781", ATTRS{idProduct}=="55b1", ATTRS{serial}=="A20033BEAC21B773", NAME="vault"
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
xserver = {
|
|
|
|
|
videoDrivers = [ "nvidia" ];
|
2023-08-03 10:38:54 +02:00
|
|
|
|
|
2023-10-09 14:56:16 +02:00
|
|
|
|
# screenSection = ''
|
|
|
|
|
# Option "metamodes" "DP-0: nvidia-auto-select +0+0 {ForceFullCompositionPipeline=On, AllowGSYNCCompatible=On}, DP-4: nvidia-auto-select +3840+0 {ForceFullCompositionPipeline=On, AllowGSYNCCompatible=On}"
|
|
|
|
|
# Option "TripleBuffer" "On"
|
|
|
|
|
# '';
|
|
|
|
|
|
|
|
|
|
# libinput = {
|
|
|
|
|
# enable = true;
|
|
|
|
|
# mouse = {
|
|
|
|
|
# naturalScrolling = true;
|
|
|
|
|
# accelSpeed = "1.0";
|
|
|
|
|
# };
|
|
|
|
|
# touchpad = {
|
|
|
|
|
# naturalScrolling = true;
|
|
|
|
|
# };
|
|
|
|
|
# };
|
2022-11-17 14:06:39 +01:00
|
|
|
|
};
|
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
icecream.daemon = {
|
|
|
|
|
enable = true;
|
2022-12-22 11:34:55 +01:00
|
|
|
|
|
2023-09-13 14:50:03 +02:00
|
|
|
|
schedulerHost = "icecream.internal.horus.nu";
|
|
|
|
|
noRemote = true;
|
|
|
|
|
openFirewall = false;
|
|
|
|
|
openBroadcast = true;
|
|
|
|
|
};
|
2024-09-16 10:31:07 +02:00
|
|
|
|
|
|
|
|
|
ollama = {
|
|
|
|
|
enable = true;
|
|
|
|
|
acceleration = "cuda";
|
|
|
|
|
host = "100.119.162.110";
|
|
|
|
|
loadModels = [
|
|
|
|
|
"mistral"
|
|
|
|
|
];
|
|
|
|
|
};
|
2024-12-18 19:29:04 +01:00
|
|
|
|
plantuml-server = {
|
|
|
|
|
enable = true;
|
|
|
|
|
listenPort = 5080;
|
|
|
|
|
};
|
2022-12-22 11:34:55 +01:00
|
|
|
|
};
|
|
|
|
|
|
2023-09-29 11:52:45 +02:00
|
|
|
|
environment = {
|
2024-02-23 11:33:18 +01:00
|
|
|
|
systemPackages = with pkgs; [
|
|
|
|
|
appimage-run
|
|
|
|
|
iwgtk
|
2024-10-02 09:16:46 +02:00
|
|
|
|
peakperf
|
2024-02-23 11:33:18 +01:00
|
|
|
|
];
|
2023-09-29 11:52:45 +02:00
|
|
|
|
|
|
|
|
|
sessionVariables = {
|
|
|
|
|
WLR_NO_HARDWARE_CURSORS = "1";
|
2024-09-18 16:13:36 +02:00
|
|
|
|
GBM_BACKEND = "nvidia-drm";
|
|
|
|
|
__GLX_VENDOR_LIBRARY_NAME = "nvidia";
|
2023-09-29 11:52:45 +02:00
|
|
|
|
};
|
|
|
|
|
};
|
2023-05-21 17:12:14 +02:00
|
|
|
|
|
2023-11-30 11:50:10 +01:00
|
|
|
|
sops = {
|
|
|
|
|
defaultSopsFile = ./secrets.yaml;
|
2022-11-11 11:54:21 +01:00
|
|
|
|
|
2023-11-30 11:50:10 +01:00
|
|
|
|
secrets = {
|
2024-12-09 09:45:11 +01:00
|
|
|
|
wireguard-horus1-privkey = {
|
|
|
|
|
owner = "systemd-network";
|
|
|
|
|
};
|
2023-11-30 11:50:10 +01:00
|
|
|
|
};
|
|
|
|
|
};
|
2022-11-11 11:54:21 +01:00
|
|
|
|
|
|
|
|
|
# This value determines the NixOS release from which the default
|
|
|
|
|
# settings for stateful data, like file locations and database versions
|
|
|
|
|
# on your system were taken. It‘s perfectly fine and recommended to leave
|
|
|
|
|
# this value at the release version of the first install of this system.
|
|
|
|
|
# Before changing this value read the documentation for this option
|
|
|
|
|
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
|
|
|
|
|
system.stateVersion = "22.11"; # Did you read the comment?
|
|
|
|
|
}
|