public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: Oliver Fuhrer <oliver.fuhrer@bluewin.ch>
To: development@lists.ipfire.org
Subject: [PATCH] BUG: 11696 - VPN Subnets missing from wpad.dat
Date: Fri, 20 Apr 2018 23:00:46 +0200	[thread overview]
Message-ID: <008901d3d8ea$a7c0be90$f7423bb0$@bluewin.ch> (raw)

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

This Patch excludes enabled ipsec/ OpenVPN N2N Subnets from wpad.dat so they
don't go through the proxy.
I could only test it with ipsec tunnels, however as the code for openvpn is
pretty much the same, I included this one as well and some basic tests
worked as expected.
As I'm not very familiar with Perl, there probably is some room for
improvement too.

Regards
Oliver


diff --git a/html/cgi-bin/proxy.cgi b/html/cgi-bin/proxy.cgi
index c36fc4e..69bfdd4 100644
--- a/html/cgi-bin/proxy.cgi
+++ b/html/cgi-bin/proxy.cgi
@@ -3014,6 +3014,11 @@ sub write_acls

 sub writepacfile
 {
+       my %vpnconfig=();
+       my %ovpnconfig=();
+       &General::readhasharray("${General::swroot}/vpn/config",
\%vpnconfig);
+       &General::readhasharray("${General::swroot}/ovpn/ovpnconfig",
\%ovpnconfig);
+
        open(FILE, ">/srv/web/ipfire/html/proxy.pac");
        flock(FILE, 2);
        print FILE "function FindProxyForURL(url, host)\n";
@@ -3039,6 +3044,26 @@ END
                print FILE "     (isInNet(host,
\"$netsettings{'ORANGE_NETADDRESS'}\", \"$netsettings{'ORANGE_NETMASK'}\"))
||\n";
        }

+       foreach my $key (sort { uc($vpnconfig{$a}[1]) cmp
uc($vpnconfig{$b}[1]) } keys %vpnconfig) {
+               if ($vpnconfig{$key}[0] eq 'on' && $vpnconfig{$key}[3] ne
'host') {
+                       my @networks = split(/\|/, $vpnconfig{$key}[11]);
+                       foreach my $network (@networks) {
+                               my ($vpnip, $vpnsub) = split("/", $network);
+                               $vpnsub =
&Network::convert_prefix2netmask($vpnsub) || $vpnsub;
+                               print FILE "     (isInNet(host, \"$vpnip\",
\"$vpnsub\")) ||\n";
+                       }
+               }
+       }
+
+        foreach my $key (sort { uc($ovpnconfig{$a}[1]) cmp
uc($ovpnconfig{$b}[1]) } keys %ovpnconfig) {
+                if ($ovpnconfig{$key}[0] eq 'on' && $ovpnconfig{$key}[3] ne
'host') {
+                        my @networks = split(/\|/, $ovpnconfig{$key}[11]);
+                        foreach my $network (@networks) {
+                                my ($vpnip, $vpnsub) = split("/",
$network);
+                                print FILE "     (isInNet(host, \"$vpnip\",
\"$vpnsub\")) ||\n";
+                        }
+                }
+        }
        print FILE <<END
      (isInNet(host, "169.254.0.0", "255.255.0.0"))
    )
--


             reply	other threads:[~2018-04-20 21:00 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-04-20 21:00 Oliver Fuhrer [this message]
2018-04-24 11:57 ` Michael Tremer
2018-04-24 14:34   ` Peter Müller
2018-04-24 14:50     ` Michael Tremer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='008901d3d8ea$a7c0be90$f7423bb0$@bluewin.ch' \
    --to=oliver.fuhrer@bluewin.ch \
    --cc=development@lists.ipfire.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox