- Add -f option for loading configuration from file (pull req #193).
- Add
sudotest
target with unit tests which require privileges to run. - Minor bugfixes and improvements.
- Add -a and -b for initial basic client certificate support (pull req #194 by @naf419, issue #46).
- Respect
SOURCE_DATE_EPOCH
for reproducible builds (pull req #192 by @anthraxx). - Sign using SHA-256 instead of SHA-1 when key type of server and key type of used CA certificate differ (issue #189).
- Fix keyUsage to match the type of leaf key used instead of copying from upstream certificate (issue #195).
- Fix build with OpenSSL 1.1.1 (pull req #186 by @sonertari, issue #183).
- Fix build on FreeBSD 12 (patch-proc.c r436571 from FreeBSD ports).
- Minor bugfixes and improvements.
- Add support for SSLv2 ClientHello handshake format for SSLv3/TLS connections and while there, essentially fixing autossl for clients using SSLv2 ClientHello handshake format with SSLv3/TLS (#185).
- Suppress Upgrade header in order to prevent upgrading connections to WebSockets or HTTP/2 (#91).
- Add -M for writing an SSLKEYLOGFILE compatible log file (issue #184).
- Fix error handling for Darwin libproc functions (-i).
- Fix session cache misses and failed unit tests on MIPS by fixing undefined behaviour in session cache hash functions (Debian #848919 and #851271).
- Synthesize MAC addresses to avoid the requirement for root privileges and waiting for ARP timeouts on some platforms in log2pcap.py (issue #169).
- Minor bugfixes and improvements.
- Dump master key in NSS key log format in debug mode, allowing decryption of SSL connections using Wireshark (issue #121).
- Add support for DSA and ECDSA certificates using hash algorithms other than SHA-1.
- Copy basicConstraints, keyUsage and extendedKeyUsage X509v3 extensions from the original certificate and only generate them anew if they were not present (issue #73).
- Add -q to set the CRL distribution point on all forged certificates (pull req #159 by @antalos).
- Add IPv6 support to netfilter NAT engine (pull req #179 by @armakar).
- Extend -L content logging with EOF message to allow log parsers to figure out when a connection ends (issue #128 by @mattes). Note that log parsers need to be adjusted to handle the new EOF message.
- Fix potential segfaults in src.bev/dst.bev (pull req #174 by @sonertari).
- Fix SSL connections that result from autossl to shutdown cleanly.
- Fix data processing when EOF is received before all incoming data has been processed.
- Fix multiple signal handling issues in the privilege separation parent which led to the parent process being killed ungracefully (SIGTERM) or being stuck in wait() while still having signals (SIGQUIT etc) queued up for forwarding to the child process (issue #137).
- No longer assume an out of memory condition when a certificate contains neither a CN nor a subjectAltName extension.
- Fix parallel make build (-j) for the test target (issue #140).
- Do not set owner and group if install target is called by unprivileged user (pull req #141 by @cgroschupp).
- Fix build with OpenSSL 1.1.0 and later (pull req #154 by @hillu, #156 by @pduldig-at-tw and issue #148).
- Add XNU headers for Mac OS X El Capitan 10.11.3 to 10.11.6, Sierra 10.12 to 10.12.6 and High Sierra 10.13; fix headers for Mac OS X 10.6 to 10.6.8.
- Minor bugfixes and improvements.
- Generically support STARTTLS through the new autossl proxyspec type that upgrades a TCP connection to SSL/TLS when a ClientHello message is seen (based on contribution by @RichardPoole42, pull req #87).
- Add separate src/dst host and port format specifiers %S, %p, %D and %q to -F (pull req #74 by @AdamJacobMuller).
- Add options -w and -W to write generated leaf key, original and forged certificates to disk (issue #67 by @psychomario).
- Add signal SIGUSR1 to re-open long-living -l/-L log files (issue #52).
- Add contributed -L log parsing scripts to extra/, including conversion to PCAP using emulated IP and TCP headers (contributed by @mak, issue #27).
- Enable full-strength DHE and ECDHE by default, even for non-RSA leaf keys, in order to avoid weak cipher warnings from browsers (issue #119).
- Use the same hash algorithm in signatures on forged certificates as the original certificates use, instead of always using SHA-1.
- Removed all references to SHA-1 and small key RSA root CA keys from documentation, examples and unit testing (issue #83).
- Introduce privilege separation architecture with privileged parent process and unprivileged child process; all files are now opened with the privileges of the user running SSLsplit; arguments to -S/-F are no longer relative to the chroot() if used with the -j option.
- Filenames generated by -S and -F %d and %s changed from [host]:port to host,port format and using underscore instead of colon in IPv6 addresses in order to be NTFS clean (issue #69).
- Connect log format: host and port are now separate fields (issues #69 #74).
- Only initialize DNS subsystems when DNS lookups are actually needed by the loaded proxy specifications (related to issue #104).
- Removed the non-standard word "unmodified" from the 2-clause BSD license.
- Warn when an OpenSSL version mismatch is detected (issue #88).
- Add XNU headers for OS X 10.11 El Capitan (issue #116).
- Fix EV_READ event re-enable bug that could lead to stalled connections after throttling one direction (issue #109).
- Fix build with LibreSSL that lacks recent OpenSSL API additions.
- Fix build with OpenSSL versions that had SSLv3 support removed.
- Fix a rare segmentation fault upon receiving EOF on the outbound connection while it has not been established yet (patch by @eunsoopark, issue #124).
- Fix SSL sessions to actually time out (patch by @eunsoopark, issue #115).
- Fix passthrough mode with -t and an empty directory (issue #92).
- Minor bugfixes and improvements.
- Fix loading of certificate chains with OpenSSL 1.0.2 (issue #79).
- Fix build on Mac OS X 10.10.2 by improving XNU header selection.
- Add option -F to log to separate files with printf-style % directives, including process information for connections originating on the same system when also using -i (pull reqs #36, #53, #54, #55 by @landonf).
- Add option -i to look up local process owning a connection for logging to connection log; initial support on Mac OS X (by @landonf) and FreeBSD.
- Add option -r to force a specific SSL/TLS protocol version (issue #30).
- Add option -R to disable specific SSL/TLS protocol versions (issue #30).
- Disallow -u with pf proxyspecs on Mac OS X because Apple restricts ioctl(/dev/pf) to root even on an fd initially opened by root (issue #65).
- Extend the certificate loading workaround for OpenSSL 1.0.0k and 1.0.1e also to OpenSSL 0.9.8y; fixes cert loading crash due to bug in in OpenSSL.
- Extend Mac OS X pf support to Yosemite 10.10.1.
- Fix startup memory leaks in key/cert loader (pull req #56 by @wjjensen).
- Replace WANT_SSLV2_CLIENT and WANT_SSLV2_SERVER build knobs with a single WITH_SSLV2 build knob.
- Minor bugfixes and improvements.
- Filter out HSTS response header to allow users to accept untrusted certs.
- Build without SSLv2 support by default (issue #26).
- Add primary group override (-m) when dropping privileges to an unprivileged user (pull req #35 by @landonf).
- Support pf on Mac OS X 10.10 Yosemite and fix segmentation fault if no NAT engine is available (pull req #32 by @landonf).
- Support DESTDIR and MANDIR in the build (pull req #34 by @swills).
- No longer chroot() to /var/empty by default if run by root, in order to prevent breaking -S and sni proxyspecs (issue #21).
- Load -t certificates before dropping privileges (issues #19 and #20).
- Fix segmentation fault when using -t without a CA.
- Minor bugfixes and improvements.
- Filter out Alternate-Protocol response header to suppress SPDY/QUIC.
- Add experimental support for pf on Mac OS X 10.7+ (issue #15).
- Also build ipfw NAT engine if pf is detected to support pf divert-to.
- Unit tests (make test) no longer require Internet connectivity.
- Always use SSL_MODE_RELEASE_BUFFERS when available, which lowers the per connection memory footprint significantly when using OpenSSL 1.0.0+.
- Fix memory corruption after the certificate in the cache had to be updated during connection setup (issue #16).
- Fix file descriptor leak in passthrough mode (-P) after SSL errors.
- Fix OpenSSL data structures memory leak on certificate forgery.
- Fix segmentation fault on connections without SNI hostname, caused by compilers optimizing away a NULL pointer check (issue #14).
- Fix thread manager startup failure under some circumstances (issue #17).
- Fix segmentation faults if thread manager fails to start (issue #10).
- Fix remaining threading issues in daemon mode.
- Filter HPKP header lines from HTTP(S) response headers in order to prevent public key pinning based on draft-ietf-websec-key-pinning-06.
- Add HTTP status code and content-length to connection log.
- Fix fallback to passthrough (-P) when no matching certificate is found for a connection (issue #9).
- Work around segmentation fault when loading certificates caused by a bug in OpenSSL 1.0.0k and 1.0.1e.
- Fix binding to ports < 1024 with default settings (issue #8).
- Add support for 2048 and 4096 bit Diffie-Hellman.
- Fix syslog error messages (issue #6).
- Fix threading issues in daemon mode (issue #5).
- Fix address family check in netfilter NAT lookup (issue #4).
- Fix build on recent glibc systems (issue #2).
- Minor code and build process improvements.
- Improve OCSP denial for GET based OCSP requests.
- Default elliptic curve is now 'secp160r2' for better ECDH performance.
- More user-friendly handling of -c, -k and friends.
- Unit test source code renamed from *.t to *.t.c to prevent them from being misdetected as perl instead of c by Github et al.
- Minor bugfixes.
- Add generic OCSP denial (-O). OCSP requests transmitted over HTTP or HTTPS are recognized and denied with OCSP tryLater(3) responses.
- Minor bugfixes.
First public release.