Serval DNA Utilities
Serval Project, February 2013
This directory contains utilities that accompany Serval DNA:
-
rhizome_mirrord
is a Python 2.7 script that continuously extracts Rhizome bundles from a local Rhizome store into a mirror directory, and optionally unpacks Zip and Tar payloads into a separate directory. -
serval_maps_push.sh
is a Shell script designed to be invoked byrhizome_mirrord
whenever in unpacks a Zip or Tar bundle. It copies the newly unpacked contents to the Serval Maps testing server using rsync(1), then prods the testing server to process them by making an HTTP request to a particular URL using curl(1).
These two scripts were originally created to inject Rhizome traffic from New Zealand Red Cross's KiwiEx 2013 field trial exercise into the Serval Maps visualisation server, as a demonstration of how Rhizome can be used to transmit situational awareness field reports back to base.
The rhizome_mirrord
script has been designed in a general fashion, and is
suitable for use in other deployments that require a similar mirror of Rhizome
content.
Instructions for use
-
The Rhizome mirror script must be executed on a server that is running as a Serval DNA node that receives Rhizome bundles for visualisation in Serval Maps. This server must be running a modern installation of Linux and must have continuous Internet access in order to communicate directly with the Serval Maps testing server.
-
Ensure that Git, Python 2.7, rsync and curl are installed on the server.
-
Download a copy of the Serval DNA source code onto the server, for example by fetching a read-only clone of the Git repository from GitHub and checking out the development branch:
git clone git://github.com/servalproject/serval-dna.git cd serval-dna git checkout development
-
Build the Serval DNA
servald
executable by following the Serval DNA build instructions. -
Create a directory to use as the Serval DNA instance directory:
mkdir /var/local/serval-node export SERVALINSTANCE_PATH=/var/local/serval-node
-
Configure Serval DNA to use the proper network interfaces, to log to a suitable log file, etc.
-
Create directories to hold the Rhizome mirror and the unpacked Zip files:
mkdir /var/local/rhizome-mirror mkdir /var/local/rhizome-unpacked
-
Edit the
serval_maps_push.sh
script to use the suitable Serval Maps visualisation page, by changing itsTARGET
variable fromtesting
to, for example,kiwiex-2013
. -
Start the Serval DNA daemon process:
./servald start
-
Start the Rhizome mirror daemon to update the mirror every minute:
./utilities/rhizome_mirrord
--interval 60
--servald ./servald
--instance /var/local/serval-node
--mirror-dir /var/local/rhizome-mirror
--unpack-dir /var/local/rhizome-unpacked
--filter-name 'nz_redcross_*.xml.instance.sam.serval'
--exec-on-unpack ./utilities/serval_maps_push.sh
--log-to-stdout
This command will only extract bundles with names matching the
--filter-name
glob pattern, so adjust that pattern to match the names of
the files produced by the application being visualised.
The --log-to-stdout
option produces a log of activity on standard output,
which may be redirected to a file if desired.
The daemon reports errors on standard output and continues execution, so standard output may also be redirected to a file if desired, possibly the same as standard error.
The daemon is relatively untested, and may terminate if there is a code error. It must be watched and restarted if necessary.