#proxy-server #socks5-proxy #socks5 #proxy #async-read #sock #networking

socks5-impl

Fundamental abstractions and async read / write functions for SOCKS5 protocol and Relatively low-level asynchronized SOCKS5 server implementation based on tokio

39 releases

0.6.0 Dec 14, 2024
0.5.17 Nov 8, 2024
0.5.16 Oct 22, 2024
0.5.14 Jun 21, 2024
0.1.8 Mar 18, 2023

#229 in Network programming

Download history 685/week @ 2024-09-15 471/week @ 2024-09-22 661/week @ 2024-09-29 452/week @ 2024-10-06 619/week @ 2024-10-13 828/week @ 2024-10-20 419/week @ 2024-10-27 527/week @ 2024-11-03 252/week @ 2024-11-10 364/week @ 2024-11-17 463/week @ 2024-11-24 252/week @ 2024-12-01 497/week @ 2024-12-08 453/week @ 2024-12-15 271/week @ 2024-12-22 404/week @ 2024-12-29

1,650 downloads per month
Used in 8 crates (6 directly)

GPL-3.0-or-later

120KB
2.5K SLoC

socks5-impl

Fundamental abstractions and async read / write functions for SOCKS5 protocol and Relatively low-level asynchronized SOCKS5 server implementation based on tokio.

This repo hosts at socks5-impl

Version Documentation License

Features

  • Fully asynchronized
  • Supports all SOCKS5 commands
    • CONNECT
    • BIND
    • ASSOCIATE
  • Customizable authentication
    • No authentication
    • Username / password
    • GSSAPI

Usage

The entry point of this crate is socks5_impl::server::Server.

Check examples for usage examples.

Example

use socks5_impl::protocol::{handshake, Address, AuthMethod, Reply, Request, Response, StreamOperation};

fn main() -> socks5_impl::Result<()> {
    let listener = std::net::TcpListener::bind("127.0.0.1:5000")?;
    let (mut stream, _) = listener.accept()?;

    let request = handshake::Request::retrieve_from_stream(&mut stream)?;

    if request.evaluate_method(AuthMethod::NoAuth) {
        let response = handshake::Response::new(AuthMethod::NoAuth);
        response.write_to_stream(&mut stream)?;
    } else {
        let response = handshake::Response::new(AuthMethod::NoAcceptableMethods);
        response.write_to_stream(&mut stream)?;
        let _ = stream.shutdown(std::net::Shutdown::Both);
        let err = "No available handshake method provided by client";
        return Err(std::io::Error::new(std::io::ErrorKind::Unsupported, err).into());
    }

    let req = match Request::retrieve_from_stream(&mut stream) {
        Ok(req) => req,
        Err(err) => {
            let resp = Response::new(Reply::GeneralFailure, Address::unspecified());
            resp.write_to_stream(&mut stream)?;
            let _ = stream.shutdown(std::net::Shutdown::Both);
            return Err(err.into());
        }
    };

    match req.command {
        _ => {} // process request
    }

    Ok(())
}

License

GNU General Public License v3.0

Dependencies

~0.5–8.5MB
~81K SLoC