Combination of wireproxy and fansocks forked/branched from wireproxy
This software only support SOCKS5 proxy. If you want to use HTTP proxy, convert SOCKS5 to HTTP with socks2http
- You simply want wireguard as a way to proxy some traffic
- You don't want root permissions or new virtual tun/tap adapter just to use/test wireguard
- Rotate socks5 proxies within wireguard network (Mullvad, IVPN, ProtonvVPN and many support this type of Multi-hop proxy)
./wirefan
-bg string
Bridge address between wire and fan (default "0.0.0.0:8080")
-bind string
Bind address/Server listen address (default "0.0.0.0:1080")
-csv string
SOCKS5 server list csv file (default "socks.csv")
-no-fan
No fan
-no-wire
No Wire
-pass string
SOCKS5 Password
-user string
SOCKS5 Username
-wg-conf string
Wireguard config file path
# Clone wireproxy repo and cd into repo
git clone https://codeberg.org/peterzam/wirefan.git
cd wirefan
# Build Docker Image
docker build -t peterzam/wirefan .
# Run Docker Container
docker run -d -v <wireguard_config_file_path>:/wg.conf -v <socks address list>:/socks.csv -p 1080:1080 peterzam/wirefan --user=<username> --pass=<password> --wg-conf=/wg.conf --csv=/socks.csv
[Interface]
PrivateKey = xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Address = xx.xx.xx.xx/xx
DNS = xx.xx.xx.xx
[Peer]
PublicKey = xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
AllowedIPs = 0.0.0.0/0
Endpoint = xx.xx.xx.xx:51820
au1-wg.socks5.relays.mullvad.net:1080
au2-wg.socks5.relays.mullvad.net:1080
au3-wg.socks5.relays.mullvad.net:1080
au4-wg.socks5.relays.mullvad.net:1080
Simple. No extra command flags.
./wirefan --wg-conf=<wireguard config> --csv=<socks list csv>
TL;DR: Connect the wireguard, rotate the multihop, can connect at bind
address.
First, wirefan connect the VPN server with wireguard, listen traffic with socks5 server at bridge, fansocks client connect the bridge, rotate the connections, open a new socks5 server at bind where the client can access.
Simple. No extra command flags.
./wirefan --wg-conf=<wireguard config> --no-fan
Just connect to wireguard. Same function as wireproxy
Simple. No extra command flags.
./wirefan --csv=<socks list csv> --no-wire
Just randomize the socks connections. Same function as fansocks
Simple. No extra command flags.
./wirefan --no-wire --no-fan
Plain socks5 server. Proxy from the running host.
Port forwarding function is dropped. If you want to use, check the origin repo at github.com/octeep/wireproxy.git