Provides the socks5
package that implements a SOCKS5 server.
SOCKS (Secure Sockets) is used to route traffic between a client and server through
an intermediate proxy layer. This can be used to bypass firewalls or NATs.
The package has the following features:
- "No Auth" mode
- User/Password authentication
- Support for the CONNECT command
- Rules to do granular filtering of commands
- Custom DNS resolution
- Unit tests
The package still needs the following:
- Support for the BIND command
- Support for the ASSOCIATE command
This fork contains a few changes to the original package:
- Add go modules support
- Replace
golang.org/x/net/context
withcontext
; - Add
Password
to payload ofsocks5.AuthContext
created bysocks5.UserPassAuthenticator
; - Add
RuleSetFunc
implementsRuleSet
interface for simplifying rules creation; - Add
CredentialStoreFunc
implementsCredentialStore
interface for simplifying credentials creation; - Allow to use multiple
Authenticator
insocks5.Server
(it will be used in reverse code order); - Add func for get and set
net.Conn
in context - Fix bug with closing connections
- Small hack with conn on handle request (use net.Conn from context)
Below is a simple example of usage
// Create a SOCKS5 server
conf := &socks5.Config{}
server, err := socks5.New(conf)
if err != nil {
panic(err)
}
// Create SOCKS5 proxy on localhost port 8000
if err := server.ListenAndServe("tcp", "127.0.0.1:8000"); err != nil {
panic(err)
}