public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
* [PATCH] proxy: Skip VPNs that route everything for proxy.pac
@ 2023-03-24 15:49 Michael Tremer
  0 siblings, 0 replies; only message in thread
From: Michael Tremer @ 2023-03-24 15:49 UTC (permalink / raw)
  To: development

[-- Attachment #1: Type: text/plain, Size: 1197 bytes --]

The function tries to figure out which networks are connected locally,
but VPN tunnels that use 0.0.0.0 and GRE/VTI interfaces will be
considered local and the proxy is being disabled for everyone.

Signed-off-by: Michael Tremer <michael.tremer(a)ipfire.org>
---
 html/cgi-bin/proxy.cgi | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/html/cgi-bin/proxy.cgi b/html/cgi-bin/proxy.cgi
index a718d5771..71be315f6 100644
--- a/html/cgi-bin/proxy.cgi
+++ b/html/cgi-bin/proxy.cgi
@@ -2986,6 +2986,7 @@ END
 			foreach my $network (@networks) {
 				my ($vpnip, $vpnsub) = split("/", $network);
 				$vpnsub = &Network::convert_prefix2netmask($vpnsub) || $vpnsub;
+				next if ($vpnip eq "0.0.0.0" || $vpnsub eq "0.0.0.0");
 				print FILE "     (isInNet(host, \"$vpnip\", \"$vpnsub\")) ||\n";
 			}
 		}
@@ -2996,6 +2997,8 @@ END
 			my @networks = split(/\|/, $ovpnconfig{$key}[11]);
 			foreach my $network (@networks) {
 				my ($vpnip, $vpnsub) = split("/", $network);
+				$vpnsub = &Network::convert_prefix2netmask($vpnsub) || $vpnsub;
+				next if ($vpnip eq "0.0.0.0" || $vpnsub eq "0.0.0.0");
 				print FILE "     (isInNet(host, \"$vpnip\", \"$vpnsub\")) ||\n";
 			}
 		}
-- 
2.30.2


^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2023-03-24 15:49 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-03-24 15:49 [PATCH] proxy: Skip VPNs that route everything for proxy.pac Michael Tremer

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox