1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
//! An unofficial shadowsocks implementation that can work with official shadowsocks.
//!
//! # Features
//!
//! - [x] [SOCKS5](https://datatracker.ietf.org/doc/html/rfc1928) CONNECT command
//! - [x] [AEAD](https://shadowsocks.org/en/wiki/AEAD-Ciphers.html) ciphers
//! - [x] Defend against [replay attacks](https://github.com/shadowsocks/shadowsocks-org/issues/44)
//! - [x] [Access control list](https://github.com/shadowsocks/shadowsocks-rust#acl)
//!
//! # Get Started
//!
//! ## Server
//!
//! Start a server listening on port 5421 using `chacha20-ietf-poly1305` AEAD cipher with password `ocfbnj`.
//!
//! ~~~bash
//! RUST_LOG=info ss-rs -s 0.0.0.0:5421 -k ocfbnj -m chacha20-ietf-poly1305
//! ~~~
//!
//! ## Client
//!
//! Start a client connecting to the `ocfbnj.cn`.
//!
//! The client listens on port 1080 for incoming SOCKS5 connections and uses `chacha20-ietf-poly1305` AEAD cipher with password `ocfbnj`.
//!
//! ~~~bash
//! RUST_LOG=info ss-rs -s ocfbnj.cn:5421 -l localhost:1080 -k ocfbnj -m chacha20-ietf-poly1305
//! ~~~
//!
//! # How to build
//!
//! ## Prerequisites
//!
//! - Cargo installed (See [this](https://www.rust-lang.org/learn/get-started)).
//!
//! ## Building with Cargo
//!
//! 1. Clone
//!
//!     ~~~bash
//!     git clone https://github.com/ocfbnj/ss-rs
//!     cd ss-rs
//!     ~~~
//!
//! 2. Build
//!
//!     ~~~bash
//!     cargo b --release
//!     ~~~
//!
//!     Now you can find the binary in `./target/release/ss-rs`.

/// Access control list.
pub mod acl;

/// Shadowsocks context.
pub mod context;

/// Encryption and decryption.
pub mod crypto;

/// Networking primitives for shadowsocks communication.
pub mod net;

/// Networking security primitives for shadowsocks communication.
pub mod security;

/// SOCKS protocol implementation.
pub mod socks;

/// Shadowsocks tcp services.
pub mod tcp;