2022-08-10 07:41:44 +00:00
|
|
|
{ config, pkgs, ... }:
|
|
|
|
|
2023-03-31 12:17:02 +00:00
|
|
|
let
|
2023-06-18 14:18:01 +00:00
|
|
|
sources = import ./sources.nix;
|
|
|
|
#lanzaboote = import sources.lanzaboote;
|
2023-03-31 12:17:02 +00:00
|
|
|
greetdSwayConfig = pkgs.writeText "greetd-sway-config" ''
|
|
|
|
# `-l` activates layer-shell mode. Notice that `swaymsg exit` will run after gtkgreet.
|
|
|
|
exec "${pkgs.greetd.gtkgreet}/bin/gtkgreet -l -c sway; swaymsg exit"
|
|
|
|
bindsym Mod4+shift+e exec swaynag \
|
|
|
|
-t warning \
|
|
|
|
-m 'What do you want to do?' \
|
|
|
|
-b 'Poweroff' 'systemctl poweroff' \
|
|
|
|
-b 'Reboot' 'systemctl reboot'
|
|
|
|
'';
|
|
|
|
in
|
2022-08-10 07:41:44 +00:00
|
|
|
{
|
|
|
|
imports = [
|
2022-12-17 16:42:55 +00:00
|
|
|
<nixos-hardware/framework/12th-gen-intel>
|
2022-08-10 07:41:44 +00:00
|
|
|
./hardware-configuration.nix
|
2023-06-18 14:18:01 +00:00
|
|
|
#lanzaboote.nixosModules.lanzaboote
|
2023-06-18 23:00:40 +00:00
|
|
|
../common/configuration/main.nix
|
2022-08-10 07:41:44 +00:00
|
|
|
];
|
|
|
|
|
2023-03-31 12:17:02 +00:00
|
|
|
virtualisation = {
|
2023-06-19 15:58:42 +00:00
|
|
|
podman.enable = true;
|
|
|
|
podman.dockerCompat = true;
|
2023-06-18 14:18:01 +00:00
|
|
|
# libvirtd.enable = true;
|
|
|
|
# spiceUSBRedirection.enable = true;
|
2023-03-31 12:17:02 +00:00
|
|
|
};
|
2022-10-04 14:54:07 +00:00
|
|
|
|
2022-08-10 07:41:44 +00:00
|
|
|
hardware = {
|
|
|
|
bluetooth.enable = true;
|
2022-08-12 00:12:03 +00:00
|
|
|
pulseaudio.enable = false;
|
2022-08-10 07:41:44 +00:00
|
|
|
opengl = {
|
|
|
|
enable = true;
|
|
|
|
driSupport32Bit = true;
|
|
|
|
extraPackages = with pkgs; [ intel-media-driver vaapiIntel ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
boot = {
|
2023-06-18 14:18:01 +00:00
|
|
|
#bootspec.enable = false;
|
|
|
|
|
2022-08-10 07:41:44 +00:00
|
|
|
loader = {
|
|
|
|
efi.canTouchEfiVariables = true;
|
|
|
|
|
|
|
|
systemd-boot = {
|
|
|
|
enable = true;
|
|
|
|
consoleMode = "auto";
|
2022-08-20 13:36:29 +00:00
|
|
|
configurationLimit = 10;
|
2022-08-10 07:41:44 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-06-18 14:18:01 +00:00
|
|
|
#lanzaboote = {
|
|
|
|
# enable = false;
|
|
|
|
# pkiBundle = "/etc/secureboot";
|
|
|
|
#};
|
|
|
|
|
2022-08-10 07:41:44 +00:00
|
|
|
kernelPackages = pkgs.linuxPackages_latest;
|
|
|
|
kernelParams = [
|
|
|
|
"quiet"
|
|
|
|
"splash"
|
|
|
|
"vga=current"
|
|
|
|
"udev.log_level=3"
|
2023-06-18 14:18:01 +00:00
|
|
|
"i915.enable_psr=2"
|
2022-08-12 00:12:54 +00:00
|
|
|
"nvme.noacpi=1"
|
2022-12-17 16:42:55 +00:00
|
|
|
"resume=/dev/disk/by-uuid/7e88d61f-5581-45fb-82f1-29a0e0caf4c0"
|
2022-08-10 07:41:44 +00:00
|
|
|
];
|
|
|
|
|
2022-08-10 17:36:57 +00:00
|
|
|
blacklistedKernelModules = [ "hid_sensor_hub" ];
|
|
|
|
|
2022-09-19 21:25:53 +00:00
|
|
|
supportedFilesystems = [ "ntfs" ];
|
|
|
|
|
2022-08-10 07:41:44 +00:00
|
|
|
loader.timeout = 0;
|
|
|
|
initrd.verbose = false;
|
|
|
|
consoleLogLevel = 0;
|
|
|
|
plymouth.enable = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
networking = {
|
|
|
|
hostName = "sijmen-framework";
|
2023-06-18 14:18:01 +00:00
|
|
|
networkmanager = {
|
|
|
|
enable = true;
|
|
|
|
unmanaged = [ "wg0" "virbr0" ];
|
|
|
|
};
|
2022-08-10 07:41:44 +00:00
|
|
|
firewall = {
|
|
|
|
allowedTCPPorts = [
|
|
|
|
22 # ssh
|
|
|
|
22000 # syncthing sync
|
|
|
|
51414 # transmission
|
|
|
|
57621 # spotify connect
|
2023-03-31 12:17:02 +00:00
|
|
|
1313
|
|
|
|
8000
|
|
|
|
8080
|
2022-08-10 07:41:44 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
allowedUDPPorts = [
|
|
|
|
21027 # syncthing discovery
|
|
|
|
22000 # syncthing sync
|
|
|
|
51820 # wireguard
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2022-08-10 11:25:38 +00:00
|
|
|
wireguard.interfaces.wg0 = {
|
|
|
|
ips = [ "10.100.0.4/32" ];
|
|
|
|
listenPort = 51820;
|
2022-08-12 00:14:49 +00:00
|
|
|
privateKeyFile = "/home/sijmen/.config/wireguard-keys/private";
|
2022-08-10 11:25:38 +00:00
|
|
|
peers = [{
|
|
|
|
publicKey = "zu9vXxxg4wm0R4yWQ2HPaAwJbizuccGYbBB/StwSsm4=";
|
|
|
|
allowedIPs = [ "10.100.0.0/24" ];
|
2023-06-18 14:18:01 +00:00
|
|
|
endpoint = "cloud.sijmenschoon.nl:51820";
|
2022-08-10 11:25:38 +00:00
|
|
|
persistentKeepalive = 25;
|
|
|
|
}];
|
|
|
|
};
|
2023-06-18 14:18:01 +00:00
|
|
|
|
|
|
|
extraHosts = ''
|
|
|
|
#127.0.0.3 youtube.com
|
|
|
|
#127.0.0.3 www.youtube.com
|
|
|
|
#127.0.0.3 i.ytimg.com
|
|
|
|
'';
|
2022-08-10 07:41:44 +00:00
|
|
|
};
|
|
|
|
|
2023-03-31 12:17:02 +00:00
|
|
|
environment.etc."greetd/environments".text = ''
|
|
|
|
sway
|
|
|
|
bash
|
|
|
|
'';
|
|
|
|
|
2022-08-10 07:41:44 +00:00
|
|
|
services = {
|
2023-03-31 12:17:02 +00:00
|
|
|
greetd = {
|
2022-08-10 07:41:44 +00:00
|
|
|
enable = true;
|
2023-03-31 12:17:02 +00:00
|
|
|
settings = {
|
|
|
|
default_session.command = "${pkgs.sway}/bin/sway --config ${greetdSwayConfig}";
|
|
|
|
};
|
2022-08-10 07:41:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
syncthing = {
|
|
|
|
overrideDevices = true;
|
|
|
|
overrideFolders = true;
|
|
|
|
|
|
|
|
devices = {
|
|
|
|
nas.id = "5XADATO-6ZKNZFK-YIX2TU3-RTUOAXR-OMWOAH6-OIUB7LE-TWM5B3C-W2I2FQU";
|
|
|
|
desktop-fedora.id = "RE3BCEP-2FVDNPA-C72KDCX-5NRTLD4-DEJZAIX-PJAMJAN-LJDFHOY-WOXNPQW";
|
|
|
|
};
|
|
|
|
|
|
|
|
folders = {
|
|
|
|
"vhuse-qjbcl" = {
|
|
|
|
path = "${config.users.users.sijmen.home}/Sync";
|
|
|
|
devices = [ "nas" "desktop-fedora" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2022-08-12 00:12:03 +00:00
|
|
|
pipewire = {
|
|
|
|
enable = true;
|
|
|
|
alsa = { enable = true; support32Bit = true; };
|
|
|
|
pulse.enable = true;
|
|
|
|
};
|
|
|
|
|
2022-08-12 00:12:54 +00:00
|
|
|
tlp = {
|
|
|
|
enable = true;
|
|
|
|
settings = {
|
2023-06-18 14:18:01 +00:00
|
|
|
INTEL_GPU_MIN_FREQ_ON_AC = "100";
|
|
|
|
INTEL_GPU_MIN_FREQ_ON_BAT = "100";
|
|
|
|
|
2022-08-12 00:12:54 +00:00
|
|
|
PCIE_ASPM_ON_BAT = "powersupersave";
|
2023-06-18 14:18:01 +00:00
|
|
|
RUNTIME_PM_ON_BAT = "1";
|
|
|
|
|
2023-06-19 15:58:42 +00:00
|
|
|
CPU_ENERGY_PERF_POLICY_ON_AC = "balance_performance";
|
2023-06-18 14:18:01 +00:00
|
|
|
CPU_ENERGY_PERF_POLICY_ON_BAT = "balance_power";
|
|
|
|
CPU_BOOST_ON_BAT = "0";
|
2023-06-19 15:58:42 +00:00
|
|
|
CPU_BOOST_ON_AC = "1";
|
2023-06-18 14:18:01 +00:00
|
|
|
CPU_HWP_DYN_BOOST_ON_BAT = "0";
|
|
|
|
SCHED_POWERSAVE_ON_BAT = "1";
|
|
|
|
NMI_WATCHDOG = "0";
|
|
|
|
|
|
|
|
USB_AUTOSUSPEND = "1";
|
|
|
|
USB_EXCLUDE_AUDIO = "1";
|
|
|
|
USB_EXCLUDE_BTUSB = "0";
|
2023-03-31 12:17:02 +00:00
|
|
|
|
|
|
|
# Bus 001 Device 040: ID 1050:0407 Yubico.com Yubikey 4/5 OTP+U2F+CCID
|
|
|
|
# Bus 001 Device 038: ID 32ac:0002 Framework HDMI Expansion Card
|
|
|
|
USB_ALLOWLIST="1050:0407 32ac:0002";
|
2022-08-12 00:12:54 +00:00
|
|
|
};
|
|
|
|
};
|
2023-03-31 12:17:02 +00:00
|
|
|
|
|
|
|
avahi = {
|
|
|
|
enable = true;
|
|
|
|
nssmdns = true;
|
|
|
|
openFirewall = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
fwupd.extraRemotes = [ "lvfs-testing" ];
|
|
|
|
fprintd.enable = true;
|
|
|
|
ratbagd.enable = true;
|
|
|
|
logind.lidSwitchDocked = "suspend";
|
|
|
|
power-profiles-daemon.enable = false;
|
2022-08-10 07:41:44 +00:00
|
|
|
};
|
|
|
|
|
2023-06-18 14:18:01 +00:00
|
|
|
security = {
|
|
|
|
pam.services.login.fprintAuth = true;
|
|
|
|
pam.services.swaylock = {};
|
|
|
|
polkit.enable = true;
|
2022-11-27 13:42:43 +00:00
|
|
|
};
|
2022-08-10 07:41:44 +00:00
|
|
|
|
2023-06-18 14:18:01 +00:00
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
gnome.adwaita-icon-theme
|
|
|
|
ifuse
|
|
|
|
libimobiledevice
|
|
|
|
libheif
|
|
|
|
sbctl
|
|
|
|
polkit
|
|
|
|
polkit_gnome
|
|
|
|
];
|
|
|
|
|
2022-08-10 07:41:44 +00:00
|
|
|
programs.steam = {
|
2023-06-18 14:18:01 +00:00
|
|
|
#enable = true;
|
2022-08-10 07:41:44 +00:00
|
|
|
remotePlay.openFirewall = true;
|
|
|
|
dedicatedServer.openFirewall = true;
|
|
|
|
};
|
|
|
|
|
2023-03-31 12:17:02 +00:00
|
|
|
nixpkgs.config = {
|
|
|
|
packageOverrides = pkgs: {
|
|
|
|
vaapiIntel = pkgs.vaapiIntel.override { enableHybridCodec = true; };
|
|
|
|
};
|
2022-08-10 07:41:44 +00:00
|
|
|
};
|
|
|
|
|
2023-06-18 23:00:40 +00:00
|
|
|
home-manager.users.sijmen.imports = [ ../common/dconf.nix ];
|
2023-06-18 14:18:01 +00:00
|
|
|
|
|
|
|
systemd.services."suspend" = {
|
|
|
|
enable = true;
|
|
|
|
# TODO Should be `before`, but then fingerprint reader doesn't work
|
|
|
|
after = [ "suspend.target" ];
|
|
|
|
wantedBy = [ "suspend.target" ];
|
|
|
|
serviceConfig = {
|
|
|
|
# TODO Make username agnostic
|
|
|
|
ExecStart =
|
|
|
|
"${pkgs.systemd}/bin/systemctl --user --machine=sijmen@ start --wait swaylock";
|
|
|
|
Type = "oneshot";
|
|
|
|
};
|
|
|
|
};
|
2022-08-10 07:41:44 +00:00
|
|
|
|
|
|
|
system.stateVersion = "22.05";
|
|
|
|
}
|