Skip to main content

A SOCKS5 toolchain/framework with programmable addons

Project description

asyncio-socks-server

Tests Docker Python License

SOCKS5 server with async Python addon hooks.

Docs · Architecture · Addon model · Public API · 简体中文

Install

pip install asyncio-socks-server

Docker images are versioned:

docker run --rm -p 1080:1080 amaindex/asyncio-socks-server:1.2.0

Run

asyncio_socks_server
asyncio_socks_server --host 127.0.0.1 --port 9050
asyncio_socks_server --auth user:pass

CLI flags:

Flag Default Meaning
--host :: Bind address
--port 1080 Bind port
--auth None username:password
--log-level INFO DEBUG, INFO, WARNING, ERROR

Use from Python

from asyncio_socks_server import Server

Server(host="::", port=1080).run()

With addons:

from asyncio_socks_server import ChainRouter, FlowStats, Server, StatsAPI

stats = FlowStats()
server = Server(
    addons=[
        stats,
        StatsAPI(stats=stats, host="127.0.0.1", port=9900),
        ChainRouter("10.0.0.5:1080"),
    ],
)
server.run()

Addon order is execution order. Built-in addons are opt-in; adding StatsAPI is what starts an HTTP listener.

FlowStats has no network side effects. Use its snapshot() and flows() methods directly, or pair it with StatsAPI for a small local HTTP API.

Model

The core handles SOCKS5 parsing, relay, and hook dispatch. Addons handle policy.

Hook dispatch has three models:

Model Hooks Contract
Competitive on_auth, on_connect, on_udp_associate First non-None result wins
Pipeline on_data Output from one addon becomes input to the next
Observational on_start, on_stop, on_flow_close, on_error All applicable addons run

Built-ins:

  • ChainRouter for TCP chain proxying
  • UdpOverTcpEntry and UdpOverTcpExitServer for UDP chain proxying
  • FlowStats for in-memory flow statistics
  • StatsAPI as an opt-in HTTP API around FlowStats
  • StatsServer as a backward-compatible name for StatsAPI
  • TrafficCounter, FileAuth, IPFilter, Logger

Architecture sketch

Client ── SOCKS5 ──▶ Server ──▶ Target
                     │
                     ├─ auth / route hooks
                     ├─ data pipeline hooks
                     └─ flow close hooks

ChainRouter:
Client ──▶ A ──▶ B ──▶ C ──▶ Target

Chain proxying

Each node only knows its next hop:

# A ─▶ B ─▶ C ─▶ target
Server(addons=[ChainRouter("B:1080")])  # A
Server(addons=[ChainRouter("C:1080")])  # B
Server()                                # C

UDP chain proxying uses TCP between proxy nodes:

from asyncio_socks_server import Server, UdpOverTcpEntry, UdpOverTcpExitServer

entry = Server(addons=[UdpOverTcpEntry("exit-host:9020")])
exit_server = UdpOverTcpExitServer(host="::", port=9020)

Client

from asyncio_socks_server import Address, connect

conn = await connect(
    proxy_addr=Address("127.0.0.1", 1080),
    target_addr=Address("93.184.216.34", 443),
)
conn.writer.write(b"hello")
await conn.writer.drain()
data = await conn.reader.read(4096)

API surface

Stable imports live at the package root:

from asyncio_socks_server import (
    Addon,
    Address,
    ChainRouter,
    Flow,
    FlowStats,
    Server,
    StatsAPI,
    StatsServer,
    UdpOverTcpEntry,
    UdpOverTcpExitServer,
    connect,
)

Root exports are the 1.x compatibility contract. Submodules remain importable.

Docs

Document Scope
Architecture Core flow, relay design, UDP-over-TCP, Flow context
Addon model Hook contracts, dispatch semantics, built-in addons
Public API 1.x compatibility surface

Development

git clone https://github.com/Amaindex/asyncio-socks-server.git
cd asyncio-socks-server
uv sync
uv run ruff check .
uv run ruff format --check .
uv run pyright
uv run pytest
uv build

Release

GitHub Actions tests Python 3.12 and 3.13, builds the Python package, and builds Docker images.

Create a GitHub Release from a tag such as v1.1.0. The release workflow publishes the Python package. The Docker workflow publishes semver image tags.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

asyncio_socks_server-1.2.0.tar.gz (61.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

asyncio_socks_server-1.2.0-py3-none-any.whl (31.3 kB view details)

Uploaded Python 3

File details

Details for the file asyncio_socks_server-1.2.0.tar.gz.

File metadata

  • Download URL: asyncio_socks_server-1.2.0.tar.gz
  • Upload date:
  • Size: 61.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.9 {"installer":{"name":"uv","version":"0.11.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for asyncio_socks_server-1.2.0.tar.gz
Algorithm Hash digest
SHA256 83a2bd7648584ada25c4d9fe257617226a30bf2482f5e32cf50604eb9b4be6f1
MD5 53e0a4d0cfc13f3dcb24efe901d3127a
BLAKE2b-256 b66c4cf4d516f931cafc3e260f8ec1c95cf21fdaffc727e43638dd79d927bb32

See more details on using hashes here.

File details

Details for the file asyncio_socks_server-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: asyncio_socks_server-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 31.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.9 {"installer":{"name":"uv","version":"0.11.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for asyncio_socks_server-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6a7a69d2e465056e4f06abc1bb6d54faf7a22fc7168f16bf98a95dfbbb1306bf
MD5 e7a53bb24be22eef88bef977531ec613
BLAKE2b-256 f206fd3d8883a14aa28a49e09f7d624ddea799875a9754eb8241940cc702de1f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page