Fabian Keil [Sun, 17 Jul 2011 13:35:32 +0000 (13:35 +0000)]
 
Do not claim to listen on a socket until we actually do.
Patch submitted by Petr Písař in #
3354485
Fabian Keil [Sun, 17 Jul 2011 13:34:36 +0000 (13:34 +0000)]
 
Allow to bind to multiple separate addresses.
Patch set submitted by Petr Písař in #
3354485.
Fabian Keil [Sun, 17 Jul 2011 13:31:35 +0000 (13:31 +0000)]
 
Fix a memory leak if the socks5 server is unreachable.
I introduced the leak after the last release so this
fix is irrelevant as far as the ChangeLog is concerned.
Fabian Keil [Sun, 17 Jul 2011 13:31:02 +0000 (13:31 +0000)]
 
Minor style fix for listen_loop().
Fabian Keil [Sun, 17 Jul 2011 13:30:43 +0000 (13:30 +0000)]
 
Remove #13 which is already implemented.
Fabian Keil [Sun, 17 Jul 2011 13:30:24 +0000 (13:30 +0000)]
 
Also log the client socket when dropping a connection.
Fabian Keil [Fri, 8 Jul 2011 13:31:40 +0000 (13:31 +0000)]
 
Document compression-level
Fabian Keil [Fri, 8 Jul 2011 13:31:17 +0000 (13:31 +0000)]
 
Document enable-compression
Fabian Keil [Fri, 8 Jul 2011 13:30:59 +0000 (13:30 +0000)]
 
Add a 'to' that was missing in the FEATURE_COMPRESSION description
Fabian Keil [Fri, 8 Jul 2011 13:30:08 +0000 (13:30 +0000)]
 
Add an enable-compression directive and disable compression by default
Fabian Keil [Fri, 8 Jul 2011 13:29:39 +0000 (13:29 +0000)]
 
parse_toggle_state() only returns 0 or 1, so check for 1 directly.
Fabian Keil [Fri, 8 Jul 2011 13:29:22 +0000 (13:29 +0000)]
 
Also let parse_toggle_state() reject values like '1[insert garbage here]'
Fabian Keil [Fri, 8 Jul 2011 13:29:06 +0000 (13:29 +0000)]
 
Add a dedicated function to parse the values of toggles
Reduces duplicated code in load_config() and provides
better error handling. Invalid or missing toggle values
are now a fatal error instead of being silently ignored.
Fabian Keil [Fri, 8 Jul 2011 13:28:11 +0000 (13:28 +0000)]
 
If compressing the buffer failed, include buffer size and compression level in the error message
Fabian Keil [Fri, 8 Jul 2011 13:27:56 +0000 (13:27 +0000)]
 
In compress_buffer(), add some room for the zlib overhead
If the entropy is high enough, the data may not be compressable,
or at least not compressable enough to make room for the header.
If the compression level is 0, the "compressed" is guaranteed
to take more room than the "uncompressed" data.
Fabian Keil [Fri, 8 Jul 2011 13:27:31 +0000 (13:27 +0000)]
 
Add the config directive compression-level
There isn't a single best compression level for
all situations, so hard-coding one makes no sense.
Fabian Keil [Mon, 4 Jul 2011 17:48:11 +0000 (17:48 +0000)]
 
#94: Add a config directive to let Privoxy prefer either IPv4 (or IPv6) addresses
Fabian Keil [Mon, 4 Jul 2011 17:47:50 +0000 (17:47 +0000)]
 
#93: Add a config directive to let Privoxy explicitly request either IPv4 (or IPv6) addresses
Fabian Keil [Mon, 4 Jul 2011 17:47:29 +0000 (17:47 +0000)]
 
In bind_port(), stop hinting AI_ADDRCONFIG to getaddrinfo()
It's not strictly needed there and causes GNU libc to fail to
return loopback addresses if no non-loopback IP address is
configured on the system. Apparently this is the result of a
somewhat strict but valid interpretation of RFC 3493 and
considered a feature. Sad but true.
This is mainly an issue if the system is using DHCP and Privoxy
is started before the network is completely configured.
Reported by Raphael Marichez in #
3349356.
Additional insight from Petr Pisar.
Fabian Keil [Sun, 3 Jul 2011 17:55:23 +0000 (17:55 +0000)]
 
Move LOWER_LENGTH_LIMIT_FOR_COMPRESSION into cgi.[ch] where it belongs
While at it, turn it into a proper variable so it can be changed from the debugger.
Fabian Keil [Sun, 3 Jul 2011 17:54:29 +0000 (17:54 +0000)]
 
Fix spelling of LOWER_LENGTH_LIMIT_FOR_COMPRESSION
Fabian Keil [Sun, 3 Jul 2011 17:53:00 +0000 (17:53 +0000)]
 
Fix the FEATURE_ZLIB description. It's mainly used for decompression.
Fabian Keil [Wed, 29 Jun 2011 20:31:05 +0000 (20:31 +0000)]
 
Unbreak execute_dumb_fetch_test().
Apparently 1.73 wasn't regression-tested. How ironic.
Fabian Keil [Wed, 29 Jun 2011 20:30:18 +0000 (20:30 +0000)]
 
Remove a stray exit(0)
Fabian Keil [Wed, 29 Jun 2011 20:29:58 +0000 (20:29 +0000)]
 
Cosmetics for generate_creation_time()
Fabian Keil [Wed, 29 Jun 2011 20:29:29 +0000 (20:29 +0000)]
 
Remove a couple of unnecessary variables in generate_creation_time()
Fabian Keil [Wed, 29 Jun 2011 20:29:12 +0000 (20:29 +0000)]
 
Let Getopt::Long perform some sanity checks for parameters that are supposed to have numerical values.
While it doesn't prevent all invalid input, it's better than nothing.
Fabian Keil [Wed, 29 Jun 2011 18:36:49 +0000 (18:36 +0000)]
 
In finish_http_response(), don't add an Content-Encoding header if compression failed.
Fabian Keil [Wed, 29 Jun 2011 18:36:24 +0000 (18:36 +0000)]
 
Let Getopt::Long perform some sanity checks for parameters that are supposed to have numerical values.
While it doesn't prevent all invalid input, it's better than nothing.
Fabian Keil [Wed, 29 Jun 2011 18:35:53 +0000 (18:35 +0000)]
 
Bump version and copyright date
Fabian Keil [Wed, 29 Jun 2011 18:35:38 +0000 (18:35 +0000)]
 
Bump generated Firefox version to 5.0
Fabian Keil [Wed, 29 Jun 2011 18:35:23 +0000 (18:35 +0000)]
 
Only randomize the release date if the new --randomize-release-date option is enabled.
Firefox versions after 4 use a fixed date string without meaning.
Fabian Keil [Wed, 29 Jun 2011 18:35:01 +0000 (18:35 +0000)]
 
Implement a --sleep-time option
Specifies a number of second to sleep between tests, defaults to 0.
Fabian Keil [Wed, 29 Jun 2011 18:34:38 +0000 (18:34 +0000)]
 
Consistently use quote() in execute_dumb_fetch_test().
Fabian Keil [Wed, 29 Jun 2011 18:34:23 +0000 (18:34 +0000)]
 
In load_action_files(), use quote() instead of quoting manually.
Fabian Keil [Sat, 25 Jun 2011 12:45:47 +0000 (12:45 +0000)]
 
Rephrase the sentence describing the default configuration file name so it doesn't mix kernels and operating systems.
Fabian Keil [Sat, 25 Jun 2011 12:41:17 +0000 (12:41 +0000)]
 
Unblock adainitiative.org/
Fabian Keil [Sat, 25 Jun 2011 12:40:55 +0000 (12:40 +0000)]
 
Remove a double space in an error message
Fabian Keil [Sat, 25 Jun 2011 12:40:27 +0000 (12:40 +0000)]
 
Terminate HTML lines in static error messages with \n instead of \r\n.
Fabian Keil [Sat, 25 Jun 2011 12:39:41 +0000 (12:39 +0000)]
 
Simplify cgi_error_unknown() a bit.
Fabian Keil [Sat, 25 Jun 2011 12:39:18 +0000 (12:39 +0000)]
 
In get_log_timestamp(), use the ISO 8601 date format %Y-%m-%d.
It's only slightly longer than the old format, but contains
the full date including the year and allows sorting by date
(when grepping in multiple log files) without hassle.
Fabian Keil [Thu, 23 Jun 2011 14:04:29 +0000 (14:04 +0000)]
 
Let the msn filter hide elements with the id 's_notf_div'.
They only seem to be used to advertise site 'enhancements'.
Fabian Keil [Thu, 23 Jun 2011 14:03:38 +0000 (14:03 +0000)]
 
Disable the range-requests tagger for tests that break if it's enabled
Fabian Keil [Thu, 23 Jun 2011 14:02:53 +0000 (14:02 +0000)]
 
Delimit the date in log messages with dashes instead of slashes
Fabian Keil [Thu, 23 Jun 2011 14:02:28 +0000 (14:02 +0000)]
 
Accept and highlight: Added header: Content-Encoding: deflate
Fabian Keil [Thu, 23 Jun 2011 14:02:02 +0000 (14:02 +0000)]
 
Accept and highlight: Compressed content from 29258 to 8630 bytes.
Fabian Keil [Thu, 23 Jun 2011 14:01:39 +0000 (14:01 +0000)]
 
Show FEATURE_COMPRESSION on the show-status page
Fabian Keil [Thu, 23 Jun 2011 14:01:01 +0000 (14:01 +0000)]
 
Add support for (re-)compression of buffered content and CGI responses.
For now it has to be explicitly enabled with the configure option --enable-compression.
Fabian Keil [Thu, 23 Jun 2011 13:59:56 +0000 (13:59 +0000)]
 
Add a fast-redirects exception for '.googleusercontent.com/.*=cache'
Fabian Keil [Thu, 23 Jun 2011 13:58:53 +0000 (13:58 +0000)]
 
Let the yahoo filter hide '.ads'
Fabian Keil [Thu, 23 Jun 2011 13:58:22 +0000 (13:58 +0000)]
 
Remove a useless check in write_socket()
Fabian Keil [Thu, 23 Jun 2011 13:57:47 +0000 (13:57 +0000)]
 
In decompress_iob() change a buffer limit check from '==' to the '>=' one would expect at first glance.
At the same time explain why we don't really have to.
Fabian Keil [Sun, 19 Jun 2011 12:17:56 +0000 (12:17 +0000)]
 
Let the msn filter hide overlay ads for Facebook 'likes' in search results.
Fabian Keil [Fri, 27 May 2011 11:37:57 +0000 (11:37 +0000)]
 
Remove two more checks that have been commented out for years
Fabian Keil [Fri, 27 May 2011 11:37:45 +0000 (11:37 +0000)]
 
Do not check for the existence of strerror() and memmove() twice
Fabian Keil [Fri, 27 May 2011 11:36:36 +0000 (11:36 +0000)]
 
Ditch two checks that have been commented out for years already, without causing any issues
Fabian Keil [Fri, 27 May 2011 11:36:15 +0000 (11:36 +0000)]
 
Remove AC_FUNC_SETPGRP as it can cause issues when cross-compiling
I considered only skipping it when cross-compiling, but given
that Privoxy doesn't use setpgrp(2), why should we care about
its prototype?
There's no justification for the check in the revision log
either, except that it was part of "Al's patch".
Fabian Keil [Fri, 27 May 2011 11:34:39 +0000 (11:34 +0000)]
 
Remove a useless '+' in main().
Fabian Keil [Fri, 27 May 2011 11:34:16 +0000 (11:34 +0000)]
 
In LogPutString(), don't bother looking at pszText when not actually logging anything
Fabian Keil [Sun, 22 May 2011 10:31:29 +0000 (10:31 +0000)]
 
Remove -prevent-compression from the fragile alias
We no longer use +prevent-compresssion anywhere by
default and it isn't known to break stuff anyway.
Fabian Keil [Sun, 22 May 2011 10:30:55 +0000 (10:30 +0000)]
 
Garbage collect the strdup() replacement for mingw32
Supposedly it was added ten years ago to paper over a mingw32
bug where the returned pointer couldn't be free'd, but I doubt
that the bug still exists assuming the problem was analyzed
correctly in the first place.
If it does, we should notice soon enough as I'd consider
free'ing pointers returned by strdup() a rather common
operation.
Fabian Keil [Sun, 22 May 2011 10:26:45 +0000 (10:26 +0000)]
 
Garbage collect safe_strerror() which isn't used anywhere
Fabian Keil [Sun, 22 May 2011 10:25:26 +0000 (10:25 +0000)]
 
If only one of the strncmpic() arguments has a length the compiler can figure out, move it to the second place
This will allow to use a macro to figure out the length later on.
Fabian Keil [Sun, 22 May 2011 10:21:54 +0000 (10:21 +0000)]
 
Change a ssplit() call to use SZ(array) as the third parameter instead of the hardcoded 3
Silences a clang complaint now that the ssplit() prototype has been fixed.
Fabian Keil [Sun, 22 May 2011 10:20:05 +0000 (10:20 +0000)]
 
Change ssplit()'s fourth parameter from int to the proper size_t
As pointed out by clang, size_t's don't necessarily have the
same width as int's and while I'm not aware of any actual
issues caused by this (here), it doesn't hurt to use the right
type anyway.
Fabian Keil [Sun, 15 May 2011 10:49:33 +0000 (10:49 +0000)]
 
Mention some of the fun one can experience when not explicitly configuring a IP addresses to listen to.
Fabian Keil [Sun, 15 May 2011 10:48:58 +0000 (10:48 +0000)]
 
Improve the listen-address documentation
Explicitly mention that hostnames can be used instead of
IP addresses, that only the first address returned will
be used and what happens if the address is invalid.
Requested by Cálestyo in #
3302213.
Fabian Keil [Sun, 8 May 2011 13:31:05 +0000 (13:31 +0000)]
 
Add a -fast-redirects exception for webcache.googleusercontent.com/
Fabian Keil [Sun, 8 May 2011 13:30:17 +0000 (13:30 +0000)]
 
Fix white-space.
Fabian Keil [Sun, 8 May 2011 13:29:59 +0000 (13:29 +0000)]
 
Use a more traditional for loop to iterate over the tests in execute_regression_tests()
While it doesn't really matter for the number of tests we have,
there's no reason to keep all the test numbers in memory.
Fabian Keil [Sun, 8 May 2011 13:28:13 +0000 (13:28 +0000)]
 
Reduce empty lines in init_our_variables().
Fabian Keil [Sun, 8 May 2011 13:27:53 +0000 (13:27 +0000)]
 
Simplify check_header_result() a bit.
Fabian Keil [Sun, 8 May 2011 13:27:10 +0000 (13:27 +0000)]
 
Fix spelling in two error messages.
Fabian Keil [Sun, 8 May 2011 13:26:24 +0000 (13:26 +0000)]
 
Add a warning that the statistics currently can't be trusted.
Mention Privoxy-Log-Parser's --statistics option as
an alternative for the time being.
Fabian Keil [Sun, 8 May 2011 13:25:14 +0000 (13:25 +0000)]
 
Add: 92) The statistics currently aren't calculated correctly by Privoxy
Fabian Keil [Tue, 3 May 2011 10:33:53 +0000 (10:33 +0000)]
 
Do not expect a trailing dot in: Request from 10.0.0.1 marked for blocking. limit-connect{0} doesn't allow CONNECT requests to example.org:443
I intended to add one, but decided to go with the submitted version.
Fabian Keil [Tue, 3 May 2011 10:19:20 +0000 (10:19 +0000)]
 
Highlight the hostport in: Request from 10.0.0.1 marked for blocking. limit-connect{0} doesn't allow CONNECT requests to example.org:443.
Fabian Keil [Tue, 3 May 2011 10:15:54 +0000 (10:15 +0000)]
 
Include the destination host in the 'Request ... marked for blocking. limit-connect{...} doesn't allow CONNECT ...' message
Patch submitted by Saperski in #
3296250.
Fabian Keil [Tue, 3 May 2011 10:13:21 +0000 (10:13 +0000)]
 
Point out that the SourceForge messaging system works like a blackhole and should thus not be used
Fabian Keil [Tue, 3 May 2011 10:12:23 +0000 (10:12 +0000)]
 
In unbreak_lines_only_loop(), accept ISO 8601 time stamps, too
Fabian Keil [Tue, 3 May 2011 10:11:24 +0000 (10:11 +0000)]
 
In rfc2553_connect_to(), prevent a duplicated log message if none of the resolved IP addresses were connectable
Fabian Keil [Tue, 3 May 2011 09:55:35 +0000 (09:55 +0000)]
 
Prevent a NULL-pointer dereference in connect_to()
It happened in case of address resolution failures when
there was no forwarding proxy enabled for the request in
the config file and forward-override{} wasn't used at all.
Regression introduced in v1.98 by yours truly.
Patch submitted by saperski in #
3296527.
Fabian Keil [Wed, 27 Apr 2011 18:11:05 +0000 (18:11 +0000)]
 
In connect_to(), do not pretent to retry if forwarded-connect-retries is zero or unset.
Fabian Keil [Tue, 26 Apr 2011 16:55:08 +0000 (16:55 +0000)]
 
Split the --user delimiter skipping across two lines and add comments.
Fabian Keil [Tue, 26 Apr 2011 16:53:21 +0000 (16:53 +0000)]
 
Make a copy of the --user value and only mess with that when splitting user and group.
On some operating systems modifying the value directly
is reflected in the output of ps and friends and can
be misleading.
While at it, use a pointer name that gives a hint
what the pointer is actually supposed to point to.
Fixes #
3292710 reported by zepard.
Fabian Keil [Tue, 26 Apr 2011 16:50:11 +0000 (16:50 +0000)]
 
Remove a harmless but pointless line in the code to handle the --user argument.
If p is not NULL, --p already has been set to '\0' previously
and it hadn't, it would be too late now as we are done with p.
Fabian Keil [Tue, 26 Apr 2011 16:48:56 +0000 (16:48 +0000)]
 
When a specified user or group can't be found, put the name in single-quotes when logging it.
Fabian Keil [Tue, 26 Apr 2011 16:48:04 +0000 (16:48 +0000)]
 
If the --user argument user[.group] contains a dot, always bail out if no group has been specified.
Previously the intended, but undocumented, behaviour was to
try interpreting the whole argument as user name, but the
detection was flawed and checked for '0' isntead of '\0',
thus merely preventing group names beginning with a zero.
Remove the incorrect check instead of fixing it to get
the documented behaviour.
Fabian Keil [Tue, 19 Apr 2011 13:18:46 +0000 (13:18 +0000)]
 
Merge a typo fix.
Fabian Keil [Tue, 19 Apr 2011 13:14:10 +0000 (13:14 +0000)]
 
Fix spelling errors in the documentation. Found with codespell.
Fabian Keil [Tue, 19 Apr 2011 13:10:11 +0000 (13:10 +0000)]
 
Fix spelling errors found with codespell.
Fabian Keil [Tue, 19 Apr 2011 13:08:51 +0000 (13:08 +0000)]
 
Fix a perldoc syntax error.
Fabian Keil [Tue, 19 Apr 2011 13:00:47 +0000 (13:00 +0000)]
 
Fix various spelling errors in the comments.
Found with codespell.
Fabian Keil [Tue, 19 Apr 2011 11:42:51 +0000 (11:42 +0000)]
 
Add a --disable-ipv6-support switch for platforms where support is detected but doesn't actually work.
Fabian Keil [Tue, 19 Apr 2011 11:42:12 +0000 (11:42 +0000)]
 
Rename the --disable-acl-files switch to --disable-acl-support
Since about 2001, ACL directives are specified in the standard config file.
Fabian Keil [Sat, 16 Apr 2011 17:31:35 +0000 (17:31 +0000)]
 
Clarify what kind of directory layout #67 is talking about.
Fabian Keil [Sat, 16 Apr 2011 17:31:24 +0000 (17:31 +0000)]
 
Mention #41 in #65
Fabian Keil [Sat, 16 Apr 2011 17:31:11 +0000 (17:31 +0000)]
 
In #42, note that the DTrace bible is preordered.
Fabian Keil [Sat, 16 Apr 2011 17:30:36 +0000 (17:30 +0000)]
 
Rephrase #40 which could be easily misunderstood.
Fabian Keil [Sat, 16 Apr 2011 17:30:23 +0000 (17:30 +0000)]
 
Remove #39. jarfile support got garbage collected before the 3.0.12 release.