7
									
								
								overlay/fetchers/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								overlay/fetchers/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| { pkgs, ... }: | ||||
| let | ||||
|   callPackage = pkgs.lib.callPackageWith { inherit pkgs; }; | ||||
| in | ||||
| { | ||||
|   sshKnownHosts = callPackage ./sshKnownHosts { }; | ||||
| } | ||||
							
								
								
									
										33
									
								
								overlay/fetchers/sshKnownHosts/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								overlay/fetchers/sshKnownHosts/default.nix
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| { pkgs, ... }: | ||||
| pkgs.lib.fetchers.withNormalizedHash { } ( | ||||
|   { | ||||
|     host, | ||||
|     name ? "ssh-known-hosts-${host}", | ||||
|     outputHash, | ||||
|     outputHashAlgo, | ||||
|     port ? 22, | ||||
|     keyTypes ? [ | ||||
|       "rsa" | ||||
|       "ecdsa" | ||||
|       "ed25519" | ||||
|     ], | ||||
|   }: | ||||
|   let | ||||
|     keyTypeArgs = pkgs.lib.concatStringsSep "," keyTypes; | ||||
|   in | ||||
|   pkgs.runCommandLocal name | ||||
|     { | ||||
|       inherit outputHash outputHashAlgo; | ||||
|       outputHashMode = "flat"; | ||||
|       preferLocalBuild = true; | ||||
|  | ||||
|       nativeBuildInputs = with pkgs; [ | ||||
|         openssh | ||||
|         gnugrep | ||||
|         coreutils | ||||
|       ]; | ||||
|     } | ||||
|     '' | ||||
|       ssh-keyscan -p ${toString port} -t ${keyTypeArgs} ${host} | grep -v '^#' | sort > $out | ||||
|     '' | ||||
| ) | ||||
		Reference in New Issue
	
	Block a user