A SOCKS proxy that balances traffic between network interfaces.
Should work on macOS, Windows, and Linux. Only tested on macOS for now.
This is a Rust rewrite of dispatch-proxy, originally written in CoffeeScript and targeting Node.js.
You'll need Rust version 1.51.0 or later. You can use rustup to install the latest version of the Rust compiler toolchain.
cargo install dispatch-proxy
In order to build on Windows, you will need to download the Npcap SDK, and copy the Packet.lib
file from the SDK to the appropriate rustup toolchain lib
folder.
In order to find which file to use and where to copy it, run rustup show
:
```bash
rustup show
Default host: aarch64-pc-windows-msvc rustup home: C:\Users\alex.rustup
stable-aarch64-pc-windows-msvc (default) rustc 1.66.1 (90743e729 2023-01-10) ```
This indicates I should copy npcap-sdk-1.13\Lib\ARM64\Packet.lib
to C:\Users\alex\.rustup\toolchains\stable-aarch64-pc-windows-msvc\lib\rustlib\aarch64-pc-windows-msvc\lib\Packet.lib
.
Here are the most common cases:
Copy npcap-sdk-1.13\Lib\x64\Packet.lib
to [rustup home]\toolchains\stable-x86_64-pc-windows-msvc\lib\rustlib\x86_64-pc-windows-msvc\lib\Packet.lib
.
Copy npcap-sdk-1.13\Lib\Packet.lib
to [rustup home]\toolchains\stable-i686-pc-windows-msvc\lib\rustlib\i686-pc-windows-msvc\lib\Packet.lib
.
Copy npcap-sdk-1.13\Lib\ARM64\Packet.lib
to [rustup home]\toolchains\stable-aarch64-pc-windows-msvc\lib\rustlib\aarch64-pc-windows-msvc\lib\Packet.lib
.
You often find yourself with multiple unused internet connections—be it 5G mobile hotspot or a free Wi-Fi network—that your system won't let you use alongside your primary one.
For instance, my first student residence used to provide me with cabled and wireless internet accesses. Both were separately capped at a bandwidth 1,200kB/s. My 3G mobile internet access provided me with an additional 400kB/s. Combining all of these with dispatch and a download manager resulted in a 2,800kB/s effective bandwidth!
The possibilities are endless:
``` $ dispatch
dispatch 0.1.0 A proxy that balances traffic between multiple internet connections
USAGE:
dispatch [FLAGS]
FLAGS: -d, --debug Write debug logs to stdout instead of a file -h, --help Prints help information -V, --version Prints version information
SUBCOMMANDS: help Prints this message or the help of the given subcommand(s) list Lists all available network interfaces start Starts the SOCKS proxy server ```
``` $ dispatch start -h
dispatch-start 0.1.0 Starts the SOCKS proxy server
USAGE:
dispatch start [OPTIONS]
FLAGS: -h, --help Prints help information -V, --version Prints version information
OPTIONS:
--ip
ARGS:
$ dispatch list
Lists all available network interfaces.
$ dispatch start 10.0.0.0 fdaa:bbcc:ddee:0:1:2:3:4
Dispatch incoming connections to local addresses 10.0.0.0
and fdaa:bbcc:ddee:0:1:2:3:4
.
$ dispatch start 10.0.0.0@7 10.0.0.1@3
Dispatch incoming connections to 10.0.0.0
7 times out of 10 and to 10.0.0.1
3 times out of 10.
Whenever the SOCKS proxy server receives an connection request to an address or domain, it selects one of the provided local addresses using the Weighted Round Robin algorithm. All further connection traffic will then go through the interface corresponding to the selected local address.
Beware: If the requested address or domain resolves to an IPv4 (resp. IPv6) address, an IPv4 (resp. IPv6) local address must be provided.
Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.