37 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
		
		
			
		
	
	
			37 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| 
								 | 
							
								{ config, lib, ... }:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								with lib;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								  options = {
							 | 
						||
| 
								 | 
							
								    security.lockKernelModules = mkOption {
							 | 
						||
| 
								 | 
							
								      type = types.bool;
							 | 
						||
| 
								 | 
							
								      default = false;
							 | 
						||
| 
								 | 
							
								      description = ''
							 | 
						||
| 
								 | 
							
								        Disable kernel module loading once the system is fully initialised.
							 | 
						||
| 
								 | 
							
								        Module loading is disabled until the next reboot.  Problems caused
							 | 
						||
| 
								 | 
							
								        by delayed module loading can be fixed by adding the module(s) in
							 | 
						||
| 
								 | 
							
								        question to <option>boot.kernelModules</option>.
							 | 
						||
| 
								 | 
							
								      '';
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  config = mkIf config.security.lockKernelModules {
							 | 
						||
| 
								 | 
							
								    systemd.services.disable-kernel-module-loading = rec {
							 | 
						||
| 
								 | 
							
								      description = "Disable kernel module loading";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      wantedBy = [ config.systemd.defaultUnit ];
							 | 
						||
| 
								 | 
							
								      after = [ "systemd-udev-settle.service" "firewall.service" "systemd-modules-load.service" ] ++ wantedBy;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      script = "echo -n 1 > /proc/sys/kernel/modules_disabled";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      unitConfig.ConditionPathIsWritable = "/proc/sys/kernel";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      serviceConfig = {
							 | 
						||
| 
								 | 
							
								        Type = "oneshot";
							 | 
						||
| 
								 | 
							
								        RemainAfterExit = true;
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  };
							 | 
						||
| 
								 | 
							
								}
							 |