Skip to content
/ rfor Public

A simple but fast traffic forwarder with routing.

Notifications You must be signed in to change notification settings

yuguorui/rfor

Repository files navigation

rfor - Rust traffic FORwarder

A simple but fast traffic forwarder with routing.

Do one thing and do it well.

Features

  • Build on Tokio with Rust, low CPU/memory overhead
    • Zero copy support with splice syscall.
  • Standard SOCKS5 proxy protocols support
  • Fast routing decision ( <= 15us with 70k rules )
  • Auto configuration and cleanup for transparent proxy with iptables and tproxy (No more mess with iptables🥳)
  • Optional source IP preserving when connects directly
  • Native IPv6 support
  • UDP transparent proxy

Build

# Install rust with:
$ curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

# Build it!
$ cargo build --release

# Or build static rfor!
# rustup target add x86_64-unknown-linux-musl
# RUSTFLAGS='-C target-feature=+crt-static' cargo build --target x86_64-unknown-linux-musl

Usage

debug: false
# disable-ipv6: false
tproxy-listen: '[::]:50080'
socks5-listen: '[::]:50081'

udp-enabled: true
# udp-timeout: 60

traffic-intercept:
  mode: auto                # auto(tproxy)/redirect/manual, set to "manual" when you want set iptables by hand.
  local-traffic: true       # set to true to allow intercept local traffic
  ports: [80,443,8080]      # ports you are interested
#   proxy-mark: 0xff42
#   direct-mark: 0xff43
#   tproxy-proxy-chain: rfor-proxy
#   tproxy-mark-chain: rfor-mark
#   rule-table: 0x42

outbounds:
  - name: PROXY
    url: socks5://127.0.0.1:1080

  - name: DIRECT
    bind_range:
      - 2000::/3        # connect with original source IP when src ip match this range.

# It is worth noting that all rules are aggregated in order to improve the speed of rule matching. 
# So the matching of rules is not sequential, but declarative. When multiple identical rules exist, 
# the matching priority is undefined.
rules:
  - DEFAULT,,DIRECT
  - DOMAIN-SUFFIX,google.com,PROXY
  - DOMAIN,www.google.com,PROXY
  - IP-CIDR,1.1.1.1/32,PROXY
  - GEOIP,Country.mmdb:JP,DIRECT
  - GEOSITE,geosite.dat:category-ads,DROP

You can run it with:

$ ./target/x86_64-unknown-linux-musl/debug/rfor -h
rfor 0.1.0
A simple and fast traffic forwarder with routing

USAGE:
    rfor [OPTIONS]

OPTIONS:
    -c, --config <CONFIG>        config file filepath [default: config.yaml]
    -h, --help                   Print help information
    -V, --version                Print version information
    -w, --work-dir <WORK_DIR>    working directory [default: .]

Known Issues

  • br_netfilter has some known issues link with tproxy, which may lead to network timeout in Docker. You can mitigate this problem with:

    echo "0" | sudo tee /proc/sys/net/bridge/bridge-nf-call-iptables
    echo "0" | sudo tee /proc/sys/net/bridge/bridge-nf-call-ip6tables
    

    And you may also switch to mode redirect, but the source IP preserving feature will not work anymore.

About

A simple but fast traffic forwarder with routing.

Resources

Stars

Watchers

Forks

Packages

No packages published