Compare commits
	
		
			3 Commits
		
	
	
		
			nix-overri
			...
			obsidian
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 45de738d59 | |||
| e6ae0c4c35 | |||
| 739f2e125f | 
| @@ -13,9 +13,9 @@ set $term alacritty | ||||
| set $menu wofi --term '$term' | ||||
|  | ||||
| ### Output configuration | ||||
| output DP-3 pos 1920 0 res 1920x1080@60Hz | ||||
| output HDMI-A-1 pos 0 0 res 1920x1080@60Hz | ||||
| output DP-2 pos 3840 0 res 1920x1080@60Hz | ||||
| output DP-3 pos 3840 0 res 1920x1080@59Hz | ||||
| output HDMI-A-1 pos 0 0 res 1920x1080@59Hz | ||||
| output DP-2 pos 1920 0 res 1920x1080@60Hz | ||||
|  | ||||
| ### Wallpaper | ||||
| output HDMI-A-1 bg ~/.wallpaper/.wallpaper.png fill | ||||
| @@ -25,19 +25,19 @@ output DP-3 bg ~/.wallpaper/.wallpaper.png fill | ||||
| ### Workspace binding | ||||
|  | ||||
| ## DP-3 bindings | ||||
| workspace 1 output DP-3 | ||||
| workspace 2 output DP-3 | ||||
| workspace 4 output DP-3 | ||||
| workspace 5 output DP-3 | ||||
| workspace 1 output DP-2 | ||||
| workspace 2 output DP-2 | ||||
| workspace 4 output DP-2 | ||||
| workspace 5 output DP-2 | ||||
|  | ||||
| ## HDMI-A-1 bindings | ||||
| workspace 3 output HDMI-A-1 | ||||
| workspace 9 output HDMI-A-1 | ||||
|  | ||||
| ## DP-2 bindings | ||||
| workspace 6 output DP-2 | ||||
| workspace 7 output DP-2 | ||||
| workspace 8 output DP-2 | ||||
| workspace 6 output DP-3 | ||||
| workspace 7 output DP-3 | ||||
| workspace 8 output DP-3 | ||||
|  | ||||
| ### Colour options | ||||
| set $bg 	#24283b | ||||
|   | ||||
							
								
								
									
										107
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										107
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -7,11 +7,11 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1759509947, | ||||
|         "narHash": "sha256-4XifSIHfpJKcCf5bZZRhj8C4aCpjNBaE3kXr02s4rHU=", | ||||
|         "lastModified": 1749744770, | ||||
|         "narHash": "sha256-MEM9XXHgBF/Cyv1RES1t6gqAX7/tvayBC1r/KPyK1ls=", | ||||
|         "owner": "lnl7", | ||||
|         "repo": "nix-darwin", | ||||
|         "rev": "000eadb231812ad6ea6aebd7526974aaf4e79355", | ||||
|         "rev": "536f951efb1ccda9b968e3c9dee39fbeb6d3fdeb", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @@ -64,11 +64,11 @@ | ||||
|         "zon2nix": "zon2nix" | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1761172581, | ||||
|         "narHash": "sha256-uX8FzMlRt15kvs4pPuOHZeQe1wztQXTEWOVtB2EwmB0=", | ||||
|         "lastModified": 1753816554, | ||||
|         "narHash": "sha256-eyFfBXb5IJaNTGTdkjpWKSMTs8wiJ0i+9n5jUKtVFa4=", | ||||
|         "owner": "ghostty-org", | ||||
|         "repo": "ghostty", | ||||
|         "rev": "bdbda2fd8380b440508246bcda0bf1198f6666e4", | ||||
|         "rev": "c78d32074ebab14d2060e5cd3c7667cbe37ab8ee", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @@ -84,11 +84,11 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1758463745, | ||||
|         "narHash": "sha256-uhzsV0Q0I9j2y/rfweWeGif5AWe0MGrgZ/3TjpDYdGA=", | ||||
|         "lastModified": 1753592768, | ||||
|         "narHash": "sha256-oV695RvbAE4+R9pcsT9shmp6zE/+IZe6evHWX63f2Qg=", | ||||
|         "owner": "nix-community", | ||||
|         "repo": "home-manager", | ||||
|         "rev": "3b955f5f0a942f9f60cdc9cacb7844335d0f21c3", | ||||
|         "rev": "fc3add429f21450359369af74c2375cb34a2d204", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @@ -116,37 +116,24 @@ | ||||
|     }, | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 315532800, | ||||
|         "narHash": "sha256-sV6pJNzFkiPc6j9Bi9JuHBnWdVhtKB/mHgVmMPvDFlk=", | ||||
|         "rev": "82c2e0d6dde50b17ae366d2aa36f224dc19af469", | ||||
|         "lastModified": 1748189127, | ||||
|         "narHash": "sha256-zRDR+EbbeObu4V2X5QCd2Bk5eltfDlCr5yvhBwUT6pY=", | ||||
|         "rev": "7c43f080a7f28b2774f3b3f43234ca11661bf334", | ||||
|         "type": "tarball", | ||||
|         "url": "https://releases.nixos.org/nixpkgs/nixpkgs-25.11pre877938.82c2e0d6dde5/nixexprs.tar.xz" | ||||
|         "url": "https://releases.nixos.org/nixos/25.05/nixos-25.05.802491.7c43f080a7f2/nixexprs.tar.xz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://channels.nixos.org/nixpkgs-unstable/nixexprs.tar.xz" | ||||
|         "url": "https://channels.nixos.org/nixos-25.05/nixexprs.tar.xz" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs_2": { | ||||
|       "locked": { | ||||
|         "lastModified": 1758360447, | ||||
|         "narHash": "sha256-XDY3A83bclygHDtesRoaRTafUd80Q30D/Daf9KSG6bs=", | ||||
|         "rev": "8eaee110344796db060382e15d3af0a9fc396e0e", | ||||
|         "type": "tarball", | ||||
|         "url": "https://releases.nixos.org/nixos/unstable/nixos-25.11pre864002.8eaee1103447/nixexprs.tar.xz" | ||||
|       }, | ||||
|       "original": { | ||||
|         "type": "tarball", | ||||
|         "url": "https://channels.nixos.org/nixos-unstable/nixexprs.tar.xz" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs_3": { | ||||
|       "locked": { | ||||
|         "lastModified": 1761016216, | ||||
|         "narHash": "sha256-G/iC4t/9j/52i/nm+0/4ybBmAF4hzR8CNHC75qEhjHo=", | ||||
|         "lastModified": 1753749649, | ||||
|         "narHash": "sha256-+jkEZxs7bfOKfBIk430K+tK9IvXlwzqQQnppC2ZKFj4=", | ||||
|         "owner": "nixos", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "481cf557888e05d3128a76f14c76397b7d7cc869", | ||||
|         "rev": "1f08a4df998e21f4e8be8fb6fbf61d11a1a5076a", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @@ -156,48 +143,13 @@ | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs_4": { | ||||
|       "locked": { | ||||
|         "lastModified": 1744536153, | ||||
|         "narHash": "sha256-awS2zRgF4uTwrOKwwiJcByDzDOdo3Q1rPZbiHQg/N38=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "18dd725c29603f582cf1900e0d25f9f1063dbf11", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "NixOS", | ||||
|         "ref": "nixpkgs-unstable", | ||||
|         "repo": "nixpkgs", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "root": { | ||||
|       "inputs": { | ||||
|         "darwin": "darwin", | ||||
|         "ghostty": "ghostty", | ||||
|         "home-manager": "home-manager", | ||||
|         "nix-flatpak": "nix-flatpak", | ||||
|         "nixpkgs": "nixpkgs_3", | ||||
|         "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" | ||||
|         "nixpkgs": "nixpkgs_2" | ||||
|       } | ||||
|     }, | ||||
|     "systems": { | ||||
| @@ -231,11 +183,11 @@ | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1760401936, | ||||
|         "narHash": "sha256-/zj5GYO5PKhBWGzbHbqT+ehY8EghuABdQ2WGfCwZpCQ=", | ||||
|         "lastModified": 1748261582, | ||||
|         "narHash": "sha256-3i0IL3s18hdDlbsf0/E+5kyPRkZwGPbSFngq5eToiAA=", | ||||
|         "owner": "mitchellh", | ||||
|         "repo": "zig-overlay", | ||||
|         "rev": "365085b6652259753b598d43b723858184980bbe", | ||||
|         "rev": "aafb1b093fb838f7a02613b719e85ec912914221", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
| @@ -246,20 +198,27 @@ | ||||
|     }, | ||||
|     "zon2nix": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": "nixpkgs_2" | ||||
|         "flake-utils": [ | ||||
|           "ghostty", | ||||
|           "flake-utils" | ||||
|         ], | ||||
|         "nixpkgs": [ | ||||
|           "ghostty", | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1758405547, | ||||
|         "narHash": "sha256-WgaDgvIZMPvlZcZrpPMjkaalTBnGF2lTG+62znXctWM=", | ||||
|         "lastModified": 1742104771, | ||||
|         "narHash": "sha256-LhidlyEA9MP8jGe1rEnyjGFCzLLgCdDpYeWggibayr0=", | ||||
|         "owner": "jcollie", | ||||
|         "repo": "zon2nix", | ||||
|         "rev": "bf983aa90ff169372b9fa8c02e57ea75e0b42245", | ||||
|         "rev": "56c159be489cc6c0e73c3930bd908ddc6fe89613", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "jcollie", | ||||
|         "repo": "zon2nix", | ||||
|         "rev": "bf983aa90ff169372b9fa8c02e57ea75e0b42245", | ||||
|         "rev": "56c159be489cc6c0e73c3930bd908ddc6fe89613", | ||||
|         "type": "github" | ||||
|       } | ||||
|     } | ||||
|   | ||||
							
								
								
									
										32
									
								
								flake.nix
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								flake.nix
									
									
									
									
									
								
							| @@ -2,27 +2,32 @@ | ||||
|   description = "Wyatt's nix configuration suite"; | ||||
|   inputs = { | ||||
|     nixpkgs.url = "github:nixos/nixpkgs/nixos-25.05"; | ||||
|     nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable"; | ||||
|     nix-flatpak.url = "github:gmodena/nix-flatpak/?ref=v0.6.0"; | ||||
|     home-manager = { | ||||
|       url = "github:nix-community/home-manager/release-25.05"; | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|     home-manager-unstable = { | ||||
|       url = "https://github.com/nix-community/home-manager"; | ||||
|       inputs.nixpkgs.follows = "nixpkgs-unstable"; | ||||
|     }; | ||||
|     darwin = { | ||||
|       url = "github:lnl7/nix-darwin/nix-darwin-25.05"; | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|     ghostty.url = "github:ghostty-org/ghostty"; | ||||
|     rust-overlay.url = "github:oxalica/rust-overlay"; | ||||
|   }; | ||||
|  | ||||
|   outputs = inputs @ { | ||||
|     self, | ||||
|     nixpkgs, | ||||
|     nixpkgs-unstable, | ||||
|     nix-flatpak, | ||||
|     darwin, | ||||
|     home-manager, | ||||
|     home-manager-unstable, | ||||
|     ghostty, | ||||
|     rust-overlay, | ||||
|     ... | ||||
|   }: let | ||||
|     userName = "wyatt"; | ||||
| @@ -31,19 +36,12 @@ | ||||
|       inherit userName userEmail ghostty; | ||||
|     }; | ||||
|  | ||||
|     myOverlays = { ... }: { | ||||
|       nixpkgs.overlays = [ | ||||
|         rust-overlay.overlays.default | ||||
|         self.common.overlays | ||||
|       ]; | ||||
|     obsidianOverlay = final: prev: { | ||||
|       obsidian = nixpkgs-unstable.legacyPackages.${final.system}.obsidian; | ||||
|     }; | ||||
|   in { | ||||
|     meta = import ./meta; | ||||
|  | ||||
|     common = { | ||||
|       overlays = import ./modules/common/overlays.nix; | ||||
|     }; | ||||
|  | ||||
|     # Primary laptop - MacBook Pro (2023, M3) | ||||
|     darwinConfigurations."sephiroth" = darwin.lib.darwinSystem { | ||||
|       system = "aarch64-darwin"; | ||||
| @@ -53,7 +51,6 @@ | ||||
|         role = "devel"; | ||||
|       }; | ||||
|       modules = [ | ||||
|         myOverlays | ||||
|         ./modules/common | ||||
|         ./modules/machine/sephiroth | ||||
|  | ||||
| @@ -62,7 +59,6 @@ | ||||
|           home-manager.useGlobalPkgs = true; | ||||
|           home-manager.useUserPackages = true; | ||||
|           home-manager.extraSpecialArgs = extraSpecialArgs; | ||||
|           home-manager.backupFileExtension = "bak"; | ||||
|           home-manager.users.${userName} = import ./home; | ||||
|         } | ||||
|       ]; | ||||
| @@ -77,17 +73,19 @@ | ||||
|         role = "devel"; | ||||
|       }; | ||||
|       modules = [ | ||||
|         myOverlays | ||||
|         nix-flatpak.nixosModules.nix-flatpak | ||||
|         ./modules/common | ||||
|         ./modules/machine/cloud | ||||
|  | ||||
|         { | ||||
|           nixpkgs.overlays = [ obsidianOverlay ]; | ||||
|         } | ||||
|  | ||||
|         home-manager.nixosModules.home-manager | ||||
|         { | ||||
|           home-manager.useGlobalPkgs = true; | ||||
|           home-manager.useUserPackages = true; | ||||
|           home-manager.extraSpecialArgs = extraSpecialArgs; | ||||
|           home-manager.backupFileExtension = "bak"; | ||||
|           home-manager.users.${userName}.imports = [ | ||||
|             ./home | ||||
|           ]; | ||||
| @@ -104,7 +102,6 @@ | ||||
|         role = "server"; | ||||
|       }; | ||||
|       modules = [ | ||||
|         myOverlays | ||||
|         ./modules/common | ||||
|         ./modules/machine/valefor | ||||
|  | ||||
| @@ -113,7 +110,6 @@ | ||||
|           home-manager.useGlobalPkgs = true; | ||||
|           home-manager.useUserPackages = true; | ||||
|           home-manager.extraSpecialArgs = extraSpecialArgs; | ||||
|           home-manager.backupFileExtension = "bak"; | ||||
|           home-manager.users.${userName}.imports = [ | ||||
|             ./home | ||||
|           ]; | ||||
| @@ -130,7 +126,6 @@ | ||||
|         role = "server"; | ||||
|       }; | ||||
|       # modules = [ | ||||
|       #   myOverlays | ||||
|       #   nix-flatpak.nixosModules.nix-flatpak | ||||
|       #   nix-ld.nixosModules.nix-ld | ||||
|       #   ./modules/nixos/hardware-configuration.nix | ||||
| @@ -143,7 +138,6 @@ | ||||
|       #     home-manager.useGlobalPkgs = true; | ||||
|       #     home-manager.useUserPackages = true; | ||||
|       #     home-manager.extraSpecialArgs = extraSpecialArgs; | ||||
|       #     home-manager.backupFileExtension = "bak"; | ||||
|       #     home-manager.users.${userName}.imports = [ | ||||
|       #       ./home | ||||
|       #     ]; | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| { pkgs, ...}: { | ||||
| {...}: { | ||||
|   programs.atuin = { | ||||
|     enable = true; | ||||
|     enableFishIntegration = true; | ||||
|     package = pkgs.atuinLatest; | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   pkgs, | ||||
|   userName, | ||||
| @@ -13,7 +14,7 @@ | ||||
|   }; | ||||
| in { | ||||
|   # Import sub modules | ||||
|   imports = map (module: import module {inherit lib pkgs dirs userName userEmail ghostty;}) [ | ||||
|   imports = map (module: import module {inherit config lib pkgs dirs userName userEmail ghostty;}) [ | ||||
|     ./atuin.nix | ||||
|     ./shell.nix | ||||
|     ./packages | ||||
| @@ -27,7 +28,7 @@ in { | ||||
|     ./browser.nix | ||||
|     ./zellij.nix | ||||
|     ./bat.nix | ||||
|     ./lazygit.nix | ||||
|     ./obsidian.nix | ||||
|   ]; | ||||
|  | ||||
|   # Home Manager needs a bit of information about you and the | ||||
| @@ -57,7 +58,7 @@ in { | ||||
|       size = 22; | ||||
|     }; | ||||
|  | ||||
|     stateVersion = "24.11"; | ||||
|     stateVersion = "25.05"; | ||||
|   }; | ||||
|  | ||||
|   # Let Home Manager install and manage itself. | ||||
|   | ||||
| @@ -15,7 +15,7 @@ | ||||
|     extraConfig = { | ||||
|       init.defaultBranch = "master"; | ||||
|       push.autoSetupRemote = true; | ||||
|       pull.rebase = false; | ||||
|       pull.merge = true; | ||||
|       merge.tool = "nvimdiff"; | ||||
|       mergetool.keepBackup = false; | ||||
|     }; | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| { pkgs, ... }: { | ||||
| {...}: { | ||||
|   programs.lazygit = { | ||||
|     enable = true; | ||||
|     package = pkgs.lazygitLatest; | ||||
|  | ||||
|     settings = { | ||||
|       gui.theme = { | ||||
|   | ||||
							
								
								
									
										53
									
								
								home/obsidian.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								home/obsidian.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | ||||
| { config, home-manager-unstable, pkgs, ...}: { | ||||
|   home.packages = with pkgs; [ | ||||
|     obsidian | ||||
|     obsidian-export | ||||
|   ]; | ||||
|   programs.obsidian = { | ||||
|     enable = true; | ||||
|     package =  | ||||
|     vaults = { | ||||
|       "notes" = { | ||||
|         enable = true; | ||||
|         target = "${config.home.homeDirectory}/Documents/obsidian/notes"; | ||||
|       }; | ||||
|       "work-notes" = { | ||||
|         enable = true; | ||||
|         target = "${config.home.homeDirectory}/Documents/obsidian/work-notes"; | ||||
|       }; | ||||
|     }; | ||||
|     # defaultSettings = { | ||||
|     #   themes = [ "catppuccin" ]; | ||||
|     # }; | ||||
|   }; | ||||
|  | ||||
|   home.activation.obsidianRepos = config.lib.dag.entryAfter ["writeBoundary"] '' | ||||
|     REPOS_DIR="${config.home.homeDirectory}/Documents/obsidian" | ||||
|      | ||||
|     # Create the repos directory if it doesn't exist | ||||
|     mkdir -p "$REPOS_DIR" | ||||
|      | ||||
|     # Function to clone or update a repository | ||||
|     clone_or_update() { | ||||
|       local repo_url="$1" | ||||
|       local vault_name="$2" | ||||
|       local vault_path="$REPOS_DIR/$vault_name" | ||||
|        | ||||
|       if [ -d "$vault_path/.git" ]; then | ||||
|         echo "Updating existing vault: $vault_name" | ||||
|         cd "$vault_path" | ||||
|         ${pkgs.git}/bin/git pull origin main || ${pkgs.git}/bin/git pull origin master || true | ||||
|       else | ||||
|         echo "Cloning new vault: $vault_name" | ||||
|         rm -rf "$vault_path"  # Remove if exists but not a git repo | ||||
|         ${pkgs.git}/bin/git clone "$repo_url" "$vault_path" || true | ||||
|       fi | ||||
|     } | ||||
|      | ||||
|     # Clone repositories | ||||
|     clone_or_update "https://scm.wyattjmiller.com/NoteFolio/notes.git" "notes" | ||||
|     clone_or_update "https://scm.wyattjmiller.com/NoteFolio/work-notes.git" "work-notes" | ||||
|      | ||||
|     echo "Obsidian repository vaults setup complete in $REPOS_DIR" | ||||
|   ''; | ||||
| } | ||||
| @@ -1,4 +1,5 @@ | ||||
| { | ||||
|   lib, | ||||
|   pkgs, | ||||
|   ... | ||||
| }: { | ||||
| @@ -13,6 +14,7 @@ | ||||
|  | ||||
|     # utils | ||||
|     tmux | ||||
|     lazygit | ||||
|     bottom | ||||
|     ripgrep | ||||
|     jq | ||||
| @@ -21,7 +23,6 @@ | ||||
|     fh | ||||
|     aria2 | ||||
|     yt-dlp | ||||
|     obsidian | ||||
|     vscode | ||||
|     weechat | ||||
|     inetutils | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| {pkgs, lib, ...}: { | ||||
| {pkgs, ...}: { | ||||
|   programs.fish = { | ||||
|     enable = true; | ||||
|     # initExtra = '' | ||||
| @@ -52,27 +52,6 @@ | ||||
|         ''; | ||||
|         onEvent = "fish_greeting"; | ||||
|       }; | ||||
|     } // lib.optionalAttrs pkgs.stdenv.isLinux { | ||||
|       block = { | ||||
|         body = '' | ||||
|           systemd-inhibit --what=sleep --who="$USER" --why="manual invocation" --mode=block sleep infinity & | ||||
|           set -g INHIBIT_PID $last_pid | ||||
|           echo "Sleep inhibited. PID: $INHIBIT_PID" | ||||
|         ''; | ||||
|       }; | ||||
|  | ||||
|       unblock = { | ||||
|         body = '' | ||||
|           if set -q INHIBIT_PID | ||||
|             kill $INHIBIT_PID 2>/dev/null | ||||
|             and echo "Sleep inhibitor removed. PID: $INHIBIT_PID" | ||||
|             or echo "Failed to kill process or already terminated." | ||||
|             set -e INHIBIT_PID | ||||
|           else | ||||
|             echo "No active sleep inhibitor found." | ||||
|           end | ||||
|         ''; | ||||
|       }; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   | ||||
| @@ -147,5 +147,20 @@ in { | ||||
|   programs.waybar = { | ||||
|     enable = pkgs.stdenv.isLinux; | ||||
|     systemd.enable = true; | ||||
|  | ||||
|     package = pkgs.waybar.overrideAttrs (old: { | ||||
|       version = "0.13.0"; | ||||
|  | ||||
|       src = pkgs.fetchFromGitHub { | ||||
|         owner = "Alexays"; | ||||
|         repo = "Waybar"; | ||||
|         rev = "0fcda9afa519eb84deda68c051f7938a6c6bdbce"; | ||||
|         sha256 = "sha256-Puo/Y4qotb6uEEe9vbu/hyFXwLntr48R2C6mrmDKs0c="; | ||||
|         fetchSubmodules = true; | ||||
|       }; | ||||
|  | ||||
|       buildInputs = old.buildInputs ++ [ pkgs.fftw ]; | ||||
|       mesonFlags = (old.mesonFlags or []) ++ [ "-Dcava=disabled" ]; | ||||
|     }); | ||||
|   }; | ||||
| } | ||||
|   | ||||
| @@ -1,19 +0,0 @@ | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   pkgs, | ||||
|   ... | ||||
| }: | ||||
| with lib; let | ||||
|   cfg = config.appimage; | ||||
| in { | ||||
|   options.appimage = { | ||||
|     enable = mkEnableOption "AppImage support"; | ||||
|   }; | ||||
|   config = mkIf cfg.enable { | ||||
|     environment.systemPackages = with pkgs; [ | ||||
|       appimageupdate | ||||
|       appimage-run | ||||
|     ]; | ||||
|   }; | ||||
| } | ||||
| @@ -8,9 +8,6 @@ | ||||
|  | ||||
|   # Allow unfree packages | ||||
|   nixpkgs.config.allowUnfree = true; | ||||
|   nixpkgs.config.permittedInsecurePackages = [ | ||||
|     "mbedtls-2.28.10" | ||||
|   ]; | ||||
|  | ||||
|   nix.package = pkgs.nix; | ||||
|  | ||||
|   | ||||
| @@ -1,9 +1,12 @@ | ||||
| { ... }: { | ||||
| { | ||||
|   pkgs, | ||||
|   lib, | ||||
|   ... | ||||
| }: { | ||||
|   imports = [ | ||||
|     ./core.nix | ||||
|     ./environment.nix | ||||
|     ./fonts.nix | ||||
|     # ./overlays.nix | ||||
|     ./users.nix | ||||
|   ]; | ||||
| } | ||||
|   | ||||
| @@ -1,23 +1,20 @@ | ||||
| { lib, pkgs, ... }: { | ||||
|   # Common packages that every system will use | ||||
|   environment.systemPackages = with pkgs; [ | ||||
|     git | ||||
|     vim | ||||
|     neovim | ||||
|     usbutils | ||||
|     coreutils | ||||
|     lshw | ||||
|     systemd | ||||
|     dmidecode | ||||
|     pciutils | ||||
|     nix-ld | ||||
|     patchelf | ||||
|     htop | ||||
|   ] ++  | ||||
|   lib.optionals pkgs.stdenv.isLinux (with pkgs; [ | ||||
|     systemd | ||||
|     lshw | ||||
|     dmidecode | ||||
|     nix-ld | ||||
|   ]) ++ | ||||
|   lib.optionals pkgs.stdenv.isDarwin (with pkgs; [ | ||||
|       # nothing here, yet ;) | ||||
|   ]); | ||||
|   ]; | ||||
|  | ||||
|   # Common environment variables that every system will use | ||||
|   environment.variables.EDITOR = "nvim"; | ||||
| } | ||||
|   | ||||
| @@ -1,50 +0,0 @@ | ||||
| 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" | ||||
|     ''; | ||||
|   }); | ||||
| } | ||||
| @@ -1,23 +1,30 @@ | ||||
| { lib, pkgs, userName, hostname, ... }: | ||||
|  | ||||
| { | ||||
|   lib, | ||||
|   pkgs, | ||||
|   userName, | ||||
|   hostname, | ||||
|   ... | ||||
| } @ args: { | ||||
|   networking.hostName = hostname; | ||||
|  | ||||
|   users.users."${userName}" = { | ||||
|     home = if pkgs.stdenv.isDarwin  | ||||
|   # Don't forget to set a password with ‘passwd’! | ||||
|   users.users."${userName}" = lib.mkMerge [ | ||||
|     { | ||||
|       home = | ||||
|         if pkgs.stdenv.isDarwin | ||||
|         then "/Users/${userName}" | ||||
|         else "/home/${userName}"; | ||||
|       description = userName; | ||||
|   } // lib.optionalAttrs pkgs.stdenv.isLinux { | ||||
|     } | ||||
|  | ||||
|     (lib.mkIf (pkgs.stdenv.isLinux) { | ||||
|       group = "${userName}"; | ||||
|       isNormalUser = true; | ||||
|   }; | ||||
|     }) | ||||
|   ]; | ||||
|  | ||||
|   users.groups.wyatt = {}; | ||||
|   nix.settings.trusted-users = [userName]; | ||||
|  | ||||
|   security = lib.optionalAttrs pkgs.stdenv.isLinux { | ||||
|     sudo.extraRules = [ | ||||
|   security.sudo = { | ||||
|     extraRules = [ | ||||
|       { | ||||
|         groups = [ "wheel" ]; | ||||
|         commands = [ | ||||
| @@ -30,9 +37,7 @@ | ||||
|     ]; | ||||
|   }; | ||||
|  | ||||
|   environment = lib.optionalAttrs pkgs.stdenv.isDarwin { | ||||
|     etc."sudoers.d/wheel-nopasswd".text = '' | ||||
|       %wheel ALL=(ALL:ALL) NOPASSWD: SETENV: ALL | ||||
|     ''; | ||||
|   }; | ||||
|   users.groups.wyatt = {}; | ||||
|  | ||||
|   nix.settings.trusted-users = [userName]; | ||||
| } | ||||
|   | ||||
| @@ -11,23 +11,20 @@ | ||||
|     "info.beyondallreason.bar" | ||||
|     "io.dbeaver.DBeaverCommunity" | ||||
|     "io.openrct2.OpenRCT2" | ||||
|     "md.obsidian.Obsidian" | ||||
|     "org.prismlauncher.PrismLauncher" | ||||
|     "sh.cider.Cider" | ||||
|   ]; | ||||
| in { | ||||
|   imports = [ | ||||
|     (import ../../apps/flatpak.nix { | ||||
|       inherit lib pkgs flatpakPackages userName; | ||||
|       inherit lib pkgs flatpakPackages; | ||||
|     }) | ||||
|     ../../apps/gaming.nix | ||||
|     ../../apps/appimage.nix | ||||
|     ../../graphics | ||||
|     ../../pwrMgmt | ||||
|     ../../networking/core.nix | ||||
|     ../../sound/pipewire.nix | ||||
|     ../../sound/shairport.nix | ||||
|     ../../sound/focusrite.nix | ||||
|     ../../virtualization/podman.nix | ||||
|     ../../virtualization/hardware.nix | ||||
|   ]; | ||||
| @@ -36,13 +33,9 @@ in { | ||||
|   nix.settings.experimental-features = ["nix-command" "flakes"]; | ||||
|  | ||||
|   # Custom kernel/boot stuff | ||||
|   boot = { | ||||
|     kernelPackages = pkgs.linuxPackages_latest; | ||||
|     loader = { | ||||
|       systemd-boot.enable = true; | ||||
|       efi.canTouchEfiVariables = true; | ||||
|     }; | ||||
|   }; | ||||
|   boot.kernelPackages = pkgs.linuxPackages_latest; | ||||
|   boot.loader.systemd-boot.enable = true; | ||||
|   boot.loader.efi.canTouchEfiVariables = true; | ||||
|  | ||||
|   # Enable Bluetooth if present | ||||
|   hardware.bluetooth.enable = true; | ||||
| @@ -69,6 +62,21 @@ in { | ||||
|     wl-clip-persist | ||||
|   ]; | ||||
|  | ||||
|   # Enable OpenSSH | ||||
|   services.openssh.enable = true; | ||||
|  | ||||
|   # Enable keyring | ||||
|   services.gnome.gnome-keyring.enable = true; | ||||
|  | ||||
|   # Enable GnuPG | ||||
|   programs.gnupg.agent = { | ||||
|     enable = true; | ||||
|     enableSSHSupport = true; | ||||
|   }; | ||||
|  | ||||
|   # Enable SUID wrappers (some programs need them) | ||||
|   programs.mtr.enable = true; | ||||
|  | ||||
|   # Enable Polkit | ||||
|   security.polkit.enable = true; | ||||
|  | ||||
| @@ -136,39 +144,14 @@ in { | ||||
|     networkManager.enable = true; | ||||
|   }; | ||||
|  | ||||
|   programs = { | ||||
|     # Enable GnuPG | ||||
|     gnupg.agent = { | ||||
|       enable = true; | ||||
|       enableSSHSupport = true; | ||||
|     }; | ||||
|  | ||||
|     # Enable SUID wrappers (some programs need them) | ||||
|     mtr.enable = true; | ||||
|  | ||||
|   # Enable dconf | ||||
|     dconf.enable = true; | ||||
|   }; | ||||
|   programs.dconf.enable = true; | ||||
|  | ||||
|   # Add username to groups "wheel" and "video" - more may be added here later | ||||
|   users.users.${userName}.extraGroups = ["wheel" "video" "gamemode" "podman" "network"]; | ||||
|  | ||||
|   services = { | ||||
|     # Enable OpenSSH | ||||
|     openssh.enable = true; | ||||
|  | ||||
|     # Enable keyring | ||||
|     gnome.gnome-keyring.enable = true; | ||||
|  | ||||
|   # Flatpak packages (see ../../apps/flatpak.nix) | ||||
|     flatpak.packages = flatpakPackages; | ||||
|   }; | ||||
|  | ||||
|   # Focusrite Scarlett audio interface support (see ../../sound/focusrite.nix) | ||||
|   sound.hardware.focusrite.enable = true; | ||||
|  | ||||
|   # AppImage support | ||||
|   appimage.enable = true; | ||||
|   services.flatpak.packages = flatpakPackages; | ||||
|  | ||||
|   # XDG stuff | ||||
|   xdg = { | ||||
| @@ -176,12 +159,12 @@ in { | ||||
|       enable = true; | ||||
|       config = { | ||||
|         sway = { | ||||
|           default = ["wlr" "gtk"]; | ||||
|           "org.freedesktop.impl.portal.Secret" = ["gnome-keyring"]; | ||||
|           default = [ "wlr" "gtk" ]; | ||||
|           "org.freedesktop.impl.portal.Secret" = [ "gnome-keyring" ]; | ||||
|         }; | ||||
|         common = { | ||||
|           default = ["gtk"]; | ||||
|           "org.freedesktop.impl.portal.Secret" = ["gnome-keyring"]; | ||||
|           default = [ "gtk" ]; | ||||
|           "org.freedesktop.impl.portal.Secret" = [ "gnome-keyring" ]; | ||||
|         }; | ||||
|       }; | ||||
|       extraPortals = with pkgs; [ | ||||
|   | ||||
| @@ -12,24 +12,24 @@ | ||||
|     (modulesPath + "/installer/scan/not-detected.nix") | ||||
|   ]; | ||||
|  | ||||
|   boot.initrd.availableKernelModules = ["nvme" "xhci_pci" "thunderbolt" "ahci" "usb_storage" "usbhid" "sd_mod"]; | ||||
|   boot.initrd.availableKernelModules = ["nvme" "xhci_pci" "ahci" "usb_storage" "usbhid" "sd_mod"]; | ||||
|   boot.initrd.kernelModules = []; | ||||
|   boot.kernelModules = ["kvm-amd"]; | ||||
|   boot.extraModulePackages = []; | ||||
|  | ||||
|   fileSystems."/" = { | ||||
|     device = "/dev/disk/by-uuid/f8f39aae-61d2-437d-a8e1-01066bbb3c5c"; | ||||
|     device = "/dev/disk/by-label/COMPUTER"; | ||||
|     fsType = "xfs"; | ||||
|   }; | ||||
|  | ||||
|   fileSystems."/boot" = { | ||||
|     device = "/dev/disk/by-uuid/B72F-087F"; | ||||
|     device = "/dev/disk/by-label/BOOT"; | ||||
|     fsType = "vfat"; | ||||
|     options = ["fmask=0022" "dmask=0022"]; | ||||
|   }; | ||||
|  | ||||
|   swapDevices = [ | ||||
|     {device = "/dev/disk/by-uuid/6d6bcc02-20a9-4ae8-9c1e-5124fb2b2634";} | ||||
|     {device = "/dev/disk/by-label/SWAP";} | ||||
|   ]; | ||||
|  | ||||
|   # Enables DHCP on each ethernet and wireless interface. In case of scripted networking | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| }: | ||||
| with lib; { | ||||
|   options = { | ||||
|     security.sudoers = { | ||||
|     security.sudo = { | ||||
|       needsPassword = mkOption { | ||||
|         type = types.bool; | ||||
|         default = true; | ||||
|   | ||||
| @@ -1,33 +0,0 @@ | ||||
| # Must be paired with the pipewire Nix module, this does nothing but install packages | ||||
| { | ||||
|   config, | ||||
|   lib, | ||||
|   pkgs, | ||||
|   ... | ||||
| }: | ||||
| with lib; let | ||||
|   cfg = config.sound.hardware.focusrite; | ||||
| in { | ||||
|   options.sound.hardware.focusrite = { | ||||
|     enable = mkEnableOption "Focusrite audio interface support"; | ||||
|     guiSupport = mkOption { | ||||
|       type = types.bool; | ||||
|       default = false; | ||||
|       description = "Enable GUI support for Focusrite Scarlett audio interface (installs alsa-scarlett-gui)"; | ||||
|     }; | ||||
|   }; | ||||
|   config = mkIf cfg.enable (mkMerge [ | ||||
|     { | ||||
|       environment.systemPackages = with pkgs; | ||||
|         [ | ||||
|           scarlett2 | ||||
|           alsa-scarlett-gui | ||||
|         ] | ||||
|         ++ ( | ||||
|           if cfg.guiSupport | ||||
|           then [pkgs.alsa-scarlett-gui] | ||||
|           else [] | ||||
|         ); | ||||
|     } | ||||
|   ]); | ||||
| } | ||||
| @@ -1,16 +1,7 @@ | ||||
| { lib, pkgs, userName, ...}: { | ||||
| {pkgs, ...}: { | ||||
|   services.shairport-sync = { | ||||
|     enable = pkgs.stdenv.isLinux; | ||||
|     openFirewall = pkgs.stdenv.isLinux; | ||||
|     # arguments = "-v -o pa"; | ||||
|   }; | ||||
|  | ||||
|   systemd.services.shairport-sync = { | ||||
|     serviceConfig = { | ||||
|       User = lib.mkForce "${userName}"; | ||||
|     }; | ||||
|     environment = { | ||||
|       XDG_RUNTIME_DIR = "/run/user/1000"; | ||||
|     }; | ||||
|     arguments = "-v -o pw"; | ||||
|   }; | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user