diff --git a/.gitignore b/.gitignore index 861c323..640abff 100644 --- a/.gitignore +++ b/.gitignore @@ -1,8 +1,7 @@ .direnv .VSCodeCounter -result +result* *.bak *.qcow2 *.raw -*.img -vm-scripts/** \ No newline at end of file +*.img \ No newline at end of file diff --git a/.sops.yaml b/.sops.yaml index b8d321a..ecba04c 100644 --- a/.sops.yaml +++ b/.sops.yaml @@ -1,6 +1,5 @@ keys: - &ataraxia ad382d058c964607b7bbf01b071a8131bf166e80 - - &suomi-vps d286fd9431753cb455537070235ec7bc757002ca - &nixos-vps 20d2e2b90c6aa179585b6b6b34cafb9db82f1d40 - &home-hypervisor a32018133c7afbfd05d5b2795f3b89af369520c6 creation_rules: @@ -8,14 +7,8 @@ creation_rules: key_groups: - pgp: - *ataraxia - - *suomi-vps - *nixos-vps - *home-hypervisor - - path_regex: secrets/suomi-vps/[^/]+\.(yaml|json|env|ini)$ - key_groups: - - pgp: - - *ataraxia - - *suomi-vps - path_regex: secrets/nixos-vps/[^/]+\.(yaml|json|env|ini)$ key_groups: - pgp: diff --git a/.vscodeignore b/.vscodeignore index 70207d7..191aacb 100644 --- a/.vscodeignore +++ b/.vscodeignore @@ -1,2 +1,2 @@ -result/** -result \ No newline at end of file +result* +result*/** \ No newline at end of file diff --git a/todo.md b/TODO.md similarity index 87% rename from todo.md rename to TODO.md index 1dfca5a..50f4cd6 100644 --- a/todo.md +++ b/TODO.md @@ -1,14 +1,14 @@ # TODO +* move some profiles to modules (like vpn.nix) +* use sops for all occurrences of hashedPassword +* auto-import gpg keys +* wait headscale start until authentik +* auto-login to tailscale for hypervisor * config qbittorrent -* telegram theme -* use theme engine from https://github.com/SenchoPens/base16.nix (?) * fix waybar config -* Firejail all the things (maybe not...) * change writeShellScript and writeShellScriptBin to writeShellApplication -* add asserts to autoinstall module * fix mime, fix aria2 -* add updateScript to my packages * move overlay and packages to root folder * Change all 'latest' tags in docker container to digest: "statping/statping@sha256:aaaaa" * or add cmd to all containers: "--pull=newer" diff --git a/flake.nix b/flake.nix index 7a7c413..75689f5 100644 --- a/flake.nix +++ b/flake.nix @@ -241,17 +241,6 @@ specialArgs = { inherit inputs; }; format = "install-iso"; }; - Flakes-ISO-Aarch64 = nixos-generators.nixosGenerate { - system = "aarch64-linux"; - modules = [ - (import (./machines/Flakes-ISO)) - { device = "Flakes-ISO"; mainuser = "ataraxia"; } - ./machines/Arch-Builder-VM/autoinstall.nix - self.customModules.autoinstall - ]; - specialArgs = { inherit inputs; }; - format = "install-iso"; - }; }; }; diff --git a/machines/AMD-Workstation/boot.nix b/machines/AMD-Workstation/boot.nix index bfe38b9..2e85e21 100644 --- a/machines/AMD-Workstation/boot.nix +++ b/machines/AMD-Workstation/boot.nix @@ -3,7 +3,7 @@ let zfs_arc_max = toString (6 * 1024 * 1024 * 1024); in { boot = { - zfs.enableUnstable = false; # For now, unstable zfs will downgrade kernel + zfs.enableUnstable = false; kernelPackages = pkgs.linuxPackages_lqx; initrd = { diff --git a/machines/AMD-Workstation/default.nix b/machines/AMD-Workstation/default.nix index f522020..910fc49 100644 --- a/machines/AMD-Workstation/default.nix +++ b/machines/AMD-Workstation/default.nix @@ -4,7 +4,6 @@ ./hardware-configuration.nix customRoles.workstation - # customProfiles.stable-diffusion customProfiles.a2ln-server customProfiles.act customProfiles.attic @@ -21,12 +20,6 @@ security.pki.certificateFiles = [ ../../misc/mitmproxy-ca-cert.pem ]; virtualisation.libvirt.guests = { - win2k22 = { - autoStart = false; - user = config.mainuser; - group = "libvirtd"; - xmlFile = ./vm/win2k22.xml; - }; win10 = { autoStart = true; user = config.mainuser; @@ -39,44 +32,15 @@ group = "libvirtd"; xmlFile = ./vm/win10-server.xml; }; - fedora-build = { - autoStart = false; - user = config.mainuser; - group = "libvirtd"; - uefi = true; - memory = 32 * 1024; - sharedMemory = true; - cpu = { cores = 6; threads = 2; }; - devices = { - disks = [ - { diskFile = "/media/libvirt/images/fedora-build.qcow2"; targetName = "vda"; } - { diskFile = "/media/libvirt/images/android-zfs.qcow2"; targetName = "sda"; bus = "scsi"; } - ]; - network.macAddress = "52:54:00:f7:be:ef"; - }; - }; }; deviceSpecific.devInfo = { - cpu = { - vendor = "amd"; - clock = 3700; - cores = 12; - }; - drive = { - type = "ssd"; - speed = 6000; - size = 1000; - }; - gpu = { - vendor = "amd"; - }; - bigScreen = true; + cpu.vendor = "amd"; + drive.type = "ssd"; + gpu.vendor = "amd"; ram = 48; fileSystem = "zfs"; }; - deviceSpecific.isHost = true; - deviceSpecific.isShared = false; deviceSpecific.isGaming = true; deviceSpecific.enableVirtualisation = true; # VPN @@ -84,17 +48,13 @@ secrets.wg-ataraxia.services = [ "wg-quick-wg0.service" ]; networking.wg-quick.interfaces.wg0.autostart = false; networking.wg-quick.interfaces.wg0.configFile = config.secrets.wg-ataraxia.decrypted; - - hardware.firmware = [ pkgs.rtl8761b-firmware ]; - programs.nix-ld.enable = true; - + # Mount secrets.files-veracrypt = { }; environment.etc.crypttab = { text = '' files-veracrypt /dev/disk/by-partuuid/15fa11a1-a6d8-4962-9c03-74b209d7c46a /var/secrets/files-veracrypt tcrypt-veracrypt ''; }; - fileSystems = { "/media/win-sys" = { fsType = "ntfs"; @@ -117,10 +77,10 @@ }; powerManagement.cpuFreqGovernor = "schedutil"; - + hardware.firmware = [ pkgs.rtl8761b-firmware ]; services.openssh.settings.PermitRootLogin = lib.mkForce "without-password"; services.ratbagd.enable = true; - + # Networking networking.firewall.allowedTCPPorts = [ 8000 5900 52736 ]; networking.nameservers = [ "192.168.0.1" ]; networking.defaultGateway = "192.168.0.1"; @@ -133,6 +93,7 @@ }]; }; + programs.nix-ld.enable = true; home-manager.users.${config.mainuser} = { home.packages = [ inputs.nixos-generators.packages.${pkgs.hostPlatform.system}.nixos-generate diff --git a/machines/AMD-Workstation/passthrough/default.nix b/machines/AMD-Workstation/passthrough/default.nix deleted file mode 100644 index 5870cee..0000000 --- a/machines/AMD-Workstation/passthrough/default.nix +++ /dev/null @@ -1,35 +0,0 @@ -{ config, ... }: { -systemd.services.libvirtd = { - path = let - env = pkgs.buildEnv { - name = "qemu-hook-env"; - paths = with pkgs; [ - libvirt bash util-linux pciutils ripgrep - procps coreutils systemd kmod gawk - ]; - }; - in [ env ]; - }; - - system.activationScripts.libvirt-hooks.text = '' - ln -Tfs /etc/libvirt/hooks /var/lib/libvirt/hooks - ln -Tfs /etc/libvirt/vgabios /var/lib/libvirt/vgabios - ''; - - environment.etc = { - "libvirt/hooks/qemu".source = ./passthrough/qemu; - "libvirt/hooks/qemu.d/win10/vfio-script.sh".source = ./passthrough/vfio-script.sh; - "libvirt/vgabios/navi22.rom".source = ./passthrough/navi22.rom; - }; - - systemd.services.hyprland-logout = { - script = "hyprctl dispatch exit"; - serviceConfig = { - Type = "oneshot"; - User = config.mainuser; - }; - path = [ - config.home-manager.users.${config.mainuser}.wayland.windowManager.hyprland.package - ]; - }; -} \ No newline at end of file diff --git a/machines/AMD-Workstation/passthrough/navi22.rom b/machines/AMD-Workstation/passthrough/navi22.rom deleted file mode 100755 index c982648..0000000 Binary files a/machines/AMD-Workstation/passthrough/navi22.rom and /dev/null differ diff --git a/machines/AMD-Workstation/passthrough/qemu b/machines/AMD-Workstation/passthrough/qemu deleted file mode 100644 index 19237dd..0000000 --- a/machines/AMD-Workstation/passthrough/qemu +++ /dev/null @@ -1,18 +0,0 @@ -#!/bin/bash - -OBJECT="$1" -OPERATION="$2" - -if [[ $OBJECT == "win10" ]]; then - case "$OPERATION" in - "prepare") - # systemctl start libvirt-nosleep@"$OBJECT" 2>&1 | tee -a /var/log/libvirt/custom_hooks.log - /etc/libvirt/hooks/qemu.d/win10/vfio-script.sh start 2>&1 | tee -a /var/log/libvirt/vfio-script.log - ;; - - "release") - # systemctl stop libvirt-nosleep@"$OBJECT" 2>&1 | tee -a /var/log/libvirt/custom_hooks.log - /etc/libvirt/hooks/qemu.d/win10/vfio-script.sh stop 2>&1 | tee -a /var/log/libvirt/vfio-script.log - ;; - esac -fi diff --git a/machines/AMD-Workstation/passthrough/vfio-script.sh b/machines/AMD-Workstation/passthrough/vfio-script.sh deleted file mode 100644 index 59c2e46..0000000 --- a/machines/AMD-Workstation/passthrough/vfio-script.sh +++ /dev/null @@ -1,140 +0,0 @@ -#!/bin/bash - -# Helpful to read output when debugging -#set -x - -##------------------------------------------------------------------------ -## Alpha version: 0.4V -## Author: AM(Tobias Rieper) -## Last Edit: 08-01-2023 -## Works with AMD GPU with systemd. -## Note: CPU Pinning is disable by default. Check Read Me To enable it ;-) -##------------------------------------------------------------------------- - -#Variables -Gen_Vars() { -NULL="/dev/null" -#Delays -Delay_1="1" -Delay_2="2" -Delay_3="3" -Delay_4="4" -Delay_5="5" -## -#Virsh Commands -PCI="pci_0000_" -REMOVE="nodedev-detach" -ADD="nodedev-reattach" -## -#Video and Audio -VIDEO=$(lspci -nn | grep VGA | head -1 | cut -d " " -f1 | tr ":." "_") -VIDEO1=$(lspci -nn | grep VGA | head -1 | cut -d " " -f1) -AUDIO=$(lspci -nn | grep "HDMI Audio" | head -1 | cut -d " " -f1 | tr ":." "_") -AUDIO1=$(lspci -nn | grep "HDMI Audio" | head -1 | cut -d " " -f1) -## -#Display Manager -DM1=$(grep '/usr/s\?bin' /etc/systemd/system/display-manager.service | tr "/" "\n" | tail -1) -DM2=$(ps auxf | awk '{print $11}' | grep -e "dm" | head -1 | tr "/" "\n" | tail -1) -## -#RTC Wake Timer -TIME="+8sec" -## -#CoolDown Delay -Delay_8="8" -## -#Loop Variables -declare -i Loop -Loop=1 -declare -i TimeOut -TimeOut=5 -## -# Helpful to read output when debugging -set -x -} -Kill_DM() { - #Just to make sure the session is dead. - # for i in $(ls /home); do echo $i; killall -u $i;kill -9 $(ps -s -U $i | awk '{print $2}' | grep -Ev "pid");done - #Fn to Stop The Display Manager - # systemctl start hyprland-logout - hyprctl dispatch exittex = (pkgs.texlive.combine { - inherit (pkgs.texlive) scheme-medium - # dvisvgm dvipng # for preview and export as html - luatex latexmk t2 tempora ccaption soul - float makecell multirow enumitem cyrillic - babel babel-russian metafont hyphen-russian - greek-fontenc; - }); - #Don't Touch this Delay - sleep $Delay_2 - #Unbinding VT Consoles if currently bound (adapted from https://www.kernel.org/doc/Documentation/fb/fbcon.txt) - for i in /sys/class/vtconsole/*; - do - echo 0 > $i/bind - done -} - -IF_AMD() { - if [ "lsmod | grep "amdgpu" &> /dev/null" ]; then - lsmod | grep amdgpu | cut -d " " -f1 >/tmp/amd-modules - #Syncing Disk and clearing The Caches(RAM) - sync; echo 1 > /proc/sys/vm/drop_caches - #Un-Binding GPU From driver - sleep $Delay_2 - echo "0000:$VIDEO1" > "/sys/bus/pci/devices/0000:$VIDEO1/driver/unbind" - echo "0000:$AUDIO1" > "/sys/bus/pci/devices/0000:$AUDIO1/driver/unbind" - #Waiting for AMD GPU To Fininsh - while ! (dmesg | grep "amdgpu 0000:$VIDEO1" | tail -5 | grep "amdgpu: finishing device."); do echo "Loop-1"; if [ "$Loop" -le "$TimeOut" ]; then echo "Waiting"; TimeOut+=1; echo "Try: $TimeOut"; sleep 1; else break;fi; done - ## Removing Video and Audio - virsh $REMOVE "$PCI$VIDEO" - sleep 1 - virsh $REMOVE "$PCI$AUDIO" - modprobe -r amdgpu - #Reseting The Loop Counter - Loop=1 - #Making Sure that AMD GPU is Un-Loaded - while (lsmod | grep amdgpu); do echo "Loop-3"; if [ "$Loop" -le "$TimeOut" ]; then echo "AMD GPU in use"; lsmod | grep amdgpu | awk '{print $1}' | while read AM; do modprobe -r $AM; done;TimeOut+=1; echo "AMDGPU try: $TimeOut"; sleep 1; else echo "Fail To Remove AMD GPU";rmmod amdgpu; break;fi;done - #may the force be with you - #rmmod -f amdgpu - #garbage collection - unset Loop - unset TimeOut - #Putting System To a quick sleep cycle to make sure that amd graphic card is Properly reset - rtcwake -m mem --date $TIME - - fi -} -CPU_Pining() { -if [[ "$*" == "enable" ]] -then - systemctl set-property --runtime -- user.slice AllowedCPUs=0,8 - systemctl set-property --runtime -- system.slice AllowedCPUs=0,8 - systemctl set-property --runtime -- init.scope AllowedCPUs=0,8 - echo "CPU Pining Enabled" -elif [[ "$*" == "disable" ]] -then - systemctl set-property --runtime -- user.slice AllowedCPUs=0-11 - systemctl set-property --runtime -- system.slice AllowedCPUs=0-11 - systemctl set-property --runtime -- init.scope AllowedCPUs=0-11 - echo "CPU Pining Disable" -fi -} -# Main Init -if [[ "$*" == "start" ]] -then - Gen_Vars - Kill_DM - IF_AMD - #CPU_Pining "enable" - echo "Start Done" -elif [[ "$*" == "stop" ]] -then - Gen_Vars - #CPU_Pining "disable" - echo "1" | tee -a /sys/bus/pci/devices/0000:$AUDIO1/remove - echo "1" | tee -a /sys/bus/pci/devices/0000:$VIDEO1/remove - rtcwake -m mem --date $TIME - sleep $Delay_3 - echo "1" | tee -a /sys/bus/pci/rescan - # systemctl restart `cat /var/tmp/Last-DM` - echo "Stop Done" -fi diff --git a/machines/AMD-Workstation/vm/win2k22.xml b/machines/AMD-Workstation/vm/win2k22.xml deleted file mode 100644 index 2cc8339..0000000 --- a/machines/AMD-Workstation/vm/win2k22.xml +++ /dev/null @@ -1,201 +0,0 @@ - - win2k22 - dcd41663-1e1d-40d0-9020-46f4e25e2777 - - - - - - 4194304 - 4194304 - - - - - 2 - - hvm - /run/libvirt/nix-ovmf/OVMF_CODE.fd - /var/lib/libvirt/qemu/nvram/win2k22_VARS.fd - - - - - - - - - - - - - - - - - - - - - - - destroy - restart - destroy - - - - - - /run/libvirt/nix-emulators/qemu-system-x86_64 - - - - - -
- - - - - - -
- - -
- - - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - - - -
- - -
- - -
- - - - - - - - -
- - - - - -
- - - - - - - - - - - -
- - -
- - - - - - - - -
- -