SOCKS Proxy Client and Server
The :std/net/socks
package provides functionality for using and running SOCKS proxies.
::: To use bindings from this module
(import :std/net/socks)
:::
SOCKS Client
You can create a SOCKS client using socks-proxy
. The returned
object is an instance of the SOCKS
interface, which you can use to
connect to another host or bind to accept an incoming connection.
SOCKS
(interface SOCKS
(protocol)
(proxy-address)
(connect (address :~ address?))
(bind (address :~ (maybe address?) := #f)))
This is the SOCKS client interface. The following methods create and operate on instances of the interface.
socks-connect
(socks-connect proxy-address [protocol = 'SOCKS4]) -> lambda (address) -> StreamSocket
Creates a connector function for establishing connextions through the
proxy at proxy-address
.
socks-proxy
(socks-proxy proxy-address (protocol SOCKS4)) -> SOCKS
address := inet address
protocol := symbol; one of SOCKS4, SOCKS4a, SOCKS5.
Connect to a SOCKS proxy, using the specified protocol
.
Returns an instance of the SOCKS
interface.
SOCKS-protocol
(SOCKS-protocol socks)
socks := instance of SOCKS
Returns the protocol used by a SOCKS
instance, as a symbol
SOCKS-proxy-address
(SOCKS-protocol socks)
socks := instance of SOCKS
Returns the address of the proxy behind a SOCKS
instance.
SOCKS-connect
(SOCKS-connect socks address) -> StreamSocket
socks := instance of SOCKS
address := inet address
Connects to address
through the proxy behind the SOCKS
instance.
Returns a StreamSocket
instance.
SOCKS-bind
(SOCKS-connect socks (maybe-address #f) -> ServerSocket
socks := instance of SOCKS
address := inet address or #f
Binds a listener in the proxy behind the SOCKS
instance for accepting an incoming
connection. Returns an instance of ServerSocket
.
Example
Here is how to use a SOCKS proxy listening at your-proxy-server-address
for http connections:
(parameterize ((http-connect (socks-connect your-proxy-server-address)))
(http-get "https://www.google.com"))