Compare commits
	
		
			1 Commits
		
	
	
		
			41b40d7b6a
			...
			wallpapers
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| db6049f8ef | 
| @@ -1,15 +0,0 @@ | |||||||
| name: Check flake |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: ['master'] |  | ||||||
| jobs: |  | ||||||
|   build-amd64-linux: |  | ||||||
|     runs-on: nix |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v4 |  | ||||||
|         with: |  | ||||||
|           ref: master |  | ||||||
|       - name: Check flake |  | ||||||
|         run: | |  | ||||||
|           echo "Checking flake at ${{ gitea.ref }}" |  | ||||||
|           nix flake check |  | ||||||
							
								
								
									
										49
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										49
									
								
								README.md
									
									
									
									
									
								
							| @@ -9,47 +9,8 @@ System and user configuration for NixOS-based systems. | |||||||
| | **Theme:** | adwaita | | | **Theme:** | adwaita | | ||||||
| | **Terminal:** | Console | | | **Terminal:** | Console | | ||||||
|  |  | ||||||
| ## Provisioning a new host | ## Quick start | ||||||
| > [nixos-anywhere](https://github.com/nix-community/nixos-anywhere) is the module used | 1. Copy SSH keypair and `known_hosts` to `~/.ssh` | ||||||
| > for provisioning | 1. Import GPG keys and set ultimate trust with `echo "KEYID:6:" | gpg --import-ownertrust` | ||||||
|  | 1. `git clone git@git.vimium.com:jordan/nix-config.git projects/jordan/nix-config` | ||||||
| Generate a new SSH host key in "$temp/etc/ssh" as per [this guide](https://nix-community.github.io/nixos-anywhere/howtos/secrets.html#example-decrypting-an-openssh-host-key-with-pass). | 1. `sudo nixos-rebuild switch --flake .#` | ||||||
| ``` |  | ||||||
| ssh-keygen -t ed25519 -f /tmp/ssh_host_ed25519_key |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Update [nix-secrets](/jordan/nix-secrets) with the new host key to enable the system to decrypt |  | ||||||
| any relevant secrets. |  | ||||||
|  |  | ||||||
| In order to use the borgmatic module for backups, go to [borgbase.com](https://borgbase.com). |  | ||||||
| Add the generated SSH host key and create a new repository for the system. |  | ||||||
|  |  | ||||||
| Create a new directory under `hosts/` with a system configuration and disk layout. |  | ||||||
|  |  | ||||||
| Boot the NixOS installer (or any Linux distribution) on the target. |  | ||||||
|  |  | ||||||
| Then run: |  | ||||||
| ``` |  | ||||||
| nix run github:nix-community/nixos-anywhere -- \ |  | ||||||
|   --disk-encryption-keys /tmp/secret.key /tmp/secret.key \ |  | ||||||
|   --extra-files "$temp" \ |  | ||||||
|   --flake .#<hostname> \ |  | ||||||
|   root@<target-ip> |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Post install |  | ||||||
|  |  | ||||||
| If backups are configured, you'll need to run: |  | ||||||
| ``` |  | ||||||
| borgmatic init --encryption repokey-blake2 |  | ||||||
| ``` |  | ||||||
| then restart `borgmatic`. |  | ||||||
|  |  | ||||||
| To join the Tailscale network, run: |  | ||||||
| ``` |  | ||||||
| tailscale up --login-server https://headscale.vimium.net |  | ||||||
| ``` |  | ||||||
| then visit the URL, SSH onto `vps1` and run `headscale --user mesh nodes register --key <key>`. |  | ||||||
|  |  | ||||||
| The new node can optionally be given a friendly name with `headscale node rename -i <index> <hostname>`. |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										651
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										651
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -4,15 +4,14 @@ | |||||||
|       "inputs": { |       "inputs": { | ||||||
|         "darwin": "darwin", |         "darwin": "darwin", | ||||||
|         "home-manager": "home-manager", |         "home-manager": "home-manager", | ||||||
|         "nixpkgs": "nixpkgs", |         "nixpkgs": "nixpkgs" | ||||||
|         "systems": "systems" |  | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1720546205, |         "lastModified": 1701216516, | ||||||
|         "narHash": "sha256-boCXsjYVxDviyzoEyAk624600f3ZBo/DKtUdvMTpbGY=", |         "narHash": "sha256-jKSeJn+7hZ1dZdiH1L+NWUGT2i/BGomKAJ54B9kT06Q=", | ||||||
|         "owner": "ryantm", |         "owner": "ryantm", | ||||||
|         "repo": "agenix", |         "repo": "agenix", | ||||||
|         "rev": "de96bd907d5fbc3b14fc33ad37d1b9a3cb15edc6", |         "rev": "13ac9ac6d68b9a0896e3d43a082947233189e247", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -21,22 +20,6 @@ | |||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "blobs": { |  | ||||||
|       "flake": false, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1604995301, |  | ||||||
|         "narHash": "sha256-wcLzgLec6SGJA8fx1OEN1yV/Py5b+U5iyYpksUY/yLw=", |  | ||||||
|         "owner": "simple-nixos-mailserver", |  | ||||||
|         "repo": "blobs", |  | ||||||
|         "rev": "2cccdf1ca48316f2cfd1c9a0017e8de5a7156265", |  | ||||||
|         "type": "gitlab" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "simple-nixos-mailserver", |  | ||||||
|         "repo": "blobs", |  | ||||||
|         "type": "gitlab" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "darwin": { |     "darwin": { | ||||||
|       "inputs": { |       "inputs": { | ||||||
|         "nixpkgs": [ |         "nixpkgs": [ | ||||||
| @@ -45,11 +28,11 @@ | |||||||
|         ] |         ] | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1700795494, |         "lastModified": 1673295039, | ||||||
|         "narHash": "sha256-gzGLZSiOhf155FW7262kdHo2YDeugp3VuIFb4/GGng0=", |         "narHash": "sha256-AsdYgE8/GPwcelGgrntlijMg4t3hLFJFCRF3tL5WVjA=", | ||||||
|         "owner": "lnl7", |         "owner": "lnl7", | ||||||
|         "repo": "nix-darwin", |         "repo": "nix-darwin", | ||||||
|         "rev": "4b9b83d5a92e8c1fbfd8eb27eda375908c11ec4d", |         "rev": "87b9d090ad39b25b2400029c64825fc2a8868943", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -59,76 +42,14 @@ | |||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "deploy-rs": { |  | ||||||
|       "inputs": { |  | ||||||
|         "flake-compat": "flake-compat", |  | ||||||
|         "nixpkgs": "nixpkgs_2", |  | ||||||
|         "utils": "utils" |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1718194053, |  | ||||||
|         "narHash": "sha256-FaGrf7qwZ99ehPJCAwgvNY5sLCqQ3GDiE/6uLhxxwSY=", |  | ||||||
|         "owner": "serokell", |  | ||||||
|         "repo": "deploy-rs", |  | ||||||
|         "rev": "3867348fa92bc892eba5d9ddb2d7a97b9e127a8a", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "serokell", |  | ||||||
|         "repo": "deploy-rs", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "devshell": { |  | ||||||
|       "inputs": { |  | ||||||
|         "flake-utils": "flake-utils", |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1717408969, |  | ||||||
|         "narHash": "sha256-Q0OEFqe35fZbbRPPRdrjTUUChKVhhWXz3T9ZSKmaoVY=", |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "devshell", |  | ||||||
|         "rev": "1ebbe68d57457c8cae98145410b164b5477761f4", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "devshell", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "disko": { |  | ||||||
|       "inputs": { |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1721417620, |  | ||||||
|         "narHash": "sha256-6q9b1h8fI3hXg2DG6/vrKWCeG8c5Wj2Kvv22RCgedzg=", |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "repo": "disko", |  | ||||||
|         "rev": "bec6e3cde912b8acb915fecdc509eda7c973fb42", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "repo": "disko", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "firefox-gnome-theme": { |     "firefox-gnome-theme": { | ||||||
|       "flake": false, |       "flake": false, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1721276923, |         "lastModified": 1702138393, | ||||||
|         "narHash": "sha256-HJKuwVvi+yGv+8n9Ez4EwaJA0B79JRss9J30vpgy/GI=", |         "narHash": "sha256-2jRm1yzX+gKpSCtdpYt1olIgWVEkJnS7FeK00o9X1ko=", | ||||||
|         "owner": "rafaelmardojai", |         "owner": "rafaelmardojai", | ||||||
|         "repo": "firefox-gnome-theme", |         "repo": "firefox-gnome-theme", | ||||||
|         "rev": "cc70ec20e2775df7cd2bccdd20dcdecc3e0a733b", |         "rev": "d2e6cfdd63651ae8168e5905d94138f406580dd6", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -137,173 +58,6 @@ | |||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "flake-compat": { |  | ||||||
|       "flake": false, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1696426674, |  | ||||||
|         "narHash": "sha256-kvjfFW7WAETZlt09AgDn1MrtKzP7t90Vf7vypd3OL1U=", |  | ||||||
|         "owner": "edolstra", |  | ||||||
|         "repo": "flake-compat", |  | ||||||
|         "rev": "0f9255e01c2351cc7d116c072cb317785dd33b33", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "edolstra", |  | ||||||
|         "repo": "flake-compat", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "flake-compat_2": { |  | ||||||
|       "flake": false, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1696426674, |  | ||||||
|         "narHash": "sha256-kvjfFW7WAETZlt09AgDn1MrtKzP7t90Vf7vypd3OL1U=", |  | ||||||
|         "owner": "edolstra", |  | ||||||
|         "repo": "flake-compat", |  | ||||||
|         "rev": "0f9255e01c2351cc7d116c072cb317785dd33b33", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "edolstra", |  | ||||||
|         "repo": "flake-compat", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "flake-compat_3": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1696426674, |  | ||||||
|         "narHash": "sha256-kvjfFW7WAETZlt09AgDn1MrtKzP7t90Vf7vypd3OL1U=", |  | ||||||
|         "rev": "0f9255e01c2351cc7d116c072cb317785dd33b33", |  | ||||||
|         "revCount": 57, |  | ||||||
|         "type": "tarball", |  | ||||||
|         "url": "https://api.flakehub.com/f/pinned/edolstra/flake-compat/1.0.1/018afb31-abd1-7bff-a5e4-cff7e18efb7a/source.tar.gz" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "type": "tarball", |  | ||||||
|         "url": "https://flakehub.com/f/edolstra/flake-compat/1.tar.gz" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "flake-compat_4": { |  | ||||||
|       "flake": false, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1696426674, |  | ||||||
|         "narHash": "sha256-kvjfFW7WAETZlt09AgDn1MrtKzP7t90Vf7vypd3OL1U=", |  | ||||||
|         "owner": "edolstra", |  | ||||||
|         "repo": "flake-compat", |  | ||||||
|         "rev": "0f9255e01c2351cc7d116c072cb317785dd33b33", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "edolstra", |  | ||||||
|         "repo": "flake-compat", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "flake-parts": { |  | ||||||
|       "inputs": { |  | ||||||
|         "nixpkgs-lib": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1719994518, |  | ||||||
|         "narHash": "sha256-pQMhCCHyQGRzdfAkdJ4cIWiw+JNuWsTX7f0ZYSyz0VY=", |  | ||||||
|         "owner": "hercules-ci", |  | ||||||
|         "repo": "flake-parts", |  | ||||||
|         "rev": "9227223f6d922fee3c7b190b2cc238a99527bbb7", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "hercules-ci", |  | ||||||
|         "repo": "flake-parts", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "flake-utils": { |  | ||||||
|       "inputs": { |  | ||||||
|         "systems": "systems_4" |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1701680307, |  | ||||||
|         "narHash": "sha256-kAuep2h5ajznlPMD9rnQyffWG8EM/C73lejGofXvdM8=", |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "flake-utils", |  | ||||||
|         "rev": "4022d587cbbfd70fe950c1e2083a02621806a725", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "flake-utils", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "git-hooks": { |  | ||||||
|       "inputs": { |  | ||||||
|         "flake-compat": "flake-compat_4", |  | ||||||
|         "gitignore": "gitignore", |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ], |  | ||||||
|         "nixpkgs-stable": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1721038330, |  | ||||||
|         "narHash": "sha256-DyIGJ+DEnKeGd346YJCwjmp9hXwiYq8wqGtikgbDqSc=", |  | ||||||
|         "owner": "cachix", |  | ||||||
|         "repo": "git-hooks.nix", |  | ||||||
|         "rev": "622291c026190caf13cb26f5136616b1ff0a07aa", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "cachix", |  | ||||||
|         "repo": "git-hooks.nix", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "gitea-github-theme": { |  | ||||||
|       "flake": false, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1717248105, |  | ||||||
|         "narHash": "sha256-BwSsIkl7DpN/c8HNXOh2aKjOuPmFsGybv4RegOC7Xq0=", |  | ||||||
|         "ref": "main", |  | ||||||
|         "rev": "4f829f88e6f443ff048c4d337bd010315aa4b50a", |  | ||||||
|         "revCount": 101, |  | ||||||
|         "type": "git", |  | ||||||
|         "url": "ssh://git@git.vimium.com/jordan/gitea-github-theme.git" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "ref": "main", |  | ||||||
|         "type": "git", |  | ||||||
|         "url": "ssh://git@git.vimium.com/jordan/gitea-github-theme.git" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "gitignore": { |  | ||||||
|       "inputs": { |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "git-hooks", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1709087332, |  | ||||||
|         "narHash": "sha256-HG2cCnktfHsKV0s4XW83gU3F57gaTljL9KNSuG6bnQs=", |  | ||||||
|         "owner": "hercules-ci", |  | ||||||
|         "repo": "gitignore.nix", |  | ||||||
|         "rev": "637db329424fd7e46cf4185293b9cc8c88c95394", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "hercules-ci", |  | ||||||
|         "repo": "gitignore.nix", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "home-manager": { |     "home-manager": { | ||||||
|       "inputs": { |       "inputs": { | ||||||
|         "nixpkgs": [ |         "nixpkgs": [ | ||||||
| @@ -312,11 +66,11 @@ | |||||||
|         ] |         ] | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1703113217, |         "lastModified": 1682203081, | ||||||
|         "narHash": "sha256-7ulcXOk63TIT2lVDSExj7XzFx09LpdSAPtvgtM7yQPE=", |         "narHash": "sha256-kRL4ejWDhi0zph/FpebFYhzqlOBrk0Pl3dzGEKSAlEw=", | ||||||
|         "owner": "nix-community", |         "owner": "nix-community", | ||||||
|         "repo": "home-manager", |         "repo": "home-manager", | ||||||
|         "rev": "3bfaacf46133c037bb356193bd2f1765d9dc82c1", |         "rev": "32d3e39c491e2f91152c84f8ad8b003420eab0a1", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -332,126 +86,27 @@ | |||||||
|         ] |         ] | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1720042825, |         "lastModified": 1702195709, | ||||||
|         "narHash": "sha256-A0vrUB6x82/jvf17qPCpxaM+ulJnD8YZwH9Ci0BsAzE=", |         "narHash": "sha256-+zRjWkm5rKqQ57PuLZ3JF3xi3vPMiOJzItb1m/43Cq4=", | ||||||
|         "owner": "nix-community", |         "owner": "nix-community", | ||||||
|         "repo": "home-manager", |         "repo": "home-manager", | ||||||
|         "rev": "e1391fb22e18a36f57e6999c7a9f966dc80ac073", |         "rev": "6761b8188b860f374b457eddfdb05c82eef9752f", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
|         "owner": "nix-community", |         "owner": "nix-community", | ||||||
|         "ref": "release-24.05", |         "ref": "release-23.11", | ||||||
|         "repo": "home-manager", |         "repo": "home-manager", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "home-manager_3": { |  | ||||||
|       "inputs": { |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1720042825, |  | ||||||
|         "narHash": "sha256-A0vrUB6x82/jvf17qPCpxaM+ulJnD8YZwH9Ci0BsAzE=", |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "repo": "home-manager", |  | ||||||
|         "rev": "e1391fb22e18a36f57e6999c7a9f966dc80ac073", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "ref": "release-24.05", |  | ||||||
|         "repo": "home-manager", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "kvlibadwaita": { |  | ||||||
|       "flake": false, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1710621848, |  | ||||||
|         "narHash": "sha256-xBl6zmpqTAH5MIT5iNAdW6kdOcB5MY0Dtrb95hdYpwA=", |  | ||||||
|         "owner": "GabePoel", |  | ||||||
|         "repo": "KvLibadwaita", |  | ||||||
|         "rev": "87c1ef9f44ec48855fd09ddab041007277e30e37", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "GabePoel", |  | ||||||
|         "repo": "KvLibadwaita", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "nix-darwin": { |  | ||||||
|       "inputs": { |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1720845312, |  | ||||||
|         "narHash": "sha256-yPhAsJTpyoIPQZJGC8Fw8W2lAXyhLoTn+HP20bmfkfk=", |  | ||||||
|         "owner": "lnl7", |  | ||||||
|         "repo": "nix-darwin", |  | ||||||
|         "rev": "5ce8503cf402cf76b203eba4b7e402bea8e44abc", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "lnl7", |  | ||||||
|         "repo": "nix-darwin", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "nixos-hardware": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1721413321, |  | ||||||
|         "narHash": "sha256-0GdiQScDceUrVGbxYpV819LHesK3szHOhJ09e6sgES4=", |  | ||||||
|         "owner": "NixOS", |  | ||||||
|         "repo": "nixos-hardware", |  | ||||||
|         "rev": "ab165a8a6cd12781d76fe9cbccb9e975d0fb634f", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "NixOS", |  | ||||||
|         "repo": "nixos-hardware", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "nixos-mailserver": { |  | ||||||
|       "inputs": { |  | ||||||
|         "blobs": "blobs", |  | ||||||
|         "flake-compat": "flake-compat_2", |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixpkgs" |  | ||||||
|         ], |  | ||||||
|         "nixpkgs-24_05": "nixpkgs-24_05", |  | ||||||
|         "utils": "utils_2" |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1718084203, |  | ||||||
|         "narHash": "sha256-Cx1xoVfSMv1XDLgKg08CUd1EoTYWB45VmB9XIQzhmzI=", |  | ||||||
|         "owner": "simple-nixos-mailserver", |  | ||||||
|         "repo": "nixos-mailserver", |  | ||||||
|         "rev": "29916981e7b3b5782dc5085ad18490113f8ff63b", |  | ||||||
|         "type": "gitlab" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "simple-nixos-mailserver", |  | ||||||
|         "ref": "nixos-24.05", |  | ||||||
|         "repo": "nixos-mailserver", |  | ||||||
|         "type": "gitlab" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "nixpkgs": { |     "nixpkgs": { | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1703013332, |         "lastModified": 1677676435, | ||||||
|         "narHash": "sha256-+tFNwMvlXLbJZXiMHqYq77z/RfmpfpiI3yjL6o/Zo9M=", |         "narHash": "sha256-6FxdcmQr5JeZqsQvfinIMr0XcTyTuR7EXX0H3ANShpQ=", | ||||||
|         "owner": "NixOS", |         "owner": "NixOS", | ||||||
|         "repo": "nixpkgs", |         "repo": "nixpkgs", | ||||||
|         "rev": "54aac082a4d9bb5bbc5c4e899603abfb76a3f6d6", |         "rev": "a08d6979dd7c82c4cef0dcc6ac45ab16051c1169", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -461,221 +116,39 @@ | |||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "nixpkgs-24_05": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1717144377, |  | ||||||
|         "narHash": "sha256-F/TKWETwB5RaR8owkPPi+SPJh83AQsm6KrQAlJ8v/uA=", |  | ||||||
|         "owner": "NixOS", |  | ||||||
|         "repo": "nixpkgs", |  | ||||||
|         "rev": "805a384895c696f802a9bf5bf4720f37385df547", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "id": "nixpkgs", |  | ||||||
|         "ref": "nixos-24.05", |  | ||||||
|         "type": "indirect" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "nixpkgs-unstable": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1721379653, |  | ||||||
|         "narHash": "sha256-8MUgifkJ7lkZs3u99UDZMB4kbOxvMEXQZ31FO3SopZ0=", |  | ||||||
|         "owner": "NixOS", |  | ||||||
|         "repo": "nixpkgs", |  | ||||||
|         "rev": "1d9c2c9b3e71b9ee663d11c5d298727dace8d374", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "id": "nixpkgs", |  | ||||||
|         "ref": "nixos-unstable", |  | ||||||
|         "type": "indirect" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "nixpkgs_2": { |     "nixpkgs_2": { | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1702272962, |         "lastModified": 1702233072, | ||||||
|         "narHash": "sha256-D+zHwkwPc6oYQ4G3A1HuadopqRwUY/JkMwHz1YF7j4Q=", |         "narHash": "sha256-H5G2wgbim2Ku6G6w+NSaQaauv6B6DlPhY9fMvArKqRo=", | ||||||
|         "owner": "NixOS", |         "owner": "NixOS", | ||||||
|         "repo": "nixpkgs", |         "repo": "nixpkgs", | ||||||
|         "rev": "e97b3e4186bcadf0ef1b6be22b8558eab1cdeb5d", |         "rev": "781e2a9797ecf0f146e81425c822dca69fe4a348", | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "NixOS", |  | ||||||
|         "ref": "nixpkgs-unstable", |  | ||||||
|         "repo": "nixpkgs", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "nixpkgs_3": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1721409541, |  | ||||||
|         "narHash": "sha256-b6PLr0Ty7JPDBtJtjnYzlBf02bbH9alWMAgispMkTwk=", |  | ||||||
|         "owner": "NixOS", |  | ||||||
|         "repo": "nixpkgs", |  | ||||||
|         "rev": "0c53b6b8c2a3e46c68e04417e247bba660689c9d", |  | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
|         "id": "nixpkgs", |         "id": "nixpkgs", | ||||||
|         "ref": "nixos-24.05", |         "ref": "nixos-23.11", | ||||||
|         "type": "indirect" |         "type": "indirect" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "nixvim": { |  | ||||||
|       "inputs": { |  | ||||||
|         "devshell": "devshell", |  | ||||||
|         "flake-compat": "flake-compat_3", |  | ||||||
|         "flake-parts": "flake-parts", |  | ||||||
|         "git-hooks": "git-hooks", |  | ||||||
|         "home-manager": "home-manager_3", |  | ||||||
|         "nix-darwin": "nix-darwin", |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixpkgs" |  | ||||||
|         ], |  | ||||||
|         "treefmt-nix": "treefmt-nix" |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1721045803, |  | ||||||
|         "narHash": "sha256-dQGvOK+t45unF7DTp5bfO37hY0NkDUw6X3MH5CCTEAs=", |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "repo": "nixvim", |  | ||||||
|         "rev": "eef2f4c6b190d92e296e47e5fe10e7ced65fd959", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "ref": "nixos-24.05", |  | ||||||
|         "repo": "nixvim", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "plasma-manager": { |  | ||||||
|       "inputs": { |  | ||||||
|         "home-manager": [ |  | ||||||
|           "home-manager" |  | ||||||
|         ], |  | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1720992717, |  | ||||||
|         "narHash": "sha256-8j1bZVfKT1vJ0e+U7NYRNBG+DdBj5C/tpwe5krxT4/4=", |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "repo": "plasma-manager", |  | ||||||
|         "rev": "460b48dc3dcd05df568e27cbb90581d23baec8dc", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-community", |  | ||||||
|         "repo": "plasma-manager", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "root": { |     "root": { | ||||||
|       "inputs": { |       "inputs": { | ||||||
|         "agenix": "agenix", |         "agenix": "agenix", | ||||||
|         "deploy-rs": "deploy-rs", |  | ||||||
|         "disko": "disko", |  | ||||||
|         "firefox-gnome-theme": "firefox-gnome-theme", |         "firefox-gnome-theme": "firefox-gnome-theme", | ||||||
|         "gitea-github-theme": "gitea-github-theme", |  | ||||||
|         "home-manager": "home-manager_2", |         "home-manager": "home-manager_2", | ||||||
|         "kvlibadwaita": "kvlibadwaita", |         "nixpkgs": "nixpkgs_2", | ||||||
|         "nixos-hardware": "nixos-hardware", |         "thunderbird-gnome-theme": "thunderbird-gnome-theme", | ||||||
|         "nixos-mailserver": "nixos-mailserver", |         "wallpapers": "wallpapers" | ||||||
|         "nixpkgs": "nixpkgs_3", |  | ||||||
|         "nixpkgs-unstable": "nixpkgs-unstable", |  | ||||||
|         "nixvim": "nixvim", |  | ||||||
|         "plasma-manager": "plasma-manager", |  | ||||||
|         "secrets": "secrets", |  | ||||||
|         "thunderbird-gnome-theme": "thunderbird-gnome-theme" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "secrets": { |  | ||||||
|       "flake": false, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1720459643, |  | ||||||
|         "narHash": "sha256-X71/NplPXPe9pCvrd9ELpnYBEYtju4+x3LA7S5I1GXM=", |  | ||||||
|         "ref": "refs/heads/master", |  | ||||||
|         "rev": "f8d68b934f4380ecbc6365b4ef7f7c632833d1aa", |  | ||||||
|         "revCount": 21, |  | ||||||
|         "type": "git", |  | ||||||
|         "url": "ssh://git@git.vimium.com/jordan/nix-secrets.git" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "type": "git", |  | ||||||
|         "url": "ssh://git@git.vimium.com/jordan/nix-secrets.git" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "systems": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1681028828, |  | ||||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "systems_2": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1681028828, |  | ||||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "systems_3": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1681028828, |  | ||||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "systems_4": { |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1681028828, |  | ||||||
|         "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=", |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "nix-systems", |  | ||||||
|         "repo": "default", |  | ||||||
|         "type": "github" |  | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "thunderbird-gnome-theme": { |     "thunderbird-gnome-theme": { | ||||||
|       "flake": false, |       "flake": false, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1721309490, |         "lastModified": 1701889124, | ||||||
|         "narHash": "sha256-Xheela/OazoNH9YjP9IgC3hzxQdnPHRQMeH9yW7xl2c=", |         "narHash": "sha256-K+6oh7+J6RDBFkxphY/pzf0B+q5+IY54ZMKZrFSKXlc=", | ||||||
|         "owner": "rafaelmardojai", |         "owner": "rafaelmardojai", | ||||||
|         "repo": "thunderbird-gnome-theme", |         "repo": "thunderbird-gnome-theme", | ||||||
|         "rev": "1c89a500dd35b7746ef1fde104a1baf809c2b59a", |         "rev": "966e9dd54bd2ce9d36d51cd6af8c3bac7a764a68", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -684,61 +157,21 @@ | |||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "treefmt-nix": { |     "wallpapers": { | ||||||
|       "inputs": { |       "flake": false, | ||||||
|         "nixpkgs": [ |  | ||||||
|           "nixvim", |  | ||||||
|           "nixpkgs" |  | ||||||
|         ] |  | ||||||
|       }, |  | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1720930114, |         "lastModified": 1702336410, | ||||||
|         "narHash": "sha256-VZK73b5hG5bSeAn97TTcnPjXUXtV7j/AtS4KN8ggCS0=", |         "narHash": "sha256-DyC9Ro5tj3X0P2M24gZdpTkFGuZEy9JXrFLUav/b5H0=", | ||||||
|         "owner": "numtide", |         "ref": "refs/heads/master", | ||||||
|         "repo": "treefmt-nix", |         "rev": "dd78ed7242af54c33e8304feee322a71da575abd", | ||||||
|         "rev": "b92afa1501ac73f1d745526adc4f89b527595f14", |         "shallow": true, | ||||||
|         "type": "github" |         "type": "git", | ||||||
|  |         "url": "ssh://git@git.vimium.com/jordan/wallpapers.git" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
|         "owner": "numtide", |         "shallow": true, | ||||||
|         "repo": "treefmt-nix", |         "type": "git", | ||||||
|         "type": "github" |         "url": "ssh://git@git.vimium.com/jordan/wallpapers.git" | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "utils": { |  | ||||||
|       "inputs": { |  | ||||||
|         "systems": "systems_2" |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1701680307, |  | ||||||
|         "narHash": "sha256-kAuep2h5ajznlPMD9rnQyffWG8EM/C73lejGofXvdM8=", |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "flake-utils", |  | ||||||
|         "rev": "4022d587cbbfd70fe950c1e2083a02621806a725", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "flake-utils", |  | ||||||
|         "type": "github" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "utils_2": { |  | ||||||
|       "inputs": { |  | ||||||
|         "systems": "systems_3" |  | ||||||
|       }, |  | ||||||
|       "locked": { |  | ||||||
|         "lastModified": 1709126324, |  | ||||||
|         "narHash": "sha256-q6EQdSeUZOG26WelxqkmR7kArjgWCdw5sfJVHPH/7j8=", |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "flake-utils", |  | ||||||
|         "rev": "d465f4819400de7c8d874d50b982301f28a84605", |  | ||||||
|         "type": "github" |  | ||||||
|       }, |  | ||||||
|       "original": { |  | ||||||
|         "owner": "numtide", |  | ||||||
|         "repo": "flake-utils", |  | ||||||
|         "type": "github" |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   | |||||||
							
								
								
									
										121
									
								
								flake.nix
									
									
									
									
									
								
							
							
						
						
									
										121
									
								
								flake.nix
									
									
									
									
									
								
							| @@ -2,78 +2,41 @@ | |||||||
|   description = "NixOS system configuration"; |   description = "NixOS system configuration"; | ||||||
|  |  | ||||||
|   inputs = { |   inputs = { | ||||||
|     nixpkgs.url = "nixpkgs/nixos-24.05"; |     nixpkgs.url = "nixpkgs/nixos-23.11"; | ||||||
|     nixpkgs-unstable.url = "nixpkgs/nixos-unstable"; |  | ||||||
|     # nixpkgs-master.url = "nixpkgs"; |  | ||||||
|     agenix.url = "github:ryantm/agenix"; |     agenix.url = "github:ryantm/agenix"; | ||||||
|     deploy-rs.url = "github:serokell/deploy-rs"; |  | ||||||
|     disko = { |  | ||||||
|       url = "github:nix-community/disko"; |  | ||||||
|       inputs.nixpkgs.follows = "nixpkgs"; |  | ||||||
|     }; |  | ||||||
|     home-manager = { |     home-manager = { | ||||||
|       url = "github:nix-community/home-manager/release-24.05"; |       url = "github:nix-community/home-manager/release-23.11"; | ||||||
|       inputs.nixpkgs.follows = "nixpkgs"; |       inputs.nixpkgs.follows = "nixpkgs"; | ||||||
|     }; |     }; | ||||||
|     firefox-gnome-theme = { |     firefox-gnome-theme = { | ||||||
|       url = "github:rafaelmardojai/firefox-gnome-theme"; |       url = "github:rafaelmardojai/firefox-gnome-theme"; | ||||||
|       flake = false; |       flake = false; | ||||||
|     }; |     }; | ||||||
|     gitea-github-theme = { |  | ||||||
|       url = "git+ssh://git@git.vimium.com/jordan/gitea-github-theme.git?ref=main"; |  | ||||||
|       flake = false; |  | ||||||
|     }; |  | ||||||
|     kvlibadwaita = { |  | ||||||
|       url = "github:GabePoel/KvLibadwaita"; |  | ||||||
|       flake = false; |  | ||||||
|     }; |  | ||||||
|     nixos-hardware.url = "github:NixOS/nixos-hardware"; |  | ||||||
|     nixos-mailserver = { |  | ||||||
|       url = "gitlab:simple-nixos-mailserver/nixos-mailserver/nixos-24.05"; |  | ||||||
|       inputs.nixpkgs.follows = "nixpkgs"; |  | ||||||
|     }; |  | ||||||
|     nixvim = { |  | ||||||
|       url = "github:nix-community/nixvim/nixos-24.05"; |  | ||||||
|       inputs.nixpkgs.follows = "nixpkgs"; |  | ||||||
|     }; |  | ||||||
|     plasma-manager = { |  | ||||||
|       url = "github:nix-community/plasma-manager"; |  | ||||||
|       inputs.nixpkgs.follows = "nixpkgs"; |  | ||||||
|       inputs.home-manager.follows = "home-manager"; |  | ||||||
|     }; |  | ||||||
|     secrets = { |  | ||||||
|       url = "git+ssh://git@git.vimium.com/jordan/nix-secrets.git"; |  | ||||||
|       flake = false; |  | ||||||
|     }; |  | ||||||
|     thunderbird-gnome-theme = { |     thunderbird-gnome-theme = { | ||||||
|       url = "github:rafaelmardojai/thunderbird-gnome-theme"; |       url = "github:rafaelmardojai/thunderbird-gnome-theme"; | ||||||
|       flake = false; |       flake = false; | ||||||
|     }; |     }; | ||||||
|  |     wallpapers = { | ||||||
|  |       url = "git+ssh://git@git.vimium.com/jordan/wallpapers.git?shallow=1"; | ||||||
|  |       flake = false; | ||||||
|  |     }; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   outputs = inputs @ { self, nixpkgs, nixpkgs-unstable, agenix, deploy-rs, disko, home-manager, nixos-hardware, nixos-mailserver, ... }: |   outputs = inputs @ { self, nixpkgs, agenix, home-manager, ... }: | ||||||
|     let |     let | ||||||
|       mkPkgsForSystem = system: inputs.nixpkgs; |       nixpkgsForSystem = system: inputs.nixpkgs; | ||||||
|       overlays = [ |       overlays = [ | ||||||
|         agenix.overlays.default |         agenix.overlays.default | ||||||
|         (import ./overlays/gnome.nix) |         (import ./overlays/gnome.nix) | ||||||
|         ( |  | ||||||
|           final: prev: { |  | ||||||
|             unstable = import inputs.nixpkgs-unstable { system = final.system; }; |  | ||||||
|             custom = self.packages { system = final.system; }; |  | ||||||
|           } |  | ||||||
|         ) |  | ||||||
|       ]; |       ]; | ||||||
|       commonModules = [ |       commonModules = [ | ||||||
|         agenix.nixosModules.age |         agenix.nixosModules.age | ||||||
|         disko.nixosModules.disko |  | ||||||
|         nixos-mailserver.nixosModule |  | ||||||
|         home-manager.nixosModule |         home-manager.nixosModule | ||||||
|         ./modules |         ./modules | ||||||
|       ]; |       ]; | ||||||
|       mkNixosSystem = { system, name, extraModules ? [] }: |       nixosSystem = system: name: | ||||||
|         let |         let | ||||||
|           nixpkgs = mkPkgsForSystem system; |           nixpkgs = nixpkgsForSystem system; | ||||||
|           lib = (import nixpkgs { inherit overlays system; }).lib; |           lib = (import nixpkgs { inherit overlays system; }).lib; | ||||||
|         in |         in | ||||||
|         inputs.nixpkgs.lib.nixosSystem { |         inputs.nixpkgs.lib.nixosSystem { | ||||||
| @@ -86,66 +49,22 @@ | |||||||
|                 nixpkgs.pkgs = import nixpkgs { |                 nixpkgs.pkgs = import nixpkgs { | ||||||
|                   inherit overlays system; |                   inherit overlays system; | ||||||
|                   config.allowUnfree = true; |                   config.allowUnfree = true; | ||||||
|                   config.nvidia.acceptLicense = true; |  | ||||||
|                 }; |                 }; | ||||||
|                 networking.hostName = name; |                 networking.hostName = name; | ||||||
|  |                 nix = { | ||||||
|  |                   extraOptions = "experimental-features = nix-command flakes"; | ||||||
|  |                 }; | ||||||
|               }) |               }) | ||||||
|             ./hosts/${name} |             ./hosts/${name} | ||||||
|           ] ++ extraModules; |  | ||||||
|         }; |  | ||||||
|     in |  | ||||||
|     { |  | ||||||
|       nixosConfigurations = { |  | ||||||
|         atlas = mkNixosSystem { system = "x86_64-linux"; name = "atlas"; }; |  | ||||||
|         eos = mkNixosSystem { system = "x86_64-linux"; name = "eos"; }; |  | ||||||
|         helios = mkNixosSystem { system = "x86_64-linux"; name = "helios"; }; |  | ||||||
|         hypnos = mkNixosSystem { system = "x86_64-linux"; name = "hypnos"; }; |  | ||||||
|         library = mkNixosSystem { system = "x86_64-linux"; name = "library"; }; |  | ||||||
|         mail = mkNixosSystem { system = "x86_64-linux"; name = "mail"; }; |  | ||||||
|         odyssey = mkNixosSystem { system = "x86_64-linux"; name = "odyssey"; }; |  | ||||||
|         pi = mkNixosSystem { system = "aarch64-linux"; name = "pi"; extraModules = [ nixos-hardware.nixosModules.raspberry-pi-4 ]; }; |  | ||||||
|         vps1 = mkNixosSystem { system = "x86_64-linux"; name = "vps1"; }; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       devShells.x86_64-linux.default = nixpkgs.legacyPackages.x86_64-linux.mkShell { |  | ||||||
|         buildInputs = [ |  | ||||||
|           deploy-rs.packages.x86_64-linux.deploy-rs |  | ||||||
|           ]; |           ]; | ||||||
|         }; |         }; | ||||||
|  |       nixosConfigurations = { | ||||||
|       deploy = { |         atlas = nixosSystem "x86_64-linux" "atlas"; | ||||||
|         magicRollback = true; |         eos = nixosSystem "x86_64-linux" "eos"; | ||||||
|         autoRollback = true; |         helios = nixosSystem "x86_64-linux" "helios"; | ||||||
|         sshUser = "root"; |         odyssey = nixosSystem "x86_64-linux" "odyssey"; | ||||||
|         nodes = { |  | ||||||
|           mail = { |  | ||||||
|             hostname = "mail.mesh.vimium.net"; |  | ||||||
|  |  | ||||||
|             profiles.system = { |  | ||||||
|               user = "root"; |  | ||||||
|               path = deploy-rs.lib.x86_64-linux.activate.nixos self.nixosConfigurations.mail; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           vps1 = { |  | ||||||
|             hostname = "vps1.mesh.vimium.net"; |  | ||||||
|  |  | ||||||
|             profiles.system = { |  | ||||||
|               user = "root"; |  | ||||||
|               path = deploy-rs.lib.x86_64-linux.activate.nixos self.nixosConfigurations.vps1; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           # pi = { |  | ||||||
|           #   hostname = "10.0.1.191"; |  | ||||||
|           # |  | ||||||
|           #   profiles.system = { |  | ||||||
|           #     user = "root"; |  | ||||||
|           #     path = deploy-rs.lib.aarch64-linux.activate.nixos self.nixosConfigurations.pi; |  | ||||||
|           #   }; |  | ||||||
|           # }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib; |  | ||||||
|       }; |       }; | ||||||
|  |     in | ||||||
|  |     { inherit nixosConfigurations; }; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| { config, lib, ... }: | { config, lib, pkgs, ... }: | ||||||
|  |  | ||||||
| { | { | ||||||
|   imports = [ |   imports = [ | ||||||
| @@ -6,18 +6,21 @@ | |||||||
|     ../desktop.nix |     ../desktop.nix | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   boot.loader = { |   boot.loader.systemd-boot.enable = true; | ||||||
|     systemd-boot.enable = true; |   boot.loader.efi.canTouchEfiVariables = true; | ||||||
|     efi.canTouchEfiVariables = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   networking = { |   networking.hostName = "atlas"; | ||||||
|     hostId = "8425e349"; |   networking.hostId = "8425e349"; | ||||||
|     networkmanager.enable = true; |   networking.networkmanager.enable = true; | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   virtualisation.virtualbox.host.enable = true; |   nix.package = pkgs.nixFlakes; | ||||||
|   users.extraGroups.vboxusers.members = [ "jordan" ]; |   nix.extraOptions = '' | ||||||
|  |     experimental-features = nix-command flakes | ||||||
|  |   ''; | ||||||
|  |  | ||||||
|  |   users.defaultUserShell = pkgs.zsh; | ||||||
|  |  | ||||||
|  |   system.stateVersion = "22.11"; | ||||||
|  |  | ||||||
|   modules = { |   modules = { | ||||||
|     desktop = { |     desktop = { | ||||||
| @@ -39,25 +42,15 @@ | |||||||
|     }; |     }; | ||||||
|     editors = { |     editors = { | ||||||
|       neovim.enable = true; |       neovim.enable = true; | ||||||
|  |       vscode.enable = true; | ||||||
|     }; |     }; | ||||||
|     security = { |     security = { | ||||||
|       gpg.enable = true; |       gpg.enable = true; | ||||||
|       pass.enable = true; |       pass.enable = true; | ||||||
|     }; |     }; | ||||||
|     services = { |  | ||||||
|       borgmatic = { |  | ||||||
|         enable = true; |  | ||||||
|         directories = [ |  | ||||||
|           "/home/jordan/Documents" |  | ||||||
|         ]; |  | ||||||
|         repoPath = "ssh://uzu2y5b1@uzu2y5b1.repo.borgbase.com/./repo"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     shell = { |     shell = { | ||||||
|       git.enable = true; |       git.enable = true; | ||||||
|       zsh.enable = true; |       zsh.enable = true; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,72 +0,0 @@ | |||||||
| { config, lib, pkgs, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   time.timeZone = "Europe/London"; |  | ||||||
|  |  | ||||||
|   i18n.defaultLocale = "en_GB.UTF-8"; |  | ||||||
|   i18n.extraLocaleSettings = { |  | ||||||
|     LC_ADDRESS = "en_GB.UTF-8"; |  | ||||||
|     LC_IDENTIFICATION = "en_GB.UTF-8"; |  | ||||||
|     LC_MEASUREMENT = "en_GB.UTF-8"; |  | ||||||
|     LC_MONETARY = "en_GB.UTF-8"; |  | ||||||
|     LC_NAME = "en_GB.UTF-8"; |  | ||||||
|     LC_NUMERIC = "en_GB.UTF-8"; |  | ||||||
|     LC_PAPER = "en_GB.UTF-8"; |  | ||||||
|     LC_TELEPHONE = "en_GB.UTF-8"; |  | ||||||
|     LC_TIME = "en_GB.UTF-8"; |  | ||||||
|   }; |  | ||||||
|    |  | ||||||
|   console.keyMap = "uk"; |  | ||||||
|  |  | ||||||
|   security.sudo.execWheelOnly = true; |  | ||||||
|  |  | ||||||
|   services.openssh = { |  | ||||||
|     enable = true; |  | ||||||
|     settings = { |  | ||||||
|       KbdInteractiveAuthentication = false; |  | ||||||
|       PasswordAuthentication = false; |  | ||||||
|       PermitRootLogin = "no"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.journald.extraConfig = '' |  | ||||||
|     SystemMaxUse=4G |  | ||||||
|     MaxRetentionSec=90day |  | ||||||
|   ''; |  | ||||||
|  |  | ||||||
|   users.defaultUserShell = pkgs.zsh; |  | ||||||
|   programs.zsh.enable = true; |  | ||||||
|  |  | ||||||
|   nix = { |  | ||||||
|     package = pkgs.nixFlakes; |  | ||||||
|     extraOptions = '' |  | ||||||
|       experimental-features = nix-command flakes |  | ||||||
|     ''; |  | ||||||
|     settings = { |  | ||||||
|       connect-timeout = 5; |  | ||||||
|       log-lines = 25; |  | ||||||
|       min-free = 128000000; |  | ||||||
|       max-free = 1000000000; |  | ||||||
|       fallback = true; |  | ||||||
|       trusted-users = [ "@wheel" ]; |  | ||||||
|       auto-optimise-store = true; |  | ||||||
|       substituters = [ |  | ||||||
|         "http://odyssey.mesh.vimium.net" |  | ||||||
|         "https://cache.nixos.org" |  | ||||||
|       ]; |  | ||||||
|       trusted-public-keys = [ |  | ||||||
|         "odyssey.mesh.vimium.net:ZhQhjscPWjoN4rlZwoMELznEiBnZ9O26iyGA27ibilQ=" |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|     gc = { |  | ||||||
|       automatic = true; |  | ||||||
|       dates = "weekly"; |  | ||||||
|       options = "-d --delete-older-than 7d"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   environment.systemPackages = with pkgs; [ |  | ||||||
|     git |  | ||||||
|     neovim |  | ||||||
|   ]; |  | ||||||
| } |  | ||||||
| @@ -1,12 +1,33 @@ | |||||||
| { config, lib, pkgs, ... }: | { config, lib, pkgs, ... }: | ||||||
|  |  | ||||||
| { | { | ||||||
|   imports = [ |   time.timeZone = "Europe/London"; | ||||||
|     ./common.nix |  | ||||||
|   ]; |   i18n.defaultLocale = "en_GB.UTF-8"; | ||||||
|  |   i18n.extraLocaleSettings = { | ||||||
|  |     LC_ADDRESS = "en_GB.UTF-8"; | ||||||
|  |     LC_IDENTIFICATION = "en_GB.UTF-8"; | ||||||
|  |     LC_MEASUREMENT = "en_GB.UTF-8"; | ||||||
|  |     LC_MONETARY = "en_GB.UTF-8"; | ||||||
|  |     LC_NAME = "en_GB.UTF-8"; | ||||||
|  |     LC_NUMERIC = "en_GB.UTF-8"; | ||||||
|  |     LC_PAPER = "en_GB.UTF-8"; | ||||||
|  |     LC_TELEPHONE = "en_GB.UTF-8"; | ||||||
|  |     LC_TIME = "en_GB.UTF-8"; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   console.keyMap = "uk"; | ||||||
|  |  | ||||||
|   services.printing.enable = true; |   services.printing.enable = true; | ||||||
|   services.openssh.startWhenNeeded = true; |   services.openssh = { | ||||||
|  |     enable = true; | ||||||
|  |     settings = { | ||||||
|  |       KbdInteractiveAuthentication = false; | ||||||
|  |       PasswordAuthentication = false; | ||||||
|  |       PermitRootLogin = "no"; | ||||||
|  |     }; | ||||||
|  |     startWhenNeeded = true; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|   sound.enable = true; |   sound.enable = true; | ||||||
|   hardware.pulseaudio.enable = false; |   hardware.pulseaudio.enable = false; | ||||||
| @@ -18,58 +39,34 @@ | |||||||
|     pulse.enable = true; |     pulse.enable = true; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   fileSystems."/mnt/library" = { |  | ||||||
|     device = "library.mesh.vimium.net:/mnt/library"; |  | ||||||
|     fsType = "nfs"; |  | ||||||
|     options = [ |  | ||||||
|       "nfsvers=4.2" |  | ||||||
|       "bg" |  | ||||||
|       "soft" |  | ||||||
|       "timeo=20" |  | ||||||
|       "retry=5" |  | ||||||
|       "nocto" |  | ||||||
|       "ro" |  | ||||||
|       "x-systemd.automount" |  | ||||||
|       "x-systemd.requires=tailscaled.service" |  | ||||||
|       "noauto" |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   system.autoUpgrade = { |  | ||||||
|     enable = true; |  | ||||||
|     flake = "git+ssh://git@git.vimium.com/jordan/nix-config.git"; |  | ||||||
|     randomizedDelaySec = "10min"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   systemd.services.NetworkManager-wait-online.enable = false; |  | ||||||
|  |  | ||||||
|   fonts.packages = with pkgs; [ |  | ||||||
|     noto-fonts |  | ||||||
|     (nerdfonts.override { fonts = [ "BigBlueTerminal" "ComicShannsMono" "Terminus" "UbuntuMono" ]; }) |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   modules = { |  | ||||||
|     desktop.gnome.enable = true; |  | ||||||
|     networking.tailscale.enable = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   environment.systemPackages = with pkgs; [ |   environment.systemPackages = with pkgs; [ | ||||||
|     bind |     git | ||||||
|     bmon |     neovim | ||||||
|     fd |  | ||||||
|     ffmpeg |  | ||||||
|     iotop |  | ||||||
|     unstable.nix-du |  | ||||||
|     # unstable.nix-melt |  | ||||||
|     unstable.nix-tree |  | ||||||
|     unstable.nix-visualize |  | ||||||
|     ripgrep |  | ||||||
|     rsync |  | ||||||
|     tcpdump |  | ||||||
|     tokei |  | ||||||
|     tree |  | ||||||
|     wl-clipboard |  | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   environment.sessionVariables.NIXOS_OZONE_WL = "1"; |   nix = { | ||||||
|  |     settings = { | ||||||
|  |       connect-timeout = 5; | ||||||
|  |       log-lines = 25; | ||||||
|  |       min-free = 128000000; | ||||||
|  |       max-free = 1000000000; | ||||||
|  |       fallback = true; | ||||||
|  |       auto-optimise-store = true; | ||||||
|  |       substituters = [ | ||||||
|  |         "http://odyssey.mesh.vimium.net" | ||||||
|  |         "https://cache.nixos.org" | ||||||
|  |       ]; | ||||||
|  |       trusted-public-keys = [ | ||||||
|  |         "odyssey.mesh.vimium.net:ZhQhjscPWjoN4rlZwoMELznEiBnZ9O26iyGA27ibilQ=" | ||||||
|  |       ]; | ||||||
|  |     }; | ||||||
|  |     gc = { | ||||||
|  |       automatic = true; | ||||||
|  |       dates = "weekly"; | ||||||
|  |       options = "-d --delete-older-than 7d"; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   modules.desktop.gnome.enable = true; | ||||||
|  |   modules.networking.tailscale.enable = true; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -6,15 +6,22 @@ | |||||||
|     ../desktop.nix |     ../desktop.nix | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   boot.loader = { |   boot.loader.systemd-boot.enable = true; | ||||||
|     systemd-boot.enable = true; |   boot.loader.efi.canTouchEfiVariables = true; | ||||||
|     efi.canTouchEfiVariables = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   networking = { |   networking.hostName = "eos"; | ||||||
|     hostId = "cc858347"; |   networking.hostId = "cc858347"; | ||||||
|     networkmanager.enable = true; |   networking.networkmanager.enable = true; | ||||||
|   }; |  | ||||||
|  |   nix.package = pkgs.nixFlakes; | ||||||
|  |   nix.extraOptions = '' | ||||||
|  |     experimental-features = nix-command flakes | ||||||
|  |   ''; | ||||||
|  |   nix.settings.auto-optimise-store = true; | ||||||
|  |  | ||||||
|  |   users.defaultUserShell = pkgs.zsh; | ||||||
|  |  | ||||||
|  |   system.stateVersion = "22.11"; | ||||||
|  |  | ||||||
|   dconf.settings = { |   dconf.settings = { | ||||||
|     "org/gnome/desktop/interface" = { |     "org/gnome/desktop/interface" = { | ||||||
| @@ -44,6 +51,4 @@ | |||||||
|       zsh.enable = true; |       zsh.enable = true; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: | { config, lib, pkgs, ... }: | ||||||
|  |  | ||||||
| { | { | ||||||
|   imports = [ |   imports = [ | ||||||
| @@ -6,18 +6,22 @@ | |||||||
|     ../desktop.nix |     ../desktop.nix | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   boot = { |   boot.loader.grub.enable = true; | ||||||
|     loader.grub = { |   boot.loader.grub.device = "/dev/sda"; | ||||||
|       enable = true; |   boot.loader.grub.zfsSupport = true; | ||||||
|       device = "/dev/sda"; |  | ||||||
|       zfsSupport = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   networking = { |   networking.hostName = "helios"; | ||||||
|     hostId = "47d23505"; |   networking.hostId = "47d23505"; | ||||||
|     networkmanager.enable = true; |   networking.networkmanager.enable = true; | ||||||
|   }; |  | ||||||
|  |   nix.package = pkgs.nixFlakes; | ||||||
|  |   nix.extraOptions = '' | ||||||
|  |     experimental-features = nix-command flakes | ||||||
|  |   ''; | ||||||
|  |  | ||||||
|  |   users.defaultUserShell = pkgs.zsh; | ||||||
|  |  | ||||||
|  |   system.stateVersion = "22.11"; | ||||||
|  |  | ||||||
|   modules = { |   modules = { | ||||||
|     desktop = { |     desktop = { | ||||||
| @@ -36,20 +40,9 @@ | |||||||
|       gpg.enable = true; |       gpg.enable = true; | ||||||
|       pass.enable = true; |       pass.enable = true; | ||||||
|     }; |     }; | ||||||
|     services = { |  | ||||||
|       borgmatic = { |  | ||||||
|         enable = true; |  | ||||||
|         directories = [ |  | ||||||
|           "/home/jordan/Documents" |  | ||||||
|         ]; |  | ||||||
|         repoPath = "ssh://b9cjl9hq@b9cjl9hq.repo.borgbase.com/./repo"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     shell = { |     shell = { | ||||||
|       git.enable = true; |       git.enable = true; | ||||||
|       zsh.enable = true; |       zsh.enable = true; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,102 +0,0 @@ | |||||||
| From d310ddee0fb8e7a5a8b89668c6cb8f9dc863ce94 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Jordan Holt <jordan@vimium.com> |  | ||||||
| Date: Sun, 28 Apr 2024 15:59:52 +0100 |  | ||||||
| Subject: [PATCH] Add apple_set_os EFI boot service |  | ||||||
|  |  | ||||||
| --- |  | ||||||
|  drivers/firmware/efi/libstub/x86-stub.c | 59 +++++++++++++++++++++++++ |  | ||||||
|  include/linux/efi.h                     |  1 + |  | ||||||
|  2 files changed, 60 insertions(+) |  | ||||||
|  |  | ||||||
| diff --git a/drivers/firmware/efi/libstub/x86-stub.c b/drivers/firmware/efi/libstub/x86-stub.c |  | ||||||
| index d5a8182cf..be722c43a 100644 |  | ||||||
| --- a/drivers/firmware/efi/libstub/x86-stub.c |  | ||||||
| +++ b/drivers/firmware/efi/libstub/x86-stub.c |  | ||||||
| @@ -449,6 +449,63 @@ static void setup_graphics(struct boot_params *boot_params) |  | ||||||
|  	} |  | ||||||
|  } |  | ||||||
|   |  | ||||||
| +typedef struct { |  | ||||||
| +	u64 version; |  | ||||||
| +	void (*set_os_version) (const char *os_version); |  | ||||||
| +	void (*set_os_vendor) (const char *os_vendor); |  | ||||||
| +} apple_set_os_interface_t; |  | ||||||
| + |  | ||||||
| +static efi_status_t apple_set_os() |  | ||||||
| +{ |  | ||||||
| +	apple_set_os_interface_t *set_os; |  | ||||||
| +	efi_guid_t set_os_guid = APPLE_SET_OS_PROTOCOL_GUID; |  | ||||||
| +	efi_status_t status; |  | ||||||
| +	void **handles; |  | ||||||
| +	unsigned long i, nr_handles, size = 0; |  | ||||||
| + |  | ||||||
| +	status = efi_bs_call(locate_handle, EFI_LOCATE_BY_PROTOCOL, |  | ||||||
| +			     &set_os_guid, NULL, &size, handles); |  | ||||||
| + |  | ||||||
| +	if (status == EFI_BUFFER_TOO_SMALL) { |  | ||||||
| +		status = efi_bs_call(allocate_pool, EFI_LOADER_DATA, |  | ||||||
| +				     size, &handles); |  | ||||||
| + |  | ||||||
| +		if (status != EFI_SUCCESS) |  | ||||||
| +			return status; |  | ||||||
| + |  | ||||||
| +		status = efi_bs_call(locate_handle, EFI_LOCATE_BY_PROTOCOL, |  | ||||||
| +				     &set_os_guid, NULL, &size, handles); |  | ||||||
| +	} |  | ||||||
| + |  | ||||||
| +	if (status != EFI_SUCCESS) |  | ||||||
| +		goto free_handle; |  | ||||||
| + |  | ||||||
| +	nr_handles = size / sizeof(void *); |  | ||||||
| +	for (i = 0; i < nr_handles; i++) { |  | ||||||
| +		void *h = handles[i]; |  | ||||||
| + |  | ||||||
| +		status = efi_bs_call(handle_protocol, h, |  | ||||||
| +				     &set_os_guid, &set_os); |  | ||||||
| + |  | ||||||
| +		if (status != EFI_SUCCESS || !set_os) |  | ||||||
| +			continue; |  | ||||||
| + |  | ||||||
| +		if (set_os->version > 0) { |  | ||||||
| +			efi_bs_call((unsigned long)set_os->set_os_version, |  | ||||||
| +					"Mac OS X 10.9"); |  | ||||||
| +		} |  | ||||||
| + |  | ||||||
| +		if (set_os->version >= 2) { |  | ||||||
| +			efi_bs_call((unsigned long)set_os->set_os_vendor, |  | ||||||
| +					"Apple Inc."); |  | ||||||
| +		} |  | ||||||
| +	} |  | ||||||
| + |  | ||||||
| +free_handle: |  | ||||||
| +	efi_bs_call(free_pool, uga_handle); |  | ||||||
| + |  | ||||||
| +	return status; |  | ||||||
| +} |  | ||||||
|   |  | ||||||
|  static void __noreturn efi_exit(efi_handle_t handle, efi_status_t status) |  | ||||||
|  { |  | ||||||
| @@ -951,6 +1008,8 @@ void __noreturn efi_stub_entry(efi_handle_t handle, |  | ||||||
|   |  | ||||||
|  	setup_unaccepted_memory(); |  | ||||||
|   |  | ||||||
| +	apple_set_os(); |  | ||||||
| + |  | ||||||
|  	status = exit_boot(boot_params, handle); |  | ||||||
|  	if (status != EFI_SUCCESS) { |  | ||||||
|  		efi_err("exit_boot() failed!\n"); |  | ||||||
| diff --git a/include/linux/efi.h b/include/linux/efi.h |  | ||||||
| index d59b0947f..81158014f 100644 |  | ||||||
| --- a/include/linux/efi.h |  | ||||||
| +++ b/include/linux/efi.h |  | ||||||
| @@ -385,6 +385,7 @@ void efi_native_runtime_setup(void); |  | ||||||
|  #define EFI_MEMORY_ATTRIBUTES_TABLE_GUID	EFI_GUID(0xdcfa911d, 0x26eb, 0x469f,  0xa2, 0x20, 0x38, 0xb7, 0xdc, 0x46, 0x12, 0x20) |  | ||||||
|  #define EFI_CONSOLE_OUT_DEVICE_GUID		EFI_GUID(0xd3b36f2c, 0xd551, 0x11d4,  0x9a, 0x46, 0x00, 0x90, 0x27, 0x3f, 0xc1, 0x4d) |  | ||||||
|  #define APPLE_PROPERTIES_PROTOCOL_GUID		EFI_GUID(0x91bd12fe, 0xf6c3, 0x44fb,  0xa5, 0xb7, 0x51, 0x22, 0xab, 0x30, 0x3a, 0xe0) |  | ||||||
| +#define APPLE_SET_OS_PROTOCOL_GUID		EFI_GUID(0xc5c5da95, 0x7d5c, 0x45e6,  0xb2, 0xf1, 0x3f, 0xd5, 0x2b, 0xb1, 0x00, 0x77) |  | ||||||
|  #define EFI_TCG2_PROTOCOL_GUID			EFI_GUID(0x607f766c, 0x7455, 0x42be,  0x93, 0x0b, 0xe4, 0xd7, 0x6d, 0xb2, 0x72, 0x0f) |  | ||||||
|  #define EFI_TCG2_FINAL_EVENTS_TABLE_GUID	EFI_GUID(0x1e2ed096, 0x30e2, 0x4254,  0xbd, 0x89, 0x86, 0x3b, 0xbe, 0xf8, 0x23, 0x25) |  | ||||||
|  #define EFI_LOAD_FILE_PROTOCOL_GUID		EFI_GUID(0x56ec3091, 0x954c, 0x11d2,  0x8e, 0x3f, 0x00, 0xa0, 0xc9, 0x69, 0x72, 0x3b) |  | ||||||
| --  |  | ||||||
| 2.42.0 |  | ||||||
|  |  | ||||||
| @@ -1,35 +0,0 @@ | |||||||
| # Hypnos |  | ||||||
|  |  | ||||||
| ## Overview |  | ||||||
| 15-inch MacBook Pro 11,3 (Mid 2014). |  | ||||||
|  |  | ||||||
| ## Specs |  | ||||||
| * CPU - Intel Core i7-4870HQ @ 2.50GHz |  | ||||||
| * Memory - 16 GB DDR3 |  | ||||||
| * GPU - Intel Iris Pro 5200 |  | ||||||
| * GPU - NVIDIA GeForce GT 750M |  | ||||||
| * NIC - Broadcom BCM43xx 802.11ac |  | ||||||
|  |  | ||||||
| ### Disks |  | ||||||
| Device | Partitions _(filesystem, size, usage)_ |  | ||||||
| --- | --- |  | ||||||
| Apple SSD SM0512F | `/dev/sda1` (EFI, 256 MiB, NixOS Boot) <br> `/dev/sda2` (ZFS, 500 GiB, NixOS Root) |  | ||||||
|  |  | ||||||
| #### ZFS pool layout |  | ||||||
| ``` |  | ||||||
| rpool/ |  | ||||||
| ├── local |  | ||||||
| │   ├── nix |  | ||||||
| │   └── tmp |  | ||||||
| ├── system |  | ||||||
| │   ├── root |  | ||||||
| │   └── var |  | ||||||
| └── user |  | ||||||
|     └── home |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| See [Graham Christensen's article](https://grahamc.com/blog/nixos-on-zfs/#datasets) for the motivation behind these datasets. |  | ||||||
|  |  | ||||||
| ### Networks |  | ||||||
| - DHCP on `10.0.1.0/24` subnet. |  | ||||||
| - Tailscale on `100.64.0.0/10` subnet. FQDN: `hypnos.mesh.vimium.net`. |  | ||||||
| @@ -1,58 +0,0 @@ | |||||||
| { config, lib, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     ./hardware-configuration.nix |  | ||||||
|     ./disko-config.nix |  | ||||||
|     ../desktop.nix |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   boot.loader = { |  | ||||||
|     systemd-boot.enable = true; |  | ||||||
|     efi.canTouchEfiVariables = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   networking.hostId = "cf791898"; |  | ||||||
|  |  | ||||||
|   # nvidia 470 driver doesn't work with Wayland |  | ||||||
|   services = { |  | ||||||
|     xserver = { |  | ||||||
|       displayManager.gdm.wayland = lib.mkForce false; |  | ||||||
|       videoDrivers = [ "nvidia" ]; |  | ||||||
|     }; |  | ||||||
|     displayManager = { |  | ||||||
|       defaultSession = if config.modules.desktop.kde.enable then "plasmax11" else "gnome-xorg"; |  | ||||||
|       sddm.wayland.enable = lib.mkForce false; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   # Workaround for label rendering bug in GTK4 with nvidia 470 driver |  | ||||||
|   environment.sessionVariables.GSK_RENDERER = "gl"; |  | ||||||
|  |  | ||||||
|   modules = { |  | ||||||
|     desktop = { |  | ||||||
|       browsers = { |  | ||||||
|         firefox.enable = true; |  | ||||||
|       }; |  | ||||||
|       media.recording = { |  | ||||||
|         audio.enable = true; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     dev = { |  | ||||||
|       node.enable = true; |  | ||||||
|     }; |  | ||||||
|     editors = { |  | ||||||
|       neovim.enable = true; |  | ||||||
|     }; |  | ||||||
|     security = { |  | ||||||
|       gpg.enable = true; |  | ||||||
|       pass.enable = true; |  | ||||||
|     }; |  | ||||||
|     shell = { |  | ||||||
|       git.enable = true; |  | ||||||
|       zsh.enable = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } |  | ||||||
| @@ -1,126 +0,0 @@ | |||||||
| { lib, ... }: |  | ||||||
| { |  | ||||||
|   disko.devices = { |  | ||||||
|     disk = { |  | ||||||
|       main = { |  | ||||||
|         type = "disk"; |  | ||||||
|         device = "/dev/disk/by-id/ata-APPLE_SSD_SM0512F_S1K5NYBF736152"; |  | ||||||
|         content = { |  | ||||||
|           type = "gpt"; |  | ||||||
|           partitions = { |  | ||||||
|             ESP = { |  | ||||||
|               size = "256M"; |  | ||||||
|               type = "EF00"; |  | ||||||
|               content = { |  | ||||||
|                 type = "filesystem"; |  | ||||||
|                 format = "vfat"; |  | ||||||
|                 mountpoint = "/boot"; |  | ||||||
|               }; |  | ||||||
|             }; |  | ||||||
|             zfs = { |  | ||||||
|               size = "100%"; |  | ||||||
|               content = { |  | ||||||
|                 type = "zfs"; |  | ||||||
|                 pool = "rpool"; |  | ||||||
|               }; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     zpool = { |  | ||||||
|       rpool = { |  | ||||||
|         type = "zpool"; |  | ||||||
|         options = { |  | ||||||
|           ashift = "12"; |  | ||||||
|         }; |  | ||||||
|         rootFsOptions = { |  | ||||||
|           canmount = "off"; |  | ||||||
|           mountpoint = "none"; |  | ||||||
|           dnodesize = "auto"; |  | ||||||
|           xattr = "sa"; |  | ||||||
|         }; |  | ||||||
|         postCreateHook = "zfs snapshot rpool@blank"; |  | ||||||
|         datasets = { |  | ||||||
|           local = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             options = { |  | ||||||
|               mountpoint = "none"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           "local/nix" = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             mountpoint = "/nix"; |  | ||||||
|             options = { |  | ||||||
|               atime = "off"; |  | ||||||
|               mountpoint = "legacy"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           "local/tmp" = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             mountpoint = "/tmp"; |  | ||||||
|             options = { |  | ||||||
|               setuid = "off"; |  | ||||||
|               devices = "off"; |  | ||||||
|               mountpoint = "legacy"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           system = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             mountpoint = "/"; |  | ||||||
|             options = { |  | ||||||
|               mountpoint = "legacy"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           "system/var" = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             mountpoint = "/var"; |  | ||||||
|             options = { |  | ||||||
|               mountpoint = "legacy"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           "system/var/tmp" = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             mountpoint = "/var/tmp"; |  | ||||||
|             options = { |  | ||||||
|               devices = "off"; |  | ||||||
|               mountpoint = "legacy"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           "system/var/log" = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             mountpoint = "/var/log"; |  | ||||||
|             options = { |  | ||||||
|               compression = "on"; |  | ||||||
|               acltype = "posix"; |  | ||||||
|               mountpoint = "legacy"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           user = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             options = { |  | ||||||
|               mountpoint = "none"; |  | ||||||
|               encryption = "aes-256-gcm"; |  | ||||||
|               keyformat = "passphrase"; |  | ||||||
|               keylocation = "file:///tmp/secret.key"; |  | ||||||
|             }; |  | ||||||
|             # use this to read the key during boot |  | ||||||
|             postCreateHook = '' |  | ||||||
|               zfs set keylocation="prompt" "rpool/$name"; |  | ||||||
|             ''; |  | ||||||
|           }; |  | ||||||
|           "user/home" = { |  | ||||||
|             type = "zfs_fs"; |  | ||||||
|             mountpoint = "/home"; |  | ||||||
|             options = { |  | ||||||
|               setuid = "off"; |  | ||||||
|               devices = "off"; |  | ||||||
|               mountpoint = "legacy"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,38 +0,0 @@ | |||||||
| { config, lib, pkgs, modulesPath, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     (modulesPath + "/installer/scan/not-detected.nix") |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   boot = { |  | ||||||
|     initrd.availableKernelModules = [ "xhci_pci" "ahci" "usbhid" "usb_storage" "sd_mod" ]; |  | ||||||
|     kernelModules = [ "applesmc" "kvm-intel" "wl" ]; |  | ||||||
|     extraModulePackages = [ |  | ||||||
|       config.boot.kernelPackages.broadcom_sta |  | ||||||
|       config.boot.kernelPackages.nvidiaPackages.legacy_470 |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   networking.useDHCP = lib.mkDefault true; |  | ||||||
|  |  | ||||||
|   nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; |  | ||||||
|  |  | ||||||
|   hardware = { |  | ||||||
|     cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; |  | ||||||
|     nvidia = { |  | ||||||
|       package = config.boot.kernelPackages.nvidiaPackages.legacy_470; |  | ||||||
|       modesetting.enable = true; |  | ||||||
|       powerManagement.enable = true; |  | ||||||
|     }; |  | ||||||
|     opengl = { |  | ||||||
|       enable = true; |  | ||||||
|       extraPackages = with pkgs; [ |  | ||||||
|         libvdpau-va-gl |  | ||||||
|       ]; |  | ||||||
|       driSupport = true; |  | ||||||
|       driSupport32Bit = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,46 +0,0 @@ | |||||||
| # Library |  | ||||||
|  |  | ||||||
| ## Overview |  | ||||||
| Media and public file server. |  | ||||||
|  |  | ||||||
| ## Specs |  | ||||||
| * CPU - AMD Ryzen 5 5600G @ 3.90GHz |  | ||||||
| * Chipset - AMD B550 |  | ||||||
| * Memory - 64 GB DDR4 |  | ||||||
| * Motherboard - ASRock B550M Pro4 |  | ||||||
| * Case - Fractal Design Node 804 |  | ||||||
|  |  | ||||||
| ### Disks |  | ||||||
| Device | Partitions _(filesystem, size, usage)_ |  | ||||||
| --- | --- |  | ||||||
| Samsung 980 Evo | `/dev/nvme0n1p1` (EFI, 512 MiB, NixOS Boot) <br> `/dev/nvme0n1p2` (ZFS `rpool`, 200 GiB, NixOS Root) |  | ||||||
|  |  | ||||||
| #### ZFS datasets |  | ||||||
| ``` |  | ||||||
| rpool/ |  | ||||||
| ├── local |  | ||||||
| │   ├── nix |  | ||||||
| │   └── tmp |  | ||||||
| ├── system |  | ||||||
| │   ├── root |  | ||||||
| │   └── var |  | ||||||
| └── user |  | ||||||
|     └── home |  | ||||||
|  |  | ||||||
| library/ |  | ||||||
| ├── books |  | ||||||
| ├── fonts |  | ||||||
| ├── movies |  | ||||||
| ├── music |  | ||||||
| ├── software |  | ||||||
| ├── tv |  | ||||||
| ├── videos |  | ||||||
| └── web |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| See [Graham Christensen's article](https://grahamc.com/blog/nixos-on-zfs/#datasets) for the motivation behind the `rpool` datasets. |  | ||||||
|  |  | ||||||
| ### Networks |  | ||||||
| - DHCP on `10.0.1.0/24` subnet. |  | ||||||
| - Tailscale on `100.64.0.0/10` subnet. FQDN: `library.mesh.vimium.net`. |  | ||||||
|  |  | ||||||
| @@ -1,194 +0,0 @@ | |||||||
| { config, pkgs, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     ./hardware-configuration.nix |  | ||||||
|     ../server.nix |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   boot = { |  | ||||||
|     loader.systemd-boot.enable = true; |  | ||||||
|     loader.efi.canTouchEfiVariables = true; |  | ||||||
|     zfs.extraPools = [ "library" ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   networking = { |  | ||||||
|     domain = "mesh.vimium.net"; |  | ||||||
|     hostId = "d24ae953"; |  | ||||||
|     firewall = { |  | ||||||
|       enable = true; |  | ||||||
|       allowedTCPPorts = [ |  | ||||||
|         22  # SSH |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.zfs = { |  | ||||||
|     autoScrub = { |  | ||||||
|       enable = true; |  | ||||||
|       pools = [ "library" ]; |  | ||||||
|     }; |  | ||||||
|     autoSnapshot = { |  | ||||||
|       enable = true; |  | ||||||
|       flags = "-k -p --utc"; |  | ||||||
|       frequent = 0; |  | ||||||
|       hourly = 0; |  | ||||||
|       daily = 7; |  | ||||||
|       monthly = 1; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.nfs.server = { |  | ||||||
|     enable = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.grafana = { |  | ||||||
|     enable = true; |  | ||||||
|     settings = { |  | ||||||
|       server = { |  | ||||||
|         domain = "library.mesh.vimium.net"; |  | ||||||
|         http_addr = "0.0.0.0"; |  | ||||||
|         http_port = 3000; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.prometheus = { |  | ||||||
|     enable = true; |  | ||||||
|     port = 9001; |  | ||||||
|     exporters = { |  | ||||||
|       node = { |  | ||||||
|         enable = true; |  | ||||||
|         enabledCollectors = [ "systemd" ]; |  | ||||||
|         port = 9002; |  | ||||||
|       }; |  | ||||||
|       zfs = { |  | ||||||
|         enable = true; |  | ||||||
|         port = 9003; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     scrapeConfigs = [ |  | ||||||
|       { |  | ||||||
|         job_name = "node"; |  | ||||||
|         static_configs = [{ |  | ||||||
|           targets = [ |  | ||||||
|             "127.0.0.1:${toString config.services.prometheus.exporters.node.port}" |  | ||||||
|             "127.0.0.1:${toString config.services.prometheus.exporters.zfs.port}" |  | ||||||
|           ]; |  | ||||||
|         }]; |  | ||||||
|       } |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   systemd.services.vps1-tunnel = { |  | ||||||
|     enable = true; |  | ||||||
|     description = "vps1.mesh.vimium.net SSH tunnel"; |  | ||||||
|     after = [ |  | ||||||
|       "network-online.target" |  | ||||||
|       "jellyfin.service" |  | ||||||
|     ]; |  | ||||||
|     wants = [ "network-online.target" ]; |  | ||||||
|     serviceConfig = { |  | ||||||
|       Type="simple"; |  | ||||||
|       ExecStart=pkgs.lib.mkForce '' |  | ||||||
|         ${pkgs.openssh}/bin/ssh \ |  | ||||||
|           -NT \ |  | ||||||
|           -o ExitOnForwardFailure=yes \ |  | ||||||
|           -o ServerAliveInterval=60 \ |  | ||||||
|           -o TCPKeepAlive=no \ |  | ||||||
|           -i %h/.ssh/id_jellyfin \ |  | ||||||
|           -R localhost:8000:localhost:8000 \ |  | ||||||
|           jellyfin@vps1.mesh.vimium.net |  | ||||||
|       ''; |  | ||||||
|       Restart="always"; |  | ||||||
|       RestartSec=20; |  | ||||||
|     }; |  | ||||||
|     wantedBy = [ "default.target" ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.nginx = let |  | ||||||
|     proxyConfig = '' |  | ||||||
|       proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; |  | ||||||
|       proxy_set_header X-Forwarded-Proto $scheme; |  | ||||||
|       proxy_set_header X-Real-IP $remote_addr; |  | ||||||
|       proxy_set_header Host $host; |  | ||||||
|  |  | ||||||
|       proxy_set_header Range $http_range; |  | ||||||
|       proxy_set_header If-Range $http_if_range; |  | ||||||
|  |  | ||||||
|       proxy_http_version 1.1; |  | ||||||
|       proxy_set_header Upgrade $http_upgrade; |  | ||||||
|       proxy_set_header Connection "upgrade"; |  | ||||||
|     ''; |  | ||||||
|   in { |  | ||||||
|     enable = true; |  | ||||||
|     package = pkgs.openresty; |  | ||||||
|     recommendedGzipSettings = true; |  | ||||||
|     recommendedOptimisation = true; |  | ||||||
|     recommendedTlsSettings = true; |  | ||||||
|     clientMaxBodySize = "2G"; |  | ||||||
|     virtualHosts = { |  | ||||||
|       "library.mesh.vimium.net" = { |  | ||||||
|         locations."/" = { |  | ||||||
|           root = "/mnt/library"; |  | ||||||
|           extraConfig = '' |  | ||||||
|             autoindex on; |  | ||||||
|           ''; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|       "jellyfin.vimium.com" = { |  | ||||||
|         default = true; |  | ||||||
|         listen = [ |  | ||||||
|           { |  | ||||||
|             addr = "127.0.0.1"; |  | ||||||
|             port = 8000; |  | ||||||
|           } |  | ||||||
|         ]; |  | ||||||
|         locations."/" = { |  | ||||||
|           proxyPass = "http://localhost:8096"; |  | ||||||
|           extraConfig = proxyConfig; |  | ||||||
|         }; |  | ||||||
|         locations."/metrics" = { |  | ||||||
|           return = "404"; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   hardware.opengl = { |  | ||||||
|     enable = true; |  | ||||||
|     extraPackages = with pkgs; [ |  | ||||||
|       vaapiVdpau |  | ||||||
|     ]; |  | ||||||
|     driSupport = true; |  | ||||||
|   }; |  | ||||||
|   users.users.jellyfin.extraGroups = [ "video" "render" ]; |  | ||||||
|   services.jellyfin = { |  | ||||||
|     enable = true; |  | ||||||
|     cacheDir = "/var/cache/jellyfin"; |  | ||||||
|     dataDir = "/var/lib/jellyfin"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   modules = { |  | ||||||
|     podman.enable = true; |  | ||||||
|     security = { |  | ||||||
|       gpg.enable = true; |  | ||||||
|     }; |  | ||||||
|     shell = { |  | ||||||
|       zsh.enable = true; |  | ||||||
|     }; |  | ||||||
|     services = { |  | ||||||
|       borgmatic = { |  | ||||||
|         enable = true; |  | ||||||
|         directories = [ |  | ||||||
|           config.services.jellyfin.dataDir |  | ||||||
|           "/home/jordan" |  | ||||||
|         ]; |  | ||||||
|         repoPath = "ssh://b61758r4@b61758r4.repo.borgbase.com/./repo"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,68 +0,0 @@ | |||||||
| { config, lib, pkgs, modulesPath, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     (modulesPath + "/installer/scan/not-detected.nix") |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   boot = { |  | ||||||
|     initrd.availableKernelModules = [ "xhci_pci" "ahci" "nvme" "usb_storage" "sd_mod" ]; |  | ||||||
|     initrd.kernelModules = [ ]; |  | ||||||
|     kernelModules = [ "kvm-amd" ]; |  | ||||||
|     extraModulePackages = [ ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/" = { |  | ||||||
|     device = "rpool/system/root"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/var" = { |  | ||||||
|     device = "rpool/system/var"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/var/log" = { |  | ||||||
|     device = "rpool/system/var/log"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/var/tmp" = { |  | ||||||
|     device = "rpool/system/var/tmp"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/var/lib/containers/storage" = { |  | ||||||
|     device = "rpool/system/var/lib-containers-storage"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/nix" = { |  | ||||||
|     device = "rpool/local/nix"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/tmp" = { |  | ||||||
|     device = "rpool/local/tmp"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/home" = { |  | ||||||
|     device = "rpool/user/home"; |  | ||||||
|     fsType = "zfs"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   fileSystems."/boot" = { |  | ||||||
|     device = "/dev/disk/by-uuid/F697-F1C0"; |  | ||||||
|     fsType = "vfat"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   swapDevices = [ ]; |  | ||||||
|  |  | ||||||
|   networking.useDHCP = lib.mkDefault true; |  | ||||||
|  |  | ||||||
|   nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; |  | ||||||
|  |  | ||||||
|   hardware.cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,18 +0,0 @@ | |||||||
| # Mail server |  | ||||||
|  |  | ||||||
| ## Overview |  | ||||||
| Mail server hosted in OVH. |  | ||||||
|  |  | ||||||
| ## Specs |  | ||||||
| * CPU - ?? |  | ||||||
| * Memory - ?? |  | ||||||
|  |  | ||||||
| ### Disks |  | ||||||
| Device | Partitions _(filesystem, usage)_ |  | ||||||
| --- | --- |  | ||||||
| NVMe | `/dev/sda1` (ext4, NixOS Root) |  | ||||||
|  |  | ||||||
| ### Networks |  | ||||||
| - DHCP on `10.0.1.0/24` subnet. |  | ||||||
| - Tailscale on `100.64.0.0/10` subnet. FQDN: `mail.mesh.vimium.net`. |  | ||||||
|  |  | ||||||
| @@ -1,49 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     ./hardware-configuration.nix |  | ||||||
|     ./disko-config.nix |  | ||||||
|     ../server.nix |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   networking = { |  | ||||||
|     hostId = "08ac2f14"; |  | ||||||
|     domain = "mesh.vimium.net"; |  | ||||||
|     firewall = { |  | ||||||
|       enable = true; |  | ||||||
|       allowedTCPPorts = [ |  | ||||||
|         22    # SSH |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   users = { |  | ||||||
|     users = { |  | ||||||
|       root = { |  | ||||||
|         openssh.authorizedKeys.keys = [ |  | ||||||
|           "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILVHTjsyMIV4THNw6yz0OxAxGnC+41gX72UrPqTzR+OS jordan@vimium.com" |  | ||||||
|         ]; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.openssh.settings.PermitRootLogin = lib.mkForce "prohibit-password"; |  | ||||||
|  |  | ||||||
|   modules = { |  | ||||||
|     services = { |  | ||||||
|       borgmatic = { |  | ||||||
|         enable = true; |  | ||||||
|         directories = [ |  | ||||||
|           "/var/dkim" |  | ||||||
|           "/var/lib" |  | ||||||
|           "/var/vmail" |  | ||||||
|         ]; |  | ||||||
|         repoPath = "ssh://kg2mpt28@kg2mpt28.repo.borgbase.com/./repo"; |  | ||||||
|       }; |  | ||||||
|       mail.enable = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } |  | ||||||
| @@ -1,55 +0,0 @@ | |||||||
| { lib, ... }: |  | ||||||
| { |  | ||||||
|   disko.devices = { |  | ||||||
|     disk.disk1 = { |  | ||||||
|       device = lib.mkDefault "/dev/sda"; |  | ||||||
|       type = "disk"; |  | ||||||
|       content = { |  | ||||||
|         type = "gpt"; |  | ||||||
|         partitions = { |  | ||||||
|           boot = { |  | ||||||
|             name = "boot"; |  | ||||||
|             size = "2M"; |  | ||||||
|             type = "EF02"; |  | ||||||
|           }; |  | ||||||
|           esp = { |  | ||||||
|             name = "ESP"; |  | ||||||
|             size = "300M"; |  | ||||||
|             type = "EF00"; |  | ||||||
|             content = { |  | ||||||
|               type = "filesystem"; |  | ||||||
|               format = "vfat"; |  | ||||||
|               mountpoint = "/boot"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|           root = { |  | ||||||
|             name = "root"; |  | ||||||
|             size = "100%"; |  | ||||||
|             content = { |  | ||||||
|               type = "lvm_pv"; |  | ||||||
|               vg = "pool"; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     lvm_vg = { |  | ||||||
|       pool = { |  | ||||||
|         type = "lvm_vg"; |  | ||||||
|         lvs = { |  | ||||||
|           root = { |  | ||||||
|             size = "100%FREE"; |  | ||||||
|             content = { |  | ||||||
|               type = "filesystem"; |  | ||||||
|               format = "ext4"; |  | ||||||
|               mountpoint = "/"; |  | ||||||
|               mountOptions = [ |  | ||||||
|                 "defaults" |  | ||||||
|               ]; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| { config, lib, pkgs, modulesPath, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     (modulesPath + "/profiles/qemu-guest.nix") |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   boot = { |  | ||||||
|     initrd = { |  | ||||||
|       availableKernelModules = [ "ata_piix" "uhci_hcd" "xen_blkfront" "vmw_pvscsi" ]; |  | ||||||
|       kernelModules = [ "nvme" ]; |  | ||||||
|     }; |  | ||||||
|     loader.grub = { |  | ||||||
|       efiSupport = true; |  | ||||||
|       efiInstallAsRemovable = true; |  | ||||||
|     }; |  | ||||||
|     tmp.cleanOnBoot = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   zramSwap.enable = true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
							
								
								
									
										45
									
								
								hosts/odyssey/audio.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								hosts/odyssey/audio.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | |||||||
|  | { config, pkgs, ... }: | ||||||
|  | let | ||||||
|  |   snd-usb-audio-module = pkgs.callPackage ./snd-usb-audio.nix { | ||||||
|  |     kernel = config.boot.kernelPackages.kernel; | ||||||
|  |   }; | ||||||
|  |   upmixConfig = '' | ||||||
|  |     stream.properties = { | ||||||
|  |       channelmix.upmix = true | ||||||
|  |       channelmix.upmix-method = psd | ||||||
|  |     } | ||||||
|  |   ''; | ||||||
|  | in { | ||||||
|  |   boot.extraModulePackages = [ | ||||||
|  |     (snd-usb-audio-module.overrideAttrs (_: { | ||||||
|  |       patches = [ ./0001-Update-device-ID-for-PreSonus-1824c.patch ]; | ||||||
|  |     })) | ||||||
|  |   ]; | ||||||
|  |  | ||||||
|  |   environment.etc = { | ||||||
|  |     "pipewire/pipewire.conf.d/surround.conf".text = '' | ||||||
|  |       context.modules = [ | ||||||
|  |         { | ||||||
|  |           name = libpipewire-module-loopback | ||||||
|  |           args = { | ||||||
|  |             node.description = "Genelec 4.1 Surround" | ||||||
|  |             capture.props = { | ||||||
|  |               node.name = "Genelec_Speakers" | ||||||
|  |               media.class = "Audio/Sink" | ||||||
|  |               audio.position = [ FL FR SL SR LFE ] | ||||||
|  |             } | ||||||
|  |             playback.props = { | ||||||
|  |               node.name = "playback.Genelec_Speakers" | ||||||
|  |               audio.position = [ AUX0 AUX1 AUX3 AUX4 AUX5 ] | ||||||
|  |               target.object = "alsa_output.usb-PreSonus_Studio_1824c_SC4E21110775-00.multichannel-output" | ||||||
|  |               stream.dont-remix = true | ||||||
|  |               node.passive = true | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       ] | ||||||
|  |     ''; | ||||||
|  |     "pipewire/pipewire-pulse.conf.d/40-upmix.conf".text = upmixConfig; | ||||||
|  |     "pipewire/client-rt.conf.d/40-upmix.conf".text = upmixConfig; | ||||||
|  |   }; | ||||||
|  |  }  | ||||||
| @@ -1,30 +1,39 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: | { config, lib, pkgs, ... }: | ||||||
|  |  | ||||||
| { | { | ||||||
|   imports = [ |   imports = [ | ||||||
|     ./hardware-configuration.nix |     ./hardware-configuration.nix | ||||||
|  |     ./audio.nix | ||||||
|     ../desktop.nix |     ../desktop.nix | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   boot.loader = { |   boot.loader.systemd-boot = { | ||||||
|     systemd-boot = { |  | ||||||
|     enable = true; |     enable = true; | ||||||
|     graceful = true; |     graceful = true; | ||||||
|     netbootxyz.enable = true; |     netbootxyz.enable = true; | ||||||
|   }; |   }; | ||||||
|     efi.canTouchEfiVariables = true; |   boot.loader.efi.canTouchEfiVariables = true; | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   networking = { |   networking.hostName = "odyssey"; | ||||||
|     hostId = "c5e68d78"; |   networking.hostId = "c5e68d78"; | ||||||
|     networkmanager.enable = true; |   networking.networkmanager.enable = true; | ||||||
|     firewall.trustedInterfaces = [ "lxdbr0" "virbr0" ]; # Work around https://github.com/NixOS/nixpkgs/issues/263359 |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   virtualisation = { |   nix.package = pkgs.nixFlakes; | ||||||
|     libvirtd.enable = true; |   nix.extraOptions = '' | ||||||
|     lxd.enable = true; |     experimental-features = nix-command flakes | ||||||
|   }; |   ''; | ||||||
|  |  | ||||||
|  |   virtualisation.libvirtd.enable = true; | ||||||
|  |   virtualisation.lxd.enable = true; | ||||||
|  |  | ||||||
|  |   users.defaultUserShell = pkgs.zsh; | ||||||
|  |  | ||||||
|  |   system.stateVersion = "22.11"; | ||||||
|  |  | ||||||
|  |   services.journald.extraConfig = '' | ||||||
|  |     SystemMaxUse=4G | ||||||
|  |     MaxRetentionSec=90day | ||||||
|  |   ''; | ||||||
|  |  | ||||||
|   services.nix-serve = { |   services.nix-serve = { | ||||||
|     enable = true; |     enable = true; | ||||||
| @@ -41,23 +50,42 @@ | |||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|  |   age.secrets."odyssey_borg_passphrase" = { | ||||||
|  |     file = ../../secrets/odyssey_borg_passphrase.age; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   services.borgmatic = { | ||||||
|  |     enable = true; | ||||||
|  |     settings = { | ||||||
|  |       location = { | ||||||
|  |         source_directories = [ | ||||||
|  |           "/home/jordan/Documents" | ||||||
|  |         ]; | ||||||
|  |         repositories = [ | ||||||
|  |           "ssh://iqwu22oq@iqwu22oq.repo.borgbase.com/./repo" | ||||||
|  |         ]; | ||||||
|  |       }; | ||||||
|  |       storage = { | ||||||
|  |         encryption_passcommand = "cat ${config.age.secrets.odyssey_borg_passphrase.path}"; | ||||||
|  |         ssh_command = "ssh -i /etc/ssh/ssh_host_ed25519_key"; | ||||||
|  |       }; | ||||||
|  |       retention = { | ||||||
|  |         keep_daily = 7; | ||||||
|  |         keep_weekly = 4; | ||||||
|  |         keep_monthly = 6; | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   # Without this override, `cat` is unavailable for `encryption_passcommand` | ||||||
|  |   systemd.services.borgmatic.confinement.fullUnit = true; | ||||||
|  |  | ||||||
|   modules = { |   modules = { | ||||||
|     desktop = { |     desktop = { | ||||||
|       apps.qbittorrent.enable = true; |       apps.qbittorrent.enable = true; | ||||||
|       browsers = { |       browsers = { | ||||||
|         firefox.enable = true; |         firefox.enable = true; | ||||||
|       }; |       }; | ||||||
|       gaming = { |  | ||||||
|         emulators = { |  | ||||||
|           gamecube.enable = true; |  | ||||||
|           ps2.enable = true; |  | ||||||
|           ps3.enable = true; |  | ||||||
|           psp.enable = true; |  | ||||||
|           wii.enable = true; |  | ||||||
|           xbox.enable = true; |  | ||||||
|         }; |  | ||||||
|         lutris.enable = true; |  | ||||||
|       }; |  | ||||||
|       media.graphics = { |       media.graphics = { | ||||||
|         modeling.enable = true; |         modeling.enable = true; | ||||||
|         raster.enable = true; |         raster.enable = true; | ||||||
| @@ -67,40 +95,21 @@ | |||||||
|         audio.enable = true; |         audio.enable = true; | ||||||
|         video.enable = true; |         video.enable = true; | ||||||
|       }; |       }; | ||||||
|       office.libreoffice.enable = true; |  | ||||||
|     }; |     }; | ||||||
|     dev = { |     dev = { | ||||||
|       node.enable = true; |       node.enable = true; | ||||||
|     }; |     }; | ||||||
|     editors = { |     editors = { | ||||||
|       neovim.enable = true; |       neovim.enable = true; | ||||||
|  |       vscode.enable = true; | ||||||
|     }; |     }; | ||||||
|     hardware.presonus-studio.enable = true; |  | ||||||
|     security = { |     security = { | ||||||
|       gpg.enable = true; |       gpg.enable = true; | ||||||
|       pass.enable = true; |       pass.enable = true; | ||||||
|     }; |     }; | ||||||
|     services = { |  | ||||||
|       borgmatic = { |  | ||||||
|         enable = true; |  | ||||||
|         directories = [ |  | ||||||
|           "/home/jordan/Documents" |  | ||||||
|           "/home/jordan/Downloads" |  | ||||||
|           "/home/jordan/Music" |  | ||||||
|           "/home/jordan/Pictures" |  | ||||||
|           "/home/jordan/projects" |  | ||||||
|           "/home/jordan/Videos" |  | ||||||
|           "/home/jordan/.mozilla" |  | ||||||
|         ]; |  | ||||||
|         repoPath = "ssh://iqwu22oq@iqwu22oq.repo.borgbase.com/./repo"; |  | ||||||
|       }; |  | ||||||
|       gitea-runner.enable = true; |  | ||||||
|     }; |  | ||||||
|     shell = { |     shell = { | ||||||
|       git.enable = true; |       git.enable = true; | ||||||
|       zsh.enable = true; |       zsh.enable = true; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -19,7 +19,6 @@ | |||||||
|     cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; |     cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; | ||||||
|     nvidia = { |     nvidia = { | ||||||
|       modesetting.enable = true; |       modesetting.enable = true; | ||||||
|       package = config.boot.kernelPackages.nvidiaPackages.beta; |  | ||||||
|       powerManagement.enable = true; |       powerManagement.enable = true; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| @@ -65,9 +64,5 @@ | |||||||
|  |  | ||||||
|   networking.useDHCP = lib.mkDefault true; |   networking.useDHCP = lib.mkDefault true; | ||||||
|  |  | ||||||
|   environment.systemPackages = [ |  | ||||||
|     pkgs.apfs-fuse |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; |   nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,25 +0,0 @@ | |||||||
| # Pi |  | ||||||
|  |  | ||||||
| ## Overview |  | ||||||
| Raspberry Pi 4 |  | ||||||
|  |  | ||||||
| ## Specs |  | ||||||
| * SoC - Broadcom BCM2711 |  | ||||||
| * CPU - ARM Cortex-A72 @ 1.8 GHz |  | ||||||
| * Memory - 8 GB LPDDR4 |  | ||||||
|  |  | ||||||
| ### Disks |  | ||||||
| Device | Partitions _(filesystem, usage)_ |  | ||||||
| --- | --- |  | ||||||
| SD card | `/dev/mmcblk0` (ext4, NixOS Root) |  | ||||||
|  |  | ||||||
| ### Networks |  | ||||||
| - DHCP on `10.0.1.0/24` subnet. |  | ||||||
| - Tailscale on `100.64.0.0/10` subnet. FQDN: `pi.mesh.vimium.net`. |  | ||||||
|  |  | ||||||
| ## Devices and connections |  | ||||||
|  |  | ||||||
| - SONOFF Zigbee 3.0 USB Dongle Plus (connected to USB 2.0 port to avoid [interference](https://www.unit3compliance.co.uk/2-4ghz-intra-system-or-self-platform-interference-demonstration/)) |  | ||||||
| - HDMI to ONKYO HT-R990 |  | ||||||
| - S/PDIF to ONKYO HT-R990 |  | ||||||
| - Ethernet to ONKYO HT-R990 |  | ||||||
| @@ -1,250 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     ./hardware-configuration.nix |  | ||||||
|     ../server.nix |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   networking.hostId = "731d1660"; |  | ||||||
|  |  | ||||||
|   hardware = { |  | ||||||
|     raspberry-pi."4" = { |  | ||||||
|       apply-overlays-dtmerge.enable = true; |  | ||||||
|       audio.enable = false; |  | ||||||
|       fkms-3d.enable = false; |  | ||||||
|       xhci.enable = false; |  | ||||||
|     }; |  | ||||||
|     deviceTree = { |  | ||||||
|       enable = true; |  | ||||||
|       filter = "*rpi-4-*.dtb"; |  | ||||||
|       overlays = [ |  | ||||||
|         { |  | ||||||
|           name = "audio-off-overlay"; |  | ||||||
|           dtsText = '' |  | ||||||
|             /dts-v1/; |  | ||||||
|             /plugin/; |  | ||||||
|  |  | ||||||
|             / { |  | ||||||
|               compatible = "brcm,bcm2711"; |  | ||||||
|  |  | ||||||
|               fragment@0 { |  | ||||||
|                 target = <&vchiq>; |  | ||||||
|  |  | ||||||
|                 __overlay__ { |  | ||||||
|                   status = "disabled"; |  | ||||||
|                 }; |  | ||||||
|               }; |  | ||||||
|             }; |  | ||||||
|           ''; |  | ||||||
|         } |  | ||||||
|         { |  | ||||||
|           # Adapted from: https://github.com/raspberrypi/linux/blob/rpi-6.1.y/arch/arm/boot/dts/overlays/hifiberry-digi-pro-overlay.dts |  | ||||||
|           # changes: |  | ||||||
|           # - modified top-level "compatible" field from bcm2835 to bcm2711 |  | ||||||
|           # - s/i2s_clk_consumer/i2s/ (name on bcm2711 platform) |  | ||||||
|           name = "hifiberry-digi-pro"; |  | ||||||
|           dtsText = '' |  | ||||||
|             /dts-v1/; |  | ||||||
|             /plugin/; |  | ||||||
|  |  | ||||||
|             / { |  | ||||||
|                 compatible = "brcm,bcm2711"; |  | ||||||
|  |  | ||||||
|                 fragment@0 { |  | ||||||
|                     target = <&i2s>; |  | ||||||
|                     __overlay__ { |  | ||||||
|                         status = "okay"; |  | ||||||
|                     }; |  | ||||||
|                 }; |  | ||||||
|  |  | ||||||
|                 fragment@1 { |  | ||||||
|                     target = <&i2c1>; |  | ||||||
|                     __overlay__ { |  | ||||||
|                         #address-cells = <1>; |  | ||||||
|                         #size-cells = <0>; |  | ||||||
|                         status = "okay"; |  | ||||||
|  |  | ||||||
|                         wm8804@3b { |  | ||||||
|                             #sound-dai-cells = <0>; |  | ||||||
|                             compatible = "wlf,wm8804"; |  | ||||||
|                             reg = <0x3b>; |  | ||||||
|                             PVDD-supply = <&vdd_3v3_reg>; |  | ||||||
|                             DVDD-supply = <&vdd_3v3_reg>; |  | ||||||
|                             status = "okay"; |  | ||||||
|                         }; |  | ||||||
|                     }; |  | ||||||
|                 }; |  | ||||||
|  |  | ||||||
|                 fragment@2 { |  | ||||||
|                     target = <&sound>; |  | ||||||
|                     __overlay__ { |  | ||||||
|                         compatible = "hifiberry,hifiberry-digi"; |  | ||||||
|                         i2s-controller = <&i2s>; |  | ||||||
|                         status = "okay"; |  | ||||||
|                         clock44-gpio = <&gpio 5 0>; |  | ||||||
|                         clock48-gpio = <&gpio 6 0>; |  | ||||||
|                     }; |  | ||||||
|                 }; |  | ||||||
|             }; |  | ||||||
|           ''; |  | ||||||
|         } |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|     firmware = with pkgs; [ |  | ||||||
|       firmwareLinuxNonfree |  | ||||||
|       wireless-regdb |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   sound.enable = true; |  | ||||||
|  |  | ||||||
|   security.rtkit.enable = true; |  | ||||||
|   services.pipewire = { |  | ||||||
|     enable = true; |  | ||||||
|     alsa.enable = true; |  | ||||||
|     alsa.support32Bit = true; |  | ||||||
|     pulse.enable = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   age.secrets."files/services/home-assistant/secrets.yaml" = { |  | ||||||
|     file = "${inputs.secrets}/files/services/home-assistant/secrets.yaml.age"; |  | ||||||
|     path = "${config.services.home-assistant.configDir}/secrets.yaml"; |  | ||||||
|     owner = "hass"; |  | ||||||
|     group = "hass"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.home-assistant = { |  | ||||||
|     enable = true; |  | ||||||
|     extraComponents = [ |  | ||||||
|       "api" |  | ||||||
|       "alert" |  | ||||||
|       "auth" |  | ||||||
|       "backup" |  | ||||||
|       "command_line" |  | ||||||
|       "default_config" |  | ||||||
|       "homekit_controller" |  | ||||||
|       "homekit" |  | ||||||
|       "http" |  | ||||||
|       "icloud" |  | ||||||
|       "jellyfin" |  | ||||||
|       "metoffice" |  | ||||||
|       "mqtt" |  | ||||||
|       "onkyo" |  | ||||||
|       "ping" |  | ||||||
|       "proximity" |  | ||||||
|       "radio_browser" |  | ||||||
|       "scrape" |  | ||||||
|       "sensor" |  | ||||||
|       "system_health" |  | ||||||
|     ]; |  | ||||||
|     config = { |  | ||||||
|       default_config = {}; |  | ||||||
|       backup = {}; |  | ||||||
|       homeassistant = { |  | ||||||
|         name = "Home"; |  | ||||||
|         latitude = "!secret latitude"; |  | ||||||
|         longitude = "!secret longitude"; |  | ||||||
|         country = "GB"; |  | ||||||
|         temperature_unit = "C"; |  | ||||||
|         time_zone = config.time.timeZone; |  | ||||||
|         unit_system = "metric"; |  | ||||||
|       }; |  | ||||||
|       mqtt = { }; |  | ||||||
|       scene = "!include scenes.yaml"; |  | ||||||
|       automation = "!include automations.yaml"; |  | ||||||
|       system_health = { }; |  | ||||||
|       recorder = { |  | ||||||
|         purge_keep_days = 365; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.mosquitto = { |  | ||||||
|     enable = true; |  | ||||||
|     listeners = [{ |  | ||||||
|       acl = [ "pattern readwrite #" ]; |  | ||||||
|       omitPasswordAuth = true; |  | ||||||
|       port = 1883; |  | ||||||
|       settings = { |  | ||||||
|         allow_anonymous = true; |  | ||||||
|       }; |  | ||||||
|     }]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   age.secrets."files/services/zigbee2mqtt/secret.yaml" = { |  | ||||||
|     file = "${inputs.secrets}/files/services/zigbee2mqtt/secret.yaml.age"; |  | ||||||
|     path = "${config.services.zigbee2mqtt.dataDir}/secret.yaml"; |  | ||||||
|     owner = "zigbee2mqtt"; |  | ||||||
|     group = "zigbee2mqtt"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.zigbee2mqtt = { |  | ||||||
|     package = pkgs.unstable.zigbee2mqtt; |  | ||||||
|     enable = true; |  | ||||||
|     dataDir = "/var/lib/zigbee2mqtt"; |  | ||||||
|     settings = { |  | ||||||
|       homeassistant = lib.optionalAttrs config.services.home-assistant.enable { |  | ||||||
|         discovery_topic = "homeassistant"; |  | ||||||
|         status_topic = "hass/status"; |  | ||||||
|         legacy_entity_attributes = true; |  | ||||||
|         legacy_triggers = true; |  | ||||||
|       }; |  | ||||||
|       availability = true; |  | ||||||
|       frontend = true; |  | ||||||
|       device_options = { |  | ||||||
|         retain = true; |  | ||||||
|       }; |  | ||||||
|       serial = { |  | ||||||
|         port = "/dev/serial/by-id/usb-Silicon_Labs_Sonoff_Zigbee_3.0_USB_Dongle_Plus_0001-if00-port0"; |  | ||||||
|       }; |  | ||||||
|       advanced = { |  | ||||||
|         channel = 20; |  | ||||||
|         network_key = "!secret.yaml network_key"; |  | ||||||
|         pan_id = 13001; |  | ||||||
|         ext_pan_id = [ 79 1 73 47 250 136 124 222 ]; |  | ||||||
|         transmit_power = 20; |  | ||||||
|       }; |  | ||||||
|       mqtt = { |  | ||||||
|         version = 5; |  | ||||||
|         server = "mqtt://localhost:1883"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   modules = { |  | ||||||
|     networking = { |  | ||||||
|       wireless = { |  | ||||||
|         enable = true; |  | ||||||
|         interfaces = [ "wlan0" ]; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     services = { |  | ||||||
|       borgmatic = { |  | ||||||
|         enable = true; |  | ||||||
|         directories = [ |  | ||||||
|           "/var/lib/mosquitto" |  | ||||||
|           "/var/lib/zigbee2mqtt" |  | ||||||
|         ]; |  | ||||||
|         repoPath = "ssh://qcw86s11@qcw86s11.repo.borgbase.com/./repo"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   # Connection to ONKYO HT-R990 |  | ||||||
|   networking.interfaces.end0 = { |  | ||||||
|     ipv4.addresses = [{ |  | ||||||
|       address = "172.16.0.1"; |  | ||||||
|       prefixLength = 30; |  | ||||||
|     }]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   environment.systemPackages = with pkgs; [ |  | ||||||
|     python311Packages.onkyo-eiscp |  | ||||||
|     libraspberrypi |  | ||||||
|     raspberrypi-eeprom |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,31 +0,0 @@ | |||||||
| { config, lib, pkgs, modulesPath, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     (modulesPath + "/installer/sd-card/sd-image-aarch64.nix") |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   boot = { |  | ||||||
|     # Stop ZFS kernel being built |  | ||||||
|     supportedFilesystems = lib.mkForce [ "btrfs" "cifs" "f2fs" "jfs" "ntfs" "reiserfs" "vfat" "xfs" ]; |  | ||||||
|     tmp.cleanOnBoot = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   # Fix missing modules |  | ||||||
|   # https://github.com/NixOS/nixpkgs/issues/154163 |  | ||||||
|   nixpkgs.overlays = [ |  | ||||||
|     (final: super: { |  | ||||||
|       makeModulesClosure = x: |  | ||||||
|         super.makeModulesClosure (x // { allowMissing = true; }); |  | ||||||
|     }) |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   fileSystems = { |  | ||||||
|     "/" = { |  | ||||||
|       device = "/dev/disk/by-label/NIXOS_SD"; |  | ||||||
|       fsType = "ext4"; |  | ||||||
|       options = [ "noatime" ]; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,57 +1,46 @@ | |||||||
| { config, lib, pkgs, ... }: | { config, lib, pkgs, ... }: | ||||||
|  |  | ||||||
| { | { | ||||||
|   imports = [ |   time.timeZone = "Europe/London"; | ||||||
|     ./common.nix |  | ||||||
|  |   i18n.defaultLocale = "en_GB.UTF-8"; | ||||||
|  |   i18n.extraLocaleSettings = { | ||||||
|  |     LC_ADDRESS = "en_GB.UTF-8"; | ||||||
|  |     LC_IDENTIFICATION = "en_GB.UTF-8"; | ||||||
|  |     LC_MEASUREMENT = "en_GB.UTF-8"; | ||||||
|  |     LC_MONETARY = "en_GB.UTF-8"; | ||||||
|  |     LC_NAME = "en_GB.UTF-8"; | ||||||
|  |     LC_NUMERIC = "en_GB.UTF-8"; | ||||||
|  |     LC_PAPER = "en_GB.UTF-8"; | ||||||
|  |     LC_TELEPHONE = "en_GB.UTF-8"; | ||||||
|  |     LC_TIME = "en_GB.UTF-8"; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   console.keyMap = "uk"; | ||||||
|  |  | ||||||
|  |   services.openssh = { | ||||||
|  |     enable = true; | ||||||
|  |     settings = { | ||||||
|  |       KbdInteractiveAuthentication = false; | ||||||
|  |       PasswordAuthentication = false; | ||||||
|  |       PermitRootLogin = "no"; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   environment.systemPackages = with pkgs; [ | ||||||
|  |     git | ||||||
|  |     neovim | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   documentation.enable = false; |   nix = { | ||||||
|  |     settings = { | ||||||
|   fonts.fontconfig.enable = false; |       auto-optimise-store = true; | ||||||
|  |  | ||||||
|   security = { |  | ||||||
|     acme = { |  | ||||||
|       acceptTerms = true; |  | ||||||
|       defaults = { |  | ||||||
|         email = "hostmaster@vimium.com"; |  | ||||||
|         group = "nginx"; |  | ||||||
|         webroot = "/var/lib/acme/acme-challenge"; |  | ||||||
|     }; |     }; | ||||||
|  |     gc = { | ||||||
|  |       automatic = true; | ||||||
|  |       dates = "weekly"; | ||||||
|  |       options = "-d --delete-older-than 7d"; | ||||||
|     }; |     }; | ||||||
|     # auditd.enable = true; |  | ||||||
|     # audit = { |  | ||||||
|     #   enable = true; |  | ||||||
|     #   rules = [ |  | ||||||
|     #     "-a exit,always -F arch=b64 -S execve" |  | ||||||
|     #   ]; |  | ||||||
|     # }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   systemd = { |  | ||||||
|     enableEmergencyMode = false; |  | ||||||
|  |  | ||||||
|     sleep.extraConfig = '' |  | ||||||
|       AllowSuspend=no |  | ||||||
|       AllowHibernation=no |  | ||||||
|     ''; |  | ||||||
|  |  | ||||||
|     watchdog = { |  | ||||||
|       runtimeTime = "20s"; |  | ||||||
|       rebootTime = "30s"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.fail2ban = { |  | ||||||
|     enable = true; |  | ||||||
|     bantime = "1h"; |  | ||||||
|     bantime-increment = { |  | ||||||
|       enable = true; |  | ||||||
|       maxtime = "24h"; |  | ||||||
|       rndtime = "7m"; |  | ||||||
|     }; |  | ||||||
|     ignoreIP = [ |  | ||||||
|       "100.64.0.0/10" |  | ||||||
|     ]; |  | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   modules.networking.tailscale = { |   modules.networking.tailscale = { | ||||||
|   | |||||||
| @@ -1,18 +0,0 @@ | |||||||
| # vps1 |  | ||||||
|  |  | ||||||
| ## Overview |  | ||||||
| VPS hosted in OVH. |  | ||||||
|  |  | ||||||
| ## Specs |  | ||||||
| * CPU - ?? |  | ||||||
| * Memory - ?? |  | ||||||
|  |  | ||||||
| ### Disks |  | ||||||
| Device | Partitions _(filesystem, usage)_ |  | ||||||
| --- | --- |  | ||||||
| NVMe | `/dev/sda1` (ext4, NixOS Root) |  | ||||||
|  |  | ||||||
| ### Networks |  | ||||||
| - DHCP on `10.0.1.0/24` subnet. |  | ||||||
| - Tailscale on `100.64.0.0/10` subnet. FQDN: `vps1.mesh.vimium.net`. |  | ||||||
|  |  | ||||||
| @@ -1,79 +0,0 @@ | |||||||
| { |  | ||||||
|   lib, |  | ||||||
|   ... |  | ||||||
| }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     ./hardware-configuration.nix |  | ||||||
|     ../server.nix |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   networking = { |  | ||||||
|     hostId = "08bf6db3"; |  | ||||||
|     domain = "mesh.vimium.net"; |  | ||||||
|     firewall = { |  | ||||||
|       enable = true; |  | ||||||
|       allowedTCPPorts = [ |  | ||||||
|         22    # SSH |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   users = { |  | ||||||
|     users = { |  | ||||||
|       jellyfin = { |  | ||||||
|         isSystemUser = true; |  | ||||||
|         group = "jellyfin"; |  | ||||||
|         shell = "/bin/sh"; |  | ||||||
|         openssh.authorizedKeys.keys = [ |  | ||||||
|           "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOaaS+KMAEAymZhIJGC4LK8aMhUzhpmloUgvP2cxeBH4 jellyfin" |  | ||||||
|         ]; |  | ||||||
|       }; |  | ||||||
|       root = { |  | ||||||
|         openssh.authorizedKeys.keys = [ |  | ||||||
|           "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILVHTjsyMIV4THNw6yz0OxAxGnC+41gX72UrPqTzR+OS jordan@vimium.com" |  | ||||||
|         ]; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     groups = { |  | ||||||
|       jellyfin = { }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   services.openssh.settings.PermitRootLogin = lib.mkForce "prohibit-password"; |  | ||||||
|  |  | ||||||
|   modules = rec { |  | ||||||
|     databases.postgresql.enable = true; |  | ||||||
|     services = { |  | ||||||
|       borgmatic = { |  | ||||||
|         enable = true; |  | ||||||
|         directories = [ |  | ||||||
|           "/home" |  | ||||||
|           "/var/lib" |  | ||||||
|           "/var/www" |  | ||||||
|         ]; |  | ||||||
|         repoPath = "ssh://p91y8oh7@p91y8oh7.repo.borgbase.com/./repo"; |  | ||||||
|       }; |  | ||||||
|       coturn = { |  | ||||||
|         enable = true; |  | ||||||
|         realm = "turn.vimium.com"; |  | ||||||
|         matrixIntegration = true; |  | ||||||
|       }; |  | ||||||
|       gitea.enable = true; |  | ||||||
|       headscale.enable = true; |  | ||||||
|       matrix = { |  | ||||||
|         enable = true; |  | ||||||
|         bridges = { |  | ||||||
|           signal = true; |  | ||||||
|           whatsapp = true; |  | ||||||
|         }; |  | ||||||
|         usePostgresql = databases.postgresql.enable; |  | ||||||
|       }; |  | ||||||
|       nginx.enable = true; |  | ||||||
|       photoprism.enable = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   system.stateVersion = "22.11"; |  | ||||||
| } |  | ||||||
| @@ -1,26 +0,0 @@ | |||||||
| { config, lib, pkgs, modulesPath, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = [ |  | ||||||
|     (modulesPath + "/profiles/qemu-guest.nix") |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   boot = { |  | ||||||
|     initrd = { |  | ||||||
|       availableKernelModules = [ "ata_piix" "uhci_hcd" "xen_blkfront" "vmw_pvscsi" ]; |  | ||||||
|       kernelModules = [ "nvme" ]; |  | ||||||
|     }; |  | ||||||
|     loader.grub.device = "/dev/sda"; |  | ||||||
|     tmp.cleanOnBoot = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   zramSwap.enable = true; |  | ||||||
|  |  | ||||||
|   fileSystems = { |  | ||||||
|     "/" = { |  | ||||||
|       device = "/dev/sda1"; |  | ||||||
|       fsType = "ext4"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| @@ -1,40 +0,0 @@ | |||||||
| { |  | ||||||
|   config, |  | ||||||
|   lib, |  | ||||||
|   ... |  | ||||||
| }: |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.databases.postgresql; |  | ||||||
| in { |  | ||||||
|   options.modules.databases.postgresql = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     services.postgresql = { |  | ||||||
|       enable = true; |  | ||||||
|       initdbArgs = [ |  | ||||||
|         "--allow-group-access" |  | ||||||
|         "--encoding=UTF8" |  | ||||||
|         "--locale=C" |  | ||||||
|       ]; |  | ||||||
|       settings = { |  | ||||||
|         log_connections = true; |  | ||||||
|         log_disconnections = true; |  | ||||||
|         log_destination = lib.mkForce "syslog"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.borgmatic.settings = { |  | ||||||
|       postgresql_databases = [ |  | ||||||
|         { |  | ||||||
|           name = "all"; |  | ||||||
|         } |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,18 +1,12 @@ | |||||||
| { | { | ||||||
|   imports = [ |   imports = [ | ||||||
|     ./options.nix |     ./options.nix | ||||||
|     ./podman.nix |  | ||||||
|     ./databases/postgresql.nix |  | ||||||
|     ./desktop/gnome.nix |     ./desktop/gnome.nix | ||||||
|     ./desktop/forensics.nix |  | ||||||
|     ./desktop/hyprland.nix |  | ||||||
|     ./desktop/kde.nix |  | ||||||
|     ./desktop/mimeapps.nix |     ./desktop/mimeapps.nix | ||||||
|     ./desktop/apps/qbittorrent.nix |     ./desktop/apps/qbittorrent.nix | ||||||
|     ./desktop/apps/slack.nix |     ./desktop/apps/slack.nix | ||||||
|     ./desktop/apps/thunderbird.nix |     ./desktop/apps/thunderbird.nix | ||||||
|     ./desktop/apps/zoom.nix |     ./desktop/apps/zoom.nix | ||||||
|     ./desktop/browsers/brave.nix |  | ||||||
|     ./desktop/browsers/firefox.nix |     ./desktop/browsers/firefox.nix | ||||||
|     ./desktop/gaming/emulators.nix |     ./desktop/gaming/emulators.nix | ||||||
|     ./desktop/gaming/lutris.nix |     ./desktop/gaming/lutris.nix | ||||||
| @@ -31,21 +25,9 @@ | |||||||
|     ./dev/zig.nix |     ./dev/zig.nix | ||||||
|     ./editors/neovim |     ./editors/neovim | ||||||
|     ./editors/vscode.nix |     ./editors/vscode.nix | ||||||
|     ./hardware/presonus-studio.nix |  | ||||||
|     ./networking/tailscale.nix |     ./networking/tailscale.nix | ||||||
|     ./networking/wireless.nix |  | ||||||
|     ./security/gpg.nix |     ./security/gpg.nix | ||||||
|     ./security/pass.nix |     ./security/pass.nix | ||||||
|     ./services/borgmatic |  | ||||||
|     ./services/chrony |  | ||||||
|     ./services/coturn |  | ||||||
|     ./services/gitea |  | ||||||
|     ./services/gitea-runner |  | ||||||
|     ./services/headscale |  | ||||||
|     ./services/mail |  | ||||||
|     ./services/matrix |  | ||||||
|     ./services/nginx |  | ||||||
|     ./services/photoprism |  | ||||||
|     ./shell/git |     ./shell/git | ||||||
|     ./shell/zsh |     ./shell/zsh | ||||||
|   ]; |   ]; | ||||||
|   | |||||||
| @@ -1,17 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| let cfg = config.modules.desktop.browsers.brave; |  | ||||||
| in { |  | ||||||
|   options.modules.desktop.browsers.brave = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     user.packages = with pkgs; [ |  | ||||||
|       brave |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| { config, lib, inputs, ... }: | { config, lib, pkgs, inputs, ... }: | ||||||
|  |  | ||||||
| let cfg = config.modules.desktop.browsers.firefox; | let cfg = config.modules.desktop.browsers.firefox; | ||||||
| in { | in { | ||||||
| @@ -35,79 +35,23 @@ in { | |||||||
|  |  | ||||||
|           ## Preferences |           ## Preferences | ||||||
|           "browser.ctrlTab.sortByRecentlyUsed" = true; |           "browser.ctrlTab.sortByRecentlyUsed" = true; | ||||||
|           "browser.discovery.enabled" = false; |  | ||||||
|           "browser.download.open_pdf_attachments_inline" = true; |  | ||||||
|           "browser.menu.showViewImageInfo" = true; |  | ||||||
|           "browser.newtabpage.enabled" = false; |           "browser.newtabpage.enabled" = false; | ||||||
|           "browser.newtabpage.activity-stream.showSponsored" = false; |  | ||||||
|           "browser.newtabpage.activity-stream.showSponsoredTopSites" = false; |  | ||||||
|           "browser.newtabpage.activity-stream.default.sites" = ""; |  | ||||||
|           "browser.privatebrowsing.forceMediaMemoryCache" = true; |  | ||||||
|           "browser.search.widget.inNavBar" = true; |           "browser.search.widget.inNavBar" = true; | ||||||
|           "browser.startup.page" = 3; |           "browser.startup.page" = 3; | ||||||
|           "browser.startup.homepage" = "https://www.vimium.com"; |           "browser.startup.homepage" = "https://www.vimium.com"; | ||||||
|           "browser.toolbars.bookmarks.visibility" = "never"; |           "browser.toolbars.bookmarks.visibility" = "never"; | ||||||
|           "browser.uitour.enabled" = false; |  | ||||||
|           "browser.urlbar.suggest.engines" = false; |  | ||||||
|           "browser.urlbar.suggest.calculator" = true; |  | ||||||
|           "browser.urlbar.trending.featureGate" = false; |  | ||||||
|           "browser.urlbar.unitConversion.enabled" = true; |  | ||||||
|           "cookiebanners.service.mode" = 1; |  | ||||||
|           "cookiebanners.service.mode.privateBrowsing" = 1; |  | ||||||
|           "network.IDN_show_punycode" = true; |  | ||||||
|  |  | ||||||
|           ## Performance |  | ||||||
|           "browser.cache.jsbc_compression_level" = 3; |  | ||||||
|           "content.notify.interval" = 100000; |  | ||||||
|           "dom.enable_web_task_scheduling" = true; |  | ||||||
|           "dom.security.sanitizer.enabled" = true; |  | ||||||
|           "gfx.canvas.accelerated.cache-items" = 4096; |  | ||||||
|           "gfx.canvas.accelerated.cache-size" = 512; |  | ||||||
|           "gfx.content.skia-font-cache-size" = 20; |  | ||||||
|           "gfx.webrender.all" = true; |  | ||||||
|           "gfx.webrender.compositor" = true; |  | ||||||
|           "gfx.webrender.enable" = true; |  | ||||||
|           "image.mem.decode_bytes_at_a_time" = 32768; |  | ||||||
|           "layers.acceleration.force-enabled" = true; |  | ||||||
|           "layout.css.grid-template-masonry-value.enabled" = true; |  | ||||||
|           "media.ffmpeg.vaapi.enabled" = true; |  | ||||||
|           "media.memory_cache_max_size" = 65536; |  | ||||||
|           "media.cache_readahead_limit" = 7200; |  | ||||||
|           "media.cache_resume_threshold" = 3600; |  | ||||||
|           "network.dns.disablePrefetch" = true; |  | ||||||
|           "network.dns.disablePrefetchFromHTTPS" = true; |  | ||||||
|           "network.dnsCacheExpiration" = 3600; |  | ||||||
|           "network.http.max-connections" = 1800; |  | ||||||
|           "network.http.max-persistent-connections-per-server" = 10; |  | ||||||
|           "network.http.max-urgent-start-excessive-connections-per-host" = 5; |  | ||||||
|           "network.http.pacing.requests.enabled" = false; |  | ||||||
|           "network.predictor.enabled" = false; |  | ||||||
|           "network.prefetch-next" = false; |  | ||||||
|           "network.ssl_tokens_cache_capacity" = 10240; |  | ||||||
|           "pdfjs.enableScripting" = false; |  | ||||||
|           "security.mixed_content.block_display_content" = true; |  | ||||||
|  |  | ||||||
|           ## Experiments |           ## Experiments | ||||||
|           "app.normandy.enabled" = false; |           "app.normandy.enabled" = false; | ||||||
|           "app.normandy.api_url" = ""; |           "app.normandy.api_url" = ""; | ||||||
|           "app.normandy.user_id" = ""; |           "app.normandy.user_id" = ""; | ||||||
|           "app.shield.optoutstudies.enabled" = false; |  | ||||||
|           "browser.shopping.experience2023.active" = false; |  | ||||||
|           "browser.shopping.experience2023.enabled" = false; |  | ||||||
|           "extensions.screenshots.disabled" = true; |           "extensions.screenshots.disabled" = true; | ||||||
|           "extensions.screenshots.upload-disabled" = true; |           "extensions.screenshots.upload-disabled" = true; | ||||||
|           "experiments.supported" = false; |           "experiments.supported" = false; | ||||||
|           "experiments.enabled" = false; |           "experiments.enabled" = false; | ||||||
|           "experiments.manifest.uri" = ""; |           "experiments.manifest.uri" = ""; | ||||||
|           "network.allow-experiments" = false; |           "network.allow-experiments" = false; | ||||||
|  |           "privacy.trackingprotection.enabled" = false; | ||||||
|           ## Privacy |  | ||||||
|           "dom.private-attribution.submission.enabled" = false; |  | ||||||
|           # "privacy.resistFingerprinting" = true; |  | ||||||
|           "privacy.resistFingerprinting.autoDeclineNoUserInputCanvasPrompts" = false; |  | ||||||
|           "privacy.trackingprotection.enabled" = true; |  | ||||||
|           "privacy.trackingprotection.pbmode.enabled" = true; |  | ||||||
|           "privacy.userContext.enabled" = true; |  | ||||||
|  |  | ||||||
|           ## Geo |           ## Geo | ||||||
|           "geo.enabled" = false; |           "geo.enabled" = false; | ||||||
| @@ -154,34 +98,12 @@ in { | |||||||
|           "dom.battery.enabled" = false; |           "dom.battery.enabled" = false; | ||||||
|           "dom.vr.enabled" = false; |           "dom.vr.enabled" = false; | ||||||
|           "media.navigator.enabled" = false; |           "media.navigator.enabled" = false; | ||||||
|           # "dom.webaudio.enabled" = false; |           "dom.webaudio.enabled" = false; | ||||||
|  |  | ||||||
|           ## Isolation |           ## Isolation | ||||||
|           "privacy.firstparty.isolate" = true; |           "privacy.firstparty.isolate" = true; | ||||||
|           "privacy.firstparty.isolate.restrict_opener_access" = true; |           "privacy.firstparty.isolate.restrict_opener_access" = true; | ||||||
|  |  | ||||||
|           ## Telemetry |  | ||||||
|           "beacon.enabled" = false; |  | ||||||
|           "browser.newtabpage.activity-stream.feeds.telemetry" = false; |  | ||||||
|           "browser.newtabpage.activity-stream.telemetry" = false; |  | ||||||
|           "browser.send_pings" = false; |  | ||||||
|           "datareporting.policy.dataSubmissionEnabled" = false; |  | ||||||
|           "datareporting.healthReport.uploadEnabled" = false; |  | ||||||
|           "toolkit.coverage.opt-out" = true; |  | ||||||
|           "toolkit.coverage.endpoint.base" = ""; |  | ||||||
|           "toolkit.telemetry.archive.enabled" = false; |  | ||||||
|           "toolkit.telemetry.bhrPing.enabled" = false; |  | ||||||
|           "toolkit.telemetry.coverage.opt-out" = true; |  | ||||||
|           "toolkit.telemetry.enabled" = false; |  | ||||||
|           "toolkit.telemetry.firstShutdownPing.enabled" = false; |  | ||||||
|           "toolkit.telemetry.hybridContent.enabled" = false; |  | ||||||
|           "toolkit.telemetry.newProfilePing.enabled" = false; |  | ||||||
|           "toolkit.telemetry.reportingPolicy.firstRun" = false; |  | ||||||
|           "toolkit.telemetry.server" = "data:,"; |  | ||||||
|           "toolkit.telemetry.shutdownPingSender.enabled" = false; |  | ||||||
|           "toolkit.telemetry.unified" = false; |  | ||||||
|           "toolkit.telemetry.updatePing.enabled" = false; |  | ||||||
|  |  | ||||||
|           ## Pocket/Hello |           ## Pocket/Hello | ||||||
|           "loop.enabled" = false; |           "loop.enabled" = false; | ||||||
|           "loop.feedback.baseUrl" = ""; |           "loop.feedback.baseUrl" = ""; | ||||||
| @@ -203,10 +125,6 @@ in { | |||||||
|           "browser.pocket.useLocaleList" = false; |           "browser.pocket.useLocaleList" = false; | ||||||
|           "brwoser.pocket.enabledLocales" = ""; |           "brwoser.pocket.enabledLocales" = ""; | ||||||
|  |  | ||||||
|           ## Plugins |  | ||||||
|           "plugin.state.flash" = 0; |  | ||||||
|           "plugin.state.java" = 0; |  | ||||||
|  |  | ||||||
|           ## Misc |           ## Misc | ||||||
|           "browser.selfsupport.url" = ""; |           "browser.selfsupport.url" = ""; | ||||||
|         }; |         }; | ||||||
|   | |||||||
| @@ -1,26 +0,0 @@ | |||||||
| { config, lib, pkgs, ... }: |  | ||||||
|  |  | ||||||
| let cfg = config.modules.desktop.forensics; |  | ||||||
| in { |  | ||||||
|   options.modules.desktop.forensics = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     user.packages = with pkgs; [ |  | ||||||
|       acquire |  | ||||||
|       afflib |  | ||||||
|       autopsy |  | ||||||
|       fatcat |  | ||||||
|       foremost |  | ||||||
|       hstsparser |  | ||||||
|       networkminer |  | ||||||
|       sleuthkit |  | ||||||
|       testdisk-qt |  | ||||||
|       tracee |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -19,10 +19,6 @@ in { | |||||||
|       default = false; |       default = false; | ||||||
|       example = true; |       example = true; | ||||||
|     }; |     }; | ||||||
|     ps1.enable      = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|     ps2.enable      = lib.mkOption { |     ps2.enable      = lib.mkOption { | ||||||
|       default = false; |       default = false; | ||||||
|       example = true; |       example = true; | ||||||
| @@ -39,36 +35,25 @@ in { | |||||||
|       default = false; |       default = false; | ||||||
|       example = true; |       example = true; | ||||||
|     }; |     }; | ||||||
|     switch.enable   = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|     wii.enable      = lib.mkOption { |     wii.enable      = lib.mkOption { | ||||||
|       default = false; |       default = false; | ||||||
|       example = true; |       example = true; | ||||||
|     }; |     }; | ||||||
|     xbox.enable     = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   config = { |   config = { | ||||||
|     user.packages = with pkgs; [ |     user.packages = with pkgs; [ | ||||||
|       (lib.mkIf cfg.ps1.enable duckstation) |       (lib.mkIf cfg.ps2.enable pcsx2) | ||||||
|       (lib.mkIf cfg.ps2.enable unstable.pcsx2) |  | ||||||
|       (lib.mkIf cfg.ps3.enable rpcs3) |       (lib.mkIf cfg.ps3.enable rpcs3) | ||||||
|       (lib.mkIf cfg.psp.enable unstable.ppsspp) |       (lib.mkIf cfg.psp.enable ppsspp) | ||||||
|       (lib.mkIf cfg.ds.enable desmume) |       (lib.mkIf cfg.ds.enable desmume) | ||||||
|       (lib.mkIf (cfg.gba.enable || |       (lib.mkIf (cfg.gba.enable || | ||||||
|              cfg.gb.enable  || |              cfg.gb.enable  || | ||||||
|              cfg.snes.enable) |              cfg.snes.enable) | ||||||
|         higan) |         higan) | ||||||
|       (lib.mkIf cfg.switch.enable yuzuPackages.mainline) |  | ||||||
|       (lib.mkIf (cfg.wii.enable || |       (lib.mkIf (cfg.wii.enable || | ||||||
|              cfg.gamecube.enable) |              cfg.gamecube.enable) | ||||||
|         dolphin-emu) |         dolphin-emu) | ||||||
|       (lib.mkIf cfg.xbox.enable unstable.xemu) |  | ||||||
|     ]; |     ]; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -10,13 +10,8 @@ in { | |||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |   config = lib.mkIf cfg.enable { | ||||||
|     environment.systemPackages = with pkgs; [ |     user.packages = with pkgs; [ | ||||||
|       (lutris.override { |       lutris | ||||||
|         extraPkgs = pkgs: [ |  | ||||||
|           winePackages.staging |  | ||||||
|           wine64Packages.staging |  | ||||||
|         ]; |  | ||||||
|       }) |  | ||||||
|       vulkan-loader |       vulkan-loader | ||||||
|       vulkan-tools |       vulkan-tools | ||||||
|     ]; |     ]; | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| { config, inputs, lib, pkgs, ... }: | { config, lib, pkgs, inputs, ... }: | ||||||
|  |  | ||||||
| let cfg = config.modules.desktop.gnome; | let cfg = config.modules.desktop.gnome; | ||||||
| in { | in { | ||||||
| @@ -17,93 +17,31 @@ in { | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     services.flatpak.enable = true; |     services.flatpak.enable = true; | ||||||
|     services.fwupd.enable = true; |  | ||||||
|  |  | ||||||
|     programs.dconf.enable = true; |     programs.dconf.enable = true; | ||||||
|     dconf.settings = { |     dconf.settings = { | ||||||
|       "io/github/celluloid-player/celluloid" = { |  | ||||||
|         draggable-video-area-enable = true; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/desktop/interface" = { |  | ||||||
|         color-scheme = "prefer-dark"; |  | ||||||
|         cursor-theme = "Adwaita"; |  | ||||||
|         enable-hot-corners = false; |  | ||||||
|         font-name = "Cantarell 11"; |  | ||||||
|         gtk-theme = "adw-gtk3-dark"; |  | ||||||
|         icon-theme = "MoreWaita"; |  | ||||||
|         monospace-font-name = "UbuntuMono Nerd Font 11"; |  | ||||||
|         toolbar-style = "both-horiz"; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/desktop/peripherals/touchpad" = { |  | ||||||
|         tap-to-click = true; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/desktop/sound" = { |  | ||||||
|         theme-name = "freedesktop"; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/desktop/search-providers" = { |  | ||||||
|         disabled = [ "org.gnome.Epiphany.desktop" ]; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/desktop/wm/keybindings" = { |  | ||||||
|         switch-group = [ "<Super>grave" ]; |  | ||||||
|         switch-group-backward = [ "<Shift><Super>grave" ]; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/desktop/wm/preferences" = { |  | ||||||
|         button-layout = "appmenu:close"; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/gnome-session" = { |  | ||||||
|         auto-save-session = true; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/gnome-system-monitor" = { |  | ||||||
|         show-dependencies = true; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/mutter" = { |  | ||||||
|         center-new-windows = true; |  | ||||||
|         edge-tiling = true; |  | ||||||
|         experimental-features = [ "scale-monitor-framebuffer" ]; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/settings-daemon/plugins/media-keys" = { |  | ||||||
|         volume-up = [ |  | ||||||
|           "<Shift>F12" |  | ||||||
|           "XF86AudioRaiseVolume" |  | ||||||
|         ]; |  | ||||||
|         volume-down = [ |  | ||||||
|           "<Shift>F11" |  | ||||||
|           "XF86AudioLowerVolume" |  | ||||||
|         ]; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/shell" = { |       "org/gnome/shell" = { | ||||||
|         disable-user-extensions = false; |         disable-user-extensions = false; | ||||||
|         enabled-extensions = [ |         enabled-extensions = [ | ||||||
|           "appindicatorsupport@rgcjonas.gmail.com" |           # "another-window-session-manager@gmail.com" | ||||||
|           # "arcmenu@arcmenu.com" |  | ||||||
|           "blur-my-shell@aunetx" |           "blur-my-shell@aunetx" | ||||||
|           # "browser-tabs@com.github.harshadgavali" |  | ||||||
|           "burn-my-windows@schneegans.github.com" |           "burn-my-windows@schneegans.github.com" | ||||||
|           "clipboard-indicator@tudmotu.com" |  | ||||||
|           "CoverflowAltTab@palatis.blogspot.com" |  | ||||||
|           # "dash-to-panel@jderose9.github.com" |  | ||||||
|           # "desktop-cube@schneegans.github.com" |           # "desktop-cube@schneegans.github.com" | ||||||
|           # "EasyScreenCast@iacopodeenosee.gmail.com" |           # "desktop-zoom@colin.kinlo.ch" | ||||||
|           "espresso@coadmunkee.github.com" |           "espresso@coadmunkee.github.com" | ||||||
|           "flypie@schneegans.github.com" |           # "flypie@schneegans.github.com" | ||||||
|           # "forge@jmmaranan.com" |           # "forge@jmmaranan.com" | ||||||
|           "gsconnect@andyholmes.github.io" |           "hue-lights@chlumskyvaclav@gmail.com" | ||||||
|           # "gSnap@micahosborne" |  | ||||||
|           # "hidetopbar@mathieu.bidon.ca" |  | ||||||
|           "just-perfection-desktop@just-perfection" |           "just-perfection-desktop@just-perfection" | ||||||
|           # "mediacontrols@cliffniff.github.com" |  | ||||||
|           # "mousefollowsfocus@matthes.biz" |  | ||||||
|           # "pano@elhan.io" |           # "pano@elhan.io" | ||||||
|           # "paperwm@hedning:matrix.org" |           # "paperwm@hedning:matrix.org" | ||||||
|           "pip-on-top@rafostar.github.com" |  | ||||||
|           # "rounded-window-corners@yilozt" |  | ||||||
|           # "search-light@icedman.github.com" |           # "search-light@icedman.github.com" | ||||||
|           # "smart-auto-move@khimaros.com" |  | ||||||
|           "space-bar@luchrioh" |           "space-bar@luchrioh" | ||||||
|  |           # "smart-auto-move@khimaros.com" | ||||||
|  |           # "systemd-manager@hardpixel.eu" | ||||||
|  |           # "tailscale-status@maxgallup.github.com" | ||||||
|           # "tiling-assistant@leleat-on-github" |           # "tiling-assistant@leleat-on-github" | ||||||
|           "Vitals@CoreCoding.com" |           "Vitals@CoreCoding.com" | ||||||
|           "windowIsReady_Remover@nunofarruca@gmail.com" |  | ||||||
|           # "worksets@blipk.xyz" |  | ||||||
|           # "wsmatrix@martin.zurowietz.de" |           # "wsmatrix@martin.zurowietz.de" | ||||||
|         ]; |         ]; | ||||||
|         favorite-apps = [ |         favorite-apps = [ | ||||||
| @@ -111,6 +49,9 @@ in { | |||||||
|           "org.gnome.Nautilus.desktop" |           "org.gnome.Nautilus.desktop" | ||||||
|         ]; |         ]; | ||||||
|       }; |       }; | ||||||
|  |       "org/gnome/shell/extensions/another-window-session-manager" = { | ||||||
|  |         enable-autorestore-sessions = true; | ||||||
|  |       }; | ||||||
|       "org/gnome/shell/extensions/blur-my-shell/panel" = { |       "org/gnome/shell/extensions/blur-my-shell/panel" = { | ||||||
|         static-blur = true; |         static-blur = true; | ||||||
|       }; |       }; | ||||||
| @@ -122,14 +63,8 @@ in { | |||||||
|         glide-open-effect = true; |         glide-open-effect = true; | ||||||
|         glide-close-effect = true; |         glide-close-effect = true; | ||||||
|       }; |       }; | ||||||
|       "org/gnome/shell/extensions/dash-to-panel" = { |       "org/gnome/shell/extensions/desktop-zoom" = { | ||||||
|         intellihide = true; |         mag-factor-delta = 0.07; | ||||||
|         panel-positions = '' |  | ||||||
|           {"0":"TOP"} |  | ||||||
|         ''; |  | ||||||
|         trans-panel-opacity = 0.3; |  | ||||||
|         trans-use-custom-opacity = true; |  | ||||||
|         trans-use-dynamic-opacity = true; |  | ||||||
|       }; |       }; | ||||||
|       "org/gnome/shell/extensions/espresso" = { |       "org/gnome/shell/extensions/espresso" = { | ||||||
|         enable-fullscreen = true; |         enable-fullscreen = true; | ||||||
| @@ -139,32 +74,18 @@ in { | |||||||
|           "com.obsproject.Studio.desktop" |           "com.obsproject.Studio.desktop" | ||||||
|         ]; |         ]; | ||||||
|       }; |       }; | ||||||
|       "org/gnome/shell/extensions/flypie" = { |       "org/gnome/shell/extensions/paperwm" = { | ||||||
|         preview-on-right-side = true; |         use-default-background = true; | ||||||
|       }; |       }; | ||||||
|       "org/gnome/shell/extensions/forge" = { |       "org/gnome/shell/extensions/forge" = { | ||||||
|         window-gap-size = 8; |         window-gap-size = 8; | ||||||
|         window-gap-hidden-on-single = false; |         window-gap-hidden-on-single = false; | ||||||
|       }; |       }; | ||||||
|       "org/gnome/shell/extensions/hidetopbar" = { |  | ||||||
|         mouse-sensitive = true; |  | ||||||
|         mouse-sensitive-fullscreen-window = true; |  | ||||||
|         enable-active-window = false; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/shell/extensions/just-perfection" = { |       "org/gnome/shell/extensions/just-perfection" = { | ||||||
|         activities-button = false; |         activities-button = false; | ||||||
|         window-demands-attention-focus = true; |         window-demands-attention-focus = true; | ||||||
|         workspace-wrap-around = true; |         workspace-wrap-around = true; | ||||||
|       }; |       }; | ||||||
|       "org/gnome/shell/extensions/paperwm" = { |  | ||||||
|         use-default-background = true; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/shell/extensions/pip-on-top" = { |  | ||||||
|         stick = true; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/shell/extensions/search-light" = { |  | ||||||
|         popup-at-cursor-monitor = true; |  | ||||||
|       }; |  | ||||||
|       "org/gnome/shell/extensions/space-bar/behavior" = { |       "org/gnome/shell/extensions/space-bar/behavior" = { | ||||||
|         enable-activate-workspace-shortcuts = true; |         enable-activate-workspace-shortcuts = true; | ||||||
|         show-empty-workspaces = true; |         show-empty-workspaces = true; | ||||||
| @@ -177,10 +98,9 @@ in { | |||||||
|         screen-left-gap = 8; |         screen-left-gap = 8; | ||||||
|         window-gap = 8; |         window-gap = 8; | ||||||
|       }; |       }; | ||||||
|       "org/gnome/Console" = { |       "org/gnome/desktop/background" = { | ||||||
|         font-scale = 1.4; |         picture-uri = "file://${inputs.wallpapers}/Aqua.png"; | ||||||
|         use-system-font = false; |         picture-uri-dark = "file://${inputs.wallpapers}/Aqua.png"; | ||||||
|         custom-font = "ComicShannsMono Nerd Font 10"; |  | ||||||
|       }; |       }; | ||||||
|       "org/gtk/settings/file-chooser" = { |       "org/gtk/settings/file-chooser" = { | ||||||
|         show-hidden = true; |         show-hidden = true; | ||||||
| @@ -190,92 +110,98 @@ in { | |||||||
|         show-hidden = true; |         show-hidden = true; | ||||||
|         sort-directories-first = true; |         sort-directories-first = true; | ||||||
|       }; |       }; | ||||||
|  |       "org/gnome/settings-daemon/plugins/media-keys" = { | ||||||
|  |         volume-up = [ | ||||||
|  |           "<Shift>F12" | ||||||
|  |           "XF86AudioRaiseVolume" | ||||||
|  |         ]; | ||||||
|  |         volume-down = [ | ||||||
|  |           "<Shift>F11" | ||||||
|  |           "XF86AudioLowerVolume" | ||||||
|  |         ]; | ||||||
|  |       }; | ||||||
|  |       "org/gnome/gnome-session" = { | ||||||
|  |         auto-save-session = true; | ||||||
|  |       }; | ||||||
|  |       "org/gnome/gnome-system-monitor" = { | ||||||
|  |         show-dependencies = true; | ||||||
|  |       }; | ||||||
|  |       "org/gnome/Console" = { | ||||||
|  |         font-scale = 1.4; | ||||||
|  |       }; | ||||||
|  |       "org/gnome/mutter" = { | ||||||
|  |         center-new-windows = true; | ||||||
|  |         experimental-features = [ "scale-monitor-framebuffer" ]; | ||||||
|  |       }; | ||||||
|  |       "org/gnome/desktop/interface" = { | ||||||
|  |         color-scheme = "prefer-dark"; | ||||||
|  |         enable-hot-corners = false; | ||||||
|  |         monospace-font-name = "Ubuntu Mono 11"; | ||||||
|  |       }; | ||||||
|  |       "org/gnome/desktop/wm/keybindings" = { | ||||||
|  |         switch-group = [ "<Super>grave" ]; | ||||||
|  |         switch-group-backward = [ "<Shift><Super>grave" ]; | ||||||
|  |       }; | ||||||
|  |       "io/github/celluloid-player/celluloid" = { | ||||||
|  |         draggable-video-area-enable = true; | ||||||
|  |       }; | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     environment.sessionVariables = { |     fonts.packages = with pkgs; [ | ||||||
|       QT_STYLE_OVERRIDE = lib.mkForce "kvantum"; |       noto-fonts | ||||||
|       QT_WAYLAND_DECORATION = lib.mkForce "adwaita"; |       ubuntu_font_family | ||||||
|     }; |     ]; | ||||||
|  |  | ||||||
|     home.configFile = { |  | ||||||
|       "Kvantum/kvantum.kvconfig".text = lib.generators.toINI {} { |  | ||||||
|         General.theme = "KvLibadwaitaDark"; |  | ||||||
|       }; |  | ||||||
|       "Kvantum/KvLibadwaita".source = "${inputs.kvlibadwaita}/src/KvLibadwaita"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     user.packages = with pkgs; [ |     user.packages = with pkgs; [ | ||||||
|       authenticator |  | ||||||
|       # bottles |  | ||||||
|       # bustle |  | ||||||
|       celluloid |       celluloid | ||||||
|       # d-spy |       fragments | ||||||
|       # drawing |  | ||||||
|       # fragments |  | ||||||
|       gnome.dconf-editor |  | ||||||
|       gnome.ghex |  | ||||||
|       # gnome-builder |  | ||||||
|       gnome-decoder |  | ||||||
|       gnome-firmware |  | ||||||
|       gnome-frog |  | ||||||
|       # gnome-obfuscate |  | ||||||
|       gnome-podcasts |  | ||||||
|       identity |  | ||||||
|       mission-center |       mission-center | ||||||
|       mousam |     ]; | ||||||
|       newsflash |  | ||||||
|       # schemes |  | ||||||
|       shortwave |  | ||||||
|       sysprof |  | ||||||
|     ] ++ (if config.virtualisation.podman.enable then [ |  | ||||||
|       pods |  | ||||||
|     ] else []); |  | ||||||
|  |  | ||||||
|     environment.systemPackages = with pkgs.unstable; [ |     environment.systemPackages = with pkgs; [ | ||||||
|       adw-gtk3 |       bind | ||||||
|       kdePackages.qtstyleplugin-kvantum |       bmon | ||||||
|       libsForQt5.qtstyleplugin-kvantum |       fd | ||||||
|       morewaita-icon-theme |       ffmpeg | ||||||
|       nautilus-python |       gnome.gnome-boxes | ||||||
|       qadwaitadecorations |       gnomeExtensions.another-window-session-manager | ||||||
|       qadwaitadecorations-qt6 |       # gnomeExtensions.bifocals | ||||||
|  |  | ||||||
|       ## Shell extensions |  | ||||||
|       gnomeExtensions.appindicator |  | ||||||
|       gnomeExtensions.arcmenu |  | ||||||
|       gnomeExtensions.blur-my-shell |       gnomeExtensions.blur-my-shell | ||||||
|       gnomeExtensions.browser-tabs |       gnomeExtensions.browser-tabs | ||||||
|       gnomeExtensions.burn-my-windows |       gnomeExtensions.burn-my-windows | ||||||
|       gnomeExtensions.clipboard-indicator |  | ||||||
|       gnomeExtensions.coverflow-alt-tab |  | ||||||
|       gnomeExtensions.dash-to-panel |  | ||||||
|       gnomeExtensions.desktop-cube |       gnomeExtensions.desktop-cube | ||||||
|       gnomeExtensions.easyScreenCast |       gnomeExtensions.desktop-zoom | ||||||
|       gnomeExtensions.espresso |       gnomeExtensions.espresso | ||||||
|       gnomeExtensions.fly-pie |       gnome44Extensions."flypie@schneegans.github.com" | ||||||
|       gnomeExtensions.forge |       # gnomeExtensions.forge | ||||||
|       gnomeExtensions.gsconnect |       # gnomeExtensions.gsnap | ||||||
|       gnomeExtensions.gsnap |       gnomeExtensions.hue-lights | ||||||
|       gnomeExtensions.hide-top-bar |  | ||||||
|       gnomeExtensions.just-perfection |       gnomeExtensions.just-perfection | ||||||
|       gnomeExtensions.media-controls |       # gnomeExtensions.mutter-primary-gpu | ||||||
|       gnomeExtensions.mouse-follows-focus |  | ||||||
|       gnomeExtensions.pano |       gnomeExtensions.pano | ||||||
|       gnomeExtensions.paperwm |       gnomeExtensions.paperwm | ||||||
|       gnomeExtensions.pip-on-top |       # gnomeExtensions.pip-on-top | ||||||
|       gnomeExtensions.rounded-window-corners |       gnomeExtensions.rounded-window-corners | ||||||
|       gnomeExtensions.search-light |       gnomeExtensions.search-light | ||||||
|       gnomeExtensions.smart-auto-move |       gnomeExtensions.smart-auto-move | ||||||
|       gnomeExtensions.space-bar |       gnomeExtensions.space-bar | ||||||
|  |       gnomeExtensions.systemd-manager | ||||||
|  |       gnomeExtensions.tailscale-status | ||||||
|       gnomeExtensions.tiling-assistant |       gnomeExtensions.tiling-assistant | ||||||
|       # gnomeExtensions.tiling-shell |       # gnomeExtensions.todotxt | ||||||
|       gnomeExtensions.todotxt |  | ||||||
|       gnomeExtensions.vitals |       gnomeExtensions.vitals | ||||||
|       gnomeExtensions.window-is-ready-remover |       # gnomeExtensions.window-is-ready-remover | ||||||
|       gnomeExtensions.worksets |       # gnomeExtensions.worksets | ||||||
|       gnomeExtensions.workspace-matrix |       # gnomeExtensions.workspace-matrix | ||||||
|  |       iotop | ||||||
|  |       ripgrep | ||||||
|  |       rsync | ||||||
|  |       tcpdump | ||||||
|  |       tokei | ||||||
|  |       tree | ||||||
|  |       wl-clipboard | ||||||
|     ]; |     ]; | ||||||
|  |  | ||||||
|     home.services.gpg-agent.pinentryPackage = pkgs.pinentry-gnome3; |     home.services.gpg-agent.pinentryFlavor = "gnome3"; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,27 +0,0 @@ | |||||||
| { config, lib, pkgs, ... }: |  | ||||||
|  |  | ||||||
| let cfg = config.modules.desktop.hyprland; |  | ||||||
| in { |  | ||||||
|   options.modules.desktop.hyprland = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     programs.hyprland.enable = true; |  | ||||||
|  |  | ||||||
|     networking.networkmanager.enable = true; |  | ||||||
|  |  | ||||||
|     user.packages = with pkgs; [ |  | ||||||
|       mpv |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     environment.systemPackages = with pkgs; [ |  | ||||||
|       adw-gtk3 |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     home.services.gpg-agent.pinentryPackage = pkgs.pinentry-gnome3; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,37 +0,0 @@ | |||||||
| { config, lib, pkgs, ... }: |  | ||||||
|  |  | ||||||
| let cfg = config.modules.desktop.kde; |  | ||||||
| in { |  | ||||||
|   options.modules.desktop.kde = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     services = { |  | ||||||
|       xserver = { |  | ||||||
|         enable = true; |  | ||||||
|       }; |  | ||||||
|       desktopManager.plasma6.enable = true; |  | ||||||
|       displayManager.sddm = { |  | ||||||
|         enable = true; |  | ||||||
|         wayland.enable = true; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     networking.networkmanager.enable = true; |  | ||||||
|  |  | ||||||
|     user.packages = with pkgs; [ |  | ||||||
|       kmail |  | ||||||
|       mpv |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     environment.systemPackages = with pkgs; [ |  | ||||||
|       adw-gtk3 |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     home.services.gpg-agent.pinentryPackage = pkgs.pinentry-qt; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,24 +1,6 @@ | |||||||
| { config, lib, pkgs, ... }: | { config, lib, pkgs, ... }: | ||||||
|  |  | ||||||
| let | let cfg = config.modules.desktop.office.libreoffice; | ||||||
|   cfg = config.modules.desktop.office.libreoffice; |  | ||||||
|   # libreoffice-gtk4 = pkgs.libreoffice.override { |  | ||||||
|   #   extraMakeWrapperArgs = [ |  | ||||||
|   #     "--set SAL_USE_VCLPLUGIN gtk4" |  | ||||||
|   #   ]; |  | ||||||
|   #   unwrapped = pkgs.libreoffice-unwrapped.overrideAttrs (oldAttrs: { |  | ||||||
|   #     buildInputs = oldAttrs.buildInputs ++ [ |  | ||||||
|   #       pkgs.gtk4 |  | ||||||
|   #     ]; |  | ||||||
|   #     configureFlags = oldAttrs.configureFlags ++ [ |  | ||||||
|   #       "--disable-werror" |  | ||||||
|   #       "--enable-gtk4" |  | ||||||
|   #     ]; |  | ||||||
|   #     passthru = oldAttrs.passthru // { |  | ||||||
|   #       inherit (pkgs) gtk4; |  | ||||||
|   #     }; |  | ||||||
|   #   }); |  | ||||||
|   # }; |  | ||||||
| in { | in { | ||||||
|   options.modules.desktop.office.libreoffice = { |   options.modules.desktop.office.libreoffice = { | ||||||
|     enable = lib.mkOption { |     enable = lib.mkOption { | ||||||
| @@ -29,10 +11,7 @@ in { | |||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |   config = lib.mkIf cfg.enable { | ||||||
|     user.packages = with pkgs; [ |     user.packages = with pkgs; [ | ||||||
|       (if config.modules.desktop.kde.enable == true then libreoffice-qt else libreoffice) |       libreoffice | ||||||
|       hunspell |  | ||||||
|       hunspellDicts.en-gb-large |  | ||||||
|       hunspellDicts.en-us-large |  | ||||||
|     ]; |     ]; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ | |||||||
|  |  | ||||||
| let | let | ||||||
|   cfg = config.modules.editors.neovim; |   cfg = config.modules.editors.neovim; | ||||||
|  |   dev = config.modules.dev; | ||||||
| in { | in { | ||||||
|   options.modules.editors.neovim = { |   options.modules.editors.neovim = { | ||||||
|     enable = lib.mkOption { |     enable = lib.mkOption { | ||||||
| @@ -11,129 +12,124 @@ in { | |||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |   config = lib.mkIf cfg.enable { | ||||||
|     home.programs.nixvim = { |     user.packages = with pkgs; [ | ||||||
|       enable = true; |       (neovim.override { | ||||||
|       defaultEditor = true; |         configure = { | ||||||
|  |           customRC = '' | ||||||
|       viAlias = true; |             luafile ~/.config/nvim/init.lua | ||||||
|       vimAlias = true; |           ''; | ||||||
|  |           packages.myPlugins = with pkgs.vimPlugins; { | ||||||
|       options = { |             start = [ | ||||||
|         number = true; |               (nvim-treesitter.withPlugins ( | ||||||
|         tabstop = 2; |                 plugins: with plugins; [ | ||||||
|         shiftwidth = 2; |                   bash | ||||||
|         expandtab = true; |                   c | ||||||
|         foldlevel = 99; |                   cmake | ||||||
|         splitbelow = true; |                   cpp | ||||||
|         splitright = true; |                   css | ||||||
|         undofile = true; |                   dockerfile | ||||||
|         updatetime = 100; |                   elm | ||||||
|         list = true; |                   glsl | ||||||
|       }; |                   graphql | ||||||
|  |                   haskell | ||||||
|       globals = { |                   http | ||||||
|         mapleader = ","; |                   html | ||||||
|         maplocalleader = ","; |                   java | ||||||
|       }; |                   javascript | ||||||
|  |                   jsdoc | ||||||
|       clipboard = { |                   json | ||||||
|         register = "unnamedplus"; |                   json5 | ||||||
|  |                   latex | ||||||
|         providers.wl-copy.enable = true; |                   lua | ||||||
|       }; |                   markdown | ||||||
|  |                   ninja | ||||||
|       plugins.comment.enable = true; |                   nix | ||||||
|  |                   org | ||||||
|       plugins.hmts.enable = true; |                   perl | ||||||
|  |                   php | ||||||
|       plugins.lightline.enable = true; |                   pug | ||||||
|  |                   python | ||||||
|       plugins.luasnip.enable = true; |                   regex | ||||||
|  |                   rst | ||||||
|       plugins.lsp = { |                   ruby | ||||||
|         enable = true; |                   rust | ||||||
|         servers = { |                   scala | ||||||
|           bashls.enable = true; |                   scss | ||||||
|           ccls.enable = true; |                   toml | ||||||
|           cssls.enable = true; |                   tsx | ||||||
|           eslint.enable = true; |                   typescript | ||||||
|           gopls.enable = true; |                   vim | ||||||
|           html.enable = true; |                   yaml | ||||||
|           lua-ls.enable = true; |                   zig | ||||||
|           pylsp.enable = true; |                 ] | ||||||
|           nixd.enable = true; |               )) | ||||||
|           rust-analyzer = { |               nvim-treesitter-context | ||||||
|             enable = true; |               nvim-treesitter-textobjects | ||||||
|             installCargo = true; |               nvim-lspconfig | ||||||
|             installRustc = true; |  | ||||||
|           }; |  | ||||||
|           tsserver.enable = true; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       plugins.nvim-autopairs.enable = true; |  | ||||||
|  |  | ||||||
|       plugins.cmp = { |  | ||||||
|         enable = true; |  | ||||||
|         autoEnableSources = true; |  | ||||||
|         settings = { |  | ||||||
|           sources = [ |  | ||||||
|             { name = "nvim_lsp"; } |  | ||||||
|             { name = "path"; } |  | ||||||
|             { name = "buffer"; } |  | ||||||
|             ]; |             ]; | ||||||
|           mapping = { |  | ||||||
|             "<Tab>" = "cmp.mapping(cmp.mapping.select_next_item(), {'i', 's'})"; |  | ||||||
|             "<S-Tab>" = "cmp.mapping(cmp.mapping.select_prev_item(), {'i', 's'})"; |  | ||||||
|             "<CR>" = "cmp.mapping.confirm({ select = true })"; |  | ||||||
|           }; |  | ||||||
|           }; |           }; | ||||||
|         }; |         }; | ||||||
|  |       }) | ||||||
|  |     ] ++ | ||||||
|  |  | ||||||
|       plugins.telescope = { |     # Install appropriate language servers | ||||||
|         enable = true; |     (if dev.cc.enable then [ | ||||||
|         keymaps = { |       ccls                                            # C/C++ | ||||||
|           "<leader>ff" = "find_files"; |     ] else []) ++ | ||||||
|           "<leader>fg" = "live_grep"; |     (if dev.java.enable then [ | ||||||
|           "<leader>b" = "buffers"; |       java-language-server                            # Java | ||||||
|           "<leader>fh" = "help_tags"; |       ltex-ls                                         # LaTeX | ||||||
|           "<C-p>" = "git_files"; |     ] else []) ++ | ||||||
|           "<C-f>" = "live_grep"; |     (if dev.lua.enable then [ | ||||||
|         }; |       sumneko-lua-language-server                     # Lua | ||||||
|       }; |     ] else []) ++ | ||||||
|  |     (if dev.node.enable then [ | ||||||
|  |       nodePackages.bash-language-server               # Bash | ||||||
|  |       nodePackages.dockerfile-language-server-nodejs  # Dockerfile | ||||||
|  |       nodePackages.graphql-language-service-cli       # GraphQL | ||||||
|  |       nodePackages.purescript-language-server         # PureScript | ||||||
|  |       nodePackages.svelte-language-server             # Svelte | ||||||
|  |       nodePackages.typescript-language-server         # JavaScript/TypeScript | ||||||
|  |       nodePackages.vim-language-server                # Vim | ||||||
|  |       nodePackages.vscode-langservers-extracted       # HTML, CSS, JSON, ESLint | ||||||
|  |       nodePackages.vue-language-server                # Vue.js | ||||||
|  |       nodePackages.yaml-language-server               # YAML | ||||||
|  |     ] else []) ++ | ||||||
|  |     (if dev.python.enable then [ | ||||||
|  |       cmake-language-server                           # CMake | ||||||
|  |       python310Packages.python-lsp-server             # Python | ||||||
|  |     ] else []) ++ | ||||||
|  |     (if dev.rust.enable then [ | ||||||
|  |       rust-analyzer                                   # Rust | ||||||
|  |     ] else []) ++ | ||||||
|  |     (if dev.scala.enable then [ | ||||||
|  |       metals                                          # Scala | ||||||
|  |     ] else []) ++ | ||||||
|  |     (if dev.zig.enable then [ | ||||||
|  |       zls                                             # Zig | ||||||
|  |     ] else []); | ||||||
|  |  | ||||||
|       plugins.treesitter = { |     home.configFile = { | ||||||
|         enable = true; |       "nvim/init.lua".source = ./init.lua; | ||||||
|  |       "nvim/lua" = { source = ./lua; recursive = true; }; | ||||||
|         nixvimInjections = true; |       "nvim/lua/config/lsp.lua".text = '' | ||||||
|  |         -- This file is autogenerated, do not edit. | ||||||
|         folding = true; |         ${if dev.cc.enable then "require('config.lsp.cc')\n" else ""} | ||||||
|         indent = true; |         ${if dev.java.enable then "require('config.lsp.java')\n" else ""} | ||||||
|       }; |         ${if dev.lua.enable then "require('config.lsp.lua')\n" else ""} | ||||||
|  |         ${if dev.node.enable then "require('config.lsp.node')\n" else ""} | ||||||
|       plugins.treesitter-refactor = { |         ${if dev.python.enable then "require('config.lsp.python')\n" else ""} | ||||||
|         enable = true; |         ${if dev.rust.enable then "require('config.lsp.rust')\n" else ""} | ||||||
|         highlightDefinitions = { |         ${if dev.scala.enable then "require('config.lsp.scala')\n" else ""} | ||||||
|           enable = true; |         ${if dev.zig.enable then "require('config.lsp.zig')\n" else ""} | ||||||
|           clearOnCursorMove = false; |       ''; | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       plugins.undotree.enable = true; |  | ||||||
|  |  | ||||||
|       # plugins.gitsigns.enable = true; |  | ||||||
|       # plugins.gitgutter.enable = true; |  | ||||||
|       # plugins.goyo.enable = true; |  | ||||||
|       # plugins.fugitive.enable = true; |  | ||||||
|       # plugins.fzf-lua.enable = true; |  | ||||||
|       # plugins.neo-tree.enable = true; |  | ||||||
|       # plugins.none-ls.enable = true; |  | ||||||
|       # plugins.nvim-tree.enable = true; |  | ||||||
|       # plugins.oil.enable = true; |  | ||||||
|       # plugins.project-nvim.enable = true; |  | ||||||
|       # plugins.surround.enable = true; |  | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     env.EDITOR = "nvim"; |     env.EDITOR = "nvim"; | ||||||
|  |  | ||||||
|  |     environment.shellAliases = { | ||||||
|  |       vim = "nvim"; | ||||||
|  |       v   = "nvim"; | ||||||
|  |     }; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								modules/editors/neovim/init.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								modules/editors/neovim/init.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | require("config.core") | ||||||
|  | require("config.keymap") | ||||||
|  | require("config.treesitter") | ||||||
|  | require("config.plugins") | ||||||
|  | require("config.lsp") | ||||||
|  |  | ||||||
							
								
								
									
										36
									
								
								modules/editors/neovim/lua/config/core.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								modules/editors/neovim/lua/config/core.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | local o = vim.opt | ||||||
|  | local wo = vim.wo | ||||||
|  | local bo = vim.bo | ||||||
|  |  | ||||||
|  | -- Global dirs | ||||||
|  | local cachedir = os.getenv("XDG_CACHE_HOME") | ||||||
|  | o.backupdir = cachedir .. "/nvim/backup/" | ||||||
|  | o.directory = cachedir .. "/nvim/swap/" | ||||||
|  | o.undodir   = cachedir .. "/nvim/undo/" | ||||||
|  |  | ||||||
|  | -- Global | ||||||
|  | o.breakindent = true | ||||||
|  | o.clipboard = "unnamedplus" | ||||||
|  | o.compatible = false | ||||||
|  | o.encoding = "utf-8" | ||||||
|  | o.expandtab = true | ||||||
|  | o.foldlevel = 99 | ||||||
|  | o.hidden = true | ||||||
|  | o.hlsearch = false | ||||||
|  | o.ignorecase = true | ||||||
|  | o.laststatus = 2 | ||||||
|  | o.listchars = { eol = '↲', tab = '▸ ', trail = '·' } | ||||||
|  | o.relativenumber = true | ||||||
|  | o.shiftwidth = 2 | ||||||
|  | o.showmode = false | ||||||
|  | o.smartcase = true | ||||||
|  | o.smarttab = true | ||||||
|  | o.softtabstop = 2 | ||||||
|  | o.synmaxcol = 150 | ||||||
|  | o.tabstop = 4 | ||||||
|  | o.undofile = true | ||||||
|  | o.wildmenu = true | ||||||
|  |  | ||||||
|  | -- Window | ||||||
|  |  | ||||||
|  | -- Buffer | ||||||
							
								
								
									
										35
									
								
								modules/editors/neovim/lua/config/keymap.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								modules/editors/neovim/lua/config/keymap.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | local keymap = vim.keymap.set | ||||||
|  | local opts = { noremap = true, silent = true } | ||||||
|  |  | ||||||
|  | vim.g.mapleader = "," | ||||||
|  |  | ||||||
|  | -- Modes | ||||||
|  | --   Normal = "n", | ||||||
|  | --   Insert = "i", | ||||||
|  | --   Visual = "v", | ||||||
|  | --   Visual Block = "x", | ||||||
|  | --   Term = "t", | ||||||
|  | --   Command = "c" | ||||||
|  |  | ||||||
|  | keymap("n", "<Left>", "<Nop>", opts) | ||||||
|  | keymap("n", "<Right>", "<Nop>", opts) | ||||||
|  | keymap("n", "<Up>", "<Nop>", opts) | ||||||
|  | keymap("n", "<Down>", "<Nop>", opts) | ||||||
|  |  | ||||||
|  | keymap("n", "<C-h>", "<C-w>h", { noremap = true }) | ||||||
|  | keymap("n", "<C-j>", "<C-w>j", { noremap = true }) | ||||||
|  | keymap("n", "<C-k>", "<C-w>k", { noremap = true }) | ||||||
|  | keymap("n", "<C-l>", "<C-w>l", { noremap = true }) | ||||||
|  |  | ||||||
|  | keymap("n", "gV", "`[v`]", opts) | ||||||
|  |  | ||||||
|  | keymap("n", ";", ":", { noremap = true }) | ||||||
|  |  | ||||||
|  | -- Bubble single lines with vim-unimpaired | ||||||
|  | keymap("n", "<C-Up>", "[e", opts) | ||||||
|  | keymap("n", "<C-Down>", "]e", opts) | ||||||
|  |  | ||||||
|  | -- Bubble multiple lines with vim-unimpaired | ||||||
|  | keymap("v", "<C-Up>", "[egv", opts) | ||||||
|  | keymap("v", "<C-Down>", "]egv", opts) | ||||||
|  |  | ||||||
							
								
								
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/cc.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/cc.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires C/C++ | ||||||
|  | lspconfig.ccls.setup{} | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								modules/editors/neovim/lua/config/lsp/java.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								modules/editors/neovim/lua/config/lsp/java.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires Java | ||||||
|  | lspconfig.java_language_server.setup{} | ||||||
|  | lspconfig.ltex.setup{} | ||||||
|  |  | ||||||
							
								
								
									
										22
									
								
								modules/editors/neovim/lua/config/lsp/lua.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								modules/editors/neovim/lua/config/lsp/lua.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires Lua | ||||||
|  | lspconfig.sumneko_lua.setup { | ||||||
|  |   settings = { | ||||||
|  |     Lua = { | ||||||
|  |       runtime = { | ||||||
|  |         -- Tell the language server which version of Lua you're using (most likely LuaJIT in the case of Neovim) | ||||||
|  |         version = 'LuaJIT', | ||||||
|  |       }, | ||||||
|  |       diagnostics = { | ||||||
|  |         -- Get the language server to recognize the `vim` global | ||||||
|  |         globals = {'vim'}, | ||||||
|  |       }, | ||||||
|  |       -- Do not send telemetry data containing a randomized but unique identifier | ||||||
|  |       telemetry = { | ||||||
|  |         enable = false, | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  |  | ||||||
							
								
								
									
										17
									
								
								modules/editors/neovim/lua/config/lsp/node.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								modules/editors/neovim/lua/config/lsp/node.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires Node.js | ||||||
|  | lspconfig.bashls.setup{} | ||||||
|  | lspconfig.cssls.setup{} | ||||||
|  | lspconfig.dockerls.setup{} | ||||||
|  | lspconfig.eslint.setup{} | ||||||
|  | lspconfig.graphql.setup{} | ||||||
|  | lspconfig.html.setup{} | ||||||
|  | lspconfig.jsonls.setup{} | ||||||
|  | lspconfig.purescriptls.setup{} | ||||||
|  | lspconfig.svelte.setup{} | ||||||
|  | lspconfig.tsserver.setup{} | ||||||
|  | lspconfig.vimls.setup{} | ||||||
|  | lspconfig.vuels.setup{} | ||||||
|  | lspconfig.yamlls.setup{} | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								modules/editors/neovim/lua/config/lsp/python.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								modules/editors/neovim/lua/config/lsp/python.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires Python | ||||||
|  | lspconfig.cmake.setup{} | ||||||
|  | lspconfig.pylsp.setup{} | ||||||
|  |  | ||||||
							
								
								
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/rust.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/rust.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires Rust | ||||||
|  | lspconfig.rls.setup{} | ||||||
|  |  | ||||||
							
								
								
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/scala.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/scala.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires Scala | ||||||
|  | lspconfig.metals.setup{} | ||||||
|  |  | ||||||
							
								
								
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/zig.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								modules/editors/neovim/lua/config/lsp/zig.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | lspconfig = require('lspconfig') | ||||||
|  |  | ||||||
|  | -- Requires Zig | ||||||
|  | lspconfig.zls.setup{} | ||||||
|  |  | ||||||
							
								
								
									
										77
									
								
								modules/editors/neovim/lua/config/plugins.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								modules/editors/neovim/lua/config/plugins.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | |||||||
|  | local fn = vim.fn | ||||||
|  |  | ||||||
|  | local install_path = fn.stdpath "data" .. "/site/pack/packer/start/packer.nvim" | ||||||
|  | if fn.empty(fn.glob(install_path)) > 0 then | ||||||
|  |   PACKER_BOOTSTRAP = fn.system { | ||||||
|  |     "git", | ||||||
|  |     "clone", | ||||||
|  |     "--depth", | ||||||
|  |     "1", | ||||||
|  |     "https://github.com/wbthomason/packer.nvim", | ||||||
|  |     install_path, | ||||||
|  |   } | ||||||
|  |   print "Installing packer close and reopen Neovim..." | ||||||
|  |   vim.cmd [[packadd packer.nvim]] | ||||||
|  | end | ||||||
|  |  | ||||||
|  | vim.cmd [[ | ||||||
|  |   augroup packer_user_config | ||||||
|  |     autocmd! | ||||||
|  |     autocmd BufWritePost plugins.lua source <afile> | PackerSync | ||||||
|  |   augroup end | ||||||
|  | ]] | ||||||
|  |  | ||||||
|  | local status_ok, packer = pcall(require, "packer") | ||||||
|  | if not status_ok then | ||||||
|  |   return | ||||||
|  | end | ||||||
|  |  | ||||||
|  | packer.init { | ||||||
|  |   display = { | ||||||
|  |     open_fn = function() | ||||||
|  |       return require("packer.util").float { border = "rounded" } | ||||||
|  |     end, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | return packer.startup(function(use) | ||||||
|  |   -- Utilities | ||||||
|  |   use { "wbthomason/packer.nvim", opt = true } | ||||||
|  |   use { "mbbill/undotree" } | ||||||
|  |   use { "nvim-lua/plenary.nvim" } | ||||||
|  |   use { "tpope/vim-fugitive", event = "User InGitRepo" } | ||||||
|  |  | ||||||
|  |   -- Editing | ||||||
|  |   use { "andymass/vim-matchup" } | ||||||
|  |   use { "godlygeek/tabular" } | ||||||
|  |   use { "JoosepAlviste/nvim-ts-context-commentstring" } | ||||||
|  |   use { "kana/vim-textobj-user" } | ||||||
|  |   use { "mg979/vim-visual-multi", branch = "master" } | ||||||
|  |   use { "p00f/nvim-ts-rainbow" } | ||||||
|  |   use { "terryma/vim-expand-region" } | ||||||
|  |   use { "tommcdo/vim-exchange", event = "VimEnter" } | ||||||
|  |   use { "tpope/vim-abolish" } | ||||||
|  |   use { "tpope/vim-commentary", event = "VimEnter" } | ||||||
|  |   use { "tpope/vim-repeat", event = "VimEnter" } | ||||||
|  |   use { "tpope/vim-surround", event = "VimEnter" } | ||||||
|  |   use { "windwp/nvim-autopairs" } | ||||||
|  |   use { "windwp/nvim-ts-autotag" } | ||||||
|  |  | ||||||
|  |   -- UI | ||||||
|  |   use { "junegunn/goyo.vim" } | ||||||
|  |   use { "junegunn/limelight.vim" } | ||||||
|  |   use { "markonm/traces.vim" } | ||||||
|  |  | ||||||
|  |   -- Searching | ||||||
|  |   use { "nvim-telescope/telescope.nvim", config = [[require('config.telescope')]] } | ||||||
|  |   use { "cljoly/telescope-repo.nvim", requires = "telescope.nvim" } | ||||||
|  |   use { "dyng/ctrlsf.vim" } | ||||||
|  |  | ||||||
|  |   -- LSP | ||||||
|  |   use { "jose-elias-alvarez/null-ls.nvim" } | ||||||
|  |  | ||||||
|  |   if PACKER_BOOTSTRAP then | ||||||
|  |     require("packer").sync() | ||||||
|  |   end | ||||||
|  | end) | ||||||
|  |  | ||||||
							
								
								
									
										46
									
								
								modules/editors/neovim/lua/config/telescope.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								modules/editors/neovim/lua/config/telescope.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | |||||||
|  | local status_ok, telescope = pcall(require, "telescope") | ||||||
|  | if not status_ok then | ||||||
|  |   return | ||||||
|  | end | ||||||
|  |  | ||||||
|  | local actions = require("telescope.actions") | ||||||
|  |  | ||||||
|  | telescope.setup({ | ||||||
|  |   defaults = { | ||||||
|  |     file_ignore_patterns = { ".git/", "node_modules" }, | ||||||
|  |   }, | ||||||
|  |   mappings = { | ||||||
|  |     i = { | ||||||
|  |       ["<Down>"] = actions.cycle_history_next, | ||||||
|  |       ["<Up>"] = actions.cycle_history_prev, | ||||||
|  |       ["<C-j>"] = actions.move_selection_next, | ||||||
|  |       ["<C-k>"] = actions.move_selection_previous, | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  |   extensions = { | ||||||
|  |     repo = { | ||||||
|  |       list = { | ||||||
|  |         fd_opts = { | ||||||
|  |           "--no-ignore-vcs", | ||||||
|  |         }, | ||||||
|  |         search_dirs = { | ||||||
|  |           "~/projects", | ||||||
|  |           "~/repos", | ||||||
|  |           "~/workspace", | ||||||
|  |         }, | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | telescope.load_extension("repo") | ||||||
|  |  | ||||||
|  | local keymap = vim.keymap.set | ||||||
|  | local opts = { noremap = true, silent = true } | ||||||
|  |  | ||||||
|  | keymap("n", "<Leader>ff", "<cmd>Telescope find_files<cr>", opts) | ||||||
|  | keymap("n", "<Leader>fg", "<cmd>Telescope live_grep<cr>", opts) | ||||||
|  | keymap("n", "<Leader>fb", "<cmd>Telescope buffers<cr>", opts) | ||||||
|  | keymap("n", "<Leader>fh", "<cmd>Telescope help_tags<cr>", opts) | ||||||
|  | keymap("n", "<Leader>fr", "<cmd>Telescope repo list<cr>", opts) | ||||||
|  |  | ||||||
							
								
								
									
										35
									
								
								modules/editors/neovim/lua/config/treesitter.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								modules/editors/neovim/lua/config/treesitter.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | require("nvim-treesitter.configs").setup({ | ||||||
|  |   ignore_install = {}, | ||||||
|  |   highlight = { | ||||||
|  |     enable = true, | ||||||
|  |     disable = {}, | ||||||
|  |   }, | ||||||
|  |   indent = { enable = true }, | ||||||
|  |   incremental_selection = { | ||||||
|  |     enable = true, | ||||||
|  |     keymaps = { | ||||||
|  |       init_selection = "gnn", | ||||||
|  |       node_incremental = "grn", | ||||||
|  |       scope_incremental = "grc", | ||||||
|  |       node_decremental = "grm", | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  |   -- Extensions | ||||||
|  |   autotag = { enable = true }, | ||||||
|  |   context_commentstring = { enable = true }, | ||||||
|  |   matchup = { enable = true }, | ||||||
|  |   rainbow = { enable = true }, | ||||||
|  |   textobjects = { | ||||||
|  |     select = { | ||||||
|  |       enable = true, | ||||||
|  |       keymaps = { | ||||||
|  |         ["af"] = "@function.outer", | ||||||
|  |         ["if"] = "@function.inner", | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | vim.opt.foldmethod = "expr" | ||||||
|  | vim.opt.foldexpr = "nvim_treesitter#foldexpr()" | ||||||
|  |  | ||||||
| @@ -1,88 +0,0 @@ | |||||||
| { config, lib, pkgs, ... }: |  | ||||||
| let |  | ||||||
|   cfg = config.modules.hardware.presonus-studio; |  | ||||||
|   snd-usb-audio-module = pkgs.callPackage ./snd-usb-audio.nix { |  | ||||||
|     kernel = config.boot.kernelPackages.kernel; |  | ||||||
|   }; |  | ||||||
|   patched = snd-usb-audio-module.overrideAttrs (prev: { |  | ||||||
|     patches = [ ./0001-Update-device-ID-for-PreSonus-1824c.patch ]; |  | ||||||
|   }); |  | ||||||
|   upmixConfig = { |  | ||||||
|     "stream.properties" = { |  | ||||||
|       "channelmix.upmix" = true; |  | ||||||
|       "channelmix.upmix-method" = "psd"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| in { |  | ||||||
|   options.modules.hardware.presonus-studio = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     boot.kernelModules = [ "snd-usb-audio" ]; |  | ||||||
|     boot.extraModulePackages = [ |  | ||||||
|       (patched) |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     # Workaround for mainline module loading instead of patched module |  | ||||||
|     systemd.services.reload-snd-usb-audio = { |  | ||||||
|       description = "Reload snd_usb_audio kernel module"; |  | ||||||
|       wantedBy = [ "sound.target" ]; |  | ||||||
|       serviceConfig.Type = "oneshot"; |  | ||||||
|       path = with pkgs; [ |  | ||||||
|         kmod |  | ||||||
|       ]; |  | ||||||
|       script = '' |  | ||||||
|         # Only reload if device hasn't been initialised |  | ||||||
|         if ! cat /proc/asound/card*/usbmixer | grep -q "Mute Main Out Switch"; then |  | ||||||
|           rmmod snd_usb_audio |  | ||||||
|           insmod /run/booted-system/kernel-modules/lib/modules/$(uname -r)/extra/snd-usb-audio.ko.xz |  | ||||||
|         fi |  | ||||||
|       ''; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.pipewire.extraConfig = { |  | ||||||
|       pipewire = { |  | ||||||
|         "10-network" = { |  | ||||||
|           "context.modules" = [ |  | ||||||
|             { |  | ||||||
|               "name" = "libpipewire-module-rtp-session"; |  | ||||||
|               "args" = { |  | ||||||
|                 "stream.props" = { |  | ||||||
|                   "node.name" = "rtp-source"; |  | ||||||
|                 }; |  | ||||||
|               }; |  | ||||||
|             } |  | ||||||
|           ]; |  | ||||||
|         }; |  | ||||||
|         "surround" = { |  | ||||||
|           "context.modules" = [ |  | ||||||
|             { |  | ||||||
|               "name" = "libpipewire-module-loopback"; |  | ||||||
|               "args" = { |  | ||||||
|                 "node.description" = "Genelec 4.1 Surround"; |  | ||||||
|                 "capture.props" = { |  | ||||||
|                   "node.name" = "Genelec_Speakers"; |  | ||||||
|                   "media.class" = "Audio/Sink"; |  | ||||||
|                   "audio.position" = [ "FL" "FR" "SL" "SR" "LFE" ]; |  | ||||||
|                 }; |  | ||||||
|                 "playback.props" = { |  | ||||||
|                   "node.name" = "playback.Genelec_Speakers"; |  | ||||||
|                   "audio.position" = [ "AUX0" "AUX1" "AUX3" "AUX4" "AUX5" ]; |  | ||||||
|                   "target.object" = "alsa_output.usb-PreSonus_Studio_1824c_SC4E21110775-00.multichannel-output"; |  | ||||||
|                   "stream.dont-remix" = true; |  | ||||||
|                   "node.passive" = true; |  | ||||||
|                 }; |  | ||||||
|               }; |  | ||||||
|             } |  | ||||||
|           ]; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|       pipewire-pulse."40-upmix" = upmixConfig; |  | ||||||
|       client-rt."40-upmix" = upmixConfig; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  }  |  | ||||||
| @@ -1,9 +1,6 @@ | |||||||
| { config, inputs, lib, pkgs, ... }: | { config, lib, pkgs, ... }: | ||||||
|  |  | ||||||
| let | let cfg = config.modules.networking.tailscale; | ||||||
|   cfg = config.modules.networking.tailscale; |  | ||||||
|   headscale = "https://headscale.vimium.net"; |  | ||||||
|   hostname = config.networking.hostName; |  | ||||||
| in { | in { | ||||||
|   options.modules.networking.tailscale = { |   options.modules.networking.tailscale = { | ||||||
|     enable = lib.mkOption { |     enable = lib.mkOption { | ||||||
| @@ -17,24 +14,8 @@ in { | |||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |   config = lib.mkIf cfg.enable { | ||||||
|     age.secrets."passwords/services/tailscale/${hostname}-authkey" = { |     services.tailscale.enable = true; | ||||||
|       file = "${inputs.secrets}/passwords/services/tailscale/${hostname}-authkey.age"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     environment.systemPackages = [ pkgs.tailscale ]; |  | ||||||
|  |  | ||||||
|     services.tailscale = { |  | ||||||
|       enable = true; |  | ||||||
|       authKeyFile = config.age.secrets."passwords/services/tailscale/${hostname}-authkey".path; |  | ||||||
|  |  | ||||||
|       extraUpFlags = [ |  | ||||||
|         "--login-server" |  | ||||||
|         headscale |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.openssh.openFirewall = !cfg.restrictSSH; |     services.openssh.openFirewall = !cfg.restrictSSH; | ||||||
|  |  | ||||||
|     networking.firewall = { |     networking.firewall = { | ||||||
|       checkReversePath = "loose"; |       checkReversePath = "loose"; | ||||||
|       trustedInterfaces = [ "tailscale0" ]; |       trustedInterfaces = [ "tailscale0" ]; | ||||||
|   | |||||||
| @@ -1,60 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let cfg = config.modules.networking.wireless; |  | ||||||
| in { |  | ||||||
|   options.modules.networking.wireless = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|       description = mdDoc "Automatically connect to known networks"; |  | ||||||
|     }; |  | ||||||
|     interfaces = mkOption { |  | ||||||
|       default = [ ];  # All interfaces |  | ||||||
|       example = [ "wlan0" ]; |  | ||||||
|       description = mdDoc "Interfaces for `wpa_supplicant` to bind to"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = mkIf cfg.enable { |  | ||||||
|     age.secrets."passwords/networks" = { |  | ||||||
|       file = "${inputs.secrets}/passwords/networks.age"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     networking = { |  | ||||||
|       wireless = { |  | ||||||
|         enable = true; |  | ||||||
|         interfaces = cfg.interfaces; |  | ||||||
|         environmentFile = config.age.secrets."passwords/networks".path; |  | ||||||
|         networks = { |  | ||||||
|           "Apollo 600 Mbps".psk = "@PSK_APOLLO@"; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|       networkmanager.ensureProfiles.profiles = { |  | ||||||
|         "Apollo" = { |  | ||||||
|           connection = { |  | ||||||
|             id = "Apollo 600 Mbps"; |  | ||||||
|             type = "wifi"; |  | ||||||
|           }; |  | ||||||
|           wifi = { |  | ||||||
|             mode = "infrastructure"; |  | ||||||
|             ssid = "Apollo 600 Mbps"; |  | ||||||
|           }; |  | ||||||
|           wifi-security = { |  | ||||||
|             auth-alg = "open"; |  | ||||||
|             key-mgmt = "wpa-psk"; |  | ||||||
|             psk = ""; |  | ||||||
|           }; |  | ||||||
|           ipv4 = { |  | ||||||
|             method = "auto"; |  | ||||||
|           }; |  | ||||||
|           ipv6 = { |  | ||||||
|             addr-gen-mode = "stable-privacy"; |  | ||||||
|             method = "auto"; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| { config, options, lib, home-manager, inputs, ... }: | { config, options, lib, home-manager, ... }: | ||||||
|  |  | ||||||
| with lib; | with lib; | ||||||
| { | { | ||||||
| @@ -29,7 +29,6 @@ with lib; | |||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   config = { |   config = { | ||||||
|     age.secrets."passwords/users/jordan".file = "${inputs.secrets}/passwords/users/jordan.age"; |  | ||||||
|     user = |     user = | ||||||
|       let user = builtins.getEnv "USER"; |       let user = builtins.getEnv "USER"; | ||||||
|           name = if elem user [ "" "root" ] then "jordan" else user; |           name = if elem user [ "" "root" ] then "jordan" else user; | ||||||
| @@ -42,7 +41,6 @@ with lib; | |||||||
|         openssh.authorizedKeys.keys = [ |         openssh.authorizedKeys.keys = [ | ||||||
|           "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILVHTjsyMIV4THNw6yz0OxAxGnC+41gX72UrPqTzR+OS jordan@vimium.com" |           "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILVHTjsyMIV4THNw6yz0OxAxGnC+41gX72UrPqTzR+OS jordan@vimium.com" | ||||||
|         ]; |         ]; | ||||||
|         hashedPasswordFile = config.age.secrets."passwords/users/jordan".path; |  | ||||||
|         home = "/home/${name}"; |         home = "/home/${name}"; | ||||||
|         group = "users"; |         group = "users"; | ||||||
|         uid = 1000; |         uid = 1000; | ||||||
| @@ -66,11 +64,6 @@ with lib; | |||||||
|         }; |         }; | ||||||
|         dconf.settings = mkAliasDefinitions options.dconf.settings; |         dconf.settings = mkAliasDefinitions options.dconf.settings; | ||||||
|       }; |       }; | ||||||
|  |  | ||||||
|       sharedModules = [ |  | ||||||
|         inputs.nixvim.homeManagerModules.nixvim |  | ||||||
|         inputs.plasma-manager.homeManagerModules.plasma-manager |  | ||||||
|       ]; |  | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     users.users.${config.user.name} = mkAliasDefinitions options.user; |     users.users.${config.user.name} = mkAliasDefinitions options.user; | ||||||
|   | |||||||
| @@ -1,45 +0,0 @@ | |||||||
| { pkgs, lib, config, ... }: |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.podman; |  | ||||||
| in { |  | ||||||
|   options.modules.podman = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|       description = mdDoc "Enable podman on this host"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = mkIf cfg.enable { |  | ||||||
|     virtualisation = { |  | ||||||
|       docker.enable = false; |  | ||||||
|  |  | ||||||
|       podman = { |  | ||||||
|         enable = true; |  | ||||||
|         defaultNetwork.settings.dns_enabled = true; |  | ||||||
|         autoPrune = { |  | ||||||
|           enable = true; |  | ||||||
|           dates = "weekly"; |  | ||||||
|           flags = [ "--all" ]; |  | ||||||
|         }; |  | ||||||
|         extraPackages = [ pkgs.zfs ]; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       containers.storage.settings.storage = { |  | ||||||
|         driver = "zfs"; |  | ||||||
|         graphroot = "/var/lib/containers/storage"; |  | ||||||
|         runroot = "/run/containers/storage"; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       oci-containers.backend = "podman"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     networking.firewall.interfaces."podman+" = { |  | ||||||
|       allowedUDPPorts = [ 53 ]; |  | ||||||
|       allowedTCPPorts = [ 53 ]; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,61 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.borgmatic; |  | ||||||
|   hostname = config.networking.hostName; |  | ||||||
| in { |  | ||||||
|   options.modules.services.borgmatic = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|       description = lib.mdDoc "Enable backups on this host with `borgmatic`"; |  | ||||||
|     }; |  | ||||||
|     directories = lib.mkOption { |  | ||||||
|       type = lib.types.listOf lib.types.str; |  | ||||||
|       default = []; |  | ||||||
|       example = [ |  | ||||||
|         "/home/jordan/Documents" |  | ||||||
|       ]; |  | ||||||
|       description = lib.mdDoc "List of directories to backup"; |  | ||||||
|     }; |  | ||||||
|     repoPath = lib.mkOption { |  | ||||||
|       type = lib.types.str; |  | ||||||
|       example = "ssh://example@example.repo.borgbase.com/./repo"; |  | ||||||
|       description = lib.mdDoc "Destination borg repository for backup"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     age.secrets."passwords/services/borg/${hostname}-passphrase" = { |  | ||||||
|       file = "${inputs.secrets}/passwords/services/borg/${hostname}-passphrase.age"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.borgmatic = { |  | ||||||
|       enable = true; |  | ||||||
|       settings = { |  | ||||||
|         source_directories = cfg.directories; |  | ||||||
|         repositories = [ |  | ||||||
|           { label = "borgbase"; path = cfg.repoPath; } |  | ||||||
|         ]; |  | ||||||
|         encryption_passcommand = "cat ${config.age.secrets."passwords/services/borg/${hostname}-passphrase".path}"; |  | ||||||
|         ssh_command = "ssh -i /etc/ssh/ssh_host_ed25519_key"; |  | ||||||
|         keep_daily = 7; |  | ||||||
|         keep_weekly = 4; |  | ||||||
|         keep_monthly = 6; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.postgresql.ensureUsers = [ |  | ||||||
|       { |  | ||||||
|         name = "root"; |  | ||||||
|         ensureClauses.superuser = true; |  | ||||||
|       } |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     # Add `pg_dumpall` to unit environment |  | ||||||
|     systemd.services.borgmatic.path = [ config.services.postgresql.package ]; |  | ||||||
|  |  | ||||||
|     # Without this override, `cat` is unavailable for `encryption_passcommand` |  | ||||||
|     systemd.services.borgmatic.confinement.fullUnit = true; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,41 +0,0 @@ | |||||||
| { config, lib, pkgs, ... }: |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.chrony; |  | ||||||
| in { |  | ||||||
|   options.modules.services.chrony = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|       description = "Enable chrony NTP deamon"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     config = mkIf cfg.enable { |  | ||||||
|       services.chrony = { |  | ||||||
|         enable = true; |  | ||||||
|  |  | ||||||
|         servers = [ |  | ||||||
|           "uk.pool.ntp.org" |  | ||||||
|           "time.cloudflare.com" |  | ||||||
|         ]; |  | ||||||
|  |  | ||||||
|         extraConfig = '' |  | ||||||
|           makestep 1.0 3 |  | ||||||
|  |  | ||||||
|           bindaddress 0.0.0.0 |  | ||||||
|           port 123 |  | ||||||
|           allow |  | ||||||
|         ''; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       services.timesyncd.enable = mkForce false; |  | ||||||
|  |  | ||||||
|       networking.firewall = { |  | ||||||
|         allowedUDPPorts = [ 123 ]; |  | ||||||
|         allowedTCPPorts = [ 123 ]; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,123 +0,0 @@ | |||||||
| { |  | ||||||
|   config, |  | ||||||
|   lib, |  | ||||||
|   inputs, |  | ||||||
|   ... |  | ||||||
| }: |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.coturn; |  | ||||||
| in { |  | ||||||
|   options.modules.services.coturn = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|     realm = lib.mkOption { |  | ||||||
|       type = lib.types.str; |  | ||||||
|       description = "The realm to be used by the TURN server."; |  | ||||||
|       example = "turn.vimium.com"; |  | ||||||
|     }; |  | ||||||
|     matrixIntegration = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       description = "Configure the matrix-synapse module to use this TURN server."; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     networking.firewall = let |  | ||||||
|       range = with config.services.coturn; lib.singleton { |  | ||||||
|         from = min-port; |  | ||||||
|         to = max-port; |  | ||||||
|       }; |  | ||||||
|     in { |  | ||||||
|       allowedTCPPorts = [ |  | ||||||
|         3478  # TURN listener |  | ||||||
|         5349  # STUN TLS |  | ||||||
|         5350  # STUN TLS alt |  | ||||||
|       ]; |  | ||||||
|       allowedUDPPorts = [ |  | ||||||
|         3478  # TURN listener |  | ||||||
|         5349  # TLS |  | ||||||
|         5350  # TLS alt |  | ||||||
|       ]; |  | ||||||
|       allowedUDPPortRanges = range; # TURN peer relays |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     security.acme.certs = { |  | ||||||
|       "${config.services.coturn.realm}" = { |  | ||||||
|         group = "turnserver"; |  | ||||||
|         reloadServices = [ "coturn" ]; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     age.secrets = { |  | ||||||
|       "passwords/services/coturn/static-auth-secret" = { |  | ||||||
|         file = "${inputs.secrets}/passwords/services/coturn/static-auth-secret.age"; |  | ||||||
|         owner = "turnserver"; |  | ||||||
|         group = "turnserver"; |  | ||||||
|       }; |  | ||||||
|     } // (if cfg.matrixIntegration then { |  | ||||||
|       "passwords/services/coturn/matrix-turn-config.yml" = { |  | ||||||
|         file = "${inputs.secrets}/passwords/services/coturn/matrix-turn-config.yml.age"; |  | ||||||
|         owner = "matrix-synapse"; |  | ||||||
|         group = "matrix-synapse"; |  | ||||||
|       }; |  | ||||||
|     } else {}); |  | ||||||
|  |  | ||||||
|     services.coturn = rec { |  | ||||||
|       enable = true; |  | ||||||
|       realm = cfg.realm; |  | ||||||
|       use-auth-secret = true; |  | ||||||
|       static-auth-secret-file = config.age.secrets."passwords/services/coturn/static-auth-secret".path; |  | ||||||
|       cert = "${config.security.acme.certs.${realm}.directory}/full.pem"; |  | ||||||
|       pkey = "${config.security.acme.certs.${realm}.directory}/key.pem"; |  | ||||||
|       min-port = 49000; |  | ||||||
|       max-port = 50000; |  | ||||||
|       no-cli = true; |  | ||||||
|       no-tcp-relay = true; |  | ||||||
|       extraConfig = '' |  | ||||||
|         cipher-list="HIGH" |  | ||||||
|         no-multicast-peers |  | ||||||
|  |  | ||||||
|         # Ban private CIDR blocks |  | ||||||
|         denied-peer-ip=0.0.0.0-0.255.255.255 |  | ||||||
|         denied-peer-ip=10.0.0.0-10.255.255.255 |  | ||||||
|         denied-peer-ip=100.64.0.0-100.127.255.255 |  | ||||||
|         denied-peer-ip=127.0.0.0-127.255.255.255 |  | ||||||
|         denied-peer-ip=169.254.0.0-169.254.255.255 |  | ||||||
|         denied-peer-ip=172.16.0.0-172.31.255.255 |  | ||||||
|         denied-peer-ip=192.0.0.0-192.0.0.255 |  | ||||||
|         denied-peer-ip=192.0.2.0-192.0.2.255 |  | ||||||
|         denied-peer-ip=192.88.99.0-192.88.99.255 |  | ||||||
|         denied-peer-ip=192.168.0.0-192.168.255.255 |  | ||||||
|         denied-peer-ip=198.18.0.0-198.19.255.255 |  | ||||||
|         denied-peer-ip=198.51.100.0-198.51.100.255 |  | ||||||
|         denied-peer-ip=203.0.113.0-203.0.113.255 |  | ||||||
|         denied-peer-ip=240.0.0.0-255.255.255.255 |  | ||||||
|         denied-peer-ip=::1 |  | ||||||
|         denied-peer-ip=64:ff9b::-64:ff9b::ffff:ffff |  | ||||||
|         denied-peer-ip=::ffff:0.0.0.0-::ffff:255.255.255.255 |  | ||||||
|         denied-peer-ip=100::-100::ffff:ffff:ffff:ffff |  | ||||||
|         denied-peer-ip=2001::-2001:1ff:ffff:ffff:ffff:ffff:ffff:ffff |  | ||||||
|         denied-peer-ip=2002::-2002:ffff:ffff:ffff:ffff:ffff:ffff:ffff |  | ||||||
|         denied-peer-ip=fc00::-fdff:ffff:ffff:ffff:ffff:ffff:ffff:ffff |  | ||||||
|         denied-peer-ip=fe80::-febf:ffff:ffff:ffff:ffff:ffff:ffff:ffff |  | ||||||
|       ''; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.matrix-synapse = lib.mkIf cfg.matrixIntegration { |  | ||||||
|       settings = with config.services.coturn; { |  | ||||||
|         turn_uris = [ |  | ||||||
|           "turn:${realm}:3478?transport=udp" |  | ||||||
|           "turn:${realm}:3478?transport=tcp" |  | ||||||
|         ]; |  | ||||||
|         turn_user_lifetime = "1h"; |  | ||||||
|       }; |  | ||||||
|       extraConfigFiles = [ |  | ||||||
|         config.age.secrets."passwords/services/coturn/matrix-turn-config.yml".path |  | ||||||
|       ]; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,226 +0,0 @@ | |||||||
| { pkgs, config, lib, inputs, ... }: |  | ||||||
|  |  | ||||||
| # Based on: https://git.clan.lol/clan/clan-infra/src/branch/main/modules/web01/gitea/actions-runner.nix |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.gitea-runner; |  | ||||||
|   hostname = config.networking.hostName; |  | ||||||
|   giteaUrl = "https://git.vimium.com"; |  | ||||||
|  |  | ||||||
|   storeDepsBins = with pkgs; [ |  | ||||||
|     coreutils |  | ||||||
|     findutils |  | ||||||
|     gnugrep |  | ||||||
|     gawk |  | ||||||
|     git |  | ||||||
|     nix |  | ||||||
|     nix-update |  | ||||||
|     bash |  | ||||||
|     jq |  | ||||||
|     nodejs |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   storeDeps = pkgs.runCommand "store-deps" { } '' |  | ||||||
|     mkdir -p $out/bin |  | ||||||
|     for dir in ${toString storeDepsBins}; do |  | ||||||
|       for bin in "$dir"/bin/*; do |  | ||||||
|         ln -s "$bin" "$out/bin/$(basename "$bin")" |  | ||||||
|       done |  | ||||||
|     done |  | ||||||
|  |  | ||||||
|     # Add SSL CA certs |  | ||||||
|     mkdir -p $out/etc/ssl/certs |  | ||||||
|     cp -a "${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt" $out/etc/ssl/certs/ca-bundle.crt |  | ||||||
|   ''; |  | ||||||
| in |  | ||||||
| { |  | ||||||
|   options.modules.services.gitea-runner = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|       description = mdDoc "Enable a runner for Gitea Actions on this host"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = mkIf cfg.enable { |  | ||||||
|     modules.podman.enable = true; |  | ||||||
|  |  | ||||||
|     systemd.services = { |  | ||||||
|       gitea-runner-nix-image = { |  | ||||||
|         wantedBy = [ "multi-user.target" ]; |  | ||||||
|         after = [ "podman.service" ]; |  | ||||||
|         requires = [ "podman.service" ]; |  | ||||||
|         path = [ config.virtualisation.podman.package pkgs.gnutar pkgs.shadow pkgs.getent ]; |  | ||||||
|         script = '' |  | ||||||
|           set -eux -o pipefail |  | ||||||
|           mkdir -p etc/nix |  | ||||||
|  |  | ||||||
|           # Create an unpriveleged user that we can use also without the run-as-user.sh script |  | ||||||
|           touch etc/passwd etc/group |  | ||||||
|           groupid=$(cut -d: -f3 < <(getent group nix-ci-user)) |  | ||||||
|           userid=$(cut -d: -f3 < <(getent passwd nix-ci-user)) |  | ||||||
|           groupadd --prefix $(pwd) --gid "$groupid" nix-ci-user |  | ||||||
|           emptypassword='$6$1ero.LwbisiU.h3D$GGmnmECbPotJoPQ5eoSTD6tTjKnSWZcjHoVTkxFLZP17W9hRi/XkmCiAMOfWruUwy8gMjINrBMNODc7cYEo4K.' |  | ||||||
|           useradd --prefix $(pwd) -p "$emptypassword" -m -d /tmp -u "$userid" -g "$groupid" -G nix-ci-user nix-ci-user |  | ||||||
|  |  | ||||||
|           cat <<NIX_CONFIG > etc/nix/nix.conf |  | ||||||
|           accept-flake-config = true |  | ||||||
|           experimental-features = nix-command flakes |  | ||||||
|           NIX_CONFIG |  | ||||||
|  |  | ||||||
|           cat <<NSSWITCH > etc/nsswitch.conf |  | ||||||
|           passwd:    files mymachines systemd |  | ||||||
|           group:     files mymachines systemd |  | ||||||
|           shadow:    files |  | ||||||
|  |  | ||||||
|           hosts:     files mymachines dns myhostname |  | ||||||
|           networks:  files |  | ||||||
|  |  | ||||||
|           ethers:    files |  | ||||||
|           services:  files |  | ||||||
|           protocols: files |  | ||||||
|           rpc:       files |  | ||||||
|           NSSWITCH |  | ||||||
|  |  | ||||||
|           # list the content as it will be imported into the container |  | ||||||
|           tar -cv . | tar -tvf - |  | ||||||
|           tar -cv . | podman import - gitea-runner-nix |  | ||||||
|         ''; |  | ||||||
|         serviceConfig = { |  | ||||||
|           RuntimeDirectory = "gitea-runner-nix-image"; |  | ||||||
|           WorkingDirectory = "/run/gitea-runner-nix-image"; |  | ||||||
|           Type = "oneshot"; |  | ||||||
|           RemainAfterExit = true; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       gitea-runner-nix = { |  | ||||||
|         after = [ "gitea-runner-nix-image.service" ]; |  | ||||||
|         requires = [ "gitea-runner-nix-image.service" ]; |  | ||||||
|  |  | ||||||
|         serviceConfig = { |  | ||||||
|           # Hardening (may overlap with DynamicUser=) |  | ||||||
|           # The following options are only for optimizing output of systemd-analyze |  | ||||||
|           AmbientCapabilities = ""; |  | ||||||
|           CapabilityBoundingSet = ""; |  | ||||||
|           # ProtectClock= adds DeviceAllow=char-rtc r |  | ||||||
|           DeviceAllow = ""; |  | ||||||
|           NoNewPrivileges = true; |  | ||||||
|           PrivateDevices = true; |  | ||||||
|           PrivateMounts = true; |  | ||||||
|           PrivateTmp = true; |  | ||||||
|           PrivateUsers = true; |  | ||||||
|           ProtectClock = true; |  | ||||||
|           ProtectControlGroups = true; |  | ||||||
|           ProtectHome = true; |  | ||||||
|           ProtectHostname = true; |  | ||||||
|           ProtectKernelLogs = true; |  | ||||||
|           ProtectKernelModules = true; |  | ||||||
|           ProtectKernelTunables = true; |  | ||||||
|           ProtectSystem = "strict"; |  | ||||||
|           RemoveIPC = true; |  | ||||||
|           RestrictNamespaces = true; |  | ||||||
|           RestrictRealtime = true; |  | ||||||
|           RestrictSUIDSGID = true; |  | ||||||
|           UMask = "0066"; |  | ||||||
|           ProtectProc = "invisible"; |  | ||||||
|           SystemCallFilter = [ |  | ||||||
|             "~@clock" |  | ||||||
|             "~@cpu-emulation" |  | ||||||
|             "~@module" |  | ||||||
|             "~@mount" |  | ||||||
|             "~@obsolete" |  | ||||||
|             "~@raw-io" |  | ||||||
|             "~@reboot" |  | ||||||
|             "~@swap" |  | ||||||
|             # needed by go? |  | ||||||
|             #"~@resources" |  | ||||||
|             "~@privileged" |  | ||||||
|             "~capset" |  | ||||||
|             "~setdomainname" |  | ||||||
|             "~sethostname" |  | ||||||
|           ]; |  | ||||||
|           RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" "AF_NETLINK" ]; |  | ||||||
|  |  | ||||||
|           # Needs network access |  | ||||||
|           PrivateNetwork = false; |  | ||||||
|           # Cannot be true due to Node |  | ||||||
|           MemoryDenyWriteExecute = false; |  | ||||||
|  |  | ||||||
|           # The more restrictive "pid" option makes `nix` commands in CI emit |  | ||||||
|           # "GC Warning: Couldn't read /proc/stat" |  | ||||||
|           # You may want to set this to "pid" if not using `nix` commands |  | ||||||
|           ProcSubset = "all"; |  | ||||||
|           # Coverage programs for compiled code such as `cargo-tarpaulin` disable |  | ||||||
|           # ASLR (address space layout randomization) which requires the |  | ||||||
|           # `personality` syscall |  | ||||||
|           # You may want to set this to `true` if not using coverage tooling on |  | ||||||
|           # compiled code |  | ||||||
|           LockPersonality = false; |  | ||||||
|  |  | ||||||
|           # Note that this has some interactions with the User setting; so you may |  | ||||||
|           # want to consult the systemd docs if using both. |  | ||||||
|           DynamicUser = true; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     users.users.nix-ci-user = { |  | ||||||
|       group = "nix-ci-user"; |  | ||||||
|       description = "Used for running nix-based CI jobs"; |  | ||||||
|       home = "/var/empty"; |  | ||||||
|       isSystemUser = true; |  | ||||||
|     }; |  | ||||||
|     users.groups.nix-ci-user = { }; |  | ||||||
|  |  | ||||||
|     age.secrets."files/services/gitea-runner/${hostname}-token" = { |  | ||||||
|       file = "${inputs.secrets}/files/services/gitea-runner/${hostname}-token.age"; |  | ||||||
|       group = "podman"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.gitea-actions-runner.instances = { |  | ||||||
|       act = { |  | ||||||
|         enable = true; |  | ||||||
|         url = giteaUrl; |  | ||||||
|         name = "act-runner-${hostname}"; |  | ||||||
|  |  | ||||||
|         tokenFile = config.age.secrets."files/services/gitea-runner/${hostname}-token".path; |  | ||||||
|         settings = { |  | ||||||
|           cache.enabled = true; |  | ||||||
|           runner.capacity = 4; |  | ||||||
|         }; |  | ||||||
|  |  | ||||||
|         labels = [ |  | ||||||
|           "debian-latest:docker://ghcr.io/catthehacker/ubuntu:act-latest" |  | ||||||
|           "ubuntu-latest:docker://ghcr.io/catthehacker/ubuntu:act-latest" |  | ||||||
|         ]; |  | ||||||
|       }; |  | ||||||
|       nix = { |  | ||||||
|         enable = true; |  | ||||||
|         url = giteaUrl; |  | ||||||
|         name = "nix-runner-${hostname}"; |  | ||||||
|  |  | ||||||
|         tokenFile = config.age.secrets."files/services/gitea-runner/${hostname}-token".path; |  | ||||||
|         settings = { |  | ||||||
|           cache.enabled = true; |  | ||||||
|           container = { |  | ||||||
|             options = "-e NIX_BUILD_SHELL=/bin/bash -e PAGER=cat -e PATH=/bin -e SSL_CERT_FILE=/etc/ssl/certs/ca-bundle.crt --device /dev/kvm -v /nix:/nix -v ${storeDeps}/bin:/bin -v ${storeDeps}/etc/ssl:/etc/ssl --user nix-ci-user"; |  | ||||||
|             network = "host"; |  | ||||||
|             valid_volumes = [ |  | ||||||
|               "/nix" |  | ||||||
|               "${storeDeps}/bin" |  | ||||||
|               "${storeDeps}/etc/ssl" |  | ||||||
|             ]; |  | ||||||
|           }; |  | ||||||
|           runner.capacity = 4; |  | ||||||
|         }; |  | ||||||
|  |  | ||||||
|         labels = [ |  | ||||||
|           "nix:docker://gitea-runner-nix" |  | ||||||
|         ]; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,94 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.gitea; |  | ||||||
| in { |  | ||||||
|   options.modules.services.gitea = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = mkIf cfg.enable { |  | ||||||
|     users = { |  | ||||||
|       users.git = { |  | ||||||
|         isSystemUser = true; |  | ||||||
|         useDefaultShell = true; |  | ||||||
|         group =  "git"; |  | ||||||
|         extraGroups = [ "gitea" ]; |  | ||||||
|         home = config.services.gitea.stateDir; |  | ||||||
|       }; |  | ||||||
|       groups.git = { }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.nginx = { |  | ||||||
|       upstreams.gitea = { |  | ||||||
|         servers = { |  | ||||||
|           "unix:${config.services.gitea.settings.server.HTTP_ADDR}" = { }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|       virtualHosts = { |  | ||||||
|         "git.vimium.com" = { |  | ||||||
|           forceSSL = true; |  | ||||||
|           enableACME = true; |  | ||||||
|           locations."/".proxyPass = "http://gitea"; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     systemd.tmpfiles.rules = [ |  | ||||||
|       "d '${config.services.gitea.customDir}/public/assets/css' 0750 ${config.services.gitea.user} ${config.services.gitea.group} - -" |  | ||||||
|       "L+ '${config.services.gitea.customDir}/public/assets/css/theme-github.css' - - - - ${inputs.gitea-github-theme}/theme-github.css" |  | ||||||
|       "L+ '${config.services.gitea.customDir}/public/assets/css/theme-github-auto.css' - - - - ${inputs.gitea-github-theme}/theme-github-auto.css" |  | ||||||
|       "L+ '${config.services.gitea.customDir}/public/assets/css/theme-github-dark.css' - - - - ${inputs.gitea-github-theme}/theme-github-dark.css" |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     services.gitea = rec { |  | ||||||
|       package = pkgs.unstable.gitea; |  | ||||||
|       enable = true; |  | ||||||
|       user = "git"; |  | ||||||
|       appName = "Vimium Git"; |  | ||||||
|       stateDir = "/var/lib/gitea"; |  | ||||||
|       repositoryRoot = "${stateDir}/repositories"; |  | ||||||
|       database = { |  | ||||||
|         type = "sqlite3"; |  | ||||||
|         inherit user; |  | ||||||
|         path = "${stateDir}/gitea.db"; |  | ||||||
|       }; |  | ||||||
|       lfs = { |  | ||||||
|         enable = true; |  | ||||||
|         contentDir = "${stateDir}/lfs"; |  | ||||||
|       }; |  | ||||||
|       settings = { |  | ||||||
|         server = { |  | ||||||
|           DOMAIN = config.networking.domain; |  | ||||||
|           LANDING_PAGE = "explore"; |  | ||||||
|           OFFLINE_MODE = true; |  | ||||||
|           PROTOCOL = "http+unix"; |  | ||||||
|           SSH_USER = "git"; |  | ||||||
|           SSH_DOMAIN = "git.vimium.com"; |  | ||||||
|           SSH_PORT = lib.head config.services.openssh.ports; |  | ||||||
|           ROOT_URL = "https://git.vimium.com/"; |  | ||||||
|         }; |  | ||||||
|         service.DISABLE_REGISTRATION = true; |  | ||||||
|         session.COOKIE_SECURE = true; |  | ||||||
|         log = { |  | ||||||
|           ROOT_PATH = "${stateDir}/log"; |  | ||||||
|           DISABLE_ROUTER_LOG = true; |  | ||||||
|         }; |  | ||||||
|         ui = { |  | ||||||
|           THEMES = "gitea,arc-green,github,github-auto,github-dark"; |  | ||||||
|           DEFAULT_THEME = "github-dark"; |  | ||||||
|         }; |  | ||||||
|         actions.ENABLED = true; |  | ||||||
|         indexer = { |  | ||||||
|           REPO_INDEXER_ENABLED = true; |  | ||||||
|         }; |  | ||||||
|         packages.CHUNKED_UPLOAD_PATH = lib.mkForce "${stateDir}/data/tmp/package-upload"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,59 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.headscale; |  | ||||||
|   fqdn = "headscale.vimium.net"; |  | ||||||
| in { |  | ||||||
|   options.modules.services.headscale = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = mkIf cfg.enable { |  | ||||||
|     environment.systemPackages = [ pkgs.headscale ]; |  | ||||||
|  |  | ||||||
|     services.headscale = { |  | ||||||
|       enable = true; |  | ||||||
|  |  | ||||||
|       port = 8080; |  | ||||||
|  |  | ||||||
|       settings = { |  | ||||||
|         ip_prefixes = [ |  | ||||||
|           "100.64.0.0/10" |  | ||||||
|         ]; |  | ||||||
|         server_url = "https://${fqdn}"; |  | ||||||
|         dns_config = { |  | ||||||
|           base_domain = "vimium.net"; |  | ||||||
|           extra_records = [ |  | ||||||
|             { |  | ||||||
|               name = "grafana.mesh.vimium.net"; |  | ||||||
|               type = "A"; |  | ||||||
|               value = "100.64.0.6"; |  | ||||||
|             } |  | ||||||
|             { |  | ||||||
|               name = "home.mesh.vimium.net"; |  | ||||||
|               type = "A"; |  | ||||||
|               value = "100.64.0.7"; |  | ||||||
|             } |  | ||||||
|           ]; |  | ||||||
|         }; |  | ||||||
|         logtail.enabled = false; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.nginx.virtualHosts = { |  | ||||||
|       "${fqdn}" = { |  | ||||||
|         forceSSL = true; |  | ||||||
|         enableACME = true; |  | ||||||
|         locations."/" = { |  | ||||||
|           proxyPass = "http://localhost:${toString config.services.headscale.port}"; |  | ||||||
|           proxyWebsockets = true; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,70 +0,0 @@ | |||||||
| { config, lib, pkgs, ... }: |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.mail; |  | ||||||
|   domains = [ |  | ||||||
|     "h0lt.com" |  | ||||||
|     "jdholt.com" |  | ||||||
|     "jordanholt.xyz" |  | ||||||
|     "vimium.co" |  | ||||||
|     "vimium.com" |  | ||||||
|     "vimium.co.uk" |  | ||||||
|     "vimium.info" |  | ||||||
|     "vimium.net" |  | ||||||
|     "vimium.org" |  | ||||||
|     "vimium.xyz" |  | ||||||
|   ]; |  | ||||||
| in { |  | ||||||
|   options.modules.services.mail = { |  | ||||||
|     enable = lib.mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     services.roundcube = { |  | ||||||
|       enable = true; |  | ||||||
|       hostName = config.mailserver.fqdn; |  | ||||||
|       extraConfig = '' |  | ||||||
|         $config['smtp_server'] = "tls://${config.mailserver.fqdn}"; |  | ||||||
|         $config['smtp_user'] = "%u"; |  | ||||||
|         $config['smtp_pass'] = "%p"; |  | ||||||
|       ''; |  | ||||||
|       plugins = [ "contextmenu" ]; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.nginx.enable = true; |  | ||||||
|  |  | ||||||
|     networking.firewall.allowedTCPPorts = [ 80 443 ]; |  | ||||||
|  |  | ||||||
|     mailserver = { |  | ||||||
|       enable = true; |  | ||||||
|       fqdn = "mail.vimium.com"; |  | ||||||
|       domains = domains; |  | ||||||
|       indexDir = "/var/lib/dovecot/indices"; |  | ||||||
|  |  | ||||||
|       certificateDomains = [ |  | ||||||
|         "imap.vimium.com" |  | ||||||
|         "smtp.vimium.com" |  | ||||||
|       ]; |  | ||||||
|       certificateScheme = "acme-nginx"; |  | ||||||
|  |  | ||||||
|       fullTextSearch.enable = true; |  | ||||||
|  |  | ||||||
|       loginAccounts = { |  | ||||||
|         "jordan@vimium.com" = { |  | ||||||
|           hashedPasswordFile = config.users.users.jordan.hashedPasswordFile; |  | ||||||
|           catchAll = domains; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|  |  | ||||||
|       extraVirtualAliases = { |  | ||||||
|         "hostmaster@vimium.com" = "jordan@vimium.com"; |  | ||||||
|         "postmaster@vimium.com" = "jordan@vimium.com"; |  | ||||||
|         "webmaster@vimium.com" = "jordan@vimium.com"; |  | ||||||
|         "abuse@vimium.com" = "jordan@vimium.com"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,254 +0,0 @@ | |||||||
| { |  | ||||||
|   config, |  | ||||||
|   lib, |  | ||||||
|   pkgs, |  | ||||||
|   inputs, |  | ||||||
|   ... |  | ||||||
| }: |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.matrix; |  | ||||||
| in { |  | ||||||
|   options.modules.services.matrix = { |  | ||||||
|     enable = lib.mkEnableOption "matrix"; |  | ||||||
|     element = { |  | ||||||
|       enable = lib.mkOption { |  | ||||||
|         type = lib.types.bool; |  | ||||||
|         default = true; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     bridges = { |  | ||||||
|       signal = lib.mkOption { |  | ||||||
|         type = lib.types.bool; |  | ||||||
|         default = false; |  | ||||||
|         description = "Enable Signal bridge."; |  | ||||||
|       }; |  | ||||||
|       whatsapp = lib.mkOption { |  | ||||||
|         type = lib.types.bool; |  | ||||||
|         default = false; |  | ||||||
|         description = "Enable WhatsApp bridge."; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     serverName = lib.mkOption { |  | ||||||
|       type = lib.types.str; |  | ||||||
|       default = "vimium.com"; |  | ||||||
|       example = "vimium.com"; |  | ||||||
|     }; |  | ||||||
|     slidingSync = { |  | ||||||
|       enable = lib.mkEnableOption "sliding-sync"; |  | ||||||
|     }; |  | ||||||
|     usePostgresql = lib.mkEnableOption "postgresql"; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = let |  | ||||||
|     matrixSubdomain = "matrix.${cfg.serverName}"; |  | ||||||
|     elementSubdomain = "chat.${cfg.serverName}"; |  | ||||||
|     matrixClientConfig = { |  | ||||||
|       "m.homeserver" = { |  | ||||||
|         base_url = "https://${matrixSubdomain}"; |  | ||||||
|         server_name = cfg.serverName; |  | ||||||
|       }; |  | ||||||
|       "m.identity_server" = {}; |  | ||||||
|       "org.matrix.msc3575.proxy" = if cfg.slidingSync.enable then { |  | ||||||
|         "url" = "https://${matrixSubdomain}"; |  | ||||||
|       } else { }; |  | ||||||
|     }; |  | ||||||
|     matrixServerConfig."m.server" = "${matrixSubdomain}:443"; |  | ||||||
|     commonBridgeSettings = bridge: { |  | ||||||
|       appservice = { |  | ||||||
|         database = lib.mkIf cfg.usePostgresql { |  | ||||||
|           type = "postgres"; |  | ||||||
|           uri = "postgresql:///${bridge}?host=/run/postgresql"; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|       bridge = { |  | ||||||
|         encryption = { |  | ||||||
|           allow = true; |  | ||||||
|           default = true; |  | ||||||
|           require = true; |  | ||||||
|         }; |  | ||||||
|         permissions = { |  | ||||||
|           "${cfg.serverName}" = "user"; |  | ||||||
|           "@jordan:${cfg.serverName}" = "admin"; |  | ||||||
|         }; |  | ||||||
|         provisioning = { |  | ||||||
|           shared_secret = "disable"; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|       homeserver = { |  | ||||||
|         address = "https://${matrixSubdomain}"; |  | ||||||
|         domain = cfg.serverName; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   in lib.mkIf cfg.enable { |  | ||||||
|     networking.firewall.allowedTCPPorts = [ |  | ||||||
|       8448 # Matrix federation |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     security.acme.certs = { |  | ||||||
|       "${matrixSubdomain}" = { |  | ||||||
|         reloadServices = [ "matrix-synapse" ]; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.nginx.virtualHosts = { |  | ||||||
|       "${matrixSubdomain}" = { |  | ||||||
|         forceSSL = true; |  | ||||||
|         enableACME = true; |  | ||||||
|         listen = [ |  | ||||||
|           { |  | ||||||
|             addr = "0.0.0.0"; |  | ||||||
|             port = 443; |  | ||||||
|             ssl = true; |  | ||||||
|           } |  | ||||||
|           { |  | ||||||
|             addr = "0.0.0.0"; |  | ||||||
|             port = 80; |  | ||||||
|           } |  | ||||||
|           { |  | ||||||
|             addr = "0.0.0.0"; |  | ||||||
|             port = 8448; |  | ||||||
|             ssl = true; |  | ||||||
|           } |  | ||||||
|           { |  | ||||||
|             addr = "[::1]"; |  | ||||||
|             port = 443; |  | ||||||
|             ssl = true; |  | ||||||
|           } |  | ||||||
|           { |  | ||||||
|             addr = "[::1]"; |  | ||||||
|             port = 80; |  | ||||||
|           } |  | ||||||
|           { |  | ||||||
|             addr = "[::1]"; |  | ||||||
|             port = 8448; |  | ||||||
|             ssl = true; |  | ||||||
|           } |  | ||||||
|         ]; |  | ||||||
|         locations = { |  | ||||||
|           "/" = { |  | ||||||
|             proxyPass = "http://localhost:8008"; |  | ||||||
|             extraConfig = '' |  | ||||||
|               proxy_set_header X-Forwarded-For $remote_addr; |  | ||||||
|             ''; |  | ||||||
|           }; |  | ||||||
|           "/_matrix" = { |  | ||||||
|             proxyPass = "http://localhost:8008"; |  | ||||||
|             extraConfig = '' |  | ||||||
|               proxy_set_header X-Forwarded-For $remote_addr; |  | ||||||
|               client_max_body_size 50M; |  | ||||||
|             ''; |  | ||||||
|           }; |  | ||||||
|           "/_synapse/client".proxyPass = "http://localhost:8008"; |  | ||||||
|           "~ ^/(client/|_matrix/client/unstable/org.matrix.msc3575/sync)" = lib.mkIf cfg.slidingSync.enable { |  | ||||||
|             priority = 100; |  | ||||||
|             proxyPass = "http://localhost:8009"; |  | ||||||
|             extraConfig = '' |  | ||||||
|               proxy_set_header X-Forwarded-For $remote_addr; |  | ||||||
|             ''; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|       "${cfg.serverName}" = let |  | ||||||
|         mkWellKnown = data: '' |  | ||||||
|           more_set_headers 'Content-Type: application/json'; |  | ||||||
|           return 200 '${builtins.toJSON data}'; |  | ||||||
|         ''; |  | ||||||
|       in { |  | ||||||
|         locations."= /.well-known/matrix/server".extraConfig = (mkWellKnown matrixServerConfig); |  | ||||||
|         locations."= /.well-known/matrix/client".extraConfig = (mkWellKnown matrixClientConfig); |  | ||||||
|       }; |  | ||||||
|     } // (if cfg.element.enable then { |  | ||||||
|       "${elementSubdomain}" = { |  | ||||||
|         forceSSL = true; |  | ||||||
|         enableACME = true; |  | ||||||
|         root = pkgs.unstable.element-web.override { |  | ||||||
|           conf = { |  | ||||||
|             default_server_config = matrixClientConfig; |  | ||||||
|             brand = "Vimium Chat"; |  | ||||||
|             branding = { |  | ||||||
|               auth_header_logo_url = "https://vimium.com/images/logo.svg"; |  | ||||||
|               auth_footer_links = [ |  | ||||||
|                 { "text" = "Vimium.com"; "url" = "https://vimium.com"; } |  | ||||||
|               ]; |  | ||||||
|             }; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     } else {}); |  | ||||||
|  |  | ||||||
|     services.matrix-synapse = { |  | ||||||
|       enable = true; |  | ||||||
|       enableRegistrationScript = true; |  | ||||||
|       settings = { |  | ||||||
|         database.name = (if cfg.usePostgresql then "psycopg2" else "sqlite3"); |  | ||||||
|         enable_metrics = false; |  | ||||||
|         enable_registration = false; |  | ||||||
|         max_upload_size = "100M"; |  | ||||||
|         report_stats = false; |  | ||||||
|         server_name = cfg.serverName; |  | ||||||
|         app_service_config_files = (lib.optional cfg.bridges.whatsapp |  | ||||||
|           "/var/lib/mautrix-whatsapp/whatsapp-registration.yaml"); |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|     systemd.services.matrix-synapse.serviceConfig.SupplementaryGroups = |  | ||||||
|       (lib.optional cfg.bridges.whatsapp |  | ||||||
|         config.systemd.services.mautrix-whatsapp.serviceConfig.Group); |  | ||||||
|  |  | ||||||
|     age.secrets = if cfg.slidingSync.enable then { |  | ||||||
|       "files/services/matrix/sliding-sync" = { |  | ||||||
|         file = "${inputs.secrets}/files/services/matrix/sliding-sync.age"; |  | ||||||
|       }; |  | ||||||
|     } else {}; |  | ||||||
|  |  | ||||||
|     services.matrix-sliding-sync = lib.mkIf cfg.slidingSync.enable { |  | ||||||
|       enable = true; |  | ||||||
|       environmentFile = config.age.secrets."files/services/matrix/sliding-sync".path; |  | ||||||
|       settings = { SYNCV3_SERVER = "https://${matrixSubdomain}"; }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.postgresql = lib.mkIf cfg.usePostgresql { |  | ||||||
|       ensureUsers = [ |  | ||||||
|         { |  | ||||||
|           name = "matrix-synapse"; |  | ||||||
|           ensureDBOwnership = true; |  | ||||||
|         } |  | ||||||
|       ] ++ (lib.optional cfg.bridges.signal |  | ||||||
|         { |  | ||||||
|           name = "mautrix-signal"; |  | ||||||
|           ensureDBOwnership = true; |  | ||||||
|         }) |  | ||||||
|         ++ (lib.optional cfg.bridges.whatsapp |  | ||||||
|         { |  | ||||||
|           name = "mautrix-whatsapp"; |  | ||||||
|           ensureDBOwnership = true; |  | ||||||
|         }); |  | ||||||
|       ensureDatabases = [ |  | ||||||
|         "matrix-synapse" |  | ||||||
|       ] ++ (lib.optional cfg.bridges.signal |  | ||||||
|         "mautrix-signal") |  | ||||||
|         ++ (lib.optional cfg.bridges.whatsapp |  | ||||||
|         "mautrix-whatsapp"); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.mautrix-signal = lib.mkIf cfg.bridges.signal { |  | ||||||
|       enable = true; |  | ||||||
|       settings = commonBridgeSettings "mautrix-signal"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.mautrix-whatsapp = lib.mkIf cfg.bridges.whatsapp { |  | ||||||
|       enable = true; |  | ||||||
|       settings = { |  | ||||||
|         bridge = { |  | ||||||
|           history_sync = { |  | ||||||
|             backfill = true; |  | ||||||
|             max_initial_conversations = -1; |  | ||||||
|             message_count = 50; |  | ||||||
|             request_full_sync = true; |  | ||||||
|           }; |  | ||||||
|           mute_bridging = true; |  | ||||||
|         }; |  | ||||||
|       } // commonBridgeSettings "mautrix-whatsapp"; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,157 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let |  | ||||||
|   cfg = config.modules.services.nginx; |  | ||||||
|   nginxErrorPages = '' |  | ||||||
|     location @error_pages { |  | ||||||
|       rewrite ^.*$ /''${status}.html break; |  | ||||||
|  |  | ||||||
|       root "/var/www/html/errors"; |  | ||||||
|     } |  | ||||||
|   ''; |  | ||||||
|   nginxEdgeHeaders = '' |  | ||||||
|     more_set_headers 'Server: Vimium'; |  | ||||||
|     more_set_headers 'Access-Control-Allow-Origin: *'; |  | ||||||
|     add_header Expect-CT max-age=30 always; |  | ||||||
|     add_header Referrer-Policy strict-origin-when-cross-origin always; |  | ||||||
|     add_header Strict-Transport-Security "max-age=63072000; includeSubDomains; preload" always; |  | ||||||
|     add_header Vimium-Responding-Instance $hostname; |  | ||||||
|     add_header X-XSS-Protection "1; mode=block" always; |  | ||||||
|     add_header X-Content-Type-Options nosniff always; |  | ||||||
|   ''; |  | ||||||
|   nginxStrictHeaders = '' |  | ||||||
|     add_header X-Frame-Options SAMEORIGIN always; |  | ||||||
|     add_header Permissions-Policy "fullscreen=(self), sync-xhr=(self)" always; |  | ||||||
|   ''; |  | ||||||
|   mkRedirect = from: to: { |  | ||||||
|     "${from}" = { |  | ||||||
|       forceSSL = true; |  | ||||||
|       enableACME = true; |  | ||||||
|       serverAliases = [ "www.${from}" ]; |  | ||||||
|       locations."/".return = "301 https://${to}$request_uri"; |  | ||||||
|       extraConfig = nginxErrorPages + nginxEdgeHeaders + nginxStrictHeaders; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| in { |  | ||||||
|   options.modules.services.nginx = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = mkIf cfg.enable { |  | ||||||
|     networking.firewall.allowedTCPPorts = [ |  | ||||||
|       80    # HTTP |  | ||||||
|       443   # HTTPS |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|     services.nginx = { |  | ||||||
|       enable = true; |  | ||||||
|       package = pkgs.openresty; |  | ||||||
|       recommendedGzipSettings = true; |  | ||||||
|       recommendedOptimisation = true; |  | ||||||
|       recommendedTlsSettings = true; |  | ||||||
|       clientMaxBodySize = "2G"; |  | ||||||
|       sslProtocols = "TLSv1.2 TLSv1.3"; |  | ||||||
|       sslCiphers = "ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384"; |  | ||||||
|       appendHttpConfig = '' |  | ||||||
|         error_page 400 @error_pages; |  | ||||||
|         error_page 401 @error_pages; |  | ||||||
|         error_page 403 @error_pages; |  | ||||||
|         error_page 404 @error_pages; |  | ||||||
|         error_page 405 @error_pages; |  | ||||||
|         error_page 429 @error_pages; |  | ||||||
|         error_page 500 @error_pages; |  | ||||||
|         error_page 501 @error_pages; |  | ||||||
|         error_page 502 @error_pages; |  | ||||||
|         error_page 503 @error_pages; |  | ||||||
|         error_page 504 @error_pages; |  | ||||||
|  |  | ||||||
|         client_body_buffer_size 16k; |  | ||||||
|         client_header_buffer_size 8k; |  | ||||||
|       ''; |  | ||||||
|       appendConfig = '' |  | ||||||
|         worker_processes auto; |  | ||||||
|         worker_cpu_affinity auto; |  | ||||||
|         worker_rlimit_nofile 50000; |  | ||||||
|       ''; |  | ||||||
|       eventsConfig = '' |  | ||||||
|         worker_connections 20000; |  | ||||||
|         multi_accept off; |  | ||||||
|       ''; |  | ||||||
|       virtualHosts = { |  | ||||||
|         ## Static sites |  | ||||||
|         "jellyfin.vimium.com" = { |  | ||||||
|           forceSSL = true; |  | ||||||
|           enableACME = true; |  | ||||||
|           extraConfig = nginxErrorPages + nginxEdgeHeaders; |  | ||||||
|           locations."/" = { |  | ||||||
|             proxyPass = "http://localhost:8000"; |  | ||||||
|             extraConfig = '' |  | ||||||
|               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; |  | ||||||
|               proxy_set_header X-Forwarded-Proto $scheme; |  | ||||||
|               proxy_set_header X-Real-IP $remote_addr; |  | ||||||
|               proxy_set_header Host $host; |  | ||||||
|  |  | ||||||
|               proxy_set_header Range $http_range; |  | ||||||
|               proxy_set_header If-Range $http_if_range; |  | ||||||
|  |  | ||||||
|               proxy_http_version 1.1; |  | ||||||
|               proxy_set_header Upgrade $http_upgrade; |  | ||||||
|               proxy_set_header Connection "upgrade"; |  | ||||||
|             ''; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|         "pki.vimium.com" = { |  | ||||||
|           addSSL = true; |  | ||||||
|           forceSSL = false; |  | ||||||
|           enableACME = true; |  | ||||||
|           extraConfig = '' |  | ||||||
|             ${nginxErrorPages} |  | ||||||
|             more_set_headers 'Server: Vimium'; |  | ||||||
|           ''; |  | ||||||
|           locations."/" = { |  | ||||||
|             root = "/var/www/pki.vimium.com"; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|         "suhailhussain.com" = { |  | ||||||
|           forceSSL = true; |  | ||||||
|           enableACME = true; |  | ||||||
|           serverAliases = [ "www.suhailhussain.com" ]; |  | ||||||
|           extraConfig = nginxErrorPages + nginxEdgeHeaders + nginxStrictHeaders; |  | ||||||
|           locations."/" = { |  | ||||||
|             root = "/var/www/suhailhussain.com"; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|         "vimium.com" = { |  | ||||||
|           default = true; |  | ||||||
|           forceSSL = true; |  | ||||||
|           enableACME = true; |  | ||||||
|           serverAliases = [ "www.vimium.com" ]; |  | ||||||
|           extraConfig = nginxErrorPages + nginxEdgeHeaders + nginxStrictHeaders + '' |  | ||||||
|             add_header Content-Security-Policy "default-src 'self' https://vimium.com https://www.vimium.com; style-src 'unsafe-inline'; object-src 'none'; upgrade-insecure-requests" always; |  | ||||||
|           ''; |  | ||||||
|           locations."/" = { |  | ||||||
|             root = "/var/www/vimium.com"; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       } |  | ||||||
|       ## Redirects |  | ||||||
|       // (mkRedirect "h0lt.com" "jdholt.com") |  | ||||||
|       // (mkRedirect "jordanholt.xyz" "jdholt.com") |  | ||||||
|       // (mkRedirect "jdholt.com" "vimium.com") |  | ||||||
|       // (mkRedirect "omnimagic.com" "vimium.com") |  | ||||||
|       // (mkRedirect "omnimagic.net" "vimium.com") |  | ||||||
|       // (mkRedirect "thelostlegend.com" "suhailhussain.com") |  | ||||||
|       // (mkRedirect "vimium.co" "vimium.com") |  | ||||||
|       // (mkRedirect "vimium.co.uk" "vimium.com") |  | ||||||
|       // (mkRedirect "vimium.info" "vimium.com") |  | ||||||
|       // (mkRedirect "vimium.net" "vimium.com") |  | ||||||
|       // (mkRedirect "vimium.org" "vimium.com") |  | ||||||
|       // (mkRedirect "vimium.xyz" "vimium.com"); |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -1,57 +0,0 @@ | |||||||
| { config, lib, pkgs, inputs, ... }: |  | ||||||
|  |  | ||||||
| with lib; |  | ||||||
|  |  | ||||||
| let cfg = config.modules.services.photoprism; |  | ||||||
| in { |  | ||||||
|   options.modules.services.photoprism = { |  | ||||||
|     enable = mkOption { |  | ||||||
|       default = false; |  | ||||||
|       example = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = mkIf cfg.enable { |  | ||||||
|     services.nginx = { |  | ||||||
|       virtualHosts = { |  | ||||||
|         "gallery.vimium.com" = { |  | ||||||
|           forceSSL = true; |  | ||||||
|           enableACME = true; |  | ||||||
|           locations."/" = { |  | ||||||
|             proxyPass = "http://localhost:${toString config.services.photoprism.port}"; |  | ||||||
|             extraConfig = '' |  | ||||||
|               proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; |  | ||||||
|               proxy_set_header X-Forwarded-Proto $scheme; |  | ||||||
|               proxy_set_header X-Real-IP $remote_addr; |  | ||||||
|               proxy_set_header Host $host; |  | ||||||
|  |  | ||||||
|               proxy_buffering off; |  | ||||||
|               proxy_http_version 1.1; |  | ||||||
|               proxy_set_header Upgrade $http_upgrade; |  | ||||||
|               proxy_set_header Connection "upgrade"; |  | ||||||
|             ''; |  | ||||||
|           }; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     age.secrets."passwords/services/photoprism/admin" = { |  | ||||||
|       file = "${inputs.secrets}/passwords/services/photoprism/admin.age"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     services.photoprism = { |  | ||||||
|       enable = true; |  | ||||||
|       address = "localhost"; |  | ||||||
|       passwordFile = config.age.secrets."passwords/services/photoprism/admin".path; |  | ||||||
|       originalsPath = "${config.services.photoprism.storagePath}/originals"; |  | ||||||
|       settings = { |  | ||||||
|         PHOTOPRISM_APP_NAME = "Vimium Gallery"; |  | ||||||
|         PHOTOPRISM_SITE_AUTHOR = "Vimium"; |  | ||||||
|         PHOTOPRISM_SITE_TITLE = "Vimium Gallery"; |  | ||||||
|         PHOTOPRISM_SITE_CAPTION = "Vimium Gallery"; |  | ||||||
|         PHOTOPRISM_DISABLE_TLS = "true"; |  | ||||||
|         PHOTOPRISM_SPONSOR = "true"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
| @@ -3,8 +3,8 @@ self: super: | |||||||
|   gnome = super.gnome.overrideScope' (gself: gsuper: { |   gnome = super.gnome.overrideScope' (gself: gsuper: { | ||||||
|     mutter = gsuper.mutter.overrideAttrs (oldAttrs: { |     mutter = gsuper.mutter.overrideAttrs (oldAttrs: { | ||||||
|       src = super.fetchurl { |       src = super.fetchurl { | ||||||
|         url = "https://gitlab.gnome.org/Community/Ubuntu/mutter/-/archive/triple-buffering-v4-46/mutter-triple-buffering-v4-46.tar.gz"; |         url = "https://gitlab.gnome.org/Community/Ubuntu/mutter/-/archive/triple-buffering-v4-45/mutter-triple-buffering-v4-45.tar.gz"; | ||||||
|         sha256 = "mmFABDsRMzYnLO3+Cf3CJ60XyUBl3y9NAUj+vs7nLqE="; |         sha256 = "tN+zQ5brk+hc+louIipqPV/Bqft42ghKOzjZZMj5Q8A="; | ||||||
|       }; |       }; | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								secrets.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								secrets.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | let | ||||||
|  |   jordan = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILVHTjsyMIV4THNw6yz0OxAxGnC+41gX72UrPqTzR+OS"; | ||||||
|  |   users = [ jordan ]; | ||||||
|  |  | ||||||
|  |   odyssey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJre8/cjdoUnbTu0x4ClTITcq4lq+FjpEyJBbLbOlox7"; | ||||||
|  |   systems = [ odyssey ]; | ||||||
|  | in | ||||||
|  | { | ||||||
|  |   "secrets/odyssey_borg_passphrase.age".publicKeys = [ jordan odyssey ]; | ||||||
|  | } | ||||||
							
								
								
									
										
											BIN
										
									
								
								secrets/odyssey_borg_passphrase.age
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								secrets/odyssey_borg_passphrase.age
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
		Reference in New Issue
	
	Block a user