forked from jan-leila/nix-config
		
	
		
			
				
	
	
		
			56 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| {
 | |
|   lib,
 | |
|   config,
 | |
|   ...
 | |
| }: let
 | |
|   dataDirectory = "/var/lib/actual/";
 | |
| in {
 | |
|   options.services.actual = {
 | |
|     subdomain = lib.mkOption {
 | |
|       type = lib.types.str;
 | |
|       default = "actual";
 | |
|       description = "subdomain of base domain that actual will be hosted at";
 | |
|     };
 | |
|   };
 | |
| 
 | |
|   config = lib.mkIf config.services.actual.enable (lib.mkMerge [
 | |
|     {
 | |
|       systemd.tmpfiles.rules = [
 | |
|         "d ${dataDirectory} 2770 actual actual"
 | |
|       ];
 | |
| 
 | |
|       services.actual = {
 | |
|         settings = {
 | |
|           ACTUAL_DATA_DIR = dataDirectory;
 | |
|         };
 | |
|       };
 | |
|     }
 | |
|     (lib.mkIf config.host.reverse_proxy.enable {
 | |
|       host = {
 | |
|         reverse_proxy.subdomains.${config.services.actual.subdomain} = {
 | |
|           target = "http://localhost:${toString config.services.actual.settings.port}";
 | |
|         };
 | |
|       };
 | |
|     })
 | |
|     (lib.mkIf config.services.fail2ban.enable {
 | |
|       # TODO: configuration for fail2ban for actual
 | |
|     })
 | |
|     (lib.mkIf config.host.impermanence.enable {
 | |
|       assertions = [
 | |
|         {
 | |
|           assertion = config.services.actual.settings.ACTUAL_DATA_DIR == dataDirectory;
 | |
|           message = "actual data location does not match persistence";
 | |
|         }
 | |
|       ];
 | |
|       environment.persistence."/persist/system/root" = {
 | |
|         directories = [
 | |
|           {
 | |
|             directory = dataDirectory;
 | |
|             user = "actual";
 | |
|             group = "actual";
 | |
|           }
 | |
|         ];
 | |
|       };
 | |
|     })
 | |
|   ]);
 | |
| }
 |