public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: Alexander Koch <ipfire@starkstromkonsument.de>
To: development@lists.ipfire.org
Subject: Re: [PATCH] squid / WPAD: Add exception-files for generation of proxy.pac
Date: Mon, 15 Apr 2019 22:12:19 +0200	[thread overview]
Message-ID: <ddc27340-1dbb-ea5d-3e8c-09fd467cbbcb@starkstromkonsument.de> (raw)
In-Reply-To: <82CC20D5-7ACF-449C-A067-921271DBEAE8@ipfire.org>

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

Hello Michael,

my motivation for the patch is to provide a possibility to make exceptions survive an update of squid, as I'm repatching proxy.cgi by myself after each upgrade. I suppose there are more people out there with the same issue. I agree that it would by very nice to have it on the GUI as well, but unfortunately I don't have any experience with CGI yet and I don't have the time to learn it right now. I think patching the integration of the exception files into proxy.cgi is a good first step. It can be used as the base for extending the GUI. Maybe somebody else with CGI experience can help out? It's "just" two textareas and some file i/o basically...

As far as I know, the WPAD-Feature does not have any GUI support in general (e.g. checkboxes for enabled, enabled on a per subnet basis, etc.) until now. Additionally the WPAD-Feature requires the user to set up the extra apache-vhost or haproxy-frontend for port 80 (for http://wpad.<IPFire-Network-Domain>/wpad.dat) via CLI by himself anyway (another ToDo for a future patch ;-).

Having this said, I think it is reasonable for the users to maintain their exceptions via CLI in the first instance until a GUI is available. Usually these things are not changed very often. It is still better than having to fix them after each upgrade of proxy.cgi If nobody else grabs this, I might possibly come back to it by myself at a later date.

Should I write a bug report for the WPAD-GUI feature request?

Best regards,
Alex 


Am 15.04.2019 um 11:43 schrieb Michael Tremer:
> Hello Alex,
> 
> Thanks for submitting the patch.
> 
> I guess the code looks fine, but where is the UI?
> 
> Why should this not be configurable on the web interface?
> 
> -Michael
> 
>> On 14 Apr 2019, at 11:08, Alexander Koch <ipfire(a)starkstromkonsument.de> wrote:
>>
>> This patch extends the script /srv/web/ipfire/cgi-bin/proxy.cgi by additional code for reading exceptions for URL's and IP's/Subnets from two new files:
>>
>> - /var/ipfire/proxy/advanced/acls/dst_noproxy_url.acl
>> - /var/ipfire/proxy/advanced/acls/dst_noproxy_ip.acl
>>
>> as described in: https://wiki.ipfire.org/configuration/network/proxy/extend/add_distri
>>
>> These can be used to define additional URL's, IP's and Subnets that should be retrieved "DIRECT" and not via the proxy. The files have to be created by the user, as the WPAD-Feature is not enabled by default anyway. If the files are not present or their size is 0, nothing is done. I'll revise the wiki-page, after the patch is merged and the core update is released.
>>
>> Signed-off-by: Alexander Koch <ipfire(a)starkstromkonsument.de>
>> ---
>> html/cgi-bin/proxy.cgi | 39 +++++++++++++++++++++++++++++++++++++++
>> 1 file changed, 39 insertions(+)
>>
>> diff --git a/html/cgi-bin/proxy.cgi b/html/cgi-bin/proxy.cgi
>> index 6daa7fb..369a5cb 100644
>> --- a/html/cgi-bin/proxy.cgi
>> +++ b/html/cgi-bin/proxy.cgi
>> @@ -124,6 +124,9 @@ my $acl_ports_safe = "$acldir/ports_safe.acl";
>> my $acl_ports_ssl  = "$acldir/ports_ssl.acl";
>> my $acl_include = "$acldir/include.acl";
>>
>> +my $acl_dst_noproxy_url = "$acldir/dst_noproxy_url.acl";
>> +my $acl_dst_noproxy_ip = "$acldir/dst_noproxy_ip.acl";
>> +
>> my $updaccelversion  = 'n/a';
>> my $urlfilterversion = 'n/a';
>>
>> @@ -2763,6 +2766,42 @@ END
>> 		print FILE "     (isInNet(host, \"$netsettings{'ORANGE_NETADDRESS'}\", \"$netsettings{'ORANGE_NETMASK'}\")) ||\n";
>> 	}
>>
>> +	# Additional exceptions for URLs
>> +	# The file has to be created by the user and should contain one entry per line
>> +	# Line-Format: <URL incl. wildcards>
>> +	# e.g. *ipfire.org*
>> +	if (-s "$acl_dst_noproxy_url") {
>> +		undef @templist;
>> +
>> +		open(NOPROXY,"$acl_dst_noproxy_url");
>> +		@templist = <NOPROXY>;
>> +		close(NOPROXY);
>> +		chomp (@templist);
>> +
>> +		foreach (@templist)
>> +		{
>> +			print FILE "     (shExpMatch(url, \"$_\")) ||\n";
>> +		}
>> +	}
>> +
>> +	# Additional exceptions for Subnets
>> +	# The file has to be created by the user and should contain one entry per line
>> +	# Line-Format: "<IP>", "<SUBNET MASK>"
>> +	# e.g. "192.168.0.0", "255.255.255.0"
>> +	if (-s "$acl_dst_noproxy_ip") {
>> +		undef @templist;
>> +
>> +		open(NOPROXY,"$acl_dst_noproxy_ip");
>> +		@templist = <NOPROXY>;
>> +		close(NOPROXY);
>> +		chomp (@templist);
>> +
>> +		foreach (@templist)
>> +		{
>> +			print FILE "     (isInNet(host, $_)) ||\n";
>> +		}
>> +	}
>> +
>> 	print FILE <<END
>>      (isInNet(host, "169.254.0.0", "255.255.0.0"))
>>    )
>> -- 
>> 2.7.4
>>
> 

  reply	other threads:[~2019-04-15 20:12 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-04-14 10:08 Alexander Koch
2019-04-15  9:43 ` Michael Tremer
2019-04-15 20:12   ` Alexander Koch [this message]
2019-04-17 14:08     ` Michael Tremer
2019-04-17 23:54       ` [PATCH 1/2] squid / WPAD: Add GUI for " Alexander Koch
2019-04-17 23:54         ` [PATCH 2/2] apache / WPAD: Add correct MIME type for wpad.dat and proxy.pac Alexander Koch
2019-04-23 15:23           ` Alexander Koch
2019-04-24 10:55             ` Michael Tremer
2019-04-18 10:27         ` [PATCH 1/2] squid / WPAD: Add GUI for exception-files for generation of proxy.pac Michael Tremer
2019-04-18  1:41       ` [PATCH] squid / WPAD: Add " Alexander Koch
2019-04-18 10:33         ` Michael Tremer
2019-04-21 21:56           ` [PATCH 1/2] squid / WPAD: Add GUI for " Alexander Koch
2019-04-21 21:56             ` [PATCH 2/2] squid / WPAD: Add Wiki-Link for required further adjustments to GUI Alexander Koch
2019-04-22  8:02             ` [PATCH 1/2] squid / WPAD: Add GUI for exception-files for generation of proxy.pac Matthias Fischer
2019-04-22 14:06               ` Tom Rymes
2019-04-22 15:10                 ` Matthias Fischer
2019-04-22 18:46                   ` Michael Tremer
2019-04-23 16:29                     ` Matthias Fischer

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=ddc27340-1dbb-ea5d-3e8c-09fd467cbbcb@starkstromkonsument.de \
    --to=ipfire@starkstromkonsument.de \
    --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