Compare commits
	
		
			2 Commits
		
	
	
		
			master
			...
			home_manag
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 869d3957b5 | |||
| 2eaffa8cfb | 
							
								
								
									
										3
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,6 @@ | ||||
| [submodule "assets/compose"] | ||||
| 	path = assets/compose | ||||
| 	url = ssh://git@code.lazyworkhorse.net:2222/gortium/compose.git | ||||
| [submodule "assets/dotfiles"] | ||||
| 	path = assets/dotfiles | ||||
| 	url = ssh://git@code.lazyworkhorse.net:2222/gortium/dotfiles.git | ||||
|   | ||||
							
								
								
									
										21
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										21
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -44,6 +44,26 @@ | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "home-manager_2": { | ||||
|       "inputs": { | ||||
|         "nixpkgs": [ | ||||
|           "nixpkgs" | ||||
|         ] | ||||
|       }, | ||||
|       "locked": { | ||||
|         "lastModified": 1755625756, | ||||
|         "narHash": "sha256-t57ayMEdV9g1aCfHzoQjHj1Fh3LDeyblceADm2hsLHM=", | ||||
|         "owner": "nix-community", | ||||
|         "repo": "home-manager", | ||||
|         "rev": "dd026d86420781e84d0732f2fa28e1c051117b59", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|         "owner": "nix-community", | ||||
|         "repo": "home-manager", | ||||
|         "type": "github" | ||||
|       } | ||||
|     }, | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 1755615617, | ||||
| @@ -63,6 +83,7 @@ | ||||
|     "root": { | ||||
|       "inputs": { | ||||
|         "agenix": "agenix", | ||||
|         "home-manager": "home-manager_2", | ||||
|         "nixpkgs": "nixpkgs" | ||||
|       } | ||||
|     }, | ||||
|   | ||||
| @@ -8,10 +8,14 @@ | ||||
|       inputs.darwin.follows = ""; | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|     home-manager = { | ||||
|       url = "github:nix-community/home-manager"; | ||||
|       inputs.nixpkgs.follows = "nixpkgs"; | ||||
|     }; | ||||
|     self.submodules = true; | ||||
|   }; | ||||
|  | ||||
|   outputs = { self, nixpkgs, agenix, ... }@inputs: | ||||
|   outputs = { self, nixpkgs, agenix, home-manager, ... }@inputs: | ||||
|     let | ||||
|       system = "x86_64-linux"; | ||||
|       keys = import ./lib/keys.nix; | ||||
| @@ -39,10 +43,11 @@ | ||||
|             modules = [ | ||||
|               { nixpkgs.overlays = overlays; } | ||||
|               agenix.nixosModules.default | ||||
|               home-manager.nixosModules.default | ||||
|               ./hosts/lazyworkhorse/configuration.nix | ||||
|               ./hosts/lazyworkhorse/hardware-configuration.nix | ||||
|               ./modules/default.nix | ||||
|               ./users/gortium.nix | ||||
|               ./users/gortium | ||||
|             ]; | ||||
|           }; | ||||
|         }; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { pkgs, lib, config, ... }: { | ||||
|   imports = | ||||
|     [ | ||||
|       ./systemd | ||||
|     ]; | ||||
| { | ||||
|   imports = [ | ||||
|     ./dotfiles.nix | ||||
|     ./systemd | ||||
|   ]; | ||||
| } | ||||
|   | ||||
							
								
								
									
										69
									
								
								modules/nixos/services/dotfiles.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								modules/nixos/services/dotfiles.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | ||||
| { config, lib, pkgs, ... }: | ||||
|  | ||||
| with lib; | ||||
|  | ||||
| let | ||||
|   cfg = config.services.dotfiles; | ||||
|   stowDir = cfg.stowDir; | ||||
|  | ||||
|   # Function to recursively find all files in a directory | ||||
|   findFiles = dir: | ||||
|     let | ||||
|       files = builtins.attrNames (builtins.readDir dir); | ||||
|     in | ||||
|       concatMap (name: | ||||
|         let | ||||
|           path = dir + "/${name}"; | ||||
|         in | ||||
|           if (builtins.typeOf (builtins.readDir path) == "set") | ||||
|           then findFiles path | ||||
|           else [ path ] | ||||
|       ) files; | ||||
|  | ||||
|   # Get a list of all packages (directories) in the stow directory | ||||
|   stowPackages = builtins.attrNames (builtins.readDir stowDir); | ||||
|  | ||||
|   # Create an attribute set where each attribute is a package name | ||||
|   # and the value is a list of files to be linked. | ||||
|   homeManagerLinks = listToAttrs (map (pkg: | ||||
|     let | ||||
|       pkgPath = stowDir + "/${pkg}"; | ||||
|       files = findFiles pkgPath; | ||||
|     in | ||||
|       nameValuePair pkg (map (file: { | ||||
|         source = file; | ||||
|         target = removePrefix (pkgPath + "/") file; | ||||
|       }) files) | ||||
|   ) stowPackages); | ||||
|  | ||||
| in | ||||
| { | ||||
|   options.services.dotfiles = { | ||||
|     enable = mkEnableOption "Enable dotfiles management"; | ||||
|  | ||||
|     stowDir = mkOption { | ||||
|       type = types.path; | ||||
|       description = "The directory where your stow packages are located."; | ||||
|     }; | ||||
|  | ||||
|     user = mkOption { | ||||
|       type = types.str; | ||||
|       description = "The user to manage dotfiles for."; | ||||
|     }; | ||||
|   }; | ||||
|  | ||||
|   config = mkIf cfg.enable { | ||||
|     home-manager.users.${cfg.user} = { | ||||
|       home.file = | ||||
|         let | ||||
|           allFiles = concatLists (attrValues homeManagerLinks); | ||||
|         in | ||||
|           listToAttrs (map (file: | ||||
|             nameValuePair file.target { | ||||
|               source = file.source; | ||||
|             } | ||||
|           ) allFiles); | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
|  | ||||
| @@ -1,4 +1,5 @@ | ||||
| { pkgs, inputs, config, keys, ... }: { | ||||
|   home-manager.users.gortium = import ./home.nix; | ||||
|   users.users.gortium = { | ||||
|     isNormalUser = true; | ||||
|     extraGroups = [ "wheel" "docker" ]; # Enable ‘sudo’ for the user. | ||||
							
								
								
									
										12
									
								
								users/gortium/home.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								users/gortium/home.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| { pkgs, ... }: { | ||||
|   services.dotfiles = { | ||||
|     enable = true; | ||||
|     stowDir = ../../../assets/dotfiles; | ||||
|     user = "gortium"; | ||||
|   }; | ||||
|  | ||||
|   home.username = "gortium"; | ||||
|   home.homeDirectory = "/home/gortium"; | ||||
|   home.stateVersion = "23.11"; # Please change this to your version. | ||||
|   programs.home-manager.enable = true; | ||||
| } | ||||
		Reference in New Issue
	
	Block a user