| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  | # This tests whether UPnP port mappings can be created using Miniupnpd | 
					
						
							|  |  |  | # and Miniupnpc. | 
					
						
							|  |  |  | # It runs a Miniupnpd service on one machine, and verifies | 
					
						
							|  |  |  | # a client can indeed create a port mapping using Miniupnpc. If | 
					
						
							|  |  |  | # this succeeds an external client will try to connect to the port | 
					
						
							|  |  |  | # mapping. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 07:54:45 +01:00
										 |  |  | import ./make-test-python.nix ({ pkgs, ... }: | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | let | 
					
						
							|  |  |  |   internalRouterAddress = "192.168.3.1"; | 
					
						
							|  |  |  |   internalClient1Address = "192.168.3.2"; | 
					
						
							|  |  |  |   externalRouterAddress = "80.100.100.1"; | 
					
						
							|  |  |  |   externalClient2Address = "80.100.100.2"; | 
					
						
							|  |  |  | in | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   name = "upnp"; | 
					
						
							|  |  |  |   meta = with pkgs.stdenv.lib.maintainers; { | 
					
						
							|  |  |  |     maintainers = [ bobvanderlinden ]; | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   nodes = | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       router = | 
					
						
							|  |  |  |         { pkgs, nodes, ... }: | 
					
						
							|  |  |  |         { virtualisation.vlans = [ 1 2 ]; | 
					
						
							|  |  |  |           networking.nat.enable = true; | 
					
						
							|  |  |  |           networking.nat.internalInterfaces = [ "eth2" ]; | 
					
						
							|  |  |  |           networking.nat.externalInterface = "eth1"; | 
					
						
							|  |  |  |           networking.firewall.enable = true; | 
					
						
							|  |  |  |           networking.firewall.trustedInterfaces = [ "eth2" ]; | 
					
						
							|  |  |  |           networking.interfaces.eth1.ipv4.addresses = [ | 
					
						
							|  |  |  |             { address = externalRouterAddress; prefixLength = 24; } | 
					
						
							|  |  |  |           ]; | 
					
						
							|  |  |  |           networking.interfaces.eth2.ipv4.addresses = [ | 
					
						
							|  |  |  |             { address = internalRouterAddress; prefixLength = 24; } | 
					
						
							|  |  |  |           ]; | 
					
						
							|  |  |  |           services.miniupnpd = { | 
					
						
							|  |  |  |             enable = true; | 
					
						
							|  |  |  |             externalInterface = "eth1"; | 
					
						
							|  |  |  |             internalIPs = [ "eth2" ]; | 
					
						
							|  |  |  |             appendConfig = ''
 | 
					
						
							|  |  |  |               ext_ip=${externalRouterAddress} | 
					
						
							|  |  |  |             '';
 | 
					
						
							|  |  |  |           }; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       client1 = | 
					
						
							|  |  |  |         { pkgs, nodes, ... }: | 
					
						
							| 
									
										
										
										
											2019-05-12 07:53:30 -04:00
										 |  |  |         { environment.systemPackages = [ pkgs.miniupnpc_2 pkgs.netcat ]; | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  |           virtualisation.vlans = [ 2 ]; | 
					
						
							|  |  |  |           networking.defaultGateway = internalRouterAddress; | 
					
						
							|  |  |  |           networking.interfaces.eth1.ipv4.addresses = [ | 
					
						
							|  |  |  |             { address = internalClient1Address; prefixLength = 24; } | 
					
						
							|  |  |  |           ]; | 
					
						
							|  |  |  |           networking.firewall.enable = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           services.httpd.enable = true; | 
					
						
							|  |  |  |           services.httpd.listen = [{ ip = "*"; port = 9000; }]; | 
					
						
							|  |  |  |           services.httpd.adminAddr = "foo@example.org"; | 
					
						
							|  |  |  |           services.httpd.documentRoot = "/tmp"; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       client2 = | 
					
						
							|  |  |  |         { pkgs, ... }: | 
					
						
							| 
									
										
										
										
											2019-05-12 07:53:30 -04:00
										 |  |  |         { environment.systemPackages = [ pkgs.miniupnpc_2 ]; | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  |           virtualisation.vlans = [ 1 ]; | 
					
						
							|  |  |  |           networking.interfaces.eth1.ipv4.addresses = [ | 
					
						
							|  |  |  |             { address = externalClient2Address; prefixLength = 24; } | 
					
						
							|  |  |  |           ]; | 
					
						
							|  |  |  |           networking.firewall.enable = false; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   testScript = | 
					
						
							|  |  |  |     { nodes, ... }: | 
					
						
							|  |  |  |     ''
 | 
					
						
							| 
									
										
										
										
											2019-11-06 07:54:45 +01:00
										 |  |  |       start_all() | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       # Wait for network and miniupnpd. | 
					
						
							| 
									
										
										
										
											2019-11-06 07:54:45 +01:00
										 |  |  |       router.wait_for_unit("network-online.target") | 
					
						
							|  |  |  |       # $router.wait_for_unit("nat") | 
					
						
							|  |  |  |       router.wait_for_unit("firewall.service") | 
					
						
							|  |  |  |       router.wait_for_unit("miniupnpd") | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 07:54:45 +01:00
										 |  |  |       client1.wait_for_unit("network-online.target") | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 07:54:45 +01:00
										 |  |  |       client1.succeed("upnpc -a ${internalClient1Address} 9000 9000 TCP") | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-06 07:54:45 +01:00
										 |  |  |       client1.wait_for_unit("httpd") | 
					
						
							|  |  |  |       client2.wait_until_succeeds("curl http://${externalRouterAddress}:9000/") | 
					
						
							| 
									
										
										
										
											2018-09-15 15:09:05 +02:00
										 |  |  |     '';
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }) |