feat: flake interface definition
This commit is contained in:
		
							
								
								
									
										12
									
								
								flake.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								flake.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| { | ||||
|   inputs = { | ||||
|     nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11"; | ||||
|   }; | ||||
|  | ||||
|   outputs = inputs: { | ||||
|     nixosModules = { | ||||
|       users = (import ./users) inputs; | ||||
|       hosts = (import ./hosts) inputs; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
							
								
								
									
										9
									
								
								hosts/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								hosts/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| inputs @ {nixpkgs, ...}: | ||||
| let | ||||
|   inherit (nixpkgs) lib; | ||||
|   isDir = _name: type: type == "directory"; | ||||
|   directoriesAsModules = dir: (builtins.mapAttrs | ||||
|     (name: _value: dir + "/${name}") | ||||
|     (lib.filterAttrs isDir (builtins.readDir dir)) | ||||
|   ); | ||||
| in directoriesAsModules ./. | ||||
							
								
								
									
										8
									
								
								hosts/git.example.tld/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								hosts/git.example.tld/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| inputs @ {config, ...}: | ||||
| let | ||||
|   allusers = (import ../../users) inputs; | ||||
| { | ||||
|   users.users = { | ||||
|     inherit (allUsers) alice bob; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										8
									
								
								hosts/web.example.org/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								hosts/web.example.org/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| inputs @ {config, ...}: | ||||
| let | ||||
|   allusers = (import ../../users) inputs; | ||||
| { | ||||
|   users.users = { | ||||
|     inherit (allUsers) alice bob mallory root; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										13
									
								
								users/alice/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								users/alice/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| {config, lib, pkgs, ...}: | ||||
| { | ||||
|   isNormalUser = true; | ||||
|   description = "Alice Lastname"; | ||||
|   packages = with pkgs; [ | ||||
|     "firefox" | ||||
|     "element-desktop" | ||||
|   ]; | ||||
|   extraGroups = [ | ||||
|     "audio" | ||||
|     "video" | ||||
|   ]; | ||||
| } | ||||
							
								
								
									
										14
									
								
								users/bob/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								users/bob/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| {config, lib, pkgs, ...}: | ||||
| { | ||||
|   isNormalUser = true; | ||||
|   description = "Bob TheBuilder"; | ||||
|   packages = with pkgs; [ | ||||
|     "firefox-beta" | ||||
|     "element-desktop" | ||||
|   ]; | ||||
|   extraGroups = [ | ||||
|     "audio" | ||||
|     "video" | ||||
|     "docker" | ||||
|   ]; | ||||
| } | ||||
							
								
								
									
										18
									
								
								users/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								users/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| {config, lib, ...}: | ||||
| let | ||||
|   alice = import ./alice; | ||||
|   bob = import ./bob; | ||||
|   mallory = import ./mallory; | ||||
|   isSystemUser = _name: userConfig: userConfig.isSystemUser == true; | ||||
| in | ||||
| { | ||||
|   users.users = { | ||||
|     inherit alice; | ||||
|     inherit bob; | ||||
|     root = { | ||||
|       openssh.authorizedKeys.keys = lib.lists.flatten (attrValues (lib.mapAttrs | ||||
|         (_name: userConfig: userConfig.openssh.authorizedKeys.keys) | ||||
|         (lib.filterAttrs isSystemUser config.users.users))) | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
							
								
								
									
										11
									
								
								users/mallory/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								users/mallory/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| {config, lib, pkgs, ...}: | ||||
| { | ||||
|   isSystemUser = true; | ||||
|   description = "muahahaaa"; | ||||
|   packages = with pkgs; [ | ||||
|     "mtr" | ||||
|     "nmap" | ||||
|     "pwntools" | ||||
|     "hexedit" | ||||
|   ]; | ||||
| } | ||||
		Reference in New Issue
	
	Block a user