37 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{
 | 
						|
  lib,
 | 
						|
  config,
 | 
						|
  ...
 | 
						|
}: let
 | 
						|
  const = import ./const.nix;
 | 
						|
  dataDirectory = const.dataDirectory;
 | 
						|
in {
 | 
						|
  options.services.actual = {
 | 
						|
    impermanence.enable = lib.mkOption {
 | 
						|
      type = lib.types.bool;
 | 
						|
      default = config.services.actual.enable && config.host.impermanence.enable;
 | 
						|
    };
 | 
						|
  };
 | 
						|
 | 
						|
  config = lib.mkIf config.services.actual.impermanence.enable {
 | 
						|
    assertions = [
 | 
						|
      {
 | 
						|
        assertion = config.services.actual.settings.dataDir == dataDirectory;
 | 
						|
        message = "actual data location does not match persistence\nconfig directory: ${config.services.actual.settings.dataDir}\npersistence directory: ${dataDirectory}";
 | 
						|
      }
 | 
						|
      {
 | 
						|
        assertion = config.systemd.services.actual.serviceConfig.DynamicUser or false;
 | 
						|
        message = "actual systemd service must have DynamicUser enabled to use private directory";
 | 
						|
      }
 | 
						|
    ];
 | 
						|
    environment.persistence."/persist/system/root" = {
 | 
						|
      directories = [
 | 
						|
        {
 | 
						|
          directory = dataDirectory;
 | 
						|
          user = "actual";
 | 
						|
          group = "actual";
 | 
						|
        }
 | 
						|
      ];
 | 
						|
    };
 | 
						|
  };
 | 
						|
}
 |