- Announcing Privoxy 3.0.34 stable
+ Announcing Privoxy 4.0.0 stable
--------------------------------------------------------------------
-Privoxy 3.0.34 fixes a few minor bugs and comes with a couple of
-general improvements and new features.
+Privoxy 4.0.0 fixes a few minor bugs and comes with a couple of
+general improvements and new features. HTTPS inspection is no
+longer considered experimental.
-Please note that Google started to bounce messages from the Privoxy
-mailing lists a couple of months ago. As a result gmail users have
-been unsubscribed by Mailman. If you are affected by this, please
-resubscribe with a different mail address. The Privoxy project has
-limited resources and limited time to investigate an issue that
-only affects gmail addresses.
+Two new features have been funded by donations. If you can,
+please consider making a donation to support future improvements.
--------------------------------------------------------------------
-ChangeLog for Privoxy 3.0.34
+ChangeLog for Privoxy 4.0.0
--------------------------------------------------------------------
- Bug fixes:
- - Improve the handling of chunk-encoded responses by buffering the data
- even if filters are disabled and properly keeping track of where the
- various chunks are supposed to start and end. Previously Privoxy would
- merely check the last bytes received to see if they looked like the
- last-chunk. This failed to work if the last-chunk wasn't received in one
- read and could also result in actual data being misdetected
- as last-chunk.
- Should fix: SF support request #1739.
- Reported by: withoutname.
- - remove_chunked_transfer_coding(): Refuse to de-chunk invalid data
- Previously the data could get corrupted even further.
- Now we simply pass the unmodified data to the client.
- - gif_deanimate(): Tolerate multiple image extensions in a row.
- This allows to deanimate all the gifs on:
- https://commons.wikimedia.org/wiki/Category:Animated_smilies
- Fixes SF bug #795 reported by Celejar.
- - OpenSSL generate_host_certificate(): Use X509_get_subject_name()
- instead of X509_get_issuer_name() to get the issuer for generated
- website certificates so there are no warnings in the browser when using
- an intermediate CA certificate instead of a self-signed root certificate.
- Problem reported and patch submitted by Chakib Benziane.
- - can_filter_request_body(): Fix a log message that contained a spurious u.
- - handle_established_connection(): Check for pending TLS data from the client
- before checking if data is available on the connection.
- The TLS library may have already consumed all the data from the client
- response in which case poll() and select() will not detect that data is
- available to be read.
- Sponsored by: Robert Klemme.
- - ssl_send_certificate_error(): Don't crash if there's no certificate
- information available. This is only relevant when Privoxy is built with
- wolfSSL 5.0.0 or later (code not yet published). Earlier wolfSSL versions
- or the other TLS backends don't seem to trigger the crash.
- - socks5_connect(): Add support for target hosts specified as IPv4 address
- Previously the IP address was sent as domain.
+ - Add missing client-body-tagger data to the action_type_info[] struct
+ so lookups based on the action index work correctly again.
+ Prevents assertion failures or segfaults when trying to edit
+ an action file with the CGI editor.
+ The type of failure depended on whether or not assertions
+ were enabled and on whether or not Privoxy had been compiled
+ with FEATURE_EXTERNAL_FILTERS.
+ Regression introduced in Privoxy 3.0.34.
+ Patch submitted by Aaron Li in #940.
+ - Bump MAX_FILTER_TYPES which should have been done in d128e6aa4
+ when introducing the client-body-tagger{} action.
+ Prevents an assertion in cgi_edit_actions_for_url() from triggering
+ after e32d03e0 when using the CGI editor with assertions enabled.
+ - is_untrusted_url(): Search the encrypted headers for the Referer
+ when the client is using https and https inspection is enabled.
+ Fixes the trust mechanism for https requests.
+ Reported by Laurent Caumont in #1767.
+ - GNUMakefile.in: Let the install target work if no group is specified.
+ - GNUMakefile.in: Set GROUP_T when installing configuration files as root
+ and there is no privoxy user available so the install target doesn't
+ fail. Patch by Fabrice Fontaine.
+ - GNUmakefile.in: Don't exit if configuration files are installed as root
+ as this can be considered acceptable when cross-compiling
+ Privoxy inside an autobuilder with only a root user.
+ Patch by Fabrice Fontaine.
+ - configure.in: Fix argument types in gmtime_r() and localtime_r() probes.
+ Otherwise these probes always fail with stricter compilers
+ even if there is C library support for these functions.
+ Patch submitted by Florian Weimer in SF#149.
+ - Fix socks4 and socks4a support under glibc's source fortification.
+ With glibc's source fortification, gcc offers the compilation warning
+ resulting in a runtime abort() when using a socks4 or socks4a upstream proxy.
+ Despite the warning, the strlcpy() call in question is fine: gcc
+ misidentifies the size of the destination buffer, estimating to hold
+ only a single char while in fact the buffer stretches beyond the end of
+ the struct socks_op.
+ The issue was originally reported in the NixOS issue tracker at
+ https://github.com/NixOS/nixpkgs/issues/265654
+ prompted by an upgrade of glibc from 2.37-39 to 2.38-0.
+ Patch submitted by Ingo Blechschmid, joint work with
+ @esclear and @richi235.
- General improvements:
- - Add a client-body-tagger action which creates tags based on
- the content of the request body.
- Sponsored by: Robert Klemme.
- - When client-body filters are enabled, buffer the whole request
- before opening a connection to the server.
- Makes it less likely that the server connection times out
- and we don't open a connection if the buffering fails anyway.
- Sponsored by: Robert Klemme.
- - Add periods to a couple of log messages.
- - accept_connection(): Add missing space to a log message.
- - Initialize ca-related defaults with strdup_or_die() so errors
- aren't silently ignored.
- - make_path: Use malloc_or_die() in cases where allocation errors
- were already fatal anyway.
- - handle_established_connection(): Improve an error message slightly.
- - receive_client_request(): Reject https URLs without CONNECT request.
- - Include all requests in the statistics if mutexes are available.
- Previously in case of reused connections only the last request got
- counted. The statistics still aren't perfect but it's an improvement.
- - Add read_socks_reply() and start using it in socks5_connect()
- to apply the socket timeout more consistently.
- - socks5_connect(): Deal with domain names in the socks reply
- - Add a filter for bundeswehr.de that hides the cookie and
- privacy info banner.
+ - Allow to use wolfSSL for https inspection.
+ wolfSSL supports TLS 1.3 and can be significantly faster than
+ mbedTLS. Mainly tested on ElectroBSD amd64 where it can compete
+ with OpenSSL and LibreSSL:
+ https://www.fabiankeil.de/gehacktes/privoxy-tls-benchmarks/
+ To enable the support, install wolfSSL and run ./configure
+ with the --with-wolfssl option.
+ Sponsored by Privoxy project funds collected at SPI.
+ - Add an test framework that leverages the curl test suite.
+ Sponsored by Privoxy project funds collected at SPI.
+ - Add pcre2 support. Closes bug #935.
+ Initial patch submitted by Gagan Sidhu.
+ - Use SHA256 as hash algorithm for the certificate and key file names
+ instead of MD5. The known MD5 vulnerabilities shouldn't matter for
+ Privoxy's use case but it doesn't hurt to use a hash algorithm that
+ isn't deprecated.
+ Sponsored by: Robert Klemme
+ - Add support for mbedTLS 3.x. This removes a sanity check
+ (whether issuer key and issuer certificate match) that seems
+ overly cautious and fails to compile with mbedTLS 3.x as the
+ struct members are private. We don't have an equivalent check
+ in the OpenSSL or wolfSSL code either.
+ - Factor out newer_privoxy_version_required() and improve the logic
+ Previously 3.0.11 was considered newer than 4.0.0.
+ - init_error_log(): Include the reason for failures to open the log file.
+ - create_client_ssl_connection(): Don't keep the certificate lock
+ longer than necessary.
+ - Add periods to a bunch of log messages.
+ - normalize_lws(): Only log the 'Reducing whitespace ...' message
+ once per header
+ - log_error() Win32: Only call LogShowActivity() for debug level
+ LOG_LEVEL_REQUEST. As of b94bbe62a950, which was part of Privoxy 3.0.29,
+ LOG_LEVEL_REQUEST is used for all requests including crunched ones.
+ Previously LogShowActivity() was called twice for crunched
+ requests, (presumably) resulting in an aborted animation.
+ - Remove ./ prefix from tarball-dist files.
+ - create_client_ssl_connection(): Make it more obvious from an
+ error message that a function failed.
+ - Use stringify() instead of section_target() and remove section_target().
+ Like the XXX comment suggested this could be done my moving the hash
+ into the templates which seems preferable anyway.
+ - Prevent some compiler warnings.
+ - parse_numeric_value(): Expect a base-ten number.
+ - windows/MYconfigure: Have gcc diagnostics in color.
- Action file improvements:
- - Disable filter{banners-by-size} for .freiheitsfoo.de/.
- - Disable filter{banners-by-size} for freebsdfoundation.org/.
- - Disable fast-redirects for consent.youtube.com/.
- - Block requests to ups.xplosion.de/.
- - Block requests for elsa.memoinsights.com/t.
- - Fix a typo in a test.
- - Disable fast-redirects for launchpad.net/.
- - Unblock .eff.org/.
- - Stop unblocking .org/.*(image|banner) which appears to be too generous
- It let requests like:
- https://stats.noblogs.org/piwik.php?action_name=anti%20gentrifizierungs%20fest&idsite=10175&rec=1&r=220192&h=17&m=7&s=44&url=https%3A%2F%2Fmuellemcalling.noblogs.org%2F&urlref=https%3A%2F%2Fmuellemcalling.noblogs.org%2Finfostande%2F&_id=&_idn=1&_refts=0&send_image=0&cookie=1&res=1366x768&pv_id=eqr7jX&pf_net=7&pf_srv=3&pf_tfr=2281&pf_dm1=156
- pass.
- The example URL http://www.gnu.org/graphics/gnu-head-banner.png is
- already unblocked due to .gnu.org being unblocked.
- - Unblock adfd.org/.
- - Disable filter{banners-by-link} for .eff.org/.
- - Block requests to odb.outbrain.com/.
- - Disable fast-redirects for .gandi.net/.
- - Disable fast-redirects{} for .onion/.*/status/.
- - Disable fast-redirects{} for twitter.com/.*/status/.
- - Unblock pinkstinks.de/.
- - Disable fast-redirects for .hagalil.com/.
+ - Block requests for .amazon-adsystem.com/
+ - Block requests to track.venatusmedia.com/
+ - Block requests to i.clean.gg/
+ - Block requests to s.cpx.to/
+ - Block requests to secure-eu.nmrodam.com/
+ - Block requests to o2.mouseflow.com/
+ - Disable fast-redirects for services.akteneinsichtsportal.de/
+ - Disable fast-redirects for /wp-content/plugins/pdf-viewer-for-elementor
+ - Disable fast-redirects for syndication.twitter.com/
+ - Disable fast-redirects for archive.softwareheritage.org/
+ - Disable fast-redirects to duckduckgogg42xjoc72x3sjasowoarfbgcmvfimaftt6twagswzczad.onion/
+ - Disable fast-redirects for .creator-spring.com/_next/image
+ - Disable fast redirects for accounts.bahn.de/
+ - Unblock .datenschmutz.de/
+ - Unblock requests for 'adventur*.'
+ - Unblock adl.windows.com/
+ as it is apparently required to update from Windows 10 to 11.
+ Reported by Sam Varshavchik.
- Privoxy-Log-Parser:
- - Bump version to 0.9.5.
- - Highlight more log messages.
- - Highlight the Crunch reason only once. Previously the "crunch reason"
- could also be highlighted when the URL contained a matching string.
- The real crunch reason only occurs once per line, so there's no need
- to continue looking for it after it has been found once.
- While at it, add a comment with an example log line.
+ - Highlight 'Couldn't deliver the error message for [...]'.
+ - Highlight 'Failed to accept() incoming connection: Software caused connection abort'.
+ - Highlight 'Keeping chunk offset at 0 despite flushing 31 bytes.'.
+ - Highlight 'Not shutting down client connection on socket 8. The socket is no longer alive.'.
+ - Bump version to 0.9.6.
+
+- Privoxy-Regression-Test.pl:
+ - Let the --min-level option increase the --max-level
+ if the latter is smaller than the former.
+ - Add --curl option to use a non-default curl binary.
+ - Bump version to 0.7.5.
- uagen:
- - Bump version to 1.2.4.
- - Update BROWSER_VERSION and BROWSER_REVISION to 102.0
- to match the User-Agent of the current Firefox ESR.
- - Explicitly document that changing the 'Gecko token' is suspicious.
- - Consistently use a lower-case 'c' as copyright symbol.
- - Bump copyright.
- - Add 'aarch64' as Linux architecture.
- - Add OpenBSD architecture 'arm64'.
- - Stop using sparc64 as FreeBSD architecture.
- It hasn't been supported for a while now.
-
-- Build system:
- - Makefile: Add a 'dok' target that depends on the 'error' target
- to show the "You are not using GNU make or did nor run configure"
- message.
- - configure: Fix --with-msan option.
- Also (probably) reported by Andrew Savchenko.
-
-- macOS build system:
- - Enable HTTPS inspection when building the macOS binary
- (using OpenSSL as TLS library).
+ - Bump BROWSER_VERSION and BROWSER_REVISION to match Firefox ESR 128.
+ - Bump version to 1.2.6.
- Documentation:
- - Add OpenSSL to the list of libraries that may be licensed under the
- Apache 2.0 license in which case the linked Privoxy binary has to be
- distributed under the GPLv3 or later.
- - config: Fix the documented ca-directory default value.
- Reported by avoidr.
- - Rebuild developer-manual and tidy with 'HTML Tidy for FreeBSD version 5.8.0'.
- - Update developer manual with new macOS packaging instructions.
- - Note that the FreeBSD installation instructions work for
- ElectroBSD as well.
- - Note that FreeBSD/ElectroBSD users can try to install Privoxy
- as binary package using 'pkg'.
+ - Add HOWTOs for https inspection and client-tags to user-manual.
+ - Suggest to use the force-text-mode action when filtering binary content
+ with external filters.
+ - Declare https-inspection non-experimental.
+ - FAQ: Mention that Privoxy Moral Licenses are available as well.
+ - Fix LibreSSL URL.
+ - Update perlre perldoc URL.
+ - config: Add SOCKS 5 to the list of supported protocols.
+ - In the Windows build section, note that one only needs tidy
+ to build the docs. If you're not building the docbook stuff you
+ don't need tidy.
+ - trust: Use the words 'allowlists' and 'blocklists'
+ instead of "whitelists" and "blacklists" which some
+ people consider to be less inclusive.
-----------------------------------------------------------------
About Privoxy: