A centralized list for these renames is not good because: - It breaks disabledModules for modules that have a rename defined - Adding/removing renames for a module means having to find them in the central file - Merge conflicts due to multiple people editing the central file
		
			
				
	
	
		
			95 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{ config, lib, pkgs, ... }:
 | 
						|
 | 
						|
with lib;
 | 
						|
 | 
						|
let
 | 
						|
  top = config.services.kubernetes;
 | 
						|
  cfg = top.proxy;
 | 
						|
in
 | 
						|
{
 | 
						|
  imports = [
 | 
						|
    (mkRenamedOptionModule [ "services" "kubernetes" "proxy" "address" ] ["services" "kubernetes" "proxy" "bindAddress"])
 | 
						|
  ];
 | 
						|
 | 
						|
  ###### interface
 | 
						|
  options.services.kubernetes.proxy = with lib.types; {
 | 
						|
 | 
						|
    bindAddress = mkOption {
 | 
						|
      description = "Kubernetes proxy listening address.";
 | 
						|
      default = "0.0.0.0";
 | 
						|
      type = str;
 | 
						|
    };
 | 
						|
 | 
						|
    enable = mkEnableOption "Kubernetes proxy";
 | 
						|
 | 
						|
    extraOpts = mkOption {
 | 
						|
      description = "Kubernetes proxy extra command line options.";
 | 
						|
      default = "";
 | 
						|
      type = str;
 | 
						|
    };
 | 
						|
 | 
						|
    featureGates = mkOption {
 | 
						|
      description = "List set of feature gates";
 | 
						|
      default = top.featureGates;
 | 
						|
      type = listOf str;
 | 
						|
    };
 | 
						|
 | 
						|
    hostname = mkOption {
 | 
						|
      description = "Kubernetes proxy hostname override.";
 | 
						|
      default = config.networking.hostName;
 | 
						|
      type = str;
 | 
						|
    };
 | 
						|
 | 
						|
    kubeconfig = top.lib.mkKubeConfigOptions "Kubernetes proxy";
 | 
						|
 | 
						|
    verbosity = mkOption {
 | 
						|
      description = ''
 | 
						|
        Optional glog verbosity level for logging statements. See
 | 
						|
        <link xlink:href="https://github.com/kubernetes/community/blob/master/contributors/devel/logging.md"/>
 | 
						|
      '';
 | 
						|
      default = null;
 | 
						|
      type = nullOr int;
 | 
						|
    };
 | 
						|
 | 
						|
  };
 | 
						|
 | 
						|
  ###### implementation
 | 
						|
  config = mkIf cfg.enable {
 | 
						|
    systemd.services.kube-proxy = {
 | 
						|
      description = "Kubernetes Proxy Service";
 | 
						|
      wantedBy = [ "kubernetes.target" ];
 | 
						|
      after = [ "kube-apiserver.service" ];
 | 
						|
      path = with pkgs; [ iptables conntrack_tools ];
 | 
						|
      serviceConfig = {
 | 
						|
        Slice = "kubernetes.slice";
 | 
						|
        ExecStart = ''${top.package}/bin/kube-proxy \
 | 
						|
          --bind-address=${cfg.bindAddress} \
 | 
						|
          ${optionalString (top.clusterCidr!=null)
 | 
						|
            "--cluster-cidr=${top.clusterCidr}"} \
 | 
						|
          ${optionalString (cfg.featureGates != [])
 | 
						|
            "--feature-gates=${concatMapStringsSep "," (feature: "${feature}=true") cfg.featureGates}"} \
 | 
						|
          --hostname-override=${cfg.hostname} \
 | 
						|
          --kubeconfig=${top.lib.mkKubeConfig "kube-proxy" cfg.kubeconfig} \
 | 
						|
          ${optionalString (cfg.verbosity != null) "--v=${toString cfg.verbosity}"} \
 | 
						|
          ${cfg.extraOpts}
 | 
						|
        '';
 | 
						|
        WorkingDirectory = top.dataDir;
 | 
						|
        Restart = "on-failure";
 | 
						|
        RestartSec = 5;
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    services.kubernetes.proxy.hostname = with config.networking; mkDefault hostName;
 | 
						|
 | 
						|
    services.kubernetes.pki.certs = {
 | 
						|
      kubeProxyClient = top.lib.mkCert {
 | 
						|
        name = "kube-proxy-client";
 | 
						|
        CN = "system:kube-proxy";
 | 
						|
        action = "systemctl restart kube-proxy.service";
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    services.kubernetes.proxy.kubeconfig.server = mkDefault top.apiserverAddress;
 | 
						|
  };
 | 
						|
}
 |