[PATCH v4] fff-hoods: Introduce sector files for custom settings

Adrian Schmutzler freifunk at adrianschmutzler.de
Mo Okt 30 16:01:03 CET 2017


Untested, but should be testable.

Privatversion fuer Christian: Config wird nur einmal zu
Beginn gezogen.

Rebase on channel v8.

While the hood file is only set by the keyexchange/hood, this
introduces a local additional configuration in a second file.
This file is retrieved from the first configap we got in w2sta
mode, of which we save the fdff address to identify it later.
Thus, a router always "knows" its specific uplink, as long as
the gateway connection is stable; otherwise: reset.

The implementation is similar to the hoodfiles with a tmp
version and a copy in the /www/public. On the "section head",
the initial configuration is located in /etc/sectorfile and
distributed from there to other nodes. Syntax should be like
the node file, except that it only contains the values to be
overwritten.

Happy commenting.

Signed-off-by: Adrian Schmutzler <freifunk at adrianschmutzler.de>

Changes in v3:
- Added redirect 2>/dev/null before sha

Changes in v4:
- Config is downloaded only once (uplink not saved)
---
 .../fff/fff-hoods/files/usr/sbin/configurehood     | 44 ++++++++++++++++++++--
 1 file changed, 41 insertions(+), 3 deletions(-)

diff --git a/src/packages/fff/fff-hoods/files/usr/sbin/configurehood b/src/packages/fff/fff-hoods/files/usr/sbin/configurehood
index b30e942..b94fd37 100755
--- a/src/packages/fff/fff-hoods/files/usr/sbin/configurehood
+++ b/src/packages/fff/fff-hoods/files/usr/sbin/configurehood
@@ -4,6 +4,10 @@
 . /lib/functions/fff/wireless
 . /lib/functions/fff/timeserver
 
+sectorlocal=/etc/sectorfile
+sectortmp=/tmp/sectorfile
+sectorcopy=/www/public/sectorfile
+
 rm -f /tmp/keyxchangev2data
 
 # Gatewaycheck function
@@ -60,6 +64,9 @@ long=$(uci -q get system. at system[0].longitude)
 # if we have Internet, we download the Hoodfile from the keyxchangev2
 if hasInternet ; then
 	wget -T15 -t5 "http://keyserver.freifunk-franken.de/v2/?lat=$lat&long=$long" -O /tmp/keyxchangev2data
+	rm -f "$sectortmp"
+	[ -s "$sectorlocal" ] || rm -f "$sectorcopy" # If internet present, no custom config should be distributed, except when local file is present
+	#UPLINK: No uplink download if internet present
 	#if no Internet, we connect to the hidden AP and download the file from another Node in range
 else
 	# connect to wireless hidden ap here and download the json File from the nearest router
@@ -68,6 +75,8 @@ else
 		#now we haven't a gateway in Range, we search for a hidden AP to get a keyxchangev2data file!
 		#first we delete all wifi settings
 		rm -f /www/public/keyxchangev2data # delete this, so interfaces are recreated if reconnect with unchanged hood file takes place
+		rm -f "$sectorcopy" # always delete: no broadcast for isolated device
+		rm -f "$sectortmp"
 
 		if ! wifiDelAll; then
 			echo "Can't delete current wifi setup"
@@ -100,9 +109,14 @@ else
 		sleep 10;
 		# and here we can download the Hoodfile from the other node
 		wget -T15 -t5 "http://[fe80::1%w2sta]/keyxchangev2data" -O /tmp/keyxchangev2data
+		#UPLINK: Set up uplink data on first contact:
+		if [ -s /tmp/keyxchangev2data ]; then
+			wget -T15 -t5 "http://[fe80::1%w2sta]/sectorfile" -O "$sectortmp"
+		fi
 	else
 		echo "We have a Gateway in Range, we load the keyxchangev2data from fe80::1"
 		wget -T15 -t5 "http://[fe80::1%br-mesh]:2342/keyxchangev2data" -O /tmp/keyxchangev2data
+		#UPLINK: Do nothing
 	fi
 fi
 
@@ -111,6 +125,20 @@ if [ -s /tmp/keyxchangev2data ]; then
 	# we get a json file in this format: 
 	# https://pw.freifunk-franken.de/patch/205/
 	# but without signature, every hood file we get is valid!
+	
+	[ -s "$sectorlocal" ] && sectortmp="$sectorlocal" # Use local file if present (configuration set by user)
+	if [ -s "$sectortmp" ] ; then
+		json_load "$(cat "$sectortmp")"
+		json_select hood
+		json_get_var s_mesh_id mesh_id
+		json_get_var s_mesh_bssid mesh_bssid
+		json_get_var s_mesh_essid mesh_essid
+		json_get_var s_essid essid
+		json_get_var s_chan2ghz channel2
+		json_get_var s_mesh_type2 mesh_type2
+		json_get_var s_chan5ghz channel5
+		json_get_var s_mesh_type5 mesh_type5
+	fi
 
 	catnew="$(cat /tmp/keyxchangev2data | sed 's/"timestamp":[0-9]*/"timestamp":0/')"
 	catold="$(cat /www/public/keyxchangev2data 2>/dev/null | sed 's/"timestamp":[0-9]*/"timestamp":0/')"
@@ -119,8 +147,8 @@ if [ -s /tmp/keyxchangev2data ]; then
 
 	json_load "$(cat /tmp/keyxchangev2data)"
 
-	if [ "$sumnew" != "$sumold" ]; then
-		echo "New file detect, we reconfigure the Node";
+	if [ "$sumnew" != "$sumold" ] ; then
+		echo "New file detected, we reconfigure the Node";
 
 		json_select hood
 
@@ -140,6 +168,15 @@ if [ -s /tmp/keyxchangev2data ]; then
 		#json_get_var protocol protocol
 		
 		json_select ".." # back to root
+		
+		[ -n "$s_mesh_id" ] && mesh_id="$s_mesh_id"
+		[ -n "$s_mesh_bssid" ] && mesh_bssid="$s_mesh_bssid"
+		[ -n "$s_mesh_essid" ] && mesh_essid="$s_mesh_essid"
+		[ -n "$s_essid" ] && essid="$s_essid"
+		[ -n "$s_chan2ghz" ] && chan2ghz="$s_chan2ghz"
+		[ -n "$s_mesh_type2" ] && mesh_type2="$s_mesh_type2"
+		[ -n "$s_chan5ghz" ] && chan5ghz="$s_chan5ghz"
+		[ -n "$s_mesh_type5" ] && mesh_type5="$s_mesh_type5"
 
 		if ! ([ -n "$chan2ghz" ] && [ -n "$chan5ghz" ]) ; then
 			# If channel is missing, do nothing
@@ -191,9 +228,10 @@ if [ -s /tmp/keyxchangev2data ]; then
 		newntp="${ntpip}" # requires routable address, no link-local
 		[ "$newntp" = "$oldntp" ] || setTimeserver "${newntp}" # only rewrite if changed
 
-		# copy the file to webroot so that other Meshrouter can download it;
+		# copy the file to webroot so that other mesh routers can download it;
 		# copy only after all other steps so IF can be reentered if something goes wrong
 		cp /tmp/keyxchangev2data /www/public/
+		cp "$sectortmp" "$sectorcopy"
 
 	else
 		echo "We have no new file. We do nothing. We try it again in 5 minutes...";
-- 
2.7.4



Mehr Informationen über die Mailingliste franken-dev