33 lines
		
	
	
	
		
			856 B
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
	
		
			856 B
		
	
	
	
		
			Nix
		
	
	
	
	
	
{
 | 
						|
  lib,
 | 
						|
  config,
 | 
						|
  ...
 | 
						|
}: let
 | 
						|
  workingDirectory = "/var/lib/private/crab-hole";
 | 
						|
in {
 | 
						|
  options.services.crab-hole = {
 | 
						|
    impermanence.enable = lib.mkOption {
 | 
						|
      type = lib.types.bool;
 | 
						|
      default = config.services.crab-hole.enable && config.host.impermanence.enable;
 | 
						|
    };
 | 
						|
  };
 | 
						|
 | 
						|
  config = lib.mkIf config.services.crab-hole.impermanence.enable {
 | 
						|
    assertions = [
 | 
						|
      {
 | 
						|
        assertion =
 | 
						|
          config.systemd.services.crab-hole.serviceConfig.WorkingDirectory == (builtins.replaceStrings ["/private"] [""] workingDirectory);
 | 
						|
        message = "crab-hole working directory does not match persistence";
 | 
						|
      }
 | 
						|
    ];
 | 
						|
    environment.persistence."/persist/system/root" = {
 | 
						|
      directories = [
 | 
						|
        {
 | 
						|
          directory = workingDirectory;
 | 
						|
          user = "crab-hole";
 | 
						|
          group = "crab-hole";
 | 
						|
        }
 | 
						|
      ];
 | 
						|
    };
 | 
						|
  };
 | 
						|
}
 |