blob: bf5d50ccb9c160b1103efd6246a19d056e4624f9 (
plain)
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
|
update_cfgtbl() {
if [ "$cmode" == $cmode_default ]; then cmode=; fi
if [ "$csplash" == $csplash_default ]; then csplash=; fi
p2ptbl update $tbl $mac "$cname,$cmode,$csplash,$cip"
}
# parse changes
while read key val; do
case "$key" in
client_access)
case "$val" in
bridged|routed|isolated) cmode=$val;;
*) fail;;
esac
lazy 20 splash_sync
;;
client_name)
[ -z "$(echo "$val" | tr -d '0-9a-z_')" ] \
|| fail 400 'Unerlaubte Zeichen verwendet'
[ "$val" != "$cname" ] \
|| continue
[ -z "$(p2ptbl show $tbl | cut -f2 | grep "^$val,")" ] \
|| fail 403 'Name bereits vergeben'
cname=$val
lazy 10 sync_dhcp
;;
# client_splash is send iff. it is checked; update_splash is
# send in every case
update_splash)
update_splash=${update_splash-false}
lazy 20 splash_sync
;;
client_splash)
update_splash=true
;;
*)
fail 400 "wtf is $key?"
;;
esac
done <<EOF
$(tr '=&' ' \n')
EOF
if [ -n "$update_splash" ]; then
csplash=$update_splash
fi
# update p2ptbl entry
lazy 00 update_cfgtbl
|