nixos/n8n: init module and test
This commit is contained in:
		
							parent
							
								
									b5ee81b8aa
								
							
						
					
					
						commit
						903b2aa9a6
					
				| @ -482,6 +482,7 @@ | |||||||
|   ./services/misc/mediatomb.nix |   ./services/misc/mediatomb.nix | ||||||
|   ./services/misc/metabase.nix |   ./services/misc/metabase.nix | ||||||
|   ./services/misc/mwlib.nix |   ./services/misc/mwlib.nix | ||||||
|  |   ./services/misc/n8n.nix | ||||||
|   ./services/misc/nix-daemon.nix |   ./services/misc/nix-daemon.nix | ||||||
|   ./services/misc/nix-gc.nix |   ./services/misc/nix-gc.nix | ||||||
|   ./services/misc/nix-optimise.nix |   ./services/misc/nix-optimise.nix | ||||||
|  | |||||||
							
								
								
									
										78
									
								
								nixos/modules/services/misc/n8n.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								nixos/modules/services/misc/n8n.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | |||||||
|  | { config, pkgs, lib, ... }: | ||||||
|  | 
 | ||||||
|  | with lib; | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   cfg = config.services.n8n; | ||||||
|  |   format = pkgs.formats.json {}; | ||||||
|  |   configFile = format.generate "n8n.json" cfg.settings; | ||||||
|  | in | ||||||
|  | { | ||||||
|  |   options.services.n8n = { | ||||||
|  | 
 | ||||||
|  |     enable = mkEnableOption "n8n server"; | ||||||
|  | 
 | ||||||
|  |     openFirewall = mkOption { | ||||||
|  |       type = types.bool; | ||||||
|  |       default = false; | ||||||
|  |       description = "Open ports in the firewall for the n8n web interface."; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     settings = mkOption { | ||||||
|  |       type = format.type; | ||||||
|  |       default = {}; | ||||||
|  |       description = '' | ||||||
|  |         Configuration for n8n, see <link xlink:href="https://docs.n8n.io/reference/configuration.html"/> | ||||||
|  |         for supported values. | ||||||
|  |       ''; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   config = mkIf cfg.enable { | ||||||
|  |     services.n8n.settings = { | ||||||
|  |       # We use this to open the firewall, so we need to know about the default at eval time | ||||||
|  |       port = lib.mkDefault 5678; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     systemd.services.n8n = { | ||||||
|  |       description = "N8N service"; | ||||||
|  |       after = [ "network.target" ]; | ||||||
|  |       wantedBy = [ "multi-user.target" ]; | ||||||
|  |       environment = { | ||||||
|  |         # This folder must be writeable as the application is storing | ||||||
|  |         # its data in it, so the StateDirectory is a good choice | ||||||
|  |         N8N_USER_FOLDER = "/var/lib/n8n"; | ||||||
|  |         N8N_CONFIG_FILES = "${configFile}"; | ||||||
|  |       }; | ||||||
|  |       serviceConfig = { | ||||||
|  |         Type = "simple"; | ||||||
|  |         ExecStart = "${pkgs.n8n}/bin/n8n"; | ||||||
|  |         Restart = "on-failure"; | ||||||
|  |         StateDirectory = "n8n"; | ||||||
|  | 
 | ||||||
|  |         # Basic Hardening | ||||||
|  |         NoNewPrivileges = "yes"; | ||||||
|  |         PrivateTmp = "yes"; | ||||||
|  |         PrivateDevices = "yes"; | ||||||
|  |         DevicePolicy = "closed"; | ||||||
|  |         DynamicUser = "true"; | ||||||
|  |         ProtectSystem = "strict"; | ||||||
|  |         ProtectHome = "read-only"; | ||||||
|  |         ProtectControlGroups = "yes"; | ||||||
|  |         ProtectKernelModules = "yes"; | ||||||
|  |         ProtectKernelTunables = "yes"; | ||||||
|  |         RestrictAddressFamilies = "AF_UNIX AF_INET AF_INET6 AF_NETLINK"; | ||||||
|  |         RestrictNamespaces = "yes"; | ||||||
|  |         RestrictRealtime = "yes"; | ||||||
|  |         RestrictSUIDSGID = "yes"; | ||||||
|  |         MemoryDenyWriteExecute = "yes"; | ||||||
|  |         LockPersonality = "yes"; | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     networking.firewall = mkIf cfg.openFirewall { | ||||||
|  |       allowedTCPPorts = [ cfg.settings.port ]; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | } | ||||||
| @ -231,6 +231,7 @@ in | |||||||
|   mysql-autobackup = handleTest ./mysql/mysql-autobackup.nix {}; |   mysql-autobackup = handleTest ./mysql/mysql-autobackup.nix {}; | ||||||
|   mysql-backup = handleTest ./mysql/mysql-backup.nix {}; |   mysql-backup = handleTest ./mysql/mysql-backup.nix {}; | ||||||
|   mysql-replication = handleTest ./mysql/mysql-replication.nix {}; |   mysql-replication = handleTest ./mysql/mysql-replication.nix {}; | ||||||
|  |   n8n = handleTest ./n8n.nix {}; | ||||||
|   nagios = handleTest ./nagios.nix {}; |   nagios = handleTest ./nagios.nix {}; | ||||||
|   nano = handleTest ./nano.nix {}; |   nano = handleTest ./nano.nix {}; | ||||||
|   nar-serve = handleTest ./nar-serve.nix {}; |   nar-serve = handleTest ./nar-serve.nix {}; | ||||||
|  | |||||||
							
								
								
									
										25
									
								
								nixos/tests/n8n.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								nixos/tests/n8n.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | import ./make-test-python.nix ({ lib, ... }: | ||||||
|  | 
 | ||||||
|  | with lib; | ||||||
|  | 
 | ||||||
|  | let | ||||||
|  |   port = 5678; | ||||||
|  | in | ||||||
|  | { | ||||||
|  |   name = "n8n"; | ||||||
|  |   meta.maintainers = with maintainers; [ freezeboy ]; | ||||||
|  | 
 | ||||||
|  |   nodes.machine = | ||||||
|  |     { pkgs, ... }: | ||||||
|  |     { | ||||||
|  |       services.n8n = { | ||||||
|  |         enable = true; | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |   testScript = '' | ||||||
|  |     machine.wait_for_unit("n8n.service") | ||||||
|  |     machine.wait_for_open_port("${toString port}") | ||||||
|  |     machine.succeed("curl --fail http://localhost:${toString port}/") | ||||||
|  |   ''; | ||||||
|  | }) | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 freezeboy
						freezeboy