mirror of
				https://github.com/NixOS/nixos-hardware.git
				synced 2025-11-04 17:27:14 +08:00 
			
		
		
		
	Extract "surface-control" management into new option-enabled module
This commit is contained in:
		@@ -7,6 +7,7 @@ in {
 | 
			
		||||
  imports = [
 | 
			
		||||
    ./kernel
 | 
			
		||||
    ./ipts
 | 
			
		||||
    ./surface-control
 | 
			
		||||
  ];
 | 
			
		||||
 | 
			
		||||
  microsoft-surface.kernelVersion = mkDefault "6.0.11";
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										25
									
								
								microsoft/surface/common/surface-control/default.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								microsoft/surface/common/surface-control/default.nix
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,25 @@
 | 
			
		||||
{ config, lib, pkgs, ... }:
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
let
 | 
			
		||||
  inherit (lib) mkDefault mkEnableOption mkIf mkMerge;
 | 
			
		||||
 | 
			
		||||
  cfg = config.microsoft-surface.surface-control;
 | 
			
		||||
 | 
			
		||||
in {
 | 
			
		||||
  options.microsoft-surface.surface-control = {
 | 
			
		||||
    enable = mkEnableOption "Enable 'surface-control' for Microsoft Surface";
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  config = mkMerge [
 | 
			
		||||
    {
 | 
			
		||||
      microsoft-surface.surface-control.enable = mkDefault false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    (mkIf cfg.enable {
 | 
			
		||||
      environment.systemPackages = with pkgs; [ surface-control ];
 | 
			
		||||
      services.udev.packages = with pkgs; [ surface-control];
 | 
			
		||||
      users.groups.surface-control = { };
 | 
			
		||||
    })
 | 
			
		||||
  ];
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user