838 |
richard |
1 |
#/bin/bash
|
958 |
franck |
2 |
# $Id: alcasar-dhcp.sh 1614 2015-04-07 15:23:44Z franck $
|
838 |
richard |
3 |
|
|
|
4 |
# alcasar-dhcp.sh
|
|
|
5 |
# by Rexy
|
|
|
6 |
# This script is distributed under the Gnu General Public License (GPL)
|
|
|
7 |
|
|
|
8 |
# active ou desactive le service DHCP sur le réseau de consultation
|
|
|
9 |
# enable or disable the DHCP service on consultation LAN
|
|
|
10 |
|
|
|
11 |
SED="/bin/sed -i"
|
841 |
richard |
12 |
CHILLI_CONF_FILE="/etc/chilli.conf"
|
838 |
richard |
13 |
ALCASAR_CONF_FILE="/usr/local/etc/alcasar.conf"
|
861 |
richard |
14 |
DNSMASQ_CONF_FILE="/etc/dnsmasq.conf"
|
838 |
richard |
15 |
|
861 |
richard |
16 |
# define DHCP parameters (LAN side)
|
841 |
richard |
17 |
PRIVATE_IP_MASK=`grep PRIVATE_IP $ALCASAR_CONF_FILE|cut -d"=" -f2`
|
|
|
18 |
PRIVATE_IP=`echo $PRIVATE_IP_MASK | cut -d"/" -f1`
|
861 |
richard |
19 |
PRIVATE_PREFIX=`/bin/ipcalc -p $PRIVATE_IP_MASK |cut -d"=" -f2` # network prefix (ie. 24)
|
841 |
richard |
20 |
PRIVATE_NETMASK=`/bin/ipcalc -m $PRIVATE_IP_MASK | cut -d"=" -f2`
|
861 |
richard |
21 |
PRIVATE_NETWORK=`/bin/ipcalc -n $PRIVATE_IP $PRIVATE_NETMASK| cut -d"=" -f2`
|
841 |
richard |
22 |
PRIVATE_PREFIX=`/bin/ipcalc -p $PRIVATE_IP $PRIVATE_NETMASK |cut -d"=" -f2`
|
861 |
richard |
23 |
PRIVATE_NETWORK_MASK=$PRIVATE_NETWORK/$PRIVATE_PREFIX # ie.: 192.168.182.0/24
|
|
|
24 |
classe=$((PRIVATE_PREFIX/8)); classe_sup=`expr $classe + 1`; classe_sup_sup=`expr $classe + 2` # ie.: 2=classe B, 3=classe C
|
|
|
25 |
PRIVATE_BROADCAST=`/bin/ipcalc -b $PRIVATE_NETWORK_MASK | cut -d"=" -f2` # private network broadcast (ie.: 192.168.182.255)
|
|
|
26 |
private_network_ending=`echo $PRIVATE_NETWORK | cut -d"." -f$classe_sup` # last octet of LAN address
|
|
|
27 |
private_broadcast_ending=`echo $PRIVATE_BROADCAST | cut -d"." -f$classe_sup` # last octet of LAN broadcast
|
|
|
28 |
PRIVATE_FIRST_IP=`echo $PRIVATE_NETWORK | cut -d"." -f1-3`"."`expr $private_network_ending + 1` # First network address (ex.: 192.168.182.1)
|
|
|
29 |
PRIVATE_LAST_IP=`echo $PRIVATE_BROADCAST | cut -d"." -f1-3`"."`expr $private_broadcast_ending - 1` # last network address (ex.: 192.168.182.254)
|
841 |
richard |
30 |
PRIVATE_NETWORK_MASK=$PRIVATE_NETWORK/$PRIVATE_PREFIX
|
967 |
franck |
31 |
EXT_DHCP_IP=`grep EXT_DHCP_IP $ALCASAR_CONF_FILE|cut -d"=" -f2` # Adresse du serveur DHCP externe
|
919 |
franck |
32 |
RELAY_DHCP_IP=`grep RELAY_DHCP_IP $ALCASAR_CONF_FILE|cut -d"=" -f2` # Adresse de l'agent Relay : IP interne (défaut 192.168.182.1) dans le cas de DHCP dans le LAN de consultation
|
1469 |
richard |
33 |
RELAY_DHCP_IP=${RELAY_DHCP_IP:=$PRIVATE_IP} # IP externe (défaut x.y.z.t) dans le cas de DHCP du côté WAN
|
916 |
franck |
34 |
RELAY_DHCP_PORT=`grep RELAY_DHCP_PORT $ALCASAR_CONF_FILE|cut -d"=" -f2` # Port de redirection vers le relay DHCP : 67 par défaut
|
|
|
35 |
RELAY_DHCP_PORT=${RELAY_DHCP_PORT:=67}
|
841 |
richard |
36 |
|
1484 |
richard |
37 |
usage="Usage: alcasar-dhcp.sh {--on | -on} | {--off | -off}"
|
838 |
richard |
38 |
nb_args=$#
|
|
|
39 |
args=$1
|
|
|
40 |
if [ $nb_args -eq 0 ]
|
|
|
41 |
then
|
|
|
42 |
echo "$usage"
|
|
|
43 |
exit 1
|
|
|
44 |
fi
|
|
|
45 |
case $args in
|
861 |
richard |
46 |
-\? | -h | --h)
|
838 |
richard |
47 |
echo "$usage"
|
|
|
48 |
exit 0
|
|
|
49 |
;;
|
|
|
50 |
--off|-off) # disable DHCP service
|
861 |
richard |
51 |
$SED "s?.*statip.*?statip\t\t$PRIVATE_NETWORK_MASK?g" $CHILLI_CONF_FILE
|
841 |
richard |
52 |
$SED "s?^#nodynip.*?nodynip?g" $CHILLI_CONF_FILE
|
861 |
richard |
53 |
$SED "s?^dynip.*?#dynip?g" $CHILLI_CONF_FILE
|
|
|
54 |
$SED "s?^#dynip.*?#dynip?g" $CHILLI_CONF_FILE
|
838 |
richard |
55 |
$SED "s?^DHCP.*?DHCP=off?g" $ALCASAR_CONF_FILE
|
1040 |
franck |
56 |
if [ "$EXT_DHCP_IP" != "none" ]
|
914 |
franck |
57 |
then
|
1157 |
stephane |
58 |
$SED "s?.*dhcpgateway\t.*?dhcpgateway\t\t $EXT_DHCP_IP?g" $CHILLI_CONF_FILE
|
914 |
franck |
59 |
$SED "s?.*dhcprelayagent.*?dhcprelayagent\t\t$RELAY_DHCP_IP?g" $CHILLI_CONF_FILE
|
1101 |
franck |
60 |
$SED "s?.*dhcpgatewayport.*?dhcpgatewayport\t\t$RELAY_DHCP_PORT?g" $CHILLI_CONF_FILE
|
|
|
61 |
else
|
|
|
62 |
$SED "s?.*dhcpgateway.*?#dhcpgateway\t\t$EXT_DHCP_IP?g" $CHILLI_CONF_FILE
|
|
|
63 |
$SED "s?.*dhcprelayagent.*?#dhcprelayagent\t\t$RELAY_DHCP_IP?g" $CHILLI_CONF_FILE
|
914 |
franck |
64 |
$SED "s?.*dhcpgatewayport.*?#dhcpgatewayport\t\t$RELAY_DHCP_PORT?g" $CHILLI_CONF_FILE
|
|
|
65 |
fi
|
1419 |
richard |
66 |
/usr/bin/systemctl restart chilli
|
838 |
richard |
67 |
;;
|
1484 |
richard |
68 |
--on|-on) # enable DHCP service on all range of IP addresses
|
861 |
richard |
69 |
$SED "s?^.*statip.*?#statip?g" $CHILLI_CONF_FILE
|
841 |
richard |
70 |
$SED "s?^nodynip.*?#nodynip?g" $CHILLI_CONF_FILE
|
1484 |
richard |
71 |
$SED "s?^DHCP.*?DHCP=on?g" $ALCASAR_CONF_FILE
|
861 |
richard |
72 |
$SED "s?^dynip.*?dynip\t\t$PRIVATE_NETWORK_MASK?g" $CHILLI_CONF_FILE
|
|
|
73 |
$SED "s?^#dynip.*?dynip\t\t$PRIVATE_NETWORK_MASK?g" $CHILLI_CONF_FILE
|
|
|
74 |
$SED "s?^dhcp_range.*?dhcp-range=$PRIVATE_FIRST_IP,$PRIVATE_LAST_IP,$PRIVATE_NETMASK,12h?g" $DNSMASQ_CONF_FILE
|
1157 |
stephane |
75 |
$SED "s?^dhcpgateway\t.*?#dhcpgateway\t\t $EXT_DHCP_IP?g" $CHILLI_CONF_FILE
|
914 |
franck |
76 |
$SED "s?^dhcprelayagent.*?#dhcprelayagent\t\t$RELAY_DHCP_IP?g" $CHILLI_CONF_FILE
|
|
|
77 |
$SED "s?^dhcpgatewayport.*?#dhcpgatewayport\t\t$RELAY_DHCP_PORT?g" $CHILLI_CONF_FILE
|
1614 |
franck |
78 |
$SED "s?^EXT_DHCP_IP.*?EXT_DHCP_IP=\$EXT_DHCP_IP?g" $ALCASAR_CONF_FILE
|
|
|
79 |
$SED "s?^RELAY_DHCP_IP.*?RELAY_DHCP_IP=\$RELAY_DHCP_IP?g" $ALCASAR_CONF_FILE
|
|
|
80 |
$SED "s?^RELAY_DHCP_PORT.*?RELAY_DHCP_PORT=\$RELAY_DHCP_PORT?g" $ALCASAR_CONF_FILE
|
1419 |
richard |
81 |
/usr/bin/systemctl restart chilli
|
841 |
richard |
82 |
;;
|
838 |
richard |
83 |
*)
|
|
|
84 |
echo "Argument inconnu :$1";
|
|
|
85 |
echo "$usage"
|
|
|
86 |
exit 1
|
|
|
87 |
;;
|
|
|
88 |
esac
|
|
|
89 |
|