Compare commits
	
		
			9 Commits
		
	
	
		
			ixion-buil
			...
			nix-overri
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0572cacd28 | |||
| ecf728bc11 | |||
| 5a59f98ebc | |||
| 5ab19d093a | |||
| 569141d227 | |||
| 48edbfdc4b | |||
| 50c62a4d3f | |||
| f4b518f806 | |||
| 7fffa45e4e | 
| @@ -13,9 +13,9 @@ set $term alacritty | |||||||
| set $menu wofi --term '$term' | set $menu wofi --term '$term' | ||||||
|  |  | ||||||
| ### Output configuration | ### Output configuration | ||||||
| output DP-3 pos 3840 0 res 1920x1080@59Hz | output DP-3 pos 1920 0 res 1920x1080@60Hz | ||||||
| output HDMI-A-1 pos 0 0 res 1920x1080@59Hz | output HDMI-A-1 pos 0 0 res 1920x1080@60Hz | ||||||
| output DP-2 pos 1920 0 res 1920x1080@60Hz | output DP-2 pos 3840 0 res 1920x1080@60Hz | ||||||
|  |  | ||||||
| ### Wallpaper | ### Wallpaper | ||||||
| output HDMI-A-1 bg ~/.wallpaper/.wallpaper.png fill | output HDMI-A-1 bg ~/.wallpaper/.wallpaper.png fill | ||||||
| @@ -25,19 +25,19 @@ output DP-3 bg ~/.wallpaper/.wallpaper.png fill | |||||||
| ### Workspace binding | ### Workspace binding | ||||||
|  |  | ||||||
| ## DP-3 bindings | ## DP-3 bindings | ||||||
| workspace 1 output DP-2 | workspace 1 output DP-3 | ||||||
| workspace 2 output DP-2 | workspace 2 output DP-3 | ||||||
| workspace 4 output DP-2 | workspace 4 output DP-3 | ||||||
| workspace 5 output DP-2 | workspace 5 output DP-3 | ||||||
|  |  | ||||||
| ## HDMI-A-1 bindings | ## HDMI-A-1 bindings | ||||||
| workspace 3 output HDMI-A-1 | workspace 3 output HDMI-A-1 | ||||||
| workspace 9 output HDMI-A-1 | workspace 9 output HDMI-A-1 | ||||||
|  |  | ||||||
| ## DP-2 bindings | ## DP-2 bindings | ||||||
| workspace 6 output DP-3 | workspace 6 output DP-2 | ||||||
| workspace 7 output DP-3 | workspace 7 output DP-2 | ||||||
| workspace 8 output DP-3 | workspace 8 output DP-2 | ||||||
|  |  | ||||||
| ### Colour options | ### Colour options | ||||||
| set $bg 	       #24283b | set $bg 	       #24283b | ||||||
|   | |||||||
							
								
								
									
										71
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										71
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -7,11 +7,11 @@ | |||||||
|         ] |         ] | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1757432263, |         "lastModified": 1759509947, | ||||||
|         "narHash": "sha256-qHn+/0+IOz5cG68BZUwL9BV3EO/e9eNKCjH3+N7wMdI=", |         "narHash": "sha256-4XifSIHfpJKcCf5bZZRhj8C4aCpjNBaE3kXr02s4rHU=", | ||||||
|         "owner": "lnl7", |         "owner": "lnl7", | ||||||
|         "repo": "nix-darwin", |         "repo": "nix-darwin", | ||||||
|         "rev": "1fef4404de4d1596aa5ab2bd68078370e1b9dcdb", |         "rev": "000eadb231812ad6ea6aebd7526974aaf4e79355", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -64,11 +64,11 @@ | |||||||
|         "zon2nix": "zon2nix" |         "zon2nix": "zon2nix" | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1759330332, |         "lastModified": 1761172581, | ||||||
|         "narHash": "sha256-ZKyOgOOm9Itjbc5xi89xMtw+cnnOFfl79zndPMTzKpU=", |         "narHash": "sha256-uX8FzMlRt15kvs4pPuOHZeQe1wztQXTEWOVtB2EwmB0=", | ||||||
|         "owner": "ghostty-org", |         "owner": "ghostty-org", | ||||||
|         "repo": "ghostty", |         "repo": "ghostty", | ||||||
|         "rev": "a5aff0e347b0016e2735d4ec4b4cdca96b5438d1", |         "rev": "bdbda2fd8380b440508246bcda0bf1198f6666e4", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -116,15 +116,15 @@ | |||||||
|     }, |     }, | ||||||
|     "nixpkgs": { |     "nixpkgs": { | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1748189127, |         "lastModified": 315532800, | ||||||
|         "narHash": "sha256-zRDR+EbbeObu4V2X5QCd2Bk5eltfDlCr5yvhBwUT6pY=", |         "narHash": "sha256-sV6pJNzFkiPc6j9Bi9JuHBnWdVhtKB/mHgVmMPvDFlk=", | ||||||
|         "rev": "7c43f080a7f28b2774f3b3f43234ca11661bf334", |         "rev": "82c2e0d6dde50b17ae366d2aa36f224dc19af469", | ||||||
|         "type": "tarball", |         "type": "tarball", | ||||||
|         "url": "https://releases.nixos.org/nixos/25.05/nixos-25.05.802491.7c43f080a7f2/nixexprs.tar.xz" |         "url": "https://releases.nixos.org/nixpkgs/nixpkgs-25.11pre877938.82c2e0d6dde5/nixexprs.tar.xz" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
|         "type": "tarball", |         "type": "tarball", | ||||||
|         "url": "https://channels.nixos.org/nixos-25.05/nixexprs.tar.xz" |         "url": "https://channels.nixos.org/nixpkgs-unstable/nixexprs.tar.xz" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "nixpkgs_2": { |     "nixpkgs_2": { | ||||||
| @@ -142,11 +142,11 @@ | |||||||
|     }, |     }, | ||||||
|     "nixpkgs_3": { |     "nixpkgs_3": { | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1759281824, |         "lastModified": 1761016216, | ||||||
|         "narHash": "sha256-FIBE1qXv9TKvSNwst6FumyHwCRH3BlWDpfsnqRDCll0=", |         "narHash": "sha256-G/iC4t/9j/52i/nm+0/4ybBmAF4hzR8CNHC75qEhjHo=", | ||||||
|         "owner": "nixos", |         "owner": "nixos", | ||||||
|         "repo": "nixpkgs", |         "repo": "nixpkgs", | ||||||
|         "rev": "5b5be50345d4113d04ba58c444348849f5585b4a", |         "rev": "481cf557888e05d3128a76f14c76397b7d7cc869", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
| @@ -156,18 +156,19 @@ | |||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "quadlet-nix": { |     "nixpkgs_4": { | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1758631655, |         "lastModified": 1744536153, | ||||||
|         "narHash": "sha256-EGeZ963L7xsNAY7snvP1JHQe7LWLVCM6f49+PzWjhEE=", |         "narHash": "sha256-awS2zRgF4uTwrOKwwiJcByDzDOdo3Q1rPZbiHQg/N38=", | ||||||
|         "owner": "SEIAROTg", |         "owner": "NixOS", | ||||||
|         "repo": "quadlet-nix", |         "repo": "nixpkgs", | ||||||
|         "rev": "2ebe01b175e2e1e6de3f172d23f0c3b88713eec9", |         "rev": "18dd725c29603f582cf1900e0d25f9f1063dbf11", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
|         "owner": "SEIAROTg", |         "owner": "NixOS", | ||||||
|         "repo": "quadlet-nix", |         "ref": "nixpkgs-unstable", | ||||||
|  |         "repo": "nixpkgs", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
| @@ -178,7 +179,25 @@ | |||||||
|         "home-manager": "home-manager", |         "home-manager": "home-manager", | ||||||
|         "nix-flatpak": "nix-flatpak", |         "nix-flatpak": "nix-flatpak", | ||||||
|         "nixpkgs": "nixpkgs_3", |         "nixpkgs": "nixpkgs_3", | ||||||
|         "quadlet-nix": "quadlet-nix" |         "rust-overlay": "rust-overlay" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "rust-overlay": { | ||||||
|  |       "inputs": { | ||||||
|  |         "nixpkgs": "nixpkgs_4" | ||||||
|  |       }, | ||||||
|  |       "locked": { | ||||||
|  |         "lastModified": 1761100675, | ||||||
|  |         "narHash": "sha256-LX3TCDBeNpCWTDXtGyRASVcLmRPChSli34bgHnZ1DCw=", | ||||||
|  |         "owner": "oxalica", | ||||||
|  |         "repo": "rust-overlay", | ||||||
|  |         "rev": "72161c6c53f6e3f8dadaf54b2204a5094c6a16ae", | ||||||
|  |         "type": "github" | ||||||
|  |       }, | ||||||
|  |       "original": { | ||||||
|  |         "owner": "oxalica", | ||||||
|  |         "repo": "rust-overlay", | ||||||
|  |         "type": "github" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "systems": { |     "systems": { | ||||||
| @@ -212,11 +231,11 @@ | |||||||
|         ] |         ] | ||||||
|       }, |       }, | ||||||
|       "locked": { |       "locked": { | ||||||
|         "lastModified": 1748261582, |         "lastModified": 1760401936, | ||||||
|         "narHash": "sha256-3i0IL3s18hdDlbsf0/E+5kyPRkZwGPbSFngq5eToiAA=", |         "narHash": "sha256-/zj5GYO5PKhBWGzbHbqT+ehY8EghuABdQ2WGfCwZpCQ=", | ||||||
|         "owner": "mitchellh", |         "owner": "mitchellh", | ||||||
|         "repo": "zig-overlay", |         "repo": "zig-overlay", | ||||||
|         "rev": "aafb1b093fb838f7a02613b719e85ec912914221", |         "rev": "365085b6652259753b598d43b723858184980bbe", | ||||||
|         "type": "github" |         "type": "github" | ||||||
|       }, |       }, | ||||||
|       "original": { |       "original": { | ||||||
|   | |||||||
							
								
								
									
										84
									
								
								flake.nix
									
									
									
									
									
								
							
							
						
						
									
										84
									
								
								flake.nix
									
									
									
									
									
								
							| @@ -12,7 +12,7 @@ | |||||||
|       inputs.nixpkgs.follows = "nixpkgs"; |       inputs.nixpkgs.follows = "nixpkgs"; | ||||||
|     }; |     }; | ||||||
|     ghostty.url = "github:ghostty-org/ghostty"; |     ghostty.url = "github:ghostty-org/ghostty"; | ||||||
|     quadlet-nix.url = "github:SEIAROTg/quadlet-nix"; |     rust-overlay.url = "github:oxalica/rust-overlay"; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   outputs = inputs @ { |   outputs = inputs @ { | ||||||
| @@ -22,27 +22,38 @@ | |||||||
|     darwin, |     darwin, | ||||||
|     home-manager, |     home-manager, | ||||||
|     ghostty, |     ghostty, | ||||||
|     quadlet-nix, |     rust-overlay, | ||||||
|     ... |     ... | ||||||
|   }: let |   }: let | ||||||
|     userName = "wyatt"; |     userName = "wyatt"; | ||||||
|     userEmail = "wyatt@wyattjmiller.com"; |     userEmail = "wyatt@wyattjmiller.com"; | ||||||
|  |     extraSpecialArgs = { | ||||||
|  |       inherit userName userEmail ghostty; | ||||||
|  |     }; | ||||||
|  |  | ||||||
|     # use this variable to take inputs and use them as arguments in your modules, this will be the common one |     myOverlays = { ... }: { | ||||||
|     customArgs = { |       nixpkgs.overlays = [ | ||||||
|       inherit userName userEmail ghostty quadlet-nix; |         rust-overlay.overlays.default | ||||||
|  |         self.common.overlays | ||||||
|  |       ]; | ||||||
|     }; |     }; | ||||||
|   in { |   in { | ||||||
|     meta = import ./meta; |     meta = import ./meta; | ||||||
|  |  | ||||||
|  |     common = { | ||||||
|  |       overlays = import ./modules/common/overlays.nix; | ||||||
|  |     }; | ||||||
|  |  | ||||||
|     # Primary laptop - MacBook Pro (2023, M3) |     # Primary laptop - MacBook Pro (2023, M3) | ||||||
|     darwinConfigurations."sephiroth" = darwin.lib.darwinSystem { |     darwinConfigurations."sephiroth" = darwin.lib.darwinSystem { | ||||||
|       system = "aarch64-darwin"; |       system = "aarch64-darwin"; | ||||||
|       specialArgs = customArgs // { |       specialArgs = { | ||||||
|  |         inherit userName userEmail ghostty; | ||||||
|         hostname = "sephiroth"; |         hostname = "sephiroth"; | ||||||
|         role = "devel"; |         role = "devel"; | ||||||
|       }; |       }; | ||||||
|       modules = [ |       modules = [ | ||||||
|  |         myOverlays | ||||||
|         ./modules/common |         ./modules/common | ||||||
|         ./modules/machine/sephiroth |         ./modules/machine/sephiroth | ||||||
|  |  | ||||||
| @@ -50,9 +61,8 @@ | |||||||
|         { |         { | ||||||
|           home-manager.useGlobalPkgs = true; |           home-manager.useGlobalPkgs = true; | ||||||
|           home-manager.useUserPackages = true; |           home-manager.useUserPackages = true; | ||||||
|           home-manager.extraSpecialArgs = customArgs // { |           home-manager.extraSpecialArgs = extraSpecialArgs; | ||||||
|             inherit home-manager; |           home-manager.backupFileExtension = "bak"; | ||||||
|           }; |  | ||||||
|           home-manager.users.${userName} = import ./home; |           home-manager.users.${userName} = import ./home; | ||||||
|         } |         } | ||||||
|       ]; |       ]; | ||||||
| @@ -61,11 +71,13 @@ | |||||||
|     # Primary desktop computer |     # Primary desktop computer | ||||||
|     nixosConfigurations."cloud" = nixpkgs.lib.nixosSystem { |     nixosConfigurations."cloud" = nixpkgs.lib.nixosSystem { | ||||||
|       system = "x86_64-linux"; |       system = "x86_64-linux"; | ||||||
|       specialArgs = customArgs // { |       specialArgs = { | ||||||
|  |         inherit userName userEmail ghostty; | ||||||
|         hostname = "cloud"; |         hostname = "cloud"; | ||||||
|         role = "devel"; |         role = "devel"; | ||||||
|       }; |       }; | ||||||
|       modules = [ |       modules = [ | ||||||
|  |         myOverlays | ||||||
|         nix-flatpak.nixosModules.nix-flatpak |         nix-flatpak.nixosModules.nix-flatpak | ||||||
|         ./modules/common |         ./modules/common | ||||||
|         ./modules/machine/cloud |         ./modules/machine/cloud | ||||||
| @@ -74,9 +86,8 @@ | |||||||
|         { |         { | ||||||
|           home-manager.useGlobalPkgs = true; |           home-manager.useGlobalPkgs = true; | ||||||
|           home-manager.useUserPackages = true; |           home-manager.useUserPackages = true; | ||||||
|           home-manager.extraSpecialArgs = customArgs // { |           home-manager.extraSpecialArgs = extraSpecialArgs; | ||||||
|             inherit home-manager; |           home-manager.backupFileExtension = "bak"; | ||||||
|           }; |  | ||||||
|           home-manager.users.${userName}.imports = [ |           home-manager.users.${userName}.imports = [ | ||||||
|             ./home |             ./home | ||||||
|           ]; |           ]; | ||||||
| @@ -87,11 +98,13 @@ | |||||||
|     # Apartment appliance server |     # Apartment appliance server | ||||||
|     nixosConfigurations."valefor" = nixpkgs.lib.nixosSystem { |     nixosConfigurations."valefor" = nixpkgs.lib.nixosSystem { | ||||||
|       system = "x86_64-linux"; |       system = "x86_64-linux"; | ||||||
|       specialArgs = customArgs // { |       specialArgs = { | ||||||
|  |         inherit userName userEmail; | ||||||
|         hostname = "valefor"; |         hostname = "valefor"; | ||||||
|         role = "server"; |         role = "server"; | ||||||
|       }; |       }; | ||||||
|       modules = [ |       modules = [ | ||||||
|  |         myOverlays | ||||||
|         ./modules/common |         ./modules/common | ||||||
|         ./modules/machine/valefor |         ./modules/machine/valefor | ||||||
|  |  | ||||||
| @@ -99,9 +112,8 @@ | |||||||
|         { |         { | ||||||
|           home-manager.useGlobalPkgs = true; |           home-manager.useGlobalPkgs = true; | ||||||
|           home-manager.useUserPackages = true; |           home-manager.useUserPackages = true; | ||||||
|           home-manager.extraSpecialArgs = customArgs // { |           home-manager.extraSpecialArgs = extraSpecialArgs; | ||||||
|             inherit home-manager; |           home-manager.backupFileExtension = "bak"; | ||||||
|           }; |  | ||||||
|           home-manager.users.${userName}.imports = [ |           home-manager.users.${userName}.imports = [ | ||||||
|             ./home |             ./home | ||||||
|           ]; |           ]; | ||||||
| @@ -112,25 +124,31 @@ | |||||||
|     # Storage, status, game, and media server |     # Storage, status, game, and media server | ||||||
|     nixosConfigurations."ixion" = nixpkgs.lib.nixosSystem { |     nixosConfigurations."ixion" = nixpkgs.lib.nixosSystem { | ||||||
|       system = "x86_64-linux"; |       system = "x86_64-linux"; | ||||||
|       specialArgs = customArgs // { |       specialArgs = { | ||||||
|  |         inherit userName userEmail; | ||||||
|         hostname = "ixion"; |         hostname = "ixion"; | ||||||
|         role = "server"; |         role = "server"; | ||||||
|       }; |       }; | ||||||
|       modules = [ |       # modules = [ | ||||||
|         quadlet-nix.nixosModules.quadlet |       #   myOverlays | ||||||
|         ./modules/common |       #   nix-flatpak.nixosModules.nix-flatpak | ||||||
|         ./modules/machine/ixion |       #   nix-ld.nixosModules.nix-ld | ||||||
|  |       #   ./modules/nixos/hardware-configuration.nix | ||||||
|         home-manager.nixosModules.home-manager |       #   ./modules/nix-core.nix | ||||||
|         { |       #   ./modules/nixos/configuration.nix | ||||||
|           home-manager.useGlobalPkgs = true; |       #   ./modules/host-users.nix | ||||||
|           home-manager.useUserPackages = true; |       # | ||||||
|           home-manager.extraSpecialArgs = customArgs; |       #   home-manager.nixosModules.home-manager | ||||||
|           home-manager.users.${userName}.imports = [ |       #   { | ||||||
|             ./home |       #     home-manager.useGlobalPkgs = true; | ||||||
|           ]; |       #     home-manager.useUserPackages = true; | ||||||
|         } |       #     home-manager.extraSpecialArgs = extraSpecialArgs; | ||||||
|       ]; |       #     home-manager.backupFileExtension = "bak"; | ||||||
|  |       #     home-manager.users.${userName}.imports = [ | ||||||
|  |       #       ./home | ||||||
|  |       #     ]; | ||||||
|  |       #   } | ||||||
|  |       # ]; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| {...}: { | { pkgs, ...}: { | ||||||
|   programs.atuin = { |   programs.atuin = { | ||||||
|     enable = true; |     enable = true; | ||||||
|     enableFishIntegration = true; |     enableFishIntegration = true; | ||||||
|  |     package = pkgs.atuinLatest; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ in { | |||||||
|     ./browser.nix |     ./browser.nix | ||||||
|     ./zellij.nix |     ./zellij.nix | ||||||
|     ./bat.nix |     ./bat.nix | ||||||
|  |     ./lazygit.nix | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   # Home Manager needs a bit of information about you and the |   # Home Manager needs a bit of information about you and the | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| {...}: { | { pkgs, ... }: { | ||||||
|   programs.lazygit = { |   programs.lazygit = { | ||||||
|     enable = true; |     enable = true; | ||||||
|  |     package = pkgs.lazygitLatest; | ||||||
|  |  | ||||||
|     settings = { |     settings = { | ||||||
|       gui.theme = { |       gui.theme = { | ||||||
|   | |||||||
| @@ -1,5 +1,4 @@ | |||||||
| { | { | ||||||
|   lib, |  | ||||||
|   pkgs, |   pkgs, | ||||||
|   ... |   ... | ||||||
| }: { | }: { | ||||||
| @@ -14,7 +13,6 @@ | |||||||
|  |  | ||||||
|     # utils |     # utils | ||||||
|     tmux |     tmux | ||||||
|     lazygit |  | ||||||
|     bottom |     bottom | ||||||
|     ripgrep |     ripgrep | ||||||
|     jq |     jq | ||||||
|   | |||||||
| @@ -8,6 +8,9 @@ | |||||||
|  |  | ||||||
|   # Allow unfree packages |   # Allow unfree packages | ||||||
|   nixpkgs.config.allowUnfree = true; |   nixpkgs.config.allowUnfree = true; | ||||||
|  |   nixpkgs.config.permittedInsecurePackages = [ | ||||||
|  |     "mbedtls-2.28.10" | ||||||
|  |   ]; | ||||||
|  |  | ||||||
|   nix.package = pkgs.nix; |   nix.package = pkgs.nix; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,12 +1,9 @@ | |||||||
| { | { ... }: { | ||||||
|   pkgs, |  | ||||||
|   lib, |  | ||||||
|   ... |  | ||||||
| }: { |  | ||||||
|   imports = [ |   imports = [ | ||||||
|     ./core.nix |     ./core.nix | ||||||
|     ./environment.nix |     ./environment.nix | ||||||
|     ./fonts.nix |     ./fonts.nix | ||||||
|  |     # ./overlays.nix | ||||||
|     ./users.nix |     ./users.nix | ||||||
|   ]; |   ]; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										50
									
								
								modules/common/overlays.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								modules/common/overlays.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | |||||||
|  | final: prev: let | ||||||
|  |   rust_1_90_0 = prev.rust-bin.stable."1.90.0".default; | ||||||
|  |   myRustPlatform = prev.makeRustPlatform { | ||||||
|  |     cargo = rust_1_90_0; | ||||||
|  |     rustc = rust_1_90_0; | ||||||
|  |   }; | ||||||
|  | in { | ||||||
|  |   lazygitLatest = prev.lazygit.overrideAttrs (_: rec { | ||||||
|  |     version = "0.55.1"; | ||||||
|  |     src = prev.fetchFromGitHub { | ||||||
|  |       owner = "jesseduffield"; | ||||||
|  |       repo = "lazygit"; | ||||||
|  |       rev = "v${version}"; | ||||||
|  |       hash = "sha256-UofhgILZhVXnYiGpb25m4Ct4sbu5pRmjVgj3oEf5Uyk="; | ||||||
|  |     }; | ||||||
|  |     vendorHash = null; | ||||||
|  |     subPackages = [ "." ]; | ||||||
|  |     ldflags = [ | ||||||
|  |       "-X main.version=${version}" | ||||||
|  |       "-X main.buildSource=nix" | ||||||
|  |     ]; | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   atuinLatest = (prev.atuin.override { | ||||||
|  |     rustPlatform = myRustPlatform; | ||||||
|  |   }).overrideAttrs (oldAttrs: rec { | ||||||
|  |     version = "18.10.0"; | ||||||
|  |  | ||||||
|  |     src = prev.fetchFromGitHub { | ||||||
|  |       owner = "atuinsh"; | ||||||
|  |       repo = "atuin"; | ||||||
|  |       rev = "v${version}"; | ||||||
|  |       hash = "sha256-bfSa3RtVXxHt3usDqqpE/oXKKDUZOrf+tD9uL59fr6M="; | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     cargoDeps = myRustPlatform.fetchCargoVendor { | ||||||
|  |       # name = "atuin-${version}-vendor.tar.gz"; | ||||||
|  |       inherit src; | ||||||
|  |       hash = "sha256-67ffivZVCly1GWA3fJ9mT8nGv2EGd6eCthbaIu/IW3M="; | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     preCheck = (oldAttrs.preCheck or "") + '' | ||||||
|  |       export HOME="$TMPDIR" | ||||||
|  |       export XDG_CONFIG_HOME="$TMPDIR/.config" | ||||||
|  |       export XDG_DATA_HOME="$TMPDIR/.local/share" | ||||||
|  |       export XDG_STATE_HOME="$TMPDIR/.local/state" | ||||||
|  |       mkdir -p "$XDG_CONFIG_HOME" "$XDG_DATA_HOME" "$XDG_STATE_HOME" | ||||||
|  |     ''; | ||||||
|  |   }); | ||||||
|  | } | ||||||
| @@ -18,7 +18,7 @@ | |||||||
| in { | in { | ||||||
|   imports = [ |   imports = [ | ||||||
|     (import ../../apps/flatpak.nix { |     (import ../../apps/flatpak.nix { | ||||||
|       inherit lib pkgs flatpakPackages; |       inherit lib pkgs flatpakPackages userName; | ||||||
|     }) |     }) | ||||||
|     ../../apps/gaming.nix |     ../../apps/gaming.nix | ||||||
|     ../../apps/appimage.nix |     ../../apps/appimage.nix | ||||||
|   | |||||||
| @@ -12,24 +12,24 @@ | |||||||
|     (modulesPath + "/installer/scan/not-detected.nix") |     (modulesPath + "/installer/scan/not-detected.nix") | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   boot.initrd.availableKernelModules = ["nvme" "xhci_pci" "ahci" "usb_storage" "usbhid" "sd_mod"]; |   boot.initrd.availableKernelModules = ["nvme" "xhci_pci" "thunderbolt" "ahci" "usb_storage" "usbhid" "sd_mod"]; | ||||||
|   boot.initrd.kernelModules = []; |   boot.initrd.kernelModules = []; | ||||||
|   boot.kernelModules = ["kvm-amd"]; |   boot.kernelModules = ["kvm-amd"]; | ||||||
|   boot.extraModulePackages = []; |   boot.extraModulePackages = []; | ||||||
|  |  | ||||||
|   fileSystems."/" = { |   fileSystems."/" = { | ||||||
|     device = "/dev/disk/by-label/COMPUTER"; |     device = "/dev/disk/by-uuid/f8f39aae-61d2-437d-a8e1-01066bbb3c5c"; | ||||||
|     fsType = "xfs"; |     fsType = "xfs"; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   fileSystems."/boot" = { |   fileSystems."/boot" = { | ||||||
|     device = "/dev/disk/by-label/BOOT"; |     device = "/dev/disk/by-uuid/B72F-087F"; | ||||||
|     fsType = "vfat"; |     fsType = "vfat"; | ||||||
|     options = ["fmask=0022" "dmask=0022"]; |     options = ["fmask=0022" "dmask=0022"]; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   swapDevices = [ |   swapDevices = [ | ||||||
|     {device = "/dev/disk/by-label/SWAP";} |     {device = "/dev/disk/by-uuid/6d6bcc02-20a9-4ae8-9c1e-5124fb2b2634";} | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   # Enables DHCP on each ethernet and wireless interface. In case of scripted networking |   # Enables DHCP on each ethernet and wireless interface. In case of scripted networking | ||||||
|   | |||||||
| @@ -1,84 +0,0 @@ | |||||||
| { |  | ||||||
|   pkgs, |  | ||||||
|   userName, |  | ||||||
|   ... |  | ||||||
| }: { |  | ||||||
|   imports = [ |  | ||||||
|     ../../pwrMgmt |  | ||||||
|     ../../networking/core.nix |  | ||||||
|     ../../virtualization/podman.nix |  | ||||||
|     ../../virtualization/quadlet.nix |  | ||||||
|     ../../virtualization/hardware.nix |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   # Enable flakes for NixOS |  | ||||||
|   nix.settings.experimental-features = ["nix-command" "flakes"]; |  | ||||||
|  |  | ||||||
|   # Custom kernel/boot stuff |  | ||||||
|   boot = { |  | ||||||
|     kernelPackages = pkgs.linuxPackages_latest; |  | ||||||
|     loader = { |  | ||||||
|       systemd-boot.enable = true; |  | ||||||
|       efi.canTouchEfiVariables = true; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   # Enable Polkit |  | ||||||
|   security.polkit.enable = true; |  | ||||||
|  |  | ||||||
|   # Make sure Bluetooth is off! |  | ||||||
|   hardware.bluetooth.enable = false; |  | ||||||
|  |  | ||||||
|   # Set your timezone |  | ||||||
|   time.timeZone = "America/Detroit"; |  | ||||||
|  |  | ||||||
|   # Power management module |  | ||||||
|   pwrMgmt = { |  | ||||||
|     enable = true; |  | ||||||
|     cpuFreqGovernor = "performance"; |  | ||||||
|     powertop.enable = false; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   # Podman module (see ../../virtualization/podman.nix) |  | ||||||
|   podman = { |  | ||||||
|     enable = true; |  | ||||||
|     extraPackages = with pkgs; [ |  | ||||||
|       docker-credential-helpers |  | ||||||
|       toolbox |  | ||||||
|       cosign |  | ||||||
|       crane |  | ||||||
|       podman-tui |  | ||||||
|     ]; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   # Core networking module (see ../../networking/core.nix) |  | ||||||
|   network = { |  | ||||||
|     firewall.enable = true; |  | ||||||
|     networkManager.enable = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   programs = { |  | ||||||
|     # Enable GnuPG |  | ||||||
|     gnupg.agent = { |  | ||||||
|       enable = true; |  | ||||||
|       enableSSHSupport = true; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     # Enable SUID wrappers (some programs need them) |  | ||||||
|     mtr.enable = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   users.users.${userName}.extraGroups = ["wheel" "video" "podman" "network"]; |  | ||||||
|  |  | ||||||
|   services = { |  | ||||||
|     # Enable OpenSSH |  | ||||||
|     openssh.enable = true; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   # Install packages to be installed system-wide |  | ||||||
|   environment.systemPackages = with pkgs; [ |  | ||||||
|     wireguard-tools |  | ||||||
|   ]; |  | ||||||
|  |  | ||||||
|   system.stateVersion = "25.05"; |  | ||||||
| } |  | ||||||
| @@ -1,6 +0,0 @@ | |||||||
| {...}: { |  | ||||||
|   imports = [ |  | ||||||
|     ./configuration.nix |  | ||||||
|     ./hardware-configuration.nix |  | ||||||
|   ]; |  | ||||||
| } |  | ||||||
| @@ -1,46 +0,0 @@ | |||||||
| # --- DO NOT USE --- |  | ||||||
| # |  | ||||||
| # this is copied from ../valefor/hardware-configuration.nix |  | ||||||
| # generate a new hardware-configuration.nix before using this! |  | ||||||
| # |  | ||||||
| # ------------------ |  | ||||||
| #  |  | ||||||
| # Do not modify this file!  It was generated by ‘nixos-generate-config’ |  | ||||||
| # and may be overwritten by future invocations.  Please make changes |  | ||||||
| # to /etc/nixos/configuration.nix instead. |  | ||||||
| { config, lib, pkgs, modulesPath, ... }: |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   imports = |  | ||||||
|     [ (modulesPath + "/installer/scan/not-detected.nix") |  | ||||||
|     ]; |  | ||||||
|  |  | ||||||
|   boot.initrd.availableKernelModules = [ "xhci_pci" "ahci" "usb_storage" "usbhid" "sd_mod" ]; |  | ||||||
|   boot.initrd.kernelModules = [ ]; |  | ||||||
|   boot.kernelModules = [ "kvm-intel" ]; |  | ||||||
|   boot.extraModulePackages = [ ]; |  | ||||||
|  |  | ||||||
|   fileSystems."/" = |  | ||||||
|     { device = "/dev/disk/by-uuid/ff89bde1-4b33-4277-b649-b92700b2406c"; |  | ||||||
|       fsType = "xfs"; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|   fileSystems."/boot" = |  | ||||||
|     { device = "/dev/disk/by-uuid/3A4B-6866"; |  | ||||||
|       fsType = "vfat"; |  | ||||||
|       options = [ "fmask=0022" "dmask=0022" ]; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|   swapDevices = [ ]; |  | ||||||
|  |  | ||||||
|   # Enables DHCP on each ethernet and wireless interface. In case of scripted networking |  | ||||||
|   # (the default) this is the recommended approach. When using systemd-networkd it's |  | ||||||
|   # still possible to use this option, but it's recommended to use it in conjunction |  | ||||||
|   # with explicit per-interface declarations with `networking.interfaces.<interface>.useDHCP`. |  | ||||||
|   networking.useDHCP = lib.mkDefault true; |  | ||||||
|   # networking.interfaces.eno1.useDHCP = lib.mkDefault true; |  | ||||||
|   # networking.interfaces.wlp1s0.useDHCP = lib.mkDefault true; |  | ||||||
|  |  | ||||||
|   nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; |  | ||||||
|   hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; |  | ||||||
| } |  | ||||||
| @@ -1,12 +1,12 @@ | |||||||
| # Power management modules | # Power management modules | ||||||
|  |  | ||||||
| This directory houses my own custom defined power management settings as NixOS modules. These are set in the machine-specific configurations (typically). | This directory houses my own custom defined power management settings. These are set in the machine-specific configurations (typically). | ||||||
|  |  | ||||||
| ## Examples | ## Examples | ||||||
|  |  | ||||||
| Given that this configuration is in the `machine/<hostname>` directory (where hostname is the name of the computer your configuring): | Given that this configuration is in the `machine/<hostname>` directory (where hostname is the name of the computer your configuring): | ||||||
|  |  | ||||||
| ### Desktop/server configuration | ### Desktop configuration | ||||||
|  |  | ||||||
| ```nix | ```nix | ||||||
|   imports = [ |   imports = [ | ||||||
|   | |||||||
| @@ -1,7 +1,16 @@ | |||||||
| {pkgs, ...}: { | { lib, pkgs, userName, ...}: { | ||||||
|   services.shairport-sync = { |   services.shairport-sync = { | ||||||
|     enable = pkgs.stdenv.isLinux; |     enable = pkgs.stdenv.isLinux; | ||||||
|     openFirewall = pkgs.stdenv.isLinux; |     openFirewall = pkgs.stdenv.isLinux; | ||||||
|     arguments = "-v -o pw"; |     # arguments = "-v -o pa"; | ||||||
|  |   }; | ||||||
|  |  | ||||||
|  |   systemd.services.shairport-sync = { | ||||||
|  |     serviceConfig = { | ||||||
|  |       User = lib.mkForce "${userName}"; | ||||||
|  |     }; | ||||||
|  |     environment = { | ||||||
|  |       XDG_RUNTIME_DIR = "/run/user/1000"; | ||||||
|  |     }; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -40,13 +40,7 @@ Example: | |||||||
|   }; |   }; | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| To get a full, comprehensive list of what you can do with the podman module, please check out [podman.nix](./podman.nix)! | To get a full, comprehensive list of what you can do with the podman module, please check out (podman.nix)[./podman.nix]! | ||||||
|  |  | ||||||
| ### Podman Quadlets |  | ||||||
|  |  | ||||||
| This is a wrapper around a project called [`quadlet-nix`](https://github.com/SEIAROTg/quadlet-nix), a way of defining systemd services as containers with Nix! Since I have existing services running inside of containers and don't want to risk breaking _everything_ that I have running, I figured this would be a safe, transitionary approach to handle this. |  | ||||||
|  |  | ||||||
| This is still a work-in-progress, check back soon on progress on this. |  | ||||||
|  |  | ||||||
| ## Kubernetes | ## Kubernetes | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,47 +0,0 @@ | |||||||
| # ---------------------- |  | ||||||
| # Wrapper for defining Quadlets in Nix via quadlet-nix |  | ||||||
| # |  | ||||||
| # Still WIP |  | ||||||
| # ---------------------- |  | ||||||
| { |  | ||||||
|   config, |  | ||||||
|   lib, |  | ||||||
|   ... |  | ||||||
| }:  |  | ||||||
| let |  | ||||||
|   cfg = config.quadlet; |  | ||||||
| in { |  | ||||||
|   options = { |  | ||||||
|     quadlet = { |  | ||||||
|       enable = lib.mkEnableOption "Enable Podman's Quadlet systemd integration"; |  | ||||||
|        |  | ||||||
|       autoUpdate = { |  | ||||||
|         enable = lib.mkEnableOption "Enable the auto update mechanism"; |  | ||||||
|          |  | ||||||
|         calendar = lib.mkOption { |  | ||||||
|           type = lib.types.str; |  | ||||||
|           default = "*-*-* 03:30:00"; |  | ||||||
|           description = "When the auto update mechanism is triggered, the calendar option will tell the auto update when to start"; |  | ||||||
|         }; |  | ||||||
|       }; |  | ||||||
|        |  | ||||||
|       extraPackages = lib.mkOption { |  | ||||||
|         type = lib.types.listOf lib.types.package; |  | ||||||
|         default = []; |  | ||||||
|         description = "Additional container-related packages to install (these likely will be installed with Podman though)"; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|   }; |  | ||||||
|  |  | ||||||
|   config = lib.mkIf cfg.enable { |  | ||||||
|     virtualisation.quadlet = { |  | ||||||
|       enable = true; |  | ||||||
|       autoUpdate = { |  | ||||||
|         enable = cfg.autoUpdate.enable; |  | ||||||
|         calendar = cfg.autoUpdate.calendar; |  | ||||||
|       }; |  | ||||||
|     }; |  | ||||||
|      |  | ||||||
|     environment.systemPackages = cfg.extraPackages; |  | ||||||
|   }; |  | ||||||
| } |  | ||||||
		Reference in New Issue
	
	Block a user