Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/things-go/go-socks5
socks5 server in pure Golang with much custom optional. Full TCP/UDP and IPv4/IPv6 support.
https://github.com/things-go/go-socks5
socks5 socks5-client socks5-server
Last synced: 3 months ago
JSON representation
socks5 server in pure Golang with much custom optional. Full TCP/UDP and IPv4/IPv6 support.
- Host: GitHub
- URL: https://github.com/things-go/go-socks5
- Owner: things-go
- License: mit
- Created: 2020-04-19T06:05:29.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-10-07T06:35:49.000Z (5 months ago)
- Last Synced: 2024-11-04T08:50:03.290Z (4 months ago)
- Topics: socks5, socks5-client, socks5-server
- Language: Go
- Homepage:
- Size: 232 KB
- Stars: 403
- Watchers: 7
- Forks: 69
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# go-socks5
[data:image/s3,"s3://crabby-images/d25a2/d25a21b9400acc373354c31a8cc830562e6acb88" alt="GoDoc"](https://godoc.org/github.com/things-go/go-socks5)
[data:image/s3,"s3://crabby-images/fa605/fa60598c46418f002df7755b9c641c2668b4b3d3" alt="Go.Dev reference"](https://pkg.go.dev/github.com/things-go/go-socks5?tab=doc)
data:image/s3,"s3://crabby-images/767cf/767cfbeb952aa5fe0ad7672f90e47f9167a0af93" alt="Action Status"
[data:image/s3,"s3://crabby-images/5f6a0/5f6a0212548ac34faa3115241e99f5b05f63c7f6" alt="codecov"](https://codecov.io/gh/things-go/go-socks5)
[data:image/s3,"s3://crabby-images/0aaf9/0aaf9f93fb8825cad4cd05414e2a516adbd38c37" alt="Go Report Card"](https://goreportcard.com/report/github.com/things-go/go-socks5)
[data:image/s3,"s3://crabby-images/c638b/c638bd41135b20aaf97fa830092a96da52f0adeb" alt="License"](https://github.com/things-go/go-socks5/raw/master/LICENSE)
[data:image/s3,"s3://crabby-images/46c9e/46c9e0f604e28859da552a823383364601fae5c7" alt="Tag"](https://github.com/things-go/go-socks5/tags)Provides the `socks5` package that implements a [SOCKS5](http://en.wikipedia.org/wiki/SOCKS).
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 socks5 server
- 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.
```bash
go get github.com/things-go/go-socks5
```Then import the socks5 server package into your own code.
```bash
import "github.com/things-go/go-socks5"
```### Example
Below is a simple example of usage, more see [example](https://github.com/things-go/go-socks5/tree/master/_example)
[embedmd]:# (_example/main.go go)
```go
package mainimport (
"log"
"os""github.com/things-go/go-socks5"
)func main() {
// Create a SOCKS5 server
server := socks5.NewServer(
socks5.WithLogger(socks5.NewLogger(log.New(os.Stdout, "socks5: ", log.LstdFlags))),
)// Create SOCKS5 proxy on localhost port 8000
if err := server.ListenAndServe("tcp", ":8000"); err != nil {
panic(err)
}
}
```### Reference
- [rfc1928](https://www.ietf.org/rfc/rfc1928.txt)
- original armon's [go-sock5](https://github.com/armon/go-socks5) library## License
This project is under MIT License. See the [LICENSE](LICENSE) file for the full license text.