From c123f7299f882e2e24c1fc8677bf7896145dddb0 Mon Sep 17 00:00:00 2001 From: Manuel Munz Date: Sat, 29 Oct 2011 21:19:05 +0000 Subject: [PATCH] contrib/meshwizard: Enable policyrouting when internet sharing is not enabled --- .../files/usr/bin/meshwizard/helpers/read_defaults.sh | 2 +- .../files/usr/bin/meshwizard/helpers/setup_olsrd.sh | 3 +-- .../usr/bin/meshwizard/helpers/setup_policyrouting.sh | 11 +++++++++++ .../meshwizard/files/usr/bin/meshwizard/wizard.sh | 7 +++++++ 4 files changed, 20 insertions(+), 3 deletions(-) create mode 100755 contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_policyrouting.sh diff --git a/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/read_defaults.sh b/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/read_defaults.sh index f58af24219..69fd48b92f 100755 --- a/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/read_defaults.sh +++ b/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/read_defaults.sh @@ -20,6 +20,6 @@ for v in system wifi_device wifi_iface interface alias dhcp olsr_interface olsr_ done # read values from meshwizard -for v in system luci_main contact community wan lan; do +for v in system luci_main contact community wan lan general; do get_var meshwizard.$v done diff --git a/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_olsrd.sh b/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_olsrd.sh index b4de9ce194..f06156a5f3 100755 --- a/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_olsrd.sh +++ b/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_olsrd.sh @@ -50,9 +50,8 @@ uci_commitverbose "Setup olsr nameservice plugin" olsrd # Setup dyngw_plain # If Sharing of Internet is enabled then enable dyngw_plain plugin -sharenet=$(uci -q get meshwizard.general.sharenet) -if [ "$sharenet" == 1 ]; then +if [ "$general_sharenet" == 1 ]; then uci set olsrd.dyngw_plain=LoadPlugin uci set olsrd.dyngw_plain.ignore=0 uci set olsrd.dyngw_plain.library="olsrd_dyn_gw_plain.so.0.4" diff --git a/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_policyrouting.sh b/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_policyrouting.sh new file mode 100755 index 0000000000..f898bd6842 --- /dev/null +++ b/contrib/package/meshwizard/files/usr/bin/meshwizard/helpers/setup_policyrouting.sh @@ -0,0 +1,11 @@ +#!/bin/sh + +. $dir/functions.sh + +uci batch << EOF + set freifunk-policyrouting.pr.enable=1 + set freifunk-policyrouting.pr.strict=1 + set freifunk-policyrouting.pr.zones="freifunk" +EOF + +uci_commitverbose "Setup policyrouting" freifunk-policyrouting diff --git a/contrib/package/meshwizard/files/usr/bin/meshwizard/wizard.sh b/contrib/package/meshwizard/files/usr/bin/meshwizard/wizard.sh index 7d389a20f6..73eddc4dfa 100755 --- a/contrib/package/meshwizard/files/usr/bin/meshwizard/wizard.sh +++ b/contrib/package/meshwizard/files/usr/bin/meshwizard/wizard.sh @@ -67,6 +67,13 @@ if [ "$lan_proto" == "static" ] && [ -n "$lan_ip4addr" ] && [ -n "$lan_netmask" $dir/helpers/setup_lan_static.sh fi +# Setup policyrouting if internet sharing is disabled and wan is not used for olsrd +# Always disable it first to make sure its disabled when the user decied to share his internet +uci set freifunk-policyrouting.pr.enable=0 +if [ ! "$sharenet" == 1 ] && [ ! "$(uci -q get meshwizard.netconfig.wan_proto)" == "olsr" ]; then + $dir/helpers/setup_policyrouting.sh +fi + # Configure found networks for net in $networks; do # radioX devices need to be renamed -- 2.30.2