fix(ops/nixos): don't set nixpkgs.pkgs explicitly
As soon as you pass in an already-instantiated nixpkgs version, it will cause nixpkgs.hostPlatform etc. to be not applied. This means it's impossible to describe the architecture of a VM closure you're deploying, and have it deviate from the machine you're evaluating from, making it quite hard to deploy that x86_64-linux machine from aarch64-linux (where I'm writing this commit message from). Drop explicitly passing in nixpkgs.path, and set nixpkgs.hostPlatform explicitly for all remaining system configurations in the repository where not already set. Change-Id: Ie2a596e0826da54674b4f02fcd8fed3569fee0a4 Reviewed-on: https://cl.snix.dev/c/snix/+/30104 Autosubmit: Florian Klink <flokli@flokli.de> Tested-by: besadii Reviewed-by: Ryan Lahfa <masterancpp@gmail.com>
This commit is contained in:
		
							parent
							
								
									2bdb497c85
								
							
						
					
					
						commit
						a59e95a287
					
				
					 5 changed files with 9 additions and 3 deletions
				
			
		|  | @ -12,6 +12,8 @@ in | ||||||
|     (depot.third_party.agenix.src + "/modules/age.nix") |     (depot.third_party.agenix.src + "/modules/age.nix") | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|  |   nixpkgs.hostPlatform = "x86_64-linux"; | ||||||
|  | 
 | ||||||
|   # Machine model taken from project Floral. |   # Machine model taken from project Floral. | ||||||
|   boot.isContainer = true; |   boot.isContainer = true; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -25,6 +25,8 @@ in | ||||||
|     (depot.third_party.disko.src + "/module.nix") |     (depot.third_party.disko.src + "/module.nix") | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|  |   nixpkgs.hostPlatform = "x86_64-linux"; | ||||||
|  | 
 | ||||||
|   infra.hardware.hetzner-cloud = { |   infra.hardware.hetzner-cloud = { | ||||||
|     enable = true; |     enable = true; | ||||||
|     ipv6 = "2a01:4f8:c013:4a58::1/64"; |     ipv6 = "2a01:4f8:c013:4a58::1/64"; | ||||||
|  |  | ||||||
|  | @ -27,6 +27,8 @@ in | ||||||
|     (depot.third_party.disko.src + "/module.nix") |     (depot.third_party.disko.src + "/module.nix") | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|  |   nixpkgs.hostPlatform = "x86_64-linux"; | ||||||
|  | 
 | ||||||
|   infra.hardware.hetzner-cloud = { |   infra.hardware.hetzner-cloud = { | ||||||
|     enable = true; |     enable = true; | ||||||
|     ipv6 = "2a01:4f8:c013:3e62::1/64"; |     ipv6 = "2a01:4f8:c013:3e62::1/64"; | ||||||
|  |  | ||||||
|  | @ -1,12 +1,10 @@ | ||||||
| # Helper functions for instantiating depot-compatible NixOS machines. | # Helper functions for instantiating depot-compatible NixOS machines. | ||||||
| { depot, lib, pkgs, ... }@args: | { depot, lib, pkgs, ... }@args: | ||||||
| 
 | 
 | ||||||
| let inherit (lib) findFirst isAttrs; | let inherit (lib) findFirst; | ||||||
| in rec { | in rec { | ||||||
|   # This provides our standard set of arguments to all NixOS modules. |   # This provides our standard set of arguments to all NixOS modules. | ||||||
|   baseModule = { ... }: { |   baseModule = { ... }: { | ||||||
|     # Ensure that pkgs == third_party.nix |  | ||||||
|     nixpkgs.pkgs = depot.third_party.nixpkgs; |  | ||||||
|     nix.nixPath = |     nix.nixPath = | ||||||
|       let |       let | ||||||
|         # Due to nixpkgsBisectPath, pkgs.path is not always in the nix store |         # Due to nixpkgsBisectPath, pkgs.path is not always in the nix store | ||||||
|  |  | ||||||
|  | @ -6,6 +6,8 @@ | ||||||
|     ../profiles/archivist.nix |     ../profiles/archivist.nix | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|  |   nixpkgs.hostPlatform = "x86_64-linux"; | ||||||
|  | 
 | ||||||
|   systemd.timers.parse-bucket-logs = { |   systemd.timers.parse-bucket-logs = { | ||||||
|     wantedBy = [ "multi-user.target" ]; |     wantedBy = [ "multi-user.target" ]; | ||||||
|     timerConfig.OnCalendar = "*-*-* 03:00:00 UTC"; |     timerConfig.OnCalendar = "*-*-* 03:00:00 UTC"; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue