forked from owenthewizard/opnatt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathopnatt.sh
executable file
·85 lines (67 loc) · 2.54 KB
/
opnatt.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#!/usr/bin/env bash
# OPNsense **DOESN'T** have bash, so make sure you install it!
source /conf/opnatt/bin/opnatt.conf
source /conf/opnatt/bin/opnatt-functions.sh
trap 'shutdown' SIGINT SIGQUIT SIGABRT SIGTERM
for mod in ${ng_modules[@]}; do
log "loading $mod..."
/sbin/kldload -n "$mod"
done
log "starting opnatt..."
log "configuration:"
log " ONT_IF = $ONT_IF"
log " RG_ETHER = $RG_ETHER"
log " EAP_IDENTITY = $EAP_IDENTITY"
log "resetting netgraph..."
ng_clean
log "configuring EAP environment for supplicant mode..."
log "cabling should look like this:"
log " ONT---[] [$ONT_IF]$HOST"
log "creating vlan node and ngeth0 interface..."
/usr/sbin/ngctl mkpeer "$ONT_IF:" vlan lower downstream
/usr/sbin/ngctl name "$ONT_IF:lower" vlan0
/usr/sbin/ngctl mkpeer vlan0: eiface vlan0 ether
/usr/sbin/ngctl msg vlan0: 'addfilter { vlan=0 hook="vlan0" }'
/usr/sbin/ngctl msg ngeth0: set "$RG_ETHER"
log "enabling promisc for $ONT_IF and spoofing MAC..."
/sbin/ifconfig "$ONT_IF" ether "$RG_ETHER" -vlanhwtag -vlanhwfilter
/sbin/ifconfig "$ONT_IF" up promisc
log "starting wpa_supplicant..."
# kill any existing wpa_supplicant process
wpa_pid=$(pgrep -f "wpa_supplicant."\*"ngeth0")
if [[ -n "$wpa_pid" ]]; then
log "terminating existing wpa_supplicant on PID ${wpa_pid}..."
kill "$wpa_pid"
fi
# start wpa_supplicant daemon
/usr/sbin/wpa_supplicant -Dwired -ingeth0 -B -C/var/run/wpa_supplicant -c/conf/opnatt/wpa/wpa_supplicant.conf
wpa_pid=$(pgrep -f "wpa_supplicant."\*"ngeth0")
log "wpa_supplicant running on PID ${wpa_pid}..."
# Set WPA configuration parameters.
log "setting wpa_supplicant network configuration..."
wpa_cli set_network 0 identity \""$EAP_IDENTITY"\"
wpa_cli set_network 0 ca_cert \""$ca_cert"\"
wpa_cli set_network 0 client_cert \""$client_cert"\"
wpa_cli set_network 0 private_key \""$private_key"\"
wpa_cli logon
# wait until wpa_cli has authenticated.
log "waiting EAP for authorization..."
for i in {1..5}; do
if [[ "$(wpa_status)" = "Authorized" ]]; then
log "EAP authorization completed..."
IP_STATUS="$(ip_status)"
if [[ -z "$IP_STATUS" ]] || [[ "$IP_STATUS" = "0.0.0.0" ]]; then
log "no IP address assigned, force restarting DHCP..."
/etc/rc.d/dhclient forcerestart ngeth0
IP_STATUS="$(ip_status)"
fi
log "IP address is ${IP_STATUS}..."
break
else
n=$((i * 4))
log "not authorized, sleeping for ${n} seconds... (${i}/5)"
sleep $((i * 4))
fi
done
log "ngeth0 should now be available to configure as your WAN..."
log "done!"