Compare commits
	
		
			1 Commits
		
	
	
		
			b49f9f5c8e
			...
			wireguard
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 84a5ff6fd4 | 
							
								
								
									
										27
									
								
								.gitlab-ci.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								.gitlab-ci.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| stages: | ||||
|   - build | ||||
|   - test | ||||
|  | ||||
| variables: | ||||
|   GIT_SUBMODULE_STRATEGY: recursive | ||||
|  | ||||
| cache: &global_cache | ||||
|   key: | ||||
|     files: | ||||
|       - flake.lock | ||||
|       - flake.nix | ||||
|   paths: | ||||
|     - /nix/store | ||||
|   policy: pull-push | ||||
|  | ||||
| build: | ||||
|   image: nixos/nix | ||||
|   stage: build | ||||
|   timeout: 48h | ||||
|   cache: | ||||
|     <<: *global_cache | ||||
|   script: | ||||
|     - nix --experimental-features 'nix-command flakes' flake check --show-trace | ||||
|  | ||||
| include: | ||||
|   - template: Jobs/Secret-Detection.gitlab-ci.yml | ||||
							
								
								
									
										14
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,8 @@ | ||||
| [submodule "secrets"] | ||||
| 	path = submodules/secrets | ||||
| 	url = git@karaolidis.com:karaolidis/nix-secrets.git | ||||
| [submodule "sas"] | ||||
| 	path = submodules/sas | ||||
| 	url = git@karaolidis.com:karaolidis/nix-sas.git | ||||
| [submodule "submodules/nixpkgs"] | ||||
| 	path = submodules/nixpkgs | ||||
| 	url = git@github.com:karaolidis/nixpkgs.git | ||||
| 	branch = integration | ||||
| [submodule "submodules/home-manager"] | ||||
| 	path = submodules/home-manager | ||||
| 	url = git@github.com:karaolidis/home-manager.git | ||||
| 	branch = integration | ||||
|   | ||||
							
								
								
									
										3
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| { | ||||
|   "sops.defaults.ageKeyFile": "./secrets/personal/key.txt" | ||||
| } | ||||
| @@ -7,6 +7,7 @@ NixOS dotfiles and configuration for various hosts and users. | ||||
| - [`flake.lock`](./flake.lock) and [`flake.nix`](./flake.nix): Core Nix flake files defining the repository's dependencies and entry points. | ||||
|  | ||||
| - [`hosts/`](./hosts): All host-specific configurations. | ||||
|  | ||||
|   - [`common/`](./hosts/common): Shared configuration definitions. | ||||
|     - [`shells/`](./hosts/common/shells): Nix dev shells. | ||||
|     - [`configs/`](./hosts/common/configs): System configurations applicable to all hosts. | ||||
| @@ -18,12 +19,17 @@ NixOS dotfiles and configuration for various hosts and users. | ||||
|  | ||||
| - [`packages/`](./packages/): Custom packages. | ||||
|  | ||||
| - `secrets/<namespace>/`: Global secrets for individual namespaces that apply across all hosts. | ||||
|  | ||||
| - [`lib/`](./lib): Nix library function definitions and utilities. | ||||
|  | ||||
|   - [`scripts/`](./lib/scripts): Utility scripts for managing the repository. | ||||
|     - [`add-host.sh`](./lib/scripts/add-host.sh): Instantiate the keys for a new host configuration. | ||||
|     - [`remove-host.sh`](./lib/scripts/remove-host.sh): Remove references to a host. | ||||
|     - [`update-keys.sh`](./lib/scripts/update-keys.sh): Update the encryption keys in all relevant files using `sops.yaml` configurations. | ||||
|     - [`update.sh`](./lib/scripts/update.sh): Update flake and all packages. | ||||
|     - [`update.sh`](./lib/scripts/update.sh): Update flake and all git submodules. | ||||
|  | ||||
| - [`submodules/`](./submodules): Flake forks used in the repository, such as [`nixpkgs`](https://github.com/NixOS/nixpkgs) and [`home-manager`](https://github.com/nix-community/home-manager). | ||||
|  | ||||
| Any `options.nix` files create custom option definitions when present. | ||||
|  | ||||
|   | ||||
							
								
								
									
										326
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										326
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -10,15 +10,16 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754932414, | ||||
|         "narHash": "sha256-V8c+68Axn5AGDCaG9Zv+EqNU4D6xWPHNXLIapq6AGiM=", | ||||
|         "lastModified": 1744557573, | ||||
|         "narHash": "sha256-XAyj0iDuI51BytJ1PwN53uLpzTDdznPDQFG4RwihlTQ=", | ||||
|         "owner": "aylur", | ||||
|         "repo": "ags", | ||||
|         "rev": "9e6912b51d7bc58f35d10b11be1a126b926b56d3", | ||||
|         "rev": "3ed9737bdbc8fc7a7c7ceef2165c9109f336bff6", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "aylur", | ||||
|         "ref": "main", | ||||
|         "repo": "ags", | ||||
|         "type": "github" | ||||
|       } | ||||
| @@ -30,34 +31,20 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754893912, | ||||
|         "narHash": "sha256-kzU/3A4k+d3PsgMLohzSh4KJybTqvzqibUVqV2yXCGY=", | ||||
|         "lastModified": 1749559749, | ||||
|         "narHash": "sha256-TM95tg1G7S6rVBBoMwurXMz8Il4xlnuZ2TI4h6lfZzg=", | ||||
|         "owner": "aylur", | ||||
|         "repo": "astal", | ||||
|         "rev": "5d4eef66392b0dff99a63a4f39ff886624bd69dd", | ||||
|         "rev": "dd8a4662f2f17fb4326a7bd0fb2d054f5d477ba3", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "aylur", | ||||
|         "ref": "main", | ||||
|         "repo": "astal", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "crane": { | ||||
|       "locked": { | ||||
|         "lastModified": 1754269165, | ||||
|         "narHash": "sha256-0tcS8FHd4QjbCVoxN9jI+PjHgA4vc/IjkUSp+N3zy0U=", | ||||
|         "owner": "ipetkov", | ||||
|         "repo": "crane", | ||||
|         "rev": "444e81206df3f7d92780680e45858e31d2f07a08", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "ipetkov", | ||||
|         "repo": "crane", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "disko": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
| @@ -65,69 +52,33 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1746728054, | ||||
|         "narHash": "sha256-eDoSOhxGEm2PykZFa/x9QG5eTH0MJdiJ9aR00VAofXE=", | ||||
|         "lastModified": 1749436314, | ||||
|         "narHash": "sha256-CqmqU5FRg5AadtIkxwu8ulDSOSoIisUMZRLlcED3Q5w=", | ||||
|         "owner": "nix-community", | ||||
|         "repo": "disko", | ||||
|         "rev": "ff442f5d1425feb86344c028298548024f21256d", | ||||
|         "rev": "dfa4d1b9c39c0342ef133795127a3af14598017a", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-community", | ||||
|         "ref": "latest", | ||||
|         "ref": "master", | ||||
|         "repo": "disko", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "flake-compat": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1747046372, | ||||
|         "narHash": "sha256-CIVLLkVgvHYbgI2UpXvIIBJ12HWgX+fjA8Xf8PUmqCY=", | ||||
|         "owner": "edolstra", | ||||
|         "repo": "flake-compat", | ||||
|         "rev": "9100a0f413b0c601e0533d1d94ffd501ce2e7885", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "edolstra", | ||||
|         "repo": "flake-compat", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "flake-input-patcher": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
|           "nixpkgs" | ||||
|         ], | ||||
|         "systems": [ | ||||
|           "systems" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1751871600, | ||||
|         "narHash": "sha256-I4/2ekJrbRMhOpKfzgnlrN45nQj9YQmZnoSeAaRa1SU=", | ||||
|         "owner": "jfly", | ||||
|         "repo": "flake-input-patcher", | ||||
|         "rev": "4ff068126d49829b106280738944bde91951d59d", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "jfly", | ||||
|         "repo": "flake-input-patcher", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "flake-parts": { | ||||
|       "inputs": { | ||||
|         "nixpkgs-lib": "nixpkgs-lib" | ||||
|         "nixpkgs-lib": [ | ||||
|           "nur", | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754487366, | ||||
|         "narHash": "sha256-pHYj8gUBapuUzKV/kN/tR3Zvqc7o6gdFB9XKXIp1SQ8=", | ||||
|         "lastModified": 1733312601, | ||||
|         "narHash": "sha256-4pDvzqnegAfRkPwO3wmwBhVi/Sye1mzps0zHWYnP88c=", | ||||
|         "owner": "hercules-ci", | ||||
|         "repo": "flake-parts", | ||||
|         "rev": "af66ad14b28a127c5c0f3bbb298218fc63528a18", | ||||
|         "rev": "205b12d8b7cd4802fbcb8e8ef6a0f1408781a4f9", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @@ -152,32 +103,11 @@ | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "numtide", | ||||
|         "ref": "main", | ||||
|         "repo": "flake-utils", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "gitignore": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
|           "lanzaboote", | ||||
|           "pre-commit-hooks-nix", | ||||
|           "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": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
| @@ -185,160 +115,73 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754974548, | ||||
|         "narHash": "sha256-XMjUjKD/QRPcqUnmSDczSYdw46SilnG0+wkho654DFM=", | ||||
|         "owner": "nix-community", | ||||
|         "lastModified": 1749678254, | ||||
|         "narHash": "sha256-6I+qez0MnHu9M2spLj3LsGA/cUGgfx17/hMPvmrUMoU=", | ||||
|         "owner": "karaolidis", | ||||
|         "repo": "home-manager", | ||||
|         "rev": "27a26be51ff0162a8f67660239f9407dba68d7c5", | ||||
|         "rev": "e248f54290b483a47c7550f69faecb8ed97e4831", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-community", | ||||
|         "owner": "karaolidis", | ||||
|         "ref": "integration", | ||||
|         "repo": "home-manager", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "lanzaboote": { | ||||
|       "inputs": { | ||||
|         "crane": "crane", | ||||
|         "flake-compat": "flake-compat", | ||||
|         "flake-parts": [ | ||||
|           "flake-parts" | ||||
|         ], | ||||
|         "nixpkgs": [ | ||||
|           "nixpkgs" | ||||
|         ], | ||||
|         "pre-commit-hooks-nix": "pre-commit-hooks-nix", | ||||
|         "rust-overlay": "rust-overlay" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754297745, | ||||
|         "narHash": "sha256-aD6/scLN3L4ZszmNbhhd3JQ9Pzv1ScYFphz14wHinfs=", | ||||
|         "owner": "nix-community", | ||||
|         "repo": "lanzaboote", | ||||
|         "rev": "892cbdca865d6b42f9c0d222fe309f7720259855", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-community", | ||||
|         "repo": "lanzaboote", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 1754725699, | ||||
|         "narHash": "sha256-iAcj9T/Y+3DBy2J0N+yF9XQQQ8IEb5swLFzs23CdP88=", | ||||
|         "owner": "NixOS", | ||||
|         "lastModified": 1749678247, | ||||
|         "narHash": "sha256-K83Q3c/o5CdMB3Npk3P1kCIz6FcUuJV8E4k6z1YN8AQ=", | ||||
|         "owner": "karaolidis", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "85dbfc7aaf52ecb755f87e577ddbe6dbbdbc1054", | ||||
|         "rev": "4d408c92fe165ab68f012a3fa36d4c58d84e83bd", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "nixos-unstable", | ||||
|         "owner": "karaolidis", | ||||
|         "ref": "integration", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs-lib": { | ||||
|       "locked": { | ||||
|         "lastModified": 1753579242, | ||||
|         "narHash": "sha256-zvaMGVn14/Zz8hnp4VWT9xVnhc8vuL3TStRqwk22biA=", | ||||
|         "owner": "nix-community", | ||||
|         "repo": "nixpkgs.lib", | ||||
|         "rev": "0f36c44e01a6129be94e3ade315a5883f0228a6e", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-community", | ||||
|         "repo": "nixpkgs.lib", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nur": { | ||||
|       "inputs": { | ||||
|         "flake-parts": [ | ||||
|           "flake-parts" | ||||
|         ], | ||||
|         "flake-parts": "flake-parts", | ||||
|         "nixpkgs": [ | ||||
|           "nixpkgs" | ||||
|         ], | ||||
|         "treefmt-nix": [ | ||||
|           "treefmt-nix" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1755067854, | ||||
|         "narHash": "sha256-VP+2GVREkB7tg8vGBJ2yOlfwng+TEv45vZGvb4eV17E=", | ||||
|         "lastModified": 1749675110, | ||||
|         "narHash": "sha256-NkDE/JyeQJmLtpXjyFZK2wKs5K7isap7MBIzoYMC9nk=", | ||||
|         "owner": "nix-community", | ||||
|         "repo": "NUR", | ||||
|         "rev": "3352304d8f256bb67b5f9662b3493b069b3cac25", | ||||
|         "rev": "0e8328c18d801a253ed5dfd17bd78254d9669d06", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-community", | ||||
|         "ref": "main", | ||||
|         "repo": "NUR", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nvidia-patch": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
|           "nixpkgs" | ||||
|         ], | ||||
|         "utils": [ | ||||
|           "flake-utils" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1755069017, | ||||
|         "narHash": "sha256-cTD5WfZRK2mwrSktlYcrk6DOEEkQbE1z78O16TF293c=", | ||||
|         "owner": "icewind1991", | ||||
|         "repo": "nvidia-patch-nixos", | ||||
|         "rev": "d187885c14bdd8520d40f527134d536168f8d92b", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "icewind1991", | ||||
|         "repo": "nvidia-patch-nixos", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "pre-commit-hooks-nix": { | ||||
|       "inputs": { | ||||
|         "flake-compat": [ | ||||
|           "lanzaboote", | ||||
|           "flake-compat" | ||||
|         ], | ||||
|         "gitignore": "gitignore", | ||||
|         "nixpkgs": [ | ||||
|           "lanzaboote", | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1750779888, | ||||
|         "narHash": "sha256-wibppH3g/E2lxU43ZQHC5yA/7kIKLGxVEnsnVK1BtRg=", | ||||
|         "owner": "cachix", | ||||
|         "repo": "pre-commit-hooks.nix", | ||||
|         "rev": "16ec914f6fb6f599ce988427d9d94efddf25fe6d", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "cachix", | ||||
|         "repo": "pre-commit-hooks.nix", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "quadlet-nix": { | ||||
|       "locked": { | ||||
|         "lastModified": 1754008153, | ||||
|         "narHash": "sha256-MYT1mDtSkiVg343agxgBFsnuNU3xS8vRy399JXX1Vw0=", | ||||
|         "lastModified": 1749099346, | ||||
|         "narHash": "sha256-5gi/YaLVsFztGvVH45eB6jsBmZf+HnvDeSA9RXUqbcY=", | ||||
|         "owner": "SEIAROTg", | ||||
|         "repo": "quadlet-nix", | ||||
|         "rev": "1b2d27d460d8c7e4da5ba44ede463b427160b5c4", | ||||
|         "rev": "d4119a3423f938427252ba8bbdbe8ce040751864", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "SEIAROTg", | ||||
|         "ref": "main", | ||||
|         "repo": "quadlet-nix", | ||||
|         "type": "github" | ||||
|       } | ||||
| @@ -348,76 +191,17 @@ | ||||
|         "ags": "ags", | ||||
|         "astal": "astal", | ||||
|         "disko": "disko", | ||||
|         "flake-input-patcher": "flake-input-patcher", | ||||
|         "flake-parts": "flake-parts", | ||||
|         "flake-utils": "flake-utils", | ||||
|         "home-manager": "home-manager", | ||||
|         "lanzaboote": "lanzaboote", | ||||
|         "nixpkgs": "nixpkgs", | ||||
|         "nur": "nur", | ||||
|         "nvidia-patch": "nvidia-patch", | ||||
|         "quadlet-nix": "quadlet-nix", | ||||
|         "sas": "sas", | ||||
|         "secrets": "secrets", | ||||
|         "sops-nix": "sops-nix", | ||||
|         "spicetify-nix": "spicetify-nix", | ||||
|         "systems": "systems", | ||||
|         "treefmt-nix": "treefmt-nix" | ||||
|       } | ||||
|     }, | ||||
|     "rust-overlay": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
|           "lanzaboote", | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754189623, | ||||
|         "narHash": "sha256-fstu5eb30UYwsxow0aQqkzxNxGn80UZjyehQVNVHuBk=", | ||||
|         "owner": "oxalica", | ||||
|         "repo": "rust-overlay", | ||||
|         "rev": "c582ff7f0d8a7ea689ae836dfb1773f1814f472a", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "oxalica", | ||||
|         "repo": "rust-overlay", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "sas": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1755243359, | ||||
|         "narHash": "sha256-R8Tt700YWn/AEIfqG3n4mklFqmtYGsqKnj+kV+Sq6u8=", | ||||
|         "ref": "refs/heads/main", | ||||
|         "rev": "7bf093db0a30e4b0d8867c1b21e461f0bf08d866", | ||||
|         "revCount": 4, | ||||
|         "type": "git", | ||||
|         "url": "ssh://git@karaolidis.com/karaolidis/nix-sas.git" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "git", | ||||
|         "url": "ssh://git@karaolidis.com/karaolidis/nix-sas.git" | ||||
|       } | ||||
|     }, | ||||
|     "secrets": { | ||||
|       "flake": false, | ||||
|       "locked": { | ||||
|         "lastModified": 1755243351, | ||||
|         "narHash": "sha256-Oa7ASrkHUcNHMf/rXnVokLytKEqiM4X2C7R8gBSy/AM=", | ||||
|         "ref": "refs/heads/main", | ||||
|         "rev": "13b3145cbabcf1d042abdab931cec9042bccc771", | ||||
|         "revCount": 32, | ||||
|         "type": "git", | ||||
|         "url": "ssh://git@karaolidis.com/karaolidis/nix-secrets.git" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "git", | ||||
|         "url": "ssh://git@karaolidis.com/karaolidis/nix-secrets.git" | ||||
|       } | ||||
|     }, | ||||
|     "sops-nix": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
| @@ -425,15 +209,16 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754988908, | ||||
|         "narHash": "sha256-t+voe2961vCgrzPFtZxha0/kmFSHFobzF00sT8p9h0U=", | ||||
|         "lastModified": 1749592509, | ||||
|         "narHash": "sha256-VunQzfZFA+Y6x3wYi2UE4DEQ8qKoAZZCnZPUlSoqC+A=", | ||||
|         "owner": "Mic92", | ||||
|         "repo": "sops-nix", | ||||
|         "rev": "3223c7a92724b5d804e9988c6b447a0d09017d48", | ||||
|         "rev": "50754dfaa0e24e313c626900d44ef431f3210138", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "Mic92", | ||||
|         "ref": "master", | ||||
|         "repo": "sops-nix", | ||||
|         "type": "github" | ||||
|       } | ||||
| @@ -448,15 +233,16 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754801101, | ||||
|         "narHash": "sha256-oxWjZ/SfhCvHFNePZcUu+LcE5j4xxuIt/yaoaSvMZk0=", | ||||
|         "lastModified": 1749357231, | ||||
|         "narHash": "sha256-AbrPgGFVYR45TlYLHYTppayG0xzOG9XXhi+1j3Klbw8=", | ||||
|         "owner": "Gerg-L", | ||||
|         "repo": "spicetify-nix", | ||||
|         "rev": "fcbfc21572518c68317df992929b28df9a1d8468", | ||||
|         "rev": "03783416f7416715c52166d4e8ba0492a7149397", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "Gerg-L", | ||||
|         "ref": "master", | ||||
|         "repo": "spicetify-nix", | ||||
|         "type": "github" | ||||
|       } | ||||
| @@ -472,6 +258,7 @@ | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-systems", | ||||
|         "ref": "main", | ||||
|         "repo": "default", | ||||
|         "type": "github" | ||||
|       } | ||||
| @@ -483,15 +270,16 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1754847726, | ||||
|         "narHash": "sha256-2vX8QjO5lRsDbNYvN9hVHXLU6oMl+V/PsmIiJREG4rE=", | ||||
|         "lastModified": 1749194973, | ||||
|         "narHash": "sha256-eEy8cuS0mZ2j/r/FE0/LYBSBcIs/MKOIVakwHVuqTfk=", | ||||
|         "owner": "numtide", | ||||
|         "repo": "treefmt-nix", | ||||
|         "rev": "7d81f6fb2e19bf84f1c65135d1060d829fae2408", | ||||
|         "rev": "a05be418a1af1198ca0f63facb13c985db4cb3c5", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "numtide", | ||||
|         "ref": "main", | ||||
|         "repo": "treefmt-nix", | ||||
|         "type": "github" | ||||
|       } | ||||
|   | ||||
							
								
								
									
										204
									
								
								flake.nix
									
									
									
									
									
								
							
							
						
						
									
										204
									
								
								flake.nix
									
									
									
									
									
								
							| @@ -1,78 +1,113 @@ | ||||
| { | ||||
|   inputs = { | ||||
|     nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; | ||||
|     nixpkgs = { | ||||
|       # --- Official | ||||
|       # type = "github"; | ||||
|       # owner = "NixOS"; | ||||
|       # repo = "nixpkgs"; | ||||
|       # ref = "master"; | ||||
|       # --- Fork | ||||
|       type = "github"; | ||||
|       owner = "karaolidis"; | ||||
|       repo = "nixpkgs"; | ||||
|       ref = "integration"; | ||||
|       # --- Local | ||||
|       # url = "git+file:./submodules/nixpkgs"; | ||||
|     }; | ||||
|  | ||||
|     home-manager = { | ||||
|       url = "github:nix-community/home-manager"; | ||||
|       # --- Official | ||||
|       # type = "github"; | ||||
|       # owner = "nix-community" | ||||
|       # repo = "home-manager"; | ||||
|       # --- Fork | ||||
|       type = "github"; | ||||
|       owner = "karaolidis"; | ||||
|       repo = "home-manager"; | ||||
|       ref = "integration"; | ||||
|       # --- Local | ||||
|       # url = "git+file:./submodules/home-manager"; | ||||
|  | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|  | ||||
|     disko = { | ||||
|       url = "github:nix-community/disko/latest"; | ||||
|       type = "github"; | ||||
|       owner = "nix-community"; | ||||
|       repo = "disko"; | ||||
|       ref = "master"; | ||||
|  | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|  | ||||
|     sops-nix = { | ||||
|       url = "github:Mic92/sops-nix"; | ||||
|       type = "github"; | ||||
|       owner = "Mic92"; | ||||
|       repo = "sops-nix"; | ||||
|       ref = "master"; | ||||
|  | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|  | ||||
|     lanzaboote = { | ||||
|       url = "github:nix-community/lanzaboote"; | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         flake-parts.follows = "flake-parts"; | ||||
|       }; | ||||
|     }; | ||||
|  | ||||
|     secrets = { | ||||
|       url = "git+ssh://git@karaolidis.com/karaolidis/nix-secrets.git"; | ||||
|       flake = false; | ||||
|     }; | ||||
|  | ||||
|     sas = { | ||||
|       url = "git+ssh://git@karaolidis.com/karaolidis/nix-sas.git"; | ||||
|       flake = false; | ||||
|     systems = { | ||||
|       type = "github"; | ||||
|       owner = "nix-systems"; | ||||
|       repo = "default"; | ||||
|       ref = "main"; | ||||
|     }; | ||||
|  | ||||
|     nur = { | ||||
|       url = "github:nix-community/NUR"; | ||||
|       type = "github"; | ||||
|       owner = "nix-community"; | ||||
|       repo = "NUR"; | ||||
|       ref = "main"; | ||||
|  | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         flake-parts.follows = "flake-parts"; | ||||
|         treefmt-nix.follows = "treefmt-nix"; | ||||
|       }; | ||||
|     }; | ||||
|  | ||||
|     flake-utils = { | ||||
|       type = "github"; | ||||
|       owner = "numtide"; | ||||
|       repo = "flake-utils"; | ||||
|       ref = "main"; | ||||
|  | ||||
|       inputs.systems.follows = "systems"; | ||||
|     }; | ||||
|  | ||||
|     treefmt-nix = { | ||||
|       url = "github:numtide/treefmt-nix"; | ||||
|       type = "github"; | ||||
|       owner = "numtide"; | ||||
|       repo = "treefmt-nix"; | ||||
|       ref = "main"; | ||||
|  | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|  | ||||
|     flake-input-patcher = { | ||||
|       url = "github:jfly/flake-input-patcher"; | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         systems.follows = "systems"; | ||||
|       }; | ||||
|     }; | ||||
|  | ||||
|     quadlet-nix.url = "github:SEIAROTg/quadlet-nix"; | ||||
|  | ||||
|     nvidia-patch = { | ||||
|       url = "github:icewind1991/nvidia-patch-nixos"; | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         utils.follows = "flake-utils"; | ||||
|       }; | ||||
|     quadlet-nix = { | ||||
|       type = "github"; | ||||
|       owner = "SEIAROTg"; | ||||
|       repo = "quadlet-nix"; | ||||
|       ref = "main"; | ||||
|     }; | ||||
|  | ||||
|     astal = { | ||||
|       url = "github:aylur/astal"; | ||||
|       type = "github"; | ||||
|       owner = "aylur"; | ||||
|       repo = "astal"; | ||||
|       ref = "main"; | ||||
|  | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|  | ||||
|     ags = { | ||||
|       url = "github:aylur/ags"; | ||||
|       type = "github"; | ||||
|       owner = "aylur"; | ||||
|       repo = "ags"; | ||||
|       ref = "main"; | ||||
|  | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         astal.follows = "astal"; | ||||
| @@ -80,46 +115,57 @@ | ||||
|     }; | ||||
|  | ||||
|     spicetify-nix = { | ||||
|       url = "github:Gerg-L/spicetify-nix"; | ||||
|       type = "github"; | ||||
|       owner = "Gerg-L"; | ||||
|       repo = "spicetify-nix"; | ||||
|       ref = "master"; | ||||
|  | ||||
|       inputs = { | ||||
|         nixpkgs.follows = "nixpkgs"; | ||||
|         systems.follows = "systems"; | ||||
|       }; | ||||
|     }; | ||||
|  | ||||
|     systems.url = "github:nix-systems/default"; | ||||
|  | ||||
|     flake-parts.url = "github:hercules-ci/flake-parts"; | ||||
|  | ||||
|     flake-utils = { | ||||
|       url = "github:numtide/flake-utils"; | ||||
|       inputs.systems.follows = "systems"; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   outputs = | ||||
|     inputs: | ||||
|     let | ||||
|       mkInputs = | ||||
|         system: | ||||
|         let | ||||
|           patcher = inputs.flake-input-patcher.lib.${system}; | ||||
|         in | ||||
|         patcher.patch inputs (import ./patches.nix { inherit patcher; }); | ||||
|  | ||||
|       mkNixosConfiguration = | ||||
|         inputs: system: modules: | ||||
|         inputs.nixpkgs.lib.nixosSystem { | ||||
|           inherit system modules; | ||||
|     { self, nixpkgs, ... }@inputs: | ||||
|     { | ||||
|       nixosConfigurations = { | ||||
|         installer = nixpkgs.lib.nixosSystem rec { | ||||
|           system = "x86_64-linux"; | ||||
|           modules = [ ./hosts/installer ]; | ||||
|           specialArgs = { inherit inputs system; }; | ||||
|         }; | ||||
|     in | ||||
|     ( | ||||
|       let | ||||
|         system = "x86_64-linux"; | ||||
|         inputs = mkInputs system; | ||||
|  | ||||
|         pkgs = import inputs.nixpkgs { | ||||
|         himalia = nixpkgs.lib.nixosSystem rec { | ||||
|           system = "x86_64-linux"; | ||||
|           modules = [ ./hosts/himalia ]; | ||||
|           specialArgs = { inherit inputs system; }; | ||||
|         }; | ||||
|  | ||||
|         elara = nixpkgs.lib.nixosSystem rec { | ||||
|           system = "x86_64-linux"; | ||||
|           modules = [ ./hosts/elara ]; | ||||
|           specialArgs = { inherit inputs system; }; | ||||
|         }; | ||||
|  | ||||
|         jupiter = nixpkgs.lib.nixosSystem rec { | ||||
|           system = "x86_64-linux"; | ||||
|           modules = [ ./hosts/jupiter ]; | ||||
|           specialArgs = { inherit inputs system; }; | ||||
|         }; | ||||
|  | ||||
|         jupiter-vps = nixpkgs.lib.nixosSystem rec { | ||||
|           system = "x86_64-linux"; | ||||
|           modules = [ ./hosts/jupiter-vps ]; | ||||
|           specialArgs = { inherit inputs system; }; | ||||
|         }; | ||||
|       }; | ||||
|     } | ||||
|     // inputs.flake-utils.lib.eachSystem [ "x86_64-linux" ] ( | ||||
|       system: | ||||
|       let | ||||
|         pkgs = import nixpkgs { | ||||
|           inherit system; | ||||
|           config.allowUnfree = true; | ||||
|         }; | ||||
| @@ -127,20 +173,12 @@ | ||||
|         treefmt = inputs.treefmt-nix.lib.evalModule pkgs ./treefmt.nix; | ||||
|       in | ||||
|       { | ||||
|         nixosConfigurations = { | ||||
|           installer = mkNixosConfiguration inputs system [ ./hosts/installer ]; | ||||
|           himalia = mkNixosConfiguration inputs system [ ./hosts/himalia ]; | ||||
|           elara = mkNixosConfiguration inputs system [ ./hosts/elara ]; | ||||
|           jupiter = mkNixosConfiguration inputs system [ ./hosts/jupiter ]; | ||||
|           jupiter-vps = mkNixosConfiguration inputs system [ ./hosts/jupiter-vps ]; | ||||
|         }; | ||||
|         devShells = import ./hosts/common/shells { inherit pkgs; }; | ||||
|         lib = import ./lib { inherit pkgs; }; | ||||
|         packages = import ./packages { inherit pkgs inputs system; }; | ||||
|  | ||||
|         devShells.${system} = import ./hosts/common/shells { inherit pkgs; }; | ||||
|         lib.${system} = import ./lib { inherit pkgs; }; | ||||
|         packages.${system} = import ./packages { inherit pkgs inputs system; }; | ||||
|  | ||||
|         formatter.${system} = treefmt.config.build.wrapper; | ||||
|         checks.formatting.${system} = treefmt.config.build.check inputs.self; | ||||
|         formatter = treefmt.config.build.wrapper; | ||||
|         checks.formatting = treefmt.config.build.check self; | ||||
|       } | ||||
|     ); | ||||
| } | ||||
|   | ||||
| @@ -233,11 +233,11 @@ in | ||||
|           unitConfig.ConditionPathExists = [ (lib.strings.escape [ " " ] c.source) ]; | ||||
|           what = c.source; | ||||
|           where = c.target; | ||||
|           options = lib.strings.concatStringsSep "," [ | ||||
|           options = lib.strings.concatStringsSep "," ([ | ||||
|             "bind" | ||||
|             "X-fstrim.notrim" | ||||
|             "x-gvfs-hide" | ||||
|           ]; | ||||
|           ]); | ||||
|         }) all; | ||||
|  | ||||
|         services = builtins.listToAttrs ( | ||||
|   | ||||
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   inputs, | ||||
|   lib, | ||||
|   pkgs, | ||||
|   ... | ||||
| }: | ||||
| { | ||||
|   imports = [ inputs.lanzaboote.nixosModules.lanzaboote ]; | ||||
|  | ||||
|   environment = { | ||||
|     persistence."/persist/state"."/var/lib/sbctl" = { }; | ||||
|  | ||||
|     systemPackages = with pkgs; [ sbctl ]; | ||||
|   }; | ||||
|  | ||||
|   boot.loader.systemd-boot.enable = lib.mkForce false; | ||||
|  | ||||
|   boot.lanzaboote = { | ||||
|     enable = true; | ||||
|     pkiBundle = "/var/lib/sbctl"; | ||||
|   }; | ||||
| } | ||||
| @@ -4,7 +4,6 @@ _nix-install_completion() { | ||||
|     '-m[Mode: 'install' or 'repair']:mode:(install repair)' | ||||
|     '-h[Host to configure]:host:($(_list_hosts))' | ||||
|     '-k[Key file to copy to user config]:key:($(_list_keys))' | ||||
|     '-s[Enroll secure boot keys on current device]' | ||||
|     '-c[Copy configuration to target]' | ||||
|     '-r[Reboot after completion]' | ||||
|   ) | ||||
|   | ||||
| @@ -1,14 +1,13 @@ | ||||
| # shellcheck shell=bash | ||||
|  | ||||
| usage() { | ||||
|   echo "Usage: $0 flake -m install|repair -h host [-k key] [-p password_file] [-s] [-c] [-r]" | ||||
|   echo "Usage: $0 flake -m install|repair -h host [-k key] [-p password_file] [-c] [-r]" | ||||
|   echo | ||||
|   echo "Options:" | ||||
|   echo "  flake               Directory containing the flake.nix file." | ||||
|   echo "  -m mode             Mode: 'install' or 'repair'." | ||||
|   echo "  -h host             Host to configure." | ||||
|   echo "  -k key              Key file to copy to user config." | ||||
|   echo "  -s                  Enroll secure boot keys on current device." | ||||
|   echo "  -c                  Copy configuration to target." | ||||
|   echo "  -r                  Reboot after completion." | ||||
|   exit 1 | ||||
| @@ -36,7 +35,7 @@ check_flake() { | ||||
| } | ||||
|  | ||||
| check_host() { | ||||
|   if ! nix flake show --allow-import-from-derivation --quiet --json "$flake" 2>/dev/null | jq -e ".nixosConfigurations[\"$host\"]" &>/dev/null; then | ||||
|   if ! nix flake show --quiet --json "$flake" 2>/dev/null | jq -e ".nixosConfigurations[\"$host\"]" &>/dev/null; then | ||||
|     echo "Host '$host' not found in flake." | ||||
|     exit 1 | ||||
|   fi | ||||
| @@ -52,8 +51,7 @@ check_key() { | ||||
| set_password_file() { | ||||
|   SOPS_AGE_KEY_FILE="$flake/secrets/$key/key.txt" | ||||
|   export SOPS_AGE_KEY_FILE | ||||
|   install -m 600 /dev/null /tmp/keyfile | ||||
|   sops --decrypt --extract "['luks']" "$flake/secrets/hosts/$host/secrets.yaml" > /tmp/keyfile | ||||
|   sops --decrypt --extract "['luks']" "$flake/hosts/$host/secrets/secrets.yaml" > /tmp/keyfile | ||||
|   unset SOPS_AGE_KEY_FILE | ||||
| } | ||||
|  | ||||
| @@ -64,9 +62,9 @@ prepare_disk() { | ||||
|   disko -m "$disko_mode" --yes-wipe-all-disks --root-mountpoint "$root" "$flake/hosts/$host/format.nix" | ||||
| } | ||||
|  | ||||
| copy_sops_keys() { | ||||
| copy_keys() { | ||||
|   mkdir -p "$root/persist/state/etc/ssh" | ||||
|   cp -f "$flake/secrets/hosts/$host/ssh_host_ed25519_key" "$root/persist/state/etc/ssh/ssh_host_ed25519_key" | ||||
|   cp -f "$flake/hosts/$host/secrets/ssh_host_ed25519_key" "$root/persist/state/etc/ssh/ssh_host_ed25519_key" | ||||
|  | ||||
|   for path in "$flake/hosts/$host/users"/*; do | ||||
|     if [[ -z "$key" ]]; then | ||||
| @@ -89,46 +87,26 @@ copy_sops_keys() { | ||||
|   done | ||||
| } | ||||
|  | ||||
| copy_secure_boot_keys() { | ||||
|   mkdir -p "$root/persist/state/var/lib/sbctl/keys"/{db,KEK,PK} | ||||
|  | ||||
|   SOPS_AGE_KEY_FILE="$flake/secrets/$key/key.txt" | ||||
|   export SOPS_AGE_KEY_FILE | ||||
|  | ||||
|   sops --decrypt --extract "['guid']" "$flake/secrets/domains/lanzaboote/secrets.yaml" > "$root/persist/state/var/lib/sbctl/GUID" | ||||
|   sops --decrypt --extract "['keys']['kek']['key']" "$flake/secrets/domains/lanzaboote/secrets.yaml" > "$root/persist/state/var/lib/sbctl/keys/KEK/KEK.key" | ||||
|   sops --decrypt --extract "['keys']['kek']['pem']" "$flake/secrets/domains/lanzaboote/secrets.yaml" > "$root/persist/state/var/lib/sbctl/keys/KEK/KEK.pem" | ||||
|   sops --decrypt --extract "['keys']['pk']['key']" "$flake/secrets/domains/lanzaboote/secrets.yaml" > "$root/persist/state/var/lib/sbctl/keys/PK/PK.key" | ||||
|   sops --decrypt --extract "['keys']['pk']['pem']" "$flake/secrets/domains/lanzaboote/secrets.yaml" > "$root/persist/state/var/lib/sbctl/keys/PK/PK.pem" | ||||
|   sops --decrypt --extract "['keys']['db']['key']" "$flake/secrets/domains/lanzaboote/secrets.yaml" > "$root/persist/state/var/lib/sbctl/keys/db/db.key" | ||||
|   sops --decrypt --extract "['keys']['db']['pem']" "$flake/secrets/domains/lanzaboote/secrets.yaml" > "$root/persist/state/var/lib/sbctl/keys/db/db.pem" | ||||
|  | ||||
|   chmod 400 "$root/persist/state/var/lib/sbctl/keys"/*/* | ||||
|  | ||||
|   unset SOPS_AGE_KEY_FILE | ||||
|  | ||||
|   mkdir -p "$root/var/lib/sbctl" | ||||
|   mount --bind -o X-fstrim.notrim,x-gvfs-hide "$root/persist/state/var/lib/sbctl" "$root/var/lib/sbctl" | ||||
| } | ||||
|  | ||||
| install_nixos() { | ||||
| install() { | ||||
|   nixos-install --root "$root" --flake "$flake#$host" --no-root-passwd | ||||
| } | ||||
|  | ||||
| enroll_secure_boot() { | ||||
|   sbctl enroll-keys --microsoft | ||||
| } | ||||
|  | ||||
| copy_config() { | ||||
|   echo "Copying configuration..." | ||||
|   mkdir -p "$root/persist/user/etc" | ||||
|   mkdir -p "$root/persist/user/etc/nixos" | ||||
|   rm -rf "$root/persist/user/etc/nixos" | ||||
|   cp -r "$flake" "$root/persist/user/etc/nixos" | ||||
| } | ||||
|  | ||||
| finish() { | ||||
|   echo "Rebooting system..." | ||||
|   trap - EXIT | ||||
|   cleanup | ||||
|   reboot | ||||
| } | ||||
|  | ||||
| cleanup() { | ||||
|   rm -f /tmp/keyfile | ||||
|   if [[ -d "$root" ]]; then umount "$root/var/lib/sbctl"; fi | ||||
|   if [[ -n "$host" ]]; then disko -m "unmount" "$flake/hosts/$host/format.nix"; fi | ||||
|   if [[ -d "$root" ]]; then rmdir "$root"; fi | ||||
| } | ||||
| @@ -146,16 +124,14 @@ main() { | ||||
|   mode="" | ||||
|   host="" | ||||
|   key="" | ||||
|   enroll_secure_boot_flag="false" | ||||
|   copy_config_flag="false" | ||||
|   reboot_flag="false" | ||||
|  | ||||
|   while getopts "m:h:k:scr" opt; do | ||||
|   while getopts "m:h:k:cr" opt; do | ||||
|     case "$opt" in | ||||
|       m) mode="$OPTARG" ;; | ||||
|       h) host="$OPTARG" ;; | ||||
|       k) key="$OPTARG" ;; | ||||
|       s) enroll_secure_boot_flag="true" ;; | ||||
|       c) copy_config_flag="true" ;; | ||||
|       r) reboot_flag="true" ;; | ||||
|       *) usage ;; | ||||
| @@ -177,17 +153,10 @@ main() { | ||||
|       ;; | ||||
|   esac | ||||
|  | ||||
|   copy_sops_keys | ||||
|   copy_secure_boot_keys | ||||
|  | ||||
|   install_nixos | ||||
|  | ||||
|   [[ "$enroll_secure_boot_flag" == "true" ]] && enroll_secure_boot | ||||
|   copy_keys | ||||
|   install | ||||
|   [[ "$copy_config_flag" == "true" ]] && copy_config | ||||
|  | ||||
|   cleanup | ||||
|  | ||||
|   [[ "$reboot_flag" == "true" ]] && reboot | ||||
|   [[ "$reboot_flag" == "true" ]] && finish | ||||
| } | ||||
|  | ||||
| main "$@" | ||||
|   | ||||
| @@ -1,4 +1,12 @@ | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   nixpkgs.overlays = [ | ||||
|     (final: prev: { | ||||
|       nix-update = prev.nix-update.overrideAttrs (oldAttrs: { | ||||
|         patches = oldAttrs.patches or [ ] ++ [ ./source-attribute.patch ]; | ||||
|       }); | ||||
|     }) | ||||
|   ]; | ||||
|  | ||||
|   environment.systemPackages = with pkgs; [ nix-update ]; | ||||
| } | ||||
|   | ||||
							
								
								
									
										127
									
								
								hosts/common/configs/system/nix-update/source-attribute.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								hosts/common/configs/system/nix-update/source-attribute.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,127 @@ | ||||
| diff --git a/nix_update/__init__.py b/nix_update/__init__.py | ||||
| index 89bbe45..93f9322 100644 | ||||
| --- a/nix_update/__init__.py | ||||
| +++ b/nix_update/__init__.py | ||||
| @@ -124,6 +124,12 @@ def parse_args(args: list[str]) -> Options: | ||||
|          default=[], | ||||
|      ) | ||||
|   | ||||
| +    parser.add_argument( | ||||
| +        "--src-attr", | ||||
| +        help="Src attribute", | ||||
| +        default="src", | ||||
| +    ) | ||||
| + | ||||
|      a = parser.parse_args(args) | ||||
|      extra_flags = ["--extra-experimental-features", "flakes nix-command"] | ||||
|      if a.system: | ||||
| @@ -146,6 +152,7 @@ def parse_args(args: list[str]) -> Options: | ||||
|          version=a.version, | ||||
|          version_preference=VersionPreference.from_str(a.version), | ||||
|          attribute=a.attribute, | ||||
| +        source_attribute=a.src_attr, | ||||
|          test=a.test, | ||||
|          version_regex=a.version_regex, | ||||
|          review=a.review, | ||||
| diff --git a/nix_update/eval.py b/nix_update/eval.py | ||||
| index 1767056..f85ea69 100644 | ||||
| --- a/nix_update/eval.py | ||||
| +++ b/nix_update/eval.py | ||||
| @@ -105,12 +105,19 @@ class Package: | ||||
|  def eval_expression( | ||||
|      escaped_import_path: str, | ||||
|      attr: str, | ||||
| +    source_attr: str, | ||||
|      flake: bool, | ||||
|      system: str | None, | ||||
|      override_filename: str | None, | ||||
|  ) -> str: | ||||
|      system = f'"{system}"' if system else "builtins.currentSystem" | ||||
|   | ||||
| +    source_attrs = source_attr.rpartition(".") | ||||
| +    source_attr_last = source_attrs[-1] or source_attr | ||||
| +    source_attr_all_but_last = ( | ||||
| +        f".{source_attrs[0]}" if source_attr_last != source_attr else "" | ||||
| +    ) | ||||
| + | ||||
|      if flake: | ||||
|          sanitize_position = ( | ||||
|              f""" | ||||
| @@ -164,8 +171,8 @@ let | ||||
|      raw_version_position | ||||
|    else if pkg ? isPhpExtension then | ||||
|      raw_version_position | ||||
| -  else if (builtins.unsafeGetAttrPos "src" pkg) != null then | ||||
| -    sanitizePosition (builtins.unsafeGetAttrPos "src" pkg) | ||||
| +  else if (builtins.unsafeGetAttrPos "{source_attr_last}" pkg) != null then | ||||
| +    sanitizePosition (builtins.unsafeGetAttrPos "{source_attr_last}" pkg{source_attr_all_but_last}) | ||||
|    else | ||||
|      sanitizePosition (positionFromMeta pkg); | ||||
|  in {{ | ||||
| @@ -174,11 +181,11 @@ in {{ | ||||
|    inherit raw_version_position; | ||||
|    filename = position.file; | ||||
|    line = position.line; | ||||
| -  urls = pkg.src.urls or null; | ||||
| -  url = pkg.src.url or null; | ||||
| -  rev = pkg.src.rev or null; | ||||
| -  tag = pkg.src.tag or null; | ||||
| -  hash = pkg.src.outputHash or null; | ||||
| +  urls = pkg.{source_attr}.urls or null; | ||||
| +  url = pkg.{source_attr}.url or null; | ||||
| +  rev = pkg.{source_attr}.rev or null; | ||||
| +  tag = pkg.{source_attr}.tag or null; | ||||
| +  hash = pkg.{source_attr}.outputHash or null; | ||||
|    go_modules = pkg.goModules.outputHash or null; | ||||
|    go_modules_old = pkg.go-modules.outputHash or null; | ||||
|    cargo_deps = pkg.cargoDeps.outputHash or null; | ||||
| @@ -205,7 +212,7 @@ in {{ | ||||
|    mix_deps = pkg.mixFodDeps.outputHash or null; | ||||
|    tests = builtins.attrNames (pkg.passthru.tests or {{}}); | ||||
|    has_update_script = {has_update_script}; | ||||
| -  src_homepage = pkg.src.meta.homepage or null; | ||||
| +  src_homepage = pkg.{source_attr}.meta.homepage or null; | ||||
|    changelog = pkg.meta.changelog or null; | ||||
|    maintainers = pkg.meta.maintainers or null; | ||||
|  }}""" | ||||
| @@ -215,6 +222,7 @@ def eval_attr(opts: Options) -> Package: | ||||
|      expr = eval_expression( | ||||
|          opts.escaped_import_path, | ||||
|          opts.escaped_attribute, | ||||
| +        opts.source_attribute, | ||||
|          opts.flake, | ||||
|          opts.system, | ||||
|          opts.override_filename, | ||||
| diff --git a/nix_update/options.py b/nix_update/options.py | ||||
| index 2d07b77..ab5c305 100644 | ||||
| --- a/nix_update/options.py | ||||
| +++ b/nix_update/options.py | ||||
| @@ -8,6 +8,7 @@ from .version.version import VersionPreference | ||||
|  @dataclass | ||||
|  class Options: | ||||
|      attribute: str | ||||
| +    source_attribute: str = "src" | ||||
|      flake: bool = False | ||||
|      version: str = "stable" | ||||
|      version_preference: VersionPreference = VersionPreference.STABLE | ||||
| @@ -33,4 +34,7 @@ class Options: | ||||
|   | ||||
|      def __post_init__(self) -> None: | ||||
|          self.escaped_attribute = ".".join(map(json.dumps, self.attribute.split("."))) | ||||
| +        self.escaped_source_attribute = ".".join( | ||||
| +            map(json.dumps, self.source_attribute.split(".")) | ||||
| +        ) | ||||
|          self.escaped_import_path = json.dumps(self.import_path) | ||||
| diff --git a/nix_update/update.py b/nix_update/update.py | ||||
| index 82b7bc5..464bf3d 100644 | ||||
| --- a/nix_update/update.py | ||||
| +++ b/nix_update/update.py | ||||
| @@ -155,7 +155,7 @@ def git_prefetch(x: tuple[str, tuple[str, str]]) -> tuple[str, str]: | ||||
|   | ||||
|   | ||||
|  def update_src_hash(opts: Options, filename: str, current_hash: str) -> None: | ||||
| -    target_hash = nix_prefetch(opts, "src") | ||||
| +    target_hash = nix_prefetch(opts, opts.source_attribute) | ||||
|      replace_hash(filename, current_hash, target_hash) | ||||
|   | ||||
|   | ||||
| @@ -3,9 +3,9 @@ | ||||
|   sops = { | ||||
|     secrets = { | ||||
|       "git/credentials/github.com/public/username".sopsFile = | ||||
|         "${inputs.secrets}/domains/personal/secrets.yaml"; | ||||
|         ../../../../../secrets/personal/secrets.yaml; | ||||
|       "git/credentials/github.com/public/password".sopsFile = | ||||
|         "${inputs.secrets}/domains/personal/secrets.yaml"; | ||||
|         ../../../../../secrets/personal/secrets.yaml; | ||||
|     }; | ||||
|  | ||||
|     templates.nix-access-tokens = { | ||||
|   | ||||
| @@ -10,10 +10,7 @@ | ||||
|       storage.settings.storage.driver = "btrfs"; | ||||
|     }; | ||||
|  | ||||
|     quadlet = { | ||||
|       enable = true; | ||||
|       autoEscape = true; | ||||
|     }; | ||||
|     quadlet.autoEscape = true; | ||||
|   }; | ||||
|  | ||||
|   environment = { | ||||
|   | ||||
| @@ -4,9 +4,4 @@ | ||||
|     smartmontools | ||||
|     nvme-cli | ||||
|   ]; | ||||
|  | ||||
|   services.smartd = { | ||||
|     enable = true; | ||||
|     defaults.autodetected = "-a -o on -n idle,10 -s (S/../.././02|L/../../7/04)"; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -18,7 +18,7 @@ | ||||
|   }; | ||||
|  | ||||
|   sops = { | ||||
|     defaultSopsFile = "${inputs.secrets}/hosts/${config.networking.hostName}/secrets.yaml"; | ||||
|     defaultSopsFile = ../../../../. + "/${config.networking.hostName}/secrets/secrets.yaml"; | ||||
|  | ||||
|     age = { | ||||
|       generateKey = true; | ||||
|   | ||||
| @@ -1,22 +1,22 @@ | ||||
| { inputs, ... }: | ||||
| { ... }: | ||||
| { | ||||
|   programs.ssh.knownHosts = { | ||||
|     installer.publicKeyFile = "${inputs.secrets}/hosts/installer/ssh_host_ed25519_key.pub"; | ||||
|     elara.publicKeyFile = "${inputs.secrets}/hosts/elara/ssh_host_ed25519_key.pub"; | ||||
|     himalia.publicKeyFile = "${inputs.secrets}/hosts/himalia/ssh_host_ed25519_key.pub"; | ||||
|     installer.publicKeyFile = ../../../../installer/secrets/ssh_host_ed25519_key.pub; | ||||
|     elara.publicKeyFile = ../../../../elara/secrets/ssh_host_ed25519_key.pub; | ||||
|     himalia.publicKeyFile = ../../../../himalia/secrets/ssh_host_ed25519_key.pub; | ||||
|  | ||||
|     jupiter = { | ||||
|       publicKeyFile = "${inputs.secrets}/hosts/jupiter/ssh_host_ed25519_key.pub"; | ||||
|       publicKeyFile = ../../../../jupiter/secrets/ssh_host_ed25519_key.pub; | ||||
|       extraHostNames = [ "karaolidis.com" ]; | ||||
|     }; | ||||
|  | ||||
|     jupiter-sish = { | ||||
|       publicKeyFile = "${inputs.secrets}/hosts/jupiter/ssh_sish_ed25519_key.pub"; | ||||
|       publicKeyFile = ../../../../jupiter/users/storm/configs/console/podman/sish/ssh_host_ed25519_key.pub; | ||||
|       extraHostNames = [ "karaolidis.com" ]; | ||||
|     }; | ||||
|  | ||||
|     jupiter-vps = { | ||||
|       publicKeyFile = "${inputs.secrets}/hosts/jupiter-vps/ssh_host_ed25519_key.pub"; | ||||
|       publicKeyFile = ../../../../jupiter-vps/secrets/ssh_host_ed25519_key.pub; | ||||
|       extraHostNames = [ "vps.karaolidis.com" ]; | ||||
|     }; | ||||
|   }; | ||||
|   | ||||
| @@ -1,11 +1,7 @@ | ||||
| { pkgs, ... }: | ||||
| { ... }: | ||||
| { | ||||
|   environment = { | ||||
|     systemPackages = with pkgs; [ | ||||
|       kitty.terminfo | ||||
|       tmux.terminfo | ||||
|     ]; | ||||
|  | ||||
|     enableAllTerminfo = true; | ||||
|     persistence."/persist/state"."/var/lib/fail2ban" = { }; | ||||
|   }; | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, pkgs, ... }: | ||||
| { | ||||
|   nixpkgs.overlays = [ | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { lib, pkgs, ... }: | ||||
| { | ||||
|   users.users.${user}.extraGroups = [ | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs.btop = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs.fastfetch.enable = true; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, inputs, ... }: | ||||
| { | ||||
|   imports = [ inputs.home-manager.nixosModules.default ]; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ imagemagick ]; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs.jq.enable = true; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.dconf.settings = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ lsof ]; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ mprocs ]; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user} = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { lib, pkgs, ... }: | ||||
| { | ||||
|   environment.persistence = { | ||||
| @@ -6,11 +9,6 @@ | ||||
|     "/persist/cache"."${home}/.cache/ncspot" = { }; | ||||
|   }; | ||||
|  | ||||
|   # FIXME: https://github.com/hrkfdn/ncspot/issues/1676 | ||||
|   networking.extraHosts = '' | ||||
|     0.0.0.0 apresolve.spotify.com | ||||
|   ''; | ||||
|  | ||||
|   home-manager.users.${user} = { | ||||
|     programs.ncspot.enable = true; | ||||
|  | ||||
|   | ||||
| @@ -3,9 +3,6 @@ volnorm = true | ||||
| default_keybindings = true | ||||
| library_tabs = [ "albums", "artists", "playlists", "browse" ] | ||||
|  | ||||
| [keybindings] | ||||
| "Esc" = "back" | ||||
|  | ||||
| [theme] | ||||
| background = "{{colors.surface.default.hex}}" | ||||
| primary = "{{colors.on_surface.default.hex}}" | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs.zsh.shellAliases.ncl = "sudo nix-cleanup"; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   lib, | ||||
|   inputs, | ||||
|   | ||||
| @@ -1,31 +1,42 @@ | ||||
| { | ||||
|   inputs = { | ||||
|     nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; | ||||
|     nixpkgs = { | ||||
|       type = "github"; | ||||
|       owner = "karaolidis"; | ||||
|       repo = "nixpkgs"; | ||||
|       ref = "integration"; | ||||
|     }; | ||||
|  | ||||
|     flake-utils = { | ||||
|       type = "github"; | ||||
|       owner = "numtide"; | ||||
|       repo = "flake-utils"; | ||||
|       ref = "main"; | ||||
|     }; | ||||
|  | ||||
|     treefmt-nix = { | ||||
|       url = "github:numtide/treefmt-nix"; | ||||
|       type = "github"; | ||||
|       owner = "numtide"; | ||||
|       repo = "treefmt-nix"; | ||||
|       ref = "main"; | ||||
|  | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   outputs = | ||||
|     inputs: | ||||
|     ( | ||||
|     { self, nixpkgs, ... }@inputs: | ||||
|     inputs.flake-utils.lib.eachDefaultSystem ( | ||||
|       system: | ||||
|       let | ||||
|         system = "x86_64-linux"; | ||||
|  | ||||
|         pkgs = import inputs.nixpkgs { | ||||
|           inherit system; | ||||
|           config.allowUnfree = true; | ||||
|         }; | ||||
|  | ||||
|         pkgs = nixpkgs.legacyPackages.${system}; | ||||
|         treefmt = inputs.treefmt-nix.lib.evalModule pkgs ./treefmt.nix; | ||||
|       in | ||||
|       { | ||||
|         devShells.${system}.default = pkgs.mkShell { packages = with pkgs; [ ]; }; | ||||
|         devShells.default = pkgs.mkShell { packages = with pkgs; [ ]; }; | ||||
|  | ||||
|         formatter.${system} = treefmt.config.build.wrapper; | ||||
|         checks.formatting.${system} = treefmt.config.build.check inputs.self; | ||||
|         formatter = treefmt.config.build.wrapper; | ||||
|         checks.formatting = treefmt.config.build.check self; | ||||
|       } | ||||
|     ); | ||||
| } | ||||
|   | ||||
| @@ -9,5 +9,9 @@ | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   settings.global.excludes = [ ".envrc" ]; | ||||
|   settings = { | ||||
|     global = { | ||||
|       excludes = [ ".envrc" ]; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   lib, | ||||
|   pkgs, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   environment.persistence."/persist/cache"."${home}/.cache/nix" = { }; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ ouch ]; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, pkgs, ... }: | ||||
| { | ||||
|   environment.persistence."/persist/state"."${home}/.local/state/wireplumber" = { }; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   lib, | ||||
|   pkgs, | ||||
| @@ -16,10 +19,7 @@ | ||||
|       settings.storage.storage.driver = "btrfs"; | ||||
|     }; | ||||
|  | ||||
|     virtualisation.quadlet = { | ||||
|       enable = true; | ||||
|       autoEscape = true; | ||||
|     }; | ||||
|     virtualisation.quadlet.autoEscape = true; | ||||
|  | ||||
|     home = { | ||||
|       packages = with pkgs; [ | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, inputs, ... }: | ||||
| { | ||||
|   environment.persistence."/persist/state"."${home}/.config/sops-nix/key.txt" = { }; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user} = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs.ssh.enable = true; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, utils, ... }: | ||||
| { | ||||
|   networking.firewall = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs.tmux.enable = true; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ tree ]; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ wget ]; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, pkgs, ... }: | ||||
| { | ||||
|   environment.persistence."/persist/user" = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
| @@ -24,7 +27,8 @@ in | ||||
|           }; | ||||
|  | ||||
|           opener = { | ||||
|             edit = [ | ||||
|             edit = | ||||
|               [ | ||||
|                 { | ||||
|                   run = "${hmConfig.programs.neovim.finalPackage}/bin/nvim \"$@\""; | ||||
|                   desc = "nvim"; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, ... }: | ||||
| { | ||||
|   home-manager.users.${user}.programs.yt-dlp = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   environment.persistence."/persist/state"."${home}/.local/share/zoxide" = { }; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { config, pkgs, ... }: | ||||
| { | ||||
|   environment = { | ||||
| @@ -11,7 +14,7 @@ | ||||
|   home-manager.users.${user} = { | ||||
|     programs.zsh = { | ||||
|       enable = true; | ||||
|       dotDir = "${home}/.config/zsh"; | ||||
|       dotDir = ".config/zsh"; | ||||
|       autocd = true; | ||||
|       history = { | ||||
|         path = "${home}/.local/share/zsh/history"; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { ... }: | ||||
| { | ||||
|   imports = [ ./options.nix ]; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import app from "ags/gtk3/app"; | ||||
| import { exec } from "ags/process"; | ||||
| import { monitorFile } from "ags/file"; | ||||
| import { App } from "astal/gtk3"; | ||||
| import { monitorFile } from "astal/file"; | ||||
| import { exec } from "astal/process"; | ||||
| import GLib from "gi://GLib"; | ||||
| import Left from "./widget/Left"; | ||||
| import Center from "./widget/Center"; | ||||
| @@ -12,15 +12,15 @@ const scss = `${HOME}/.config/astal/theme.sass`; | ||||
|  | ||||
| monitorFile(scss, () => { | ||||
|   exec(`sassc ${scss} ${css}`); | ||||
|   app.apply_css(css, true); | ||||
|   App.apply_css(css, true); | ||||
| }); | ||||
|  | ||||
| exec(`sassc ${scss} ${css}`); | ||||
|  | ||||
| app.start({ | ||||
| App.start({ | ||||
|   css, | ||||
|   main() { | ||||
|     app.get_monitors().map((monitor) => { | ||||
|     App.get_monitors().map((monitor) => { | ||||
|       Left(monitor); | ||||
|       Center(monitor); | ||||
|       Right(monitor); | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| import { Gdk } from "ags/gtk3"; | ||||
| import { Gdk } from "astal/gtk3"; | ||||
| import Hyprland from "gi://AstalHyprland"; | ||||
|  | ||||
| export const range = (length: number, start = 1) => { | ||||
|   return Array.from({ length }, (_, i) => i + start); | ||||
|   return Array.from({ length }, (n, i) => i + start); | ||||
| }; | ||||
|  | ||||
| export const getHyprlandMonitor = (gdkmonitor: Gdk.Monitor) => { | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| { | ||||
|   "name": "astal-shell", | ||||
|   "dependencies": { | ||||
|     "ags": "*" | ||||
|     "astal": "~/.local/share/ags" | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| { | ||||
|   "$schema": "https://json.schemastore.org/tsconfig", | ||||
|   "compilerOptions": { | ||||
|     "jsx": "react-jsx", | ||||
|     "jsxImportSource": "ags/gtk3", | ||||
|     "lib": ["ES2023"], | ||||
|     "experimentalDecorators": true, | ||||
|     "strict": true, | ||||
|     "target": "ES2022", | ||||
|     "module": "ES2022", | ||||
|     "moduleResolution": "Bundler", | ||||
|     "strict": true, | ||||
|     "target": "ES2020" | ||||
|     "jsx": "react-jsx", | ||||
|     "jsxImportSource": "astal/gtk3" | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,19 +1,17 @@ | ||||
| import { Astal, Gtk, Gdk } from "ags/gtk3"; | ||||
| import { App, Astal, Gtk, Gdk } from "astal/gtk3"; | ||||
| import Date from "./components/Date"; | ||||
| import Hidden from "./components/Hidden"; | ||||
| import app from "ags/gtk3/app"; | ||||
|  | ||||
| export default (monitor: Gdk.Monitor) => ( | ||||
|   <window | ||||
|     visible | ||||
|     class="root" | ||||
|     className="root" | ||||
|     gdkmonitor={monitor} | ||||
|     exclusivity={Astal.Exclusivity.IGNORE} | ||||
|     anchor={Astal.WindowAnchor.TOP} | ||||
|     application={app} | ||||
|     application={App} | ||||
|   > | ||||
|     <Hidden> | ||||
|       <box class="widgets" hexpand halign={Gtk.Align.CENTER}> | ||||
|       <box className="widgets" hexpand halign={Gtk.Align.CENTER}> | ||||
|         <Date /> | ||||
|       </box> | ||||
|     </Hidden> | ||||
|   | ||||
| @@ -1,22 +1,21 @@ | ||||
| import { Astal, Gtk, Gdk } from "ags/gtk3"; | ||||
| import app from "ags/gtk3/app"; | ||||
| import { App, Astal, Gtk, Gdk } from "astal/gtk3"; | ||||
| import Launcher from "./components/Launcher"; | ||||
| import Workspace from "./components/Workspaces"; | ||||
| import Hidden from "./components/Hidden"; | ||||
| import { getHyprlandMonitor } from "../lib"; | ||||
|  | ||||
| export default (monitor: Gdk.Monitor) => ( | ||||
|   <window | ||||
|     visible | ||||
|     class="root" | ||||
|     className="root" | ||||
|     gdkmonitor={monitor} | ||||
|     exclusivity={Astal.Exclusivity.IGNORE} | ||||
|     anchor={Astal.WindowAnchor.TOP | Astal.WindowAnchor.LEFT} | ||||
|     application={app} | ||||
|     application={App} | ||||
|   > | ||||
|     <Hidden> | ||||
|       <box class="widgets" hexpand halign={Gtk.Align.START}> | ||||
|       <box className="widgets" hexpand halign={Gtk.Align.START}> | ||||
|         <Launcher /> | ||||
|         <Workspace gdkmonitor={monitor} /> | ||||
|         <Workspace monitor={getHyprlandMonitor(monitor)!} /> | ||||
|       </box> | ||||
|     </Hidden> | ||||
|   </window> | ||||
|   | ||||
| @@ -1,21 +1,18 @@ | ||||
| import { Astal, Gtk } from "ags/gtk3"; | ||||
| import app from "ags/gtk3/app"; | ||||
| import Gdk from "gi://Gdk"; | ||||
| import { App, Astal, Gtk, Gdk } from "astal/gtk3"; | ||||
| import Systray from "./components/Tray"; | ||||
| import Hidden from "./components/Hidden"; | ||||
| import Battery from "./components/Battery"; | ||||
|  | ||||
| export default (monitor: Gdk.Monitor) => ( | ||||
|   <window | ||||
|     visible | ||||
|     class="root" | ||||
|     className="root" | ||||
|     gdkmonitor={monitor} | ||||
|     exclusivity={Astal.Exclusivity.IGNORE} | ||||
|     anchor={Astal.WindowAnchor.TOP | Astal.WindowAnchor.RIGHT} | ||||
|     application={app} | ||||
|     application={App} | ||||
|   > | ||||
|     <Hidden> | ||||
|       <box class="widgets" hexpand halign={Gtk.Align.END}> | ||||
|       <box className="widgets" hexpand halign={Gtk.Align.END}> | ||||
|         <Systray /> | ||||
|         <Battery /> | ||||
|       </box> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import { createBinding, createComputed } from "ags"; | ||||
| import { bind, Variable } from "astal"; | ||||
| import AstalBattery from "gi://AstalBattery"; | ||||
|  | ||||
| const battery = AstalBattery.get_default(); | ||||
| @@ -9,19 +9,19 @@ const formatTime = (seconds: number) => | ||||
|     : "--:--"; | ||||
|  | ||||
| export default () => { | ||||
|   const percentage = createBinding(battery, "percentage").as( | ||||
|   const percentage = bind(battery, "percentage").as( | ||||
|     (p) => Math.round(p * 100) + "%", | ||||
|   ); | ||||
|   const charging = createBinding(battery, "charging"); | ||||
|   const timeToFull = createBinding(battery, "timeToFull"); | ||||
|   const timeToEmpty = createBinding(battery, "timeToEmpty"); | ||||
|   const charging = bind(battery, "charging"); | ||||
|   const timeToFull = bind(battery, "timeToFull"); | ||||
|   const timeToEmpty = bind(battery, "timeToEmpty"); | ||||
|  | ||||
|   const time = createComputed( | ||||
|   const time = Variable.derive( | ||||
|     [charging, timeToFull, timeToEmpty], | ||||
|     (charging, full, empty) => formatTime(charging ? full : empty), | ||||
|   ); | ||||
|  | ||||
|   const label = createComputed( | ||||
|   const label = Variable.derive( | ||||
|     [percentage, charging, time], | ||||
|     (percentage, charging, time) => { | ||||
|       const arrow = charging ? "▲" : "▼"; | ||||
| @@ -30,8 +30,8 @@ export default () => { | ||||
|   ); | ||||
|  | ||||
|   return ( | ||||
|     <button class="battery"> | ||||
|       <label class="label" label={label} /> | ||||
|     <button className="battery"> | ||||
|       <label className="label" label={bind(label)} /> | ||||
|     </button> | ||||
|   ); | ||||
| }; | ||||
|   | ||||
| @@ -1,16 +1,21 @@ | ||||
| import { createPoll } from "ags/time"; | ||||
| import GLib from "gi://GLib?version=2.0"; | ||||
| import { bind, Variable } from "astal"; | ||||
| import { GLib } from "astal"; | ||||
|  | ||||
| export default () => { | ||||
|   const time = createPoll( | ||||
|   const time = Variable( | ||||
|     GLib.DateTime.new_now_local().format("%H:%M - %A, %d %B %Y")!, | ||||
|   ).poll( | ||||
|     1000, | ||||
|     () => GLib.DateTime.new_now_local().format("%H:%M - %A, %d %B %Y")!, | ||||
|   ); | ||||
|  | ||||
|   return ( | ||||
|     <button class="date"> | ||||
|       <label class="label" label={time} /> | ||||
|     <button className="date"> | ||||
|       <label | ||||
|         className="label" | ||||
|         onDestroy={() => time.drop()} | ||||
|         label={bind(time)} | ||||
|       /> | ||||
|     </button> | ||||
|   ); | ||||
| }; | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| import { createState } from "ags"; | ||||
| import { Gtk } from "ags/gtk3"; | ||||
| import { timeout } from "ags/time"; | ||||
| import { Gtk } from "astal/gtk3"; | ||||
| import { Variable, bind, timeout } from "astal"; | ||||
|  | ||||
| export default function Hidden({ | ||||
|   child, | ||||
| @@ -13,20 +12,24 @@ export default function Hidden({ | ||||
|   orientation?: Gtk.Orientation; | ||||
|   transitionType?: Gtk.RevealerTransitionType; | ||||
| }) { | ||||
|   const [show, setShow] = createState(true); | ||||
|   const show = Variable(true); | ||||
|   const contents = child ?? children; | ||||
|  | ||||
|   return ( | ||||
|     <eventbox onHover={() => setShow(true)} onHoverLost={() => setShow(false)}> | ||||
|     <eventbox | ||||
|       clickThrough | ||||
|       onHover={() => show.set(true)} | ||||
|       onHoverLost={() => show.set(false)} | ||||
|     > | ||||
|       <box orientation={orientation}> | ||||
|         <revealer | ||||
|           onRealize={() => timeout(2000, () => setShow(false))} | ||||
|           revealChild={show} | ||||
|           setup={(self) => timeout(2000, () => (self.revealChild = false))} | ||||
|           revealChild={bind(show)} | ||||
|           transitionType={transitionType} | ||||
|         > | ||||
|           {Array.isArray(contents) ? <>{contents}</> : contents} | ||||
|         </revealer> | ||||
|         <box class="trigger-guard" /> | ||||
|         <box clickThrough className="trigger-guard" /> | ||||
|       </box> | ||||
|     </eventbox> | ||||
|   ); | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| import { execAsync } from "ags/process"; | ||||
| import { execAsync } from "astal/process"; | ||||
|  | ||||
| export default () => ( | ||||
|   <button | ||||
|     class="launcher" | ||||
|     onClicked={() => | ||||
|     className="launcher" | ||||
|     onClickRelease={() => | ||||
|       execAsync( | ||||
|         'rofi -modes drun -show drun -run-command \"uwsm app -- {cmd}\"', | ||||
|       ) | ||||
|     } | ||||
|   > | ||||
|     <icon class="icon" icon="nix-snowflake-symbolic" />; | ||||
|     <icon className="icon" icon="nix-snowflake-symbolic" />; | ||||
|   </button> | ||||
| ); | ||||
|   | ||||
| @@ -1,37 +1,28 @@ | ||||
| import { createBinding, For } from "ags"; | ||||
| import app from "ags/gtk3/app"; | ||||
| import { App } from "astal/gtk3"; | ||||
| import { bind } from "astal"; | ||||
| import Tray from "gi://AstalTray"; | ||||
|  | ||||
| const tray = Tray.get_default(); | ||||
|  | ||||
| const TrayButton = ({ item }: { item: Tray.TrayItem }) => ( | ||||
|   <menubutton | ||||
|     class="item" | ||||
|     tooltipMarkup={createBinding(item, "tooltipMarkup")} | ||||
|     className="item" | ||||
|     tooltipMarkup={bind(item, "tooltipMarkup")} | ||||
|     usePopover={false} | ||||
|     menuModel={createBinding(item, "menuModel")} | ||||
|     onRealize={(self) => { | ||||
|       createBinding(item, "action_group").as((action_group) => | ||||
|         self.insert_action_group("dbusmenu", action_group), | ||||
|       ); | ||||
|       self.insert_action_group("dbusmenu", item.action_group); | ||||
|     }} | ||||
|     menuModel={bind(item, "menuModel")} | ||||
|     actionGroup={bind(item, "actionGroup").as((ag) => ["dbusmenu", ag])} | ||||
|   > | ||||
|     <icon gicon={createBinding(item, "gicon")} /> | ||||
|     <icon gicon={bind(item, "gicon")} /> | ||||
|   </menubutton> | ||||
| ); | ||||
|  | ||||
| export default () => { | ||||
|   let items = createBinding(tray, "items"); | ||||
|  | ||||
|   return ( | ||||
|     <box class="systray"> | ||||
|       <For each={items}> | ||||
|         {(item, _) => { | ||||
|           if (item.iconThemePath) app.add_icons(item.iconThemePath); | ||||
| export default () => ( | ||||
|   <box className="systray"> | ||||
|     {bind(tray, "items").as((items) => | ||||
|       items.map((item) => { | ||||
|         if (item.iconThemePath) App.add_icons(item.iconThemePath); | ||||
|         return <TrayButton item={item} />; | ||||
|         }} | ||||
|       </For> | ||||
|       }), | ||||
|     )} | ||||
|   </box> | ||||
| ); | ||||
| }; | ||||
|   | ||||
| @@ -1,83 +1,74 @@ | ||||
| import { bind, Variable } from "astal"; | ||||
| import Hyprland from "gi://AstalHyprland"; | ||||
| import { getHyprlandMonitor, range } from "../../lib"; | ||||
| import { | ||||
|   Accessor, | ||||
|   createBinding, | ||||
|   createComputed, | ||||
|   createState, | ||||
|   Setter, | ||||
| } from "ags"; | ||||
| import { Gdk, Gtk } from "ags/gtk3"; | ||||
| import { range } from "../../lib"; | ||||
|  | ||||
| const hyprland = Hyprland.get_default(); | ||||
| const BLOCK_SIZE = 10; | ||||
|  | ||||
| const Workspace = ({ id }: { id: number }) => { | ||||
|   let clients: Accessor<string[]>; | ||||
|   let setClients: Setter<string[]>; | ||||
|   let clients: Variable<string[]>; | ||||
|  | ||||
|   try { | ||||
|     const workspace = hyprland.get_workspace(id); | ||||
|     [clients, setClients] = createState( | ||||
|       workspace.clients.map((client) => client.address), | ||||
|     ); | ||||
|     clients = Variable(workspace.clients.map((client) => client.address)); | ||||
|   } catch (_) { | ||||
|     [clients, setClients] = createState<string[]>([]); | ||||
|     clients = Variable([]); | ||||
|   } | ||||
|  | ||||
|   const active = createComputed( | ||||
|     [createBinding(hyprland, "focusedWorkspace")], | ||||
|   const active = Variable.derive( | ||||
|     [bind(hyprland, "focusedWorkspace")], | ||||
|     (focused) => focused.id == id, | ||||
|   ); | ||||
|  | ||||
|   hyprland.connect("workspace-added", (_, workspace) => { | ||||
|     if (workspace.id != id) return; | ||||
|     setClients(workspace.clients.map((client) => client.address)); | ||||
|     clients.set(workspace.clients.map((client) => client.address)); | ||||
|   }); | ||||
|  | ||||
|   hyprland.connect("workspace-removed", (_, workspaceId) => { | ||||
|     if (workspaceId != id) return; | ||||
|     setClients([]); | ||||
|     clients.set([]); | ||||
|   }); | ||||
|  | ||||
|   hyprland.connect("client-added", (_hyprland, client) => { | ||||
|     if (client.workspace.id != id) return; | ||||
|     setClients([...clients.get(), client.address]); | ||||
|     clients.set([...clients.get(), client.address]); | ||||
|   }); | ||||
|  | ||||
|   // Explicit separate event handling instead of Variable.derive(workspaces, clients) | ||||
|   // because client-moved events appear to be broken if done that way. | ||||
|   hyprland.connect("client-moved", (_hyprland, client, workspace) => { | ||||
|     if (workspace.id == id) { | ||||
|       setClients([...clients.get(), client.address]); | ||||
|       clients.set([...clients.get(), client.address]); | ||||
|     } else { | ||||
|       setClients( | ||||
|       clients.set( | ||||
|         clients.get().filter((oldClient) => oldClient != client.address), | ||||
|       ); | ||||
|     } | ||||
|   }); | ||||
|  | ||||
|   hyprland.connect("client-removed", (_hyprland, address) => { | ||||
|     setClients(clients.get().filter((oldClient) => oldClient != address)); | ||||
|     clients.set(clients.get().filter((oldClient) => oldClient != address)); | ||||
|   }); | ||||
|  | ||||
|   const className = createComputed([active, clients], (active, clients) => { | ||||
|   const className = Variable.derive([active, clients], (active, clients) => { | ||||
|     if (active) return "button active"; | ||||
|     if (clients.length > 0) return "button occupied"; | ||||
|     return "button"; | ||||
|   }); | ||||
|  | ||||
|   return ( | ||||
|     <box orientation={Gtk.Orientation.VERTICAL}> | ||||
|     <box vertical> | ||||
|       <box vexpand /> | ||||
|       <eventbox onClickRelease={() => hyprland.dispatch("workspace", `${id}`)}> | ||||
|         <label class={className} /> | ||||
|         <label className={className()} /> | ||||
|       </eventbox> | ||||
|       <box vexpand /> | ||||
|     </box> | ||||
|   ); | ||||
| }; | ||||
|  | ||||
| export default ({ gdkmonitor }: { gdkmonitor: Gdk.Monitor }) => { | ||||
|   const monitor = getHyprlandMonitor(gdkmonitor)!; | ||||
| export default ({ monitor }: { monitor: Hyprland.Monitor }) => { | ||||
|   const workspaces = hyprland.get_workspaces(); | ||||
|   const displayWorkspaces = workspaces.filter( | ||||
|     (w) => w.monitor.id === monitor.id, | ||||
| @@ -87,7 +78,7 @@ export default ({ gdkmonitor }: { gdkmonitor: Gdk.Monitor }) => { | ||||
|  | ||||
|   return ( | ||||
|     <eventbox | ||||
|       class="workspaces" | ||||
|       className="workspaces" | ||||
|       onScroll={(_, e) => { | ||||
|         hyprland.dispatch("workspace", e.delta_y > 0 ? "m+1" : "m-1"); | ||||
|       }} | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
							
								
								
									
										20
									
								
								hosts/common/configs/user/gui/brightnessctl/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								hosts/common/configs/user/gui/brightnessctl/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { lib, pkgs, ... }: | ||||
| { | ||||
|   users.users.${user}.extraGroups = [ | ||||
|     "video" | ||||
|     "inputs" | ||||
|   ]; | ||||
|  | ||||
|   home-manager.users.${user}.wayland.windowManager.hyprland.settings.bindle = | ||||
|     let | ||||
|       brightnessctl = lib.meta.getExe pkgs.brightnessctl; | ||||
|     in | ||||
|     [ | ||||
|       ", XF86MonBrightnessUp, exec, ${brightnessctl} -q s 5%+" | ||||
|       ", XF86MonBrightnessDown, exec, ${brightnessctl} -q s 5%-" | ||||
|     ]; | ||||
| } | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   inputs, | ||||
| @@ -82,6 +85,6 @@ in | ||||
|     }; | ||||
|  | ||||
|     sops.secrets."jupiter/photos.karaolidis.com/admin".sopsFile = | ||||
|       "${inputs.secrets}/domains/personal/secrets.yaml"; | ||||
|       ../../../../../../secrets/personal/secrets.yaml; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { lib, pkgs, ... }: | ||||
| { | ||||
|   environment.persistence."/persist/state"."${home}/.config/vesktop" = { }; | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { lib, pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user} = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
| @@ -60,7 +63,6 @@ in | ||||
|               "browser.bookmarks.restore_default_bookmarks" = false; | ||||
|               "browser.bookmarks.showMobileBookmarks" = true; | ||||
|               "browser.download.useDownloadDir" = false; | ||||
|               "browser.newtabpage.activity-stream.feeds.system.topstories" = false; | ||||
|               "browser.toolbars.bookmarks.visibility" = "never"; | ||||
|               "browser.sessionstore.restore_on_demand" = true; | ||||
|               "browser.sessionstore.restore_pinned_tabs_on_demand" = false; | ||||
| @@ -72,10 +74,10 @@ in | ||||
|                     "unified-extensions-area" = [ | ||||
|                       "_73a6fe31-595d-460b-a920-fcc0f8843232_-browser-action" | ||||
|                       "sponsorblocker_ajay_app-browser-action" | ||||
|                       "_44df5123-f715-9146-bfaa-c6e8d4461d44_-browser-action" | ||||
|                       "_446900e4-71c2-419f-a6a7-df9c091e268b_-browser-action" | ||||
|                       "_aecec67f-0d10-4fa7-b7c7-609a2db280cf_-browser-action" | ||||
|                       "languagetool-webextension_languagetool_org-browser-action" | ||||
|                       "_a6c4a591-f1b2-4f03-b3ff-767e5bedf4e7_-browser-action" | ||||
|                     ]; | ||||
|                     "nav-bar" = [ | ||||
|                       "sidebar-button" | ||||
| @@ -102,6 +104,7 @@ in | ||||
|                   }; | ||||
|                   "seen" = [ | ||||
|                     "wayback_machine_mozilla_org-browser-action" | ||||
|                     "_44df5123-f715-9146-bfaa-c6e8d4461d44_-browser-action" | ||||
|                     "addon_darkreader_org-browser-action" | ||||
|                     "ublock0_raymondhill_net-browser-action" | ||||
|                     "_446900e4-71c2-419f-a6a7-df9c091e268b_-browser-action" | ||||
| @@ -110,8 +113,6 @@ in | ||||
|                     "sponsorblocker_ajay_app-browser-action" | ||||
|                     "_73a6fe31-595d-460b-a920-fcc0f8843232_-browser-action" | ||||
|                     "developer-button" | ||||
|                     "_a6c4a591-f1b2-4f03-b3ff-767e5bedf4e7_-browser-action" | ||||
|                     "screenshot-button" | ||||
|                   ]; | ||||
|                   "dirtyAreaCache" = [ | ||||
|                     "unified-extensions-area" | ||||
| @@ -142,7 +143,7 @@ in | ||||
|           ublock-origin | ||||
|           violentmonkey | ||||
|           wayback-machine | ||||
|           user-agent-string-switcher | ||||
|           fakespot-fake-reviews-amazon | ||||
|         ]; | ||||
|  | ||||
|         search = { | ||||
|   | ||||
| @@ -1,5 +0,0 @@ | ||||
| { user, home }: | ||||
| { ... }: | ||||
| { | ||||
|   programs.gamemode.enable = true; | ||||
| } | ||||
| @@ -1,11 +0,0 @@ | ||||
| { user, home }: | ||||
| { ... }: | ||||
| { | ||||
|   programs.gamescope = { | ||||
|     enable = true; | ||||
|     args = [ | ||||
|       "--rt" | ||||
|       "-f" | ||||
|     ]; | ||||
|   }; | ||||
| } | ||||
| @@ -1,30 +0,0 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   pkgs, | ||||
|   ... | ||||
| }: | ||||
| # https://bonkmaykr.xyz/content/discovery_lin.htm | ||||
| { | ||||
|   boot.kernel.sysctl."vm.max_map_count" = 1048576; | ||||
|  | ||||
|   security.pam.loginLimits = [ | ||||
|     { | ||||
|       domain = user; | ||||
|       item = "nofile"; | ||||
|       type = "soft"; | ||||
|       value = 200000; | ||||
|     } | ||||
|     { | ||||
|       domain = user; | ||||
|       item = "nofile"; | ||||
|       type = "hard"; | ||||
|       value = 200000; | ||||
|     } | ||||
|   ]; | ||||
|  | ||||
|   home-manager.users.${user}.wayland.windowManager.hyprland.settings.env = [ | ||||
|     "__GL_SHADER_DISK_CACHE_SKIP_CLEANUP,1" | ||||
|   ]; | ||||
| } | ||||
| @@ -1,14 +0,0 @@ | ||||
| { user, home }: | ||||
| { config, pkgs, ... }: | ||||
| let | ||||
|   hmConfig = config.home-manager.users.${user}; | ||||
| in | ||||
| { | ||||
|   environment.persistence."/persist/state"."${home}/.local/share/PrismLauncher" = { }; | ||||
|  | ||||
|   home-manager.users.${user}.home = { | ||||
|     packages = with pkgs; [ prismlauncher ]; | ||||
|     file."Games/PrismLauncher".source = | ||||
|       hmConfig.lib.file.mkOutOfStoreSymlink "${home}/.local/share/PrismLauncher"; | ||||
|   }; | ||||
| } | ||||
| @@ -1,17 +0,0 @@ | ||||
| { user, home }: | ||||
| { lib, pkgs, ... }: | ||||
| { | ||||
|   environment.persistence."/persist/state"."${home}/.local/share/proton" = { }; | ||||
|  | ||||
|   home-manager.users.${user}.home.packages = [ | ||||
|     (pkgs.writeShellApplication { | ||||
|       name = "proton-launch"; | ||||
|       runtimeInputs = with pkgs; [ coreutils ]; | ||||
|       runtimeEnv = { | ||||
|         PROTON = lib.makeSearchPathOutput "steamcompattool" "" [ pkgs.proton-ge-bin ]; | ||||
|         STEAM_RUN = lib.meta.getExe pkgs.steam-run; | ||||
|       }; | ||||
|       text = builtins.readFile ./proton-launch.sh; | ||||
|     }) | ||||
|   ]; | ||||
| } | ||||
| @@ -1,17 +0,0 @@ | ||||
| # shellcheck shell=bash | ||||
|  | ||||
| if [ "$#" -lt 1 ]; then | ||||
|   echo "Usage: $0 <executable-path> [args...]" | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| PROTON_DATA="$HOME/.local/share/proton" | ||||
|  | ||||
| exec="$(realpath "$1")" | ||||
| name="$(basename "$exec")" | ||||
| mkdir -p "$PROTON_DATA/$name" | ||||
|  | ||||
| export STEAM_COMPAT_DATA_PATH="$PROTON_DATA/$name" | ||||
| export STEAM_COMPAT_CLIENT_INSTALL_PATH="$PROTON" | ||||
|  | ||||
| "$STEAM_RUN" "$PROTON/proton" run "$exec" "${@:2}" >/dev/null 2>&1 & disown | ||||
| @@ -1,33 +0,0 @@ | ||||
| { user, home }: | ||||
| { pkgs, ... }: | ||||
| { | ||||
|   networking.firewall = { | ||||
|     allowedTCPPorts = [ 9757 ]; | ||||
|     allowedUDPPorts = [ 9757 ]; | ||||
|   }; | ||||
|  | ||||
|   services = { | ||||
|     udev.packages = with pkgs; [ android-udev-rules ]; | ||||
|  | ||||
|     avahi = { | ||||
|       enable = true; | ||||
|       openFirewall = true; | ||||
|       publish = { | ||||
|         enable = true; | ||||
|         userServices = true; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   environment = { | ||||
|     pathsToLink = [ "/share/openxr" ]; | ||||
|     etc."xdg/openxr/1/active_runtime.json".source = "${pkgs.wivrn}/share/openxr/1/openxr_wivrn.json"; | ||||
|  | ||||
|     persistence = { | ||||
|       "/persist/cache"."${home}/.cache/wivrn" = { }; | ||||
|       "/persist/state"."${home}/.config/wivrn" = { }; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   home-manager.users.${user}.home.packages = with pkgs; [ wivrn ]; | ||||
| } | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
| @@ -37,7 +40,8 @@ in | ||||
|     home = { | ||||
|       pointerCursor.gtk.enable = true; | ||||
|  | ||||
|       file = { | ||||
|       file = | ||||
|         { | ||||
|           ".icons/default/index.theme".enable = false; | ||||
|         } | ||||
|         // builtins.listToAttrs ( | ||||
|   | ||||
| @@ -1,21 +0,0 @@ | ||||
| { user, home }: | ||||
| { ... }: | ||||
| { | ||||
|   home-manager.users.${user}.services.hypridle = { | ||||
|     enable = true; | ||||
|     settings = { | ||||
|       listener = [ | ||||
|         { | ||||
|           timeout = 60; | ||||
|           on-timeout = "brightnessctl -s set 10%"; | ||||
|           on-resume = "brightnessctl -r"; | ||||
|         } | ||||
|         { | ||||
|           timeout = 300; | ||||
|           on-timeout = "hyprctl dispatch dpms off"; | ||||
|           on-resume = "hyprctl dispatch dpms on"; | ||||
|         } | ||||
|       ]; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
							
								
								
									
										78
									
								
								hosts/common/configs/user/gui/hyprland/auto-center.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								hosts/common/configs/user/gui/hyprland/auto-center.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | ||||
| diff --git a/src/Compositor.cpp b/src/Compositor.cpp | ||||
| index c6593923..b4d3aaea 100644 | ||||
| --- a/src/Compositor.cpp | ||||
| +++ b/src/Compositor.cpp | ||||
| @@ -2890,6 +2890,30 @@ void CCompositor::arrangeMonitors() { | ||||
|              case eAutoDirs::DIR_AUTO_LEFT: newPosition.x = maxXOffsetLeft - m->m_size.x; break; | ||||
|              case eAutoDirs::DIR_AUTO_RIGHT: | ||||
|              case eAutoDirs::DIR_AUTO_NONE: newPosition.x = maxXOffsetRight; break; | ||||
| +            case eAutoDirs::DIR_AUTO_CENTER_UP: { | ||||
| +                int width     = maxXOffsetRight - maxXOffsetLeft; | ||||
| +                newPosition.y = maxYOffsetUp - m->m_size.y; | ||||
| +                newPosition.x = maxXOffsetLeft + (width - m->m_size.x) / 2; | ||||
| +                break; | ||||
| +            } | ||||
| +            case eAutoDirs::DIR_AUTO_CENTER_DOWN: { | ||||
| +                int width     = maxXOffsetRight - maxXOffsetLeft; | ||||
| +                newPosition.y = maxYOffsetDown; | ||||
| +                newPosition.x = maxXOffsetLeft + (width - m->m_size.x) / 2; | ||||
| +                break; | ||||
| +            } | ||||
| +            case eAutoDirs::DIR_AUTO_CENTER_LEFT: { | ||||
| +                int height    = maxYOffsetDown - maxYOffsetUp; | ||||
| +                newPosition.x = maxXOffsetLeft - m->m_size.x; | ||||
| +                newPosition.y = maxYOffsetUp + (height - m->m_size.y) / 2; | ||||
| +                break; | ||||
| +            } | ||||
| +            case eAutoDirs::DIR_AUTO_CENTER_RIGHT: { | ||||
| +                int height    = maxYOffsetDown - maxYOffsetUp; | ||||
| +                newPosition.x = maxXOffsetRight; | ||||
| +                newPosition.y = maxYOffsetUp + (height - m->m_size.y) / 2; | ||||
| +                break; | ||||
| +            } | ||||
|              default: UNREACHABLE(); | ||||
|          } | ||||
|          Debug::log(LOG, "arrangeMonitors: {} auto {:j}", m->m_name, m->m_position); | ||||
| diff --git a/src/config/ConfigManager.cpp b/src/config/ConfigManager.cpp | ||||
| index f5f0bed3..3c988a53 100644 | ||||
| --- a/src/config/ConfigManager.cpp | ||||
| +++ b/src/config/ConfigManager.cpp | ||||
| @@ -2046,10 +2046,20 @@ std::optional<std::string> CConfigManager::handleMonitor(const std::string& comm | ||||
|              newrule.autoDir = eAutoDirs::DIR_AUTO_UP; | ||||
|          else if (ARGS[2] == "auto-down") | ||||
|              newrule.autoDir = eAutoDirs::DIR_AUTO_DOWN; | ||||
| +        else if (ARGS[2] == "auto-center-right") | ||||
| +            newrule.autoDir = eAutoDirs::DIR_AUTO_CENTER_RIGHT; | ||||
| +        else if (ARGS[2] == "auto-center-left") | ||||
| +            newrule.autoDir = eAutoDirs::DIR_AUTO_CENTER_LEFT; | ||||
| +        else if (ARGS[2] == "auto-center-up") | ||||
| +            newrule.autoDir = eAutoDirs::DIR_AUTO_CENTER_UP; | ||||
| +        else if (ARGS[2] == "auto-center-down") | ||||
| +            newrule.autoDir = eAutoDirs::DIR_AUTO_CENTER_DOWN; | ||||
|          else { | ||||
|              Debug::log(WARN, | ||||
|                         "Invalid auto direction. Valid options are 'auto'," | ||||
| -                       "'auto-up', 'auto-down', 'auto-left', and 'auto-right'."); | ||||
| +                       "'auto-up', 'auto-down', 'auto-left', 'auto-right'," | ||||
| +                       "'auto-center-up', 'auto-center-down'," | ||||
| +                       "'auto-center-left', and 'auto-center-right'."); | ||||
|              error += "invalid auto direction "; | ||||
|          } | ||||
|      } else { | ||||
| diff --git a/src/helpers/Monitor.hpp b/src/helpers/Monitor.hpp | ||||
| index 31777b0c..019a5547 100644 | ||||
| --- a/src/helpers/Monitor.hpp | ||||
| +++ b/src/helpers/Monitor.hpp | ||||
| @@ -25,7 +25,11 @@ enum eAutoDirs : uint8_t { | ||||
|      DIR_AUTO_UP, | ||||
|      DIR_AUTO_DOWN, | ||||
|      DIR_AUTO_LEFT, | ||||
| -    DIR_AUTO_RIGHT | ||||
| +    DIR_AUTO_RIGHT, | ||||
| +    DIR_AUTO_CENTER_UP, | ||||
| +    DIR_AUTO_CENTER_DOWN, | ||||
| +    DIR_AUTO_CENTER_LEFT, | ||||
| +    DIR_AUTO_CENTER_RIGHT | ||||
|  }; | ||||
|   | ||||
|  enum eCMType : uint8_t { | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
| @@ -9,7 +12,10 @@ | ||||
|   nixpkgs.overlays = [ | ||||
|     (final: prev: { | ||||
|       hyprland = prev.hyprland.overrideAttrs (oldAttrs: { | ||||
|         patches = oldAttrs.patches or [ ] ++ [ ./fix-maxwidth-resolution-mode.patch ]; | ||||
|         patches = oldAttrs.patches or [ ] ++ [ | ||||
|           ./auto-center.patch | ||||
|           ./maxwidth-resolution-mode.patch | ||||
|         ]; | ||||
|       }); | ||||
|     }) | ||||
|   ]; | ||||
| @@ -152,9 +158,6 @@ | ||||
|           no_update_news = true; | ||||
|           no_donation_nag = true; | ||||
|         }; | ||||
|  | ||||
|         # FIXME: https://github.com/ValveSoftware/gamescope/issues/1825 | ||||
|         debug.full_cm_proto = true; | ||||
|       }; | ||||
|  | ||||
|       extraConfig = "source = ./theme.conf"; | ||||
|   | ||||
| @@ -1,13 +0,0 @@ | ||||
| diff --git a/src/config/ConfigManager.cpp b/src/config/ConfigManager.cpp | ||||
| index 635c7977..80093c0d 100644 | ||||
| --- a/src/config/ConfigManager.cpp | ||||
| +++ b/src/config/ConfigManager.cpp | ||||
| @@ -2091,6 +2091,8 @@ bool CMonitorRuleParser::parseMode(const std::string& value) { | ||||
|          m_rule.resolution = Vector2D(-1, -1); | ||||
|      else if (value.starts_with("highres")) | ||||
|          m_rule.resolution = Vector2D(-1, -2); | ||||
| +    else if (value.starts_with("maxwidth")) | ||||
| +        m_rule.resolution = Vector2D(-1, -3); | ||||
|      else if (parseModeLine(value, m_rule.drmMode)) { | ||||
|          m_rule.resolution  = Vector2D(m_rule.drmMode.hdisplay, m_rule.drmMode.vdisplay); | ||||
|          m_rule.refreshRate = float(m_rule.drmMode.vrefresh) / 1000; | ||||
| @@ -0,0 +1,44 @@ | ||||
| diff --git a/src/config/ConfigManager.cpp b/src/config/ConfigManager.cpp | ||||
| index f5f0bed3..cfe39b70 100644 | ||||
| --- a/src/config/ConfigManager.cpp | ||||
| +++ b/src/config/ConfigManager.cpp | ||||
| @@ -2013,6 +2013,8 @@ std::optional<std::string> CConfigManager::handleMonitor(const std::string& comm | ||||
|          newrule.resolution = Vector2D(-1, -1); | ||||
|      } else if (ARGS[1].starts_with("highres")) { | ||||
|          newrule.resolution = Vector2D(-1, -2); | ||||
| +    } else if (ARGS[1].starts_with("maxwidth")) { | ||||
| +        newrule.resolution = Vector2D(-1, -3); | ||||
|      } else if (parseModeLine(ARGS[1], newrule.drmMode)) { | ||||
|          newrule.resolution  = Vector2D(newrule.drmMode.hdisplay, newrule.drmMode.vdisplay); | ||||
|          newrule.refreshRate = float(newrule.drmMode.vrefresh) / 1000; | ||||
| diff --git a/src/helpers/Monitor.cpp b/src/helpers/Monitor.cpp | ||||
| index 4dc0942d..72a221f5 100644 | ||||
| --- a/src/helpers/Monitor.cpp | ||||
| +++ b/src/helpers/Monitor.cpp | ||||
| @@ -515,7 +515,7 @@ bool CMonitor::applyMonitorRule(SMonitorRule* pMonitorRule, bool force) { | ||||
|      } else if (RULE->resolution == Vector2D(-1, -2)) { | ||||
|          requestedStr = "highres"; | ||||
|   | ||||
| -        // sort prioritizing resultion 1st and refresh rate 2nd, then add best 3 | ||||
| +        // sort prioritizing resolution 1st and refresh rate 2nd, then add best 3 | ||||
|          addBest3Modes([](auto const& a, auto const& b) { | ||||
|              if (a->pixelSize.x > b->pixelSize.x && a->pixelSize.y > b->pixelSize.y) | ||||
|                  return true; | ||||
| @@ -524,6 +524,17 @@ bool CMonitor::applyMonitorRule(SMonitorRule* pMonitorRule, bool force) { | ||||
|                  return true; | ||||
|              return false; | ||||
|          }); | ||||
| +    } else if (RULE->resolution == Vector2D(-1, -3)) { | ||||
| +        requestedStr = "maxwidth"; | ||||
| + | ||||
| +        // sort prioritizing widest resolution 1st and refresh rate 2nd, then add best 3 | ||||
| +        addBest3Modes([](auto const& a, auto const& b) { | ||||
| +            if (a->pixelSize.x > b->pixelSize.x) | ||||
| +                return true; | ||||
| +            if (a->pixelSize.x == b->pixelSize.x && std::round(a->refreshRate) > std::round(b->refreshRate)) | ||||
| +                return true; | ||||
| +            return false; | ||||
| +        }); | ||||
|      } else if (RULE->resolution != Vector2D()) { | ||||
|          // user requested mode | ||||
|          requestedStr = std::format("{:X0}@{:.2f}Hz", RULE->resolution, RULE->refreshRate); | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { lib, pkgs, ... }: | ||||
| { | ||||
|   home-manager.users.${user} = { | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   | ||||
| @@ -1,4 +1,7 @@ | ||||
| { user, home }: | ||||
| { | ||||
|   user ? throw "user argument is required", | ||||
|   home ? throw "home argument is required", | ||||
| }: | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
| @@ -21,12 +24,8 @@ in | ||||
|         inherit (hmConfig.theme.font) size; | ||||
|       }; | ||||
|  | ||||
|       settings = { | ||||
|         confirm_os_window_close = 0; | ||||
|         enable_audio_bell = false; | ||||
|       }; | ||||
|  | ||||
|       extraConfig = '' | ||||
|         confirm_os_window_close 0 | ||||
|         include theme.conf | ||||
|       ''; | ||||
|     }; | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user