51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
		
		
			
		
	
	
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| 
								 | 
							
								{ config, lib, pkgs, ... }:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								with lib;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								let
							 | 
						||
| 
								 | 
							
								  cfg = config.services.coredns;
							 | 
						||
| 
								 | 
							
								  configFile = pkgs.writeText "Corefile" cfg.config;
							 | 
						||
| 
								 | 
							
								in {
							 | 
						||
| 
								 | 
							
								  options.services.coredns = {
							 | 
						||
| 
								 | 
							
								    enable = mkEnableOption "Coredns dns server";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    config = mkOption {
							 | 
						||
| 
								 | 
							
								      default = "";
							 | 
						||
| 
								 | 
							
								      example = ''
							 | 
						||
| 
								 | 
							
								        . {
							 | 
						||
| 
								 | 
							
								          whoami
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								      '';
							 | 
						||
| 
								 | 
							
								      type = types.lines;
							 | 
						||
| 
								 | 
							
								      description = "Verbatim Corefile to use. See <link xlink:href=\"https://coredns.io/manual/toc/#configuration\"/> for details.";
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    package = mkOption {
							 | 
						||
| 
								 | 
							
								      default = pkgs.coredns;
							 | 
						||
| 
								 | 
							
								      defaultText = "pkgs.coredns";
							 | 
						||
| 
								 | 
							
								      type = types.package;
							 | 
						||
| 
								 | 
							
								      description = "Coredns package to use.";
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  config = mkIf cfg.enable {
							 | 
						||
| 
								 | 
							
								    systemd.services.coredns = {
							 | 
						||
| 
								 | 
							
								      description = "Coredns dns server";
							 | 
						||
| 
								 | 
							
								      after = [ "network.target" ];
							 | 
						||
| 
								 | 
							
								      wantedBy = [ "multi-user.target" ];
							 | 
						||
| 
								 | 
							
								      serviceConfig = {
							 | 
						||
| 
								 | 
							
								        PermissionsStartOnly = true;
							 | 
						||
| 
								 | 
							
								        LimitNPROC = 512;
							 | 
						||
| 
								 | 
							
								        LimitNOFILE = 1048576;
							 | 
						||
| 
								 | 
							
								        CapabilityBoundingSet = "cap_net_bind_service";
							 | 
						||
| 
								 | 
							
								        AmbientCapabilities = "cap_net_bind_service";
							 | 
						||
| 
								 | 
							
								        NoNewPrivileges = true;
							 | 
						||
| 
								 | 
							
								        DynamicUser = true;
							 | 
						||
| 
								 | 
							
								        ExecStart = "${getBin cfg.package}/bin/coredns -conf=${configFile}";
							 | 
						||
| 
								 | 
							
								        ExecReload = "${pkgs.coreutils}/bin/kill -SIGUSR1 $MAINPID";
							 | 
						||
| 
								 | 
							
								        Restart = "on-failure";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								}
							 |