Notice this branch is a compilation of some features from other repositories. if you want to fork the project to work on it use the main repository at https://github.com/ffnord/meshviewer/ (github reverted the fork-history, so rubo77's fork is not the latest).
Pull requests should be made against the dev branch of the main project at https://github.com/ffnord/meshviewer/
Meshviewer is a frontend for ffmap-backend.
- npm
- bower
- grunt-cli
- Sass (>= 3.2)
Install npm and Sass with your package-manager. On Debian-like systems run:
sudo apt-get install npm ruby-sass
Execute these commands on your server as a normal user to prepare the dependencies:
git clone https://github.com/tcatm/meshviewer.git
cd meshviewer
npm install
npm install bower grunt-cli
node_modules/.bin/bower install
Copy config.js.example
to config.js
and change it to match your community.
dataPath
must point to a directory containing nodes.json
and graph.json
(both are generated by
ffmap-backend). Don't forget the
trailing slash! Data may be served from a different domain with CORS enabled.
Also, GZip will greatly reduce bandwidth consumption.
Change this to match your communities' name. It will be used in various places.
This affects the initial scale of the map. Greater values will show a larger area. Values like 1.0 and 0.5 might be good choices.
Setting this to false
will hide contact information for nodes.
Nodes being online for less than maxAge days are considered "new". Likewise, nodes being offline for less than than maxAge days are considered "lost".
A list of objects describing map layers. Each object has at least name
property and optionally url
and config
properties. If no url
is supplied
name
is assumed to name a
Leaflet-provider.
This option allows to show client statistics depending on following case-sensitive parameters:
name
caption of statistics segment in infoboxhref
absolute or relative URL to statistics imagethumbnail
absolute or relative URL to thumbnail image, can be the same likehref
caption
is shown, ifthumbnail
is not present (no thumbnail in infobox)
To insert current node-id in either href
, thumbnail
or caption
you can use the case-sensitive template string {NODE_ID}
.
Examples for nodeInfos
:
"nodeInfos": [
{ "name": "Clientstatistik",
"href": "nodes/{NODE_ID}.png",
"thumbnail": "nodes/{NODE_ID}.png",
"caption": "Knoten {NODE_ID}"
},
{ "name": "Uptime",
"href": "nodes_uptime/{NODE_ID}.png",
"thumbnail": "nodes_uptime/{NODE_ID}.png",
"caption": "Knoten {NODE_ID}"
}
]
In order to have statistics images available, you have to run the backend with parameter --with-rrd
or generate them in other ways.
This option allows to show global statistics on statistics page depending on following case-sensitive parameters:
name
caption of statistics segment in infoboxhref
absolute or relative URL to statistics imagethumbnail
absolute or relative URL to thumbnail image, can be the same likehref
caption
is shown, ifthumbnail
is not present (no thumbnail in infobox)
In contrast to nodeInfos
there is no template substitution in href
, thumbnail
or caption
.
Examples for globalInfos
:
"globalInfos": [
{ "name": "Wochenstatistik",
"href": "nodes/globalGraph.png",
"thumbnail": "nodes/globalGraph.png",
"caption": "Bild mit Wochenstatistik"
},
{ "name": "Jahresstatistik",
"href": "nodes/globalGraph52.png",
"thumbnail": "nodes/globalGraph52.png",
"caption": "Bild mit Jahresstatistik"
}
]
In order to have global statistics available, you have to run the backend with parameter --with-rrd
(this only creates globalGraph.png) or generate them in other ways.
In lib/map.js
you can change the colors and radius for nodes in different states:
- iconNew: Nodes that are online for less than maxAge days (default: green, radius: 6)
- iconOnline: online for more than
maxAge
days (default blue, radius: 6) - iconAlert: nodes offline less than 8 Hours (default: blinking red, radius: 5)
- iconLost: nodes being offline for less than than
maxAge
days (default: red, radius: 5) - iconOffline: offline for more than
maxAge
days up to the maximum prune time of the backend (default: red, radius: 3)
Just run the following command from the meshviewer directory:
node_modules/.bin/grunt
This will generate build/
containing all required files.
To deploy the meshviewer on your server, just rsync build/
into your servers document-home, for example:
sudo rsync -av --delete build/ /var/www/meshviewer/