dest-unreach / socat / socat-version2
socat version 2 is currently under development. Its main enhancement are so called address chains that concatenate simple addresses. Address chains are similar to command shell pipes, but they work bidirectionally.
Here is a simple example that drives OpenSSL via SCTP/IPv6:
socat - 'OPENSSL,verify=0 | SCTP6:sctp.domain.com:443'
A more complex example connects with TCP to an HTTP proxy server on port 8080, requests a connection to home.provider.com:443, then drives OpenSSL over the proxy to the home server (where a socks server is prepared), and requests a socks connection to some target server:
socat - 'SOCKS:www.forbidden.org:80|OPENSSL-CLIENT,cafile=./server.crt|PROXY:home.provider.com:443|TCP:proxy.domain.com:8080
Documentation: man page in the package; address chain mini howto; integration of external programs; a less detailled introduction to the new features can be found in the Linuxwochen presentation starting with slide 39.
Currently socat version 2 is in beta state. socat 2.0.0-b1 was branched off
socat 126.96.36.199; 2.0.0-b2 is a merge of 2.0.0-b1 and 188.8.131.52, that means it is
directly derived from 2.0.0-b1 but contains all bug fixes and features that
have been introduced with versions 184.108.40.206 and 220.127.116.11.
2.0.0-b3 is a merge of 2.0.0-b2 and 18.104.22.168.
Beta development state currently means: has not been compiled on a system other than Linux; no systematic tests beyond executing the test.sh script have been performed; documentation is incomplete. Bugs that occur during beta development but have not been present in version 1 will be fixed without notice. More significant changes might be performed before the stable release.
Download: socat-2.0.0-b8.tar.gz, socat-2.0.0-b8.tar.bz2