Browse Source

Fixing a lot of stuff

Julien VAUBOURG 10 years ago
parent
commit
2f77fb4b1a
3 changed files with 22 additions and 13 deletions
  1. 14 2
      conf/ynh-hotspot
  2. 7 10
      scripts/install
  3. 1 1
      scripts/remove

+ 14 - 2
conf/ynh-hotspot

@@ -49,6 +49,16 @@ is_running() {
   && is_hostapd_running && is_radvd_running && is_dhcpd_running
 }
 
+internet_device=$(ip r | awk '/default via/ { print $NF; }')
+internet_device_vpn=tun0
+internet_device_default=${internet_device}
+
+# Apply NAT on tun0 if IPv6 address if VPN is used
+ip l sh dev tun0 &> /dev/null
+if [ "$?" -eq 0 ]; then
+  internet_device_default=${internet_device_vpn}
+fi
+
 case "$1" in
   start)
     if is_running; then
@@ -61,7 +71,7 @@ case "$1" in
 
       if ! is_nat_set; then
         echo "Set NAT"
-        iptables -t nat -A POSTROUTING -o <TPL:WIRED_DEVICE> -j MASQUERADE
+        iptables -t nat -A POSTROUTING -o ${internet_device_default} -j MASQUERADE
       fi
 
       if ! is_ip4nataddr_set; then
@@ -107,7 +117,9 @@ case "$1" in
   
     if is_nat_set; then
       echo "Unset NAT"
-      iptables -t nat -D POSTROUTING -o <TPL:WIRED_DEVICE> -j MASQUERADE
+      # Depending on the presence or not of a VPN at the last startup, one of these 2 lines is unnecessary
+      iptables -t nat -D POSTROUTING -o ${internet_device} -j MASQUERADE 2> /dev/null
+      iptables -t nat -D POSTROUTING -o ${internet_device_vpn} -j MASQUERADE 2> /dev/null
     fi
 
     if is_ip4nataddr_set; then

+ 7 - 10
scripts/install

@@ -22,10 +22,9 @@ sudo apt-get --assume-yes --force-yes install hostapd radvd isc-dhcp-server ipta
 sudo apt-get --assume-yes --force-yes install sipcalc
 
 # Compute extra arguments
-wired_device=$(ip r | awk '/default via/ { print $NF; }')
 ip6_expanded_net=$(sipcalc ${ip6_net} | grep Expanded | awk '{ print $NF; }')
 ip6_net=$(sipcalc ${ip6_net} | grep Compressed | awk '{ print $NF; }')
-ip6_addr=$(echo "$(echo ${ip6_expanded_net} | cut -d: -f1-7):42")
+ip6_addr=$(echo "$(echo ${ip6_expanded_net} | cut -d: -f1-7):1")
 ip6_addr=$(sipcalc ${ip6_addr} | grep Compressed | awk '{ print $NF; }')
 ip4_nat_prefix=10.0.242
 
@@ -33,7 +32,6 @@ ip4_nat_prefix=10.0.242
 sudo yunohost app setting hotspot wifi_ssid -v ${wifi_ssid}
 sudo yunohost app setting hotspot wifi_passphrase -v ${wifi_passphrase}
 sudo yunohost app setting hotspot wifi_device -v ${wifi_device}
-sudo yunohost app setting hotspot wired_device -v ${wired_device}
 sudo yunohost app setting hotspot ip6_addr -v ${ip6_addr}
 sudo yunohost app setting hotspot ip6_net -v ${ip6_net}
 sudo yunohost app setting hotspot ip6_dns0 -v ${ip6_dns0}
@@ -73,17 +71,10 @@ sudo install -b -o root -g root -m 0755 ../conf/ynh-hotspot /etc/init.d/
 sudo sed "s|<TPL:IP6_ADDR>|${ip6_addr}|g" -i /etc/init.d/ynh-hotspot
 sudo sed "s|<TPL:IP4_NAT_PREFIX>|${ip4_nat_prefix}|g" -i /etc/init.d/ynh-hotspot
 sudo sed "s|<TPL:WIFI_DEVICE>|${wifi_device}|g" -i /etc/init.d/ynh-hotspot
-sudo sed "s|<TPL:WIRED_DEVICE>|${wired_device}|g" -i /etc/init.d/ynh-hotspot
 
 ## hostapd
 sudo sed 's|^DAEMON_CONF=$|&/etc/hostapd/hostapd.conf|' -i /etc/init.d/hostapd
 
-# Remove IPv6 address if vpnclient is installed because from now this one is handle by this app
-yunohost app list -f vpnclient --json | grep -q '"installed": true'
-if [ "$?" -eq 0 ]; then
-  ip a d ${ip6_addr}/128 dev tun0 &> /dev/null
-fi
-
 # Set default inits
 # The boot order of these services are important, so they are disabled by default
 # and the ynh-hotspot service handles them.
@@ -98,6 +89,12 @@ sudo yunohost service add hostapd
 sudo yunohost service stop hostapd 
 sudo yunohost service disable hostapd 
 
+# Remove IPv6 address if vpnclient is installed because from now this one is handle by this app
+sudo yunohost app list -f vpnclient --json | grep -q '"installed": true'
+if [ "$?" -eq 0 ]; then
+  ip a d ${ip6_addr}/128 dev tun0 &> /dev/null
+fi
+
 # Gooo
 sudo yunohost service add ynh-hotspot
 sudo yunohost service enable ynh-hotspot

+ 1 - 1
scripts/remove

@@ -6,7 +6,7 @@ sudo yunohost service remove ynh-hotspot
 sudo rm -f /etc/init.d/ynh-hotspot
 
 # Remove confs
-sudo rm -rf /etc/hostapd/ /etc/radvd.conf /etc/dhcp/dhcpd.conf
+sudo rm -f /etc/hostapd/hostapd.conf /etc/radvd.conf /etc/dhcp/dhcpd.conf
 
 # Remove packets
 # The yunohost policy is currently to not uninstall packets (dependency problems)