3 unstable releases

0.2.0 Nov 13, 2023
0.1.1 Nov 12, 2023
0.1.0 Sep 11, 2023

#1690 in Network programming

Download history 1/week @ 2024-02-18 30/week @ 2024-02-25 14/week @ 2024-03-10 45/week @ 2024-03-31

59 downloads per month

MIT license

38KB
363 lines

yprox

A modifying, multiplexer tcp proxy server tool and library.

Usage

As an executable

To use yprox as an executable, simply install it using Cargo:

cargo install yprox

Then, you can run it with:

yprox <listen_addr> <target_addr1>...<target_addrN>

For example:

yprox 127.0.0.1:8080 127.0.0.1:9000 127.0.0.1:9001

This will start a proxy server that listens on 127.0.0.1:8080 and forwards incoming connections to 127.0.0.1:9000 and 127.0.0.1:9001.

As a library

To use yprox as a library, add it to your Cargo.toml file:

[dependencies]
yprox = "0.1"

Then, you can use it in your code:

use yprox::proxy::Proxy;

#[tokio::main]
async fn main() {
    let listen_addr = "127.0.0.1:8080";
    let target_addrs = vec!["127.0.0.1:9000", "127.0.0.1:9001"];
    proxy(listen_addr, target_addrs).await.unwrap();
}

This will start a proxy server that listens on 127.0.0.1:8080 and forwards incoming connections to 127.0.0.1:9000 and 127.0.0.1:9001.

Using a modifying function

Optionally you can modify the data stream before forwarding it to the target. You can do that using the start_modifying function:

use yprox::proxy::Proxy;

#[tokio::main]
async fn main() {
    let listen_addr = "127.0.0.1:8080";
    let target_addrs = vec!["127.0.0.1:9000", "127.0.0.1:9001"];
    let modify_fn = |data: Vec<u8>| -> Vec<u8> {
        // Modify data here
        data
    };
    proxy(listen_addr, target_addrs, Some(modify_fn)).await.unwrap();
}

Dependencies

~1.2–1.8MB
~34K SLoC