forked from Mythologyli/qBittorrent-NAT-TCP-Hole-Punching
-
Notifications
You must be signed in to change notification settings - Fork 0
/
update_nft.sh
40 lines (31 loc) · 1.42 KB
/
update_nft.sh
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
#!/bin/sh
#set -x
# Natter/NATMap
private_port=$4 # Natter: $3; NATMap: $4
public_port=$2 # Natter: $5; NATMap: $2
# qBittorrent.
qb_addr_url="http://localhost:8080"
#qb_ip_addr="192.168.1.2" # Only needed when qbit runs on a different host
qb_username="admin"
qb_password="adminadmin"
echo "Update qBittorrent listen port to $public_port..."
# Update qBittorrent listen port.
qb_cookie=$(curl -s -i --header "Referer: $qb_addr_url" --data "username=$qb_username&password=$qb_password" $qb_addr_url/api/v2/auth/login | grep -i set-cookie | cut -c13-48)
curl -X POST -b "$qb_cookie" -d 'json={"listen_port":"'$public_port'"}' "$qb_addr_url/api/v2/app/setPreferences"
echo "Update nftables..."
# Use nftables to forward traffic.
if nft list tables | grep -q "qbit_redirect"; then
nft delete table inet qbit_redirect
fi
nft add table inet qbit_redirect
nft 'add chain inet qbit_redirect prerouting { type nat hook prerouting priority -100; }'
if [ "$qb_ip_addr" = "" ];then
nft add rule inet qbit_redirect prerouting tcp dport $private_port redirect to :$public_port
# redirect the udp
nft add rule inet qbit_redirect prerouting udp dport $private_port redirect to :$public_port
else
nft add rule inet qbit_redirect prerouting tcp dport $private_port dnat to $qb_ip_addr:$public_port
# redirect the udp
nft add rule inet qbit_redirect prerouting udp dport $private_port dnat to $qb_ip_addr:$public_port
fi
echo "Done."