76 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
		
		
			
		
	
	
			76 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| 
								 | 
							
								{ config, lib, pkgs, ... }:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								with lib;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								let
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  cfg = config.services.pgpkeyserver-lite;
							 | 
						||
| 
								 | 
							
								  sksCfg = config.services.sks;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  webPkg = cfg.package;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								in
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  options = {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    services.pgpkeyserver-lite = {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      enable = mkEnableOption "pgpkeyserver-lite on a nginx vHost proxying to a gpg keyserver";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      package = mkOption {
							 | 
						||
| 
								 | 
							
								        default = pkgs.pgpkeyserver-lite;
							 | 
						||
| 
								 | 
							
								        defaultText = "pkgs.pgpkeyserver-lite";
							 | 
						||
| 
								 | 
							
								        type = types.package;
							 | 
						||
| 
								 | 
							
								        description = "
							 | 
						||
| 
								 | 
							
								          Which webgui derivation to use.
							 | 
						||
| 
								 | 
							
								        ";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      hostname = mkOption {
							 | 
						||
| 
								 | 
							
								        type = types.str;
							 | 
						||
| 
								 | 
							
								        description = "
							 | 
						||
| 
								 | 
							
								          Which hostname to set the vHost to that is proxying to sks.
							 | 
						||
| 
								 | 
							
								        ";
							 | 
						||
| 
								 | 
							
								      };     
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      hkpAddress = mkOption {
							 | 
						||
| 
								 | 
							
								        default = builtins.head sksCfg.hkpAddress;
							 | 
						||
| 
								 | 
							
								        type = types.str;
							 | 
						||
| 
								 | 
							
								        description = "
							 | 
						||
| 
								 | 
							
								          Wich ip address the sks-keyserver is listening on.
							 | 
						||
| 
								 | 
							
								        ";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      hkpPort = mkOption {
							 | 
						||
| 
								 | 
							
								        default = sksCfg.hkpPort;
							 | 
						||
| 
								 | 
							
								        type = types.int;
							 | 
						||
| 
								 | 
							
								        description = "
							 | 
						||
| 
								 | 
							
								          Which port the sks-keyserver is listening on.
							 | 
						||
| 
								 | 
							
								        ";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  config = mkIf cfg.enable {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    services.nginx.enable = true;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    services.nginx.virtualHosts = let
							 | 
						||
| 
								 | 
							
								      hkpPort = builtins.toString cfg.hkpPort;
							 | 
						||
| 
								 | 
							
								    in {
							 | 
						||
| 
								 | 
							
								      "${cfg.hostname}" = {
							 | 
						||
| 
								 | 
							
								        root = webPkg;
							 | 
						||
| 
								 | 
							
								        locations = {
							 | 
						||
| 
								 | 
							
								          "/pks".extraConfig = ''
							 | 
						||
| 
								 | 
							
								            proxy_pass         http://${cfg.hkpAddress}:${hkpPort};
							 | 
						||
| 
								 | 
							
								            proxy_pass_header  Server;
							 | 
						||
| 
								 | 
							
								            add_header         Via "1.1 ${cfg.hostname}";
							 | 
						||
| 
								 | 
							
								          '';
							 | 
						||
| 
								 | 
							
								        };
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								}
							 |