Go to file
2020-08-31 14:46:08 +08:00
_example fix example 2020-08-07 08:22:39 +08:00
.github/workflows fix ci 2020-08-30 11:15:05 +08:00
bufferpool add associate test 2020-08-06 14:31:36 +08:00
ccsocks5 fix ci 2020-08-30 11:15:05 +08:00
statute fix ci 2020-08-30 11:15:05 +08:00
testing fix test 2020-08-06 20:15:25 +08:00
.gitignore use buffer pool interface 2020-08-06 10:12:46 +08:00
.golangci.yaml fix ci 2020-08-30 11:15:05 +08:00
.revive.toml fix ci 2020-08-31 14:46:08 +08:00
.travis.yml fix ci 2020-08-31 14:46:08 +08:00
auth_test.go add more test 2020-08-05 14:40:07 +08:00
auth.go add more test 2020-08-05 14:40:07 +08:00
credentials_test.go add more test 2020-08-05 14:40:07 +08:00
credentials.go add more test 2020-08-05 14:40:07 +08:00
go.mod add header test 2020-08-05 10:34:29 +08:00
go.sum add header test 2020-08-05 10:34:29 +08:00
handle_test.go fix ci 2020-08-30 11:15:05 +08:00
handle.go fix testing 2020-08-10 08:34:34 +08:00
LICENSE Initial commit 2014-01-22 15:49:51 -08:00
logger.go add user handle 2020-04-22 10:15:40 +08:00
option.go add associate test 2020-08-06 14:31:36 +08:00
README.md fix readme 2020-08-10 08:41:33 +08:00
resolver_test.go add more test 2020-08-05 14:40:07 +08:00
resolver.go add user handle 2020-04-22 10:15:40 +08:00
revive.sh fix ci 2020-08-31 14:46:08 +08:00
ruleset_test.go fix request/response statute 2020-08-05 18:10:50 +08:00
ruleset.go add more test 2020-08-05 14:40:07 +08:00
server_test.go fix ci 2020-08-30 11:15:05 +08:00
server.go fix ci 2020-08-30 11:15:05 +08:00

go-socks5

GoDoc Go.Dev reference Build Status Action Status codecov Go Report Card License Tag

Provides the socks5 package that implements a SOCKS5. 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.

Feature

The package has the following features:

  • Support client(under ccsocks5 directory) and server(under root directory)
  • Support TCP/UDP and IPv4/IPv6
  • Unit tests
  • "No Auth" mode
  • User/Password authentication optional user addr limit
  • Support for the CONNECT command
  • Support for the ASSOCIATE command
  • Rules to do granular filtering of commands
  • Custom DNS resolution
  • Custom goroutine pool
  • buffer pool design and optional custom buffer pool
  • Custom logger

TODO

The package still needs the following:

  • Support for the BIND command

Installation

Use go get.

    go get github.com/thinkgos/go-socks5

Then import the socks5 server package into your own code.

    import "github.com/thinkgos/go-socks5"

or

import the socks5 client package into your own code.

    import "github.com/thinkgos/go-socks5/ccsocks5"

Example

Below is a simple example of usage, more see example

    // Server: 

    // Create a SOCKS5 server
    server := socks5.NewServer()
    
    // Create SOCKS5 proxy on localhost port 8000
    if err := server.ListenAndServe("tcp", ":8000"); err != nil {
      panic(err)
    }
   // Client: 
   client := ccsocks5.NewClient("127.0.0.1:10800")
    conn, err := client.Dial("tcp", "127.0.0.1:12345") // server you want to visitor
    if err != nil {
    	panic(err)
    }
    conn.Write([]byte("hahaha"))
    time.Sleep(time.Second)

Reference