An open API service indexing awesome lists of open source software.

https://github.com/ai-ql/go-socks5

Socks5 Server in Golang
https://github.com/ai-ql/go-socks5

golang socks5

Last synced: about 1 year ago
JSON representation

Socks5 Server in Golang

Awesome Lists containing this project

README

          

# Go Socks5

Go-Socks5 provides the `socks5` package that implements a [SOCKS5 server](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.

## Before You Begin
This repository only provides a basic socks5 package written in Golang.

If you need a ready-to-use socks5 proxy server, please refer to: [go-socks5-proxy](https://github.com/AI-QL/go-socks5-proxy).

## Features

The package has the following features:
* "No Auth" mode
* User/Password authentication
* Support for the CONNECT command
* Support for the BIND command
* Support for the ASSOCIATE command
* Rules to do granular filtering of commands
* Custom DNS resolution
* Unit tests

## Example

Below is a simple example of usage

```go
// 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)
}
```

## Godoc

Remember to double-check the Godoc, as it will be auto-generated on [pkg.go.dev](https://pkg.go.dev/github.com/AI-QL/go-socks5).

### Step 1: Install `godoc`
First, ensure that you have `godoc` installed. You can install it using the following command:

```bash
go install golang.org/x/tools/cmd/godoc@latest
```

### Step 2: Run `godoc` Server
Next, run the `godoc` server to serve the documentation for your Go project:

```bash
godoc -http=:6060 -index
```

This command starts a web server on port 6060, serving the documentation for your Go project.

# Reference

This repository was originally cloned from [go-socks5](https://github.com/armon/go-socks5) due to its long period of inactivity. It is a small yet elegant repo, and we aim to use it as a pilot project to transform it into a comprehensive library with thorough documentation and automation. We will also strive to optimize and enhance it using AI.