From 92494597ce18e21ca8db4d0cd7ba1be3ba05e735 Mon Sep 17 00:00:00 2001 From: Yawning Angel Date: Sun, 25 May 2014 09:14:14 +0000 Subject: Wire in go.net/proxy, enabling SOCKS5 via TOR_PT_PROXY. With tor patched to support 8402, obfs4 bootstraps via a SOCKSv5 proxy now. Other schemes will bail with a PROXY-ERROR, as the go.net/proxy package does not support them, and I have not gotten around to writing dialers for them yet (next on my TODO list). Part of issue #7. --- obfs4proxy/obfs4proxy.go | 29 +++++++++++++++++++---------- 1 file changed, 19 insertions(+), 10 deletions(-) (limited to 'obfs4proxy/obfs4proxy.go') diff --git a/obfs4proxy/obfs4proxy.go b/obfs4proxy/obfs4proxy.go index 2e8a011..c00ee88 100644 --- a/obfs4proxy/obfs4proxy.go +++ b/obfs4proxy/obfs4proxy.go @@ -53,6 +53,7 @@ import ( "io/ioutil" "log" "net" + "net/url" "os" "os/signal" "path" @@ -222,7 +223,7 @@ func serverSetup() (launched bool) { return } -func clientHandler(conn *pt.SocksConn) error { +func clientHandler(conn *pt.SocksConn, proxyURI *url.URL) error { defer conn.Close() var addr string @@ -254,8 +255,13 @@ func clientHandler(conn *pt.SocksConn) error { }() defer logAndRecover(nil) - remote, err := obfs4.DialObfs4("tcp", conn.Req.Target, nodeID, publicKey, - iatObfuscation) + dialFn, err := getProxyDialer(proxyURI) + if err != nil { + log.Printf("[ERROR] client: failed to get proxy dialer: %s", err) + conn.Reject() + return err + } + remote, err := obfs4.DialObfs4DialFn(dialFn, "tcp", conn.Req.Target, nodeID, publicKey, iatObfuscation) if err != nil { log.Printf("[ERROR] client: %p: Handshake failed: %s", remote, err) conn.Reject() @@ -272,7 +278,7 @@ func clientHandler(conn *pt.SocksConn) error { return nil } -func clientAcceptLoop(ln *pt.SocksListener) error { +func clientAcceptLoop(ln *pt.SocksListener, proxyURI *url.URL) error { defer ln.Close() for { conn, err := ln.AcceptSocks() @@ -282,7 +288,7 @@ func clientAcceptLoop(ln *pt.SocksListener) error { } continue } - go clientHandler(conn) + go clientHandler(conn, proxyURI) } } @@ -296,17 +302,20 @@ func clientSetup() (launched bool) { ptClientInfo, err := pt.ClientSetup([]string{obfs4Method}) if err != nil { log.Fatal(err) - return } ptClientProxy, err := ptGetProxy() if err != nil { log.Fatal(err) - return } if ptClientProxy != nil { - // XXX: Remove this once done. - ptProxyError("proxy are not supported yet") + // XXX: Limit this to SOCKS5 for now. + if ptClientProxy.Scheme != "socks5" { + ptProxyError(fmt.Sprintf("proxy scheme not supported: %s", + ptClientProxy.Scheme)) + return + } + ptProxyDone() } for _, methodName := range ptClientInfo.MethodNames { @@ -317,7 +326,7 @@ func clientSetup() (launched bool) { pt.CmethodError(methodName, err.Error()) break } - go clientAcceptLoop(ln) + go clientAcceptLoop(ln, ptClientProxy) pt.Cmethod(methodName, ln.Version(), ln.Addr()) ptListeners = append(ptListeners, ln) launched = true -- cgit v1.2.3