You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Martin/Geno d372718264
show error message on database connect
1 year ago
.ci add gitlab-ci build 1 year ago
data fix gitlab ci 1 year ago
runtime change logger library 1 year ago
ssh change logger library 1 year ago
tools fix misspelling 1 year ago
webroot relativ leaflet files 1 year ago
websocket change logger library 1 year ago
.gitignore cleanup and migrate to newer libraries (use NEW Javascript env) + add secret 2 years ago
.gitlab-ci.yml fix gitlab ci 1 year ago
.gitmodules [TASK] add vendor for yanic client 3 years ago
.test-coverage [TASK] add vendor for yanic client 3 years ago
.travis.yml fix travis builds 2 years ago Create 3 years ago README: document setcap command (necessary for pinger) 1 year ago
config_example.conf make pinger every,timeout and count configurable 1 year ago
main.go show error message on database connect 1 year ago

FreifunkManager Build Status Coverage Status

is a little software to manage gluon nodes with the help of ssh and yanic (used on the Breminale since 2017)

Preparations for Building

Install Go 1.10 or newer:

mkdir -p ~/inst
cd ~/inst
tar xf go1.10.3.linux-amd64.tar.gz
export PATH=~/inst/go/bin/:$PATH
export GOROOT=~/inst/go/


export GOPATH=$HOME/go

Install nodejs >= 4.8:

mkdir -p ~/inst
cd ~/inst
tar xf node-v8.11.3-linux-x64.tar.xz
export PATH=~/inst/node-v8.11.3-linux-x64/bin/:$PATH

Install yarn (

mkdir -p ~/inst
cd ~/inst
tar xf yarn-v1.7.0.tar.gz
export PATH=~/inst/yarn-v1.7.0/bin/:$PATH

Building & Running

Download and build freifunkmanager:

go get -t
go get
go get
cd $GOPATH/src/
go build
sudo setcap cap_net_raw+ep freifunkmanager # necessary for sending ping packets
cd webroot
yarn install
yarn gulp build


./freifunkmanager -config config_example.conf


Visit http://localhost:8080/

Navigation bar at top of page:

  • marker icon: (TODO)
  • List: show list of all known nodes
    • use Edit link in last column of a node to edit its details; changes made on the Edit page are saved immediately
    • to change just the hostname, double-click on hostname field in list and make your change
  • Map: show map of nodes
    • use Layers icon in upper right corner to enable geojson overlay and view clients
  • Statistics: show statistics about nodes, clients, used channels...
  • Login with text field: enter password (value of "secret" in config file) and click "Login" to log in
    • this is necessary to make any changes
    • there is no user management; anybody who has the password has full access
  • blue rectangle on the far right: (TODO: connection status?)

Technical Details

List of known nodes will be retrieved with the respondd protocol (ie. by periodic UDP multicast requests to all reachable nodes). For this, FFMan uses a built-in Yanic instance. The respondd protocol provides configuration details and statistics for each node.

Alternatively, FFMan can also be configured to just listen to respondd responses (without sending requests); this is useful to "listen in" on the responses requested by a separate Yanic process running on the same network. This mode can be enabled by setting yanic_collect_interval to 0s and settings yanic.send_no_request to true.

Additionally, nodes can be added manually by visiting a page like /#/n/apname (where "apname" is the node-id of the new device), and then setting a hostname.

The web interface displays all nodes that were found (except for nodes which don't respond to SSH - these are blacklisted). The web interface is updated live, by using a websocket connection; this also means that changes made in one tab will appear immediately in other tabs as well.

When node settings are changed in the web interface, an SSH connection is opened to the node to apply the new settings.

All changes are also saved to a state file (eg. /tmp/freifunkmanager.json - can be changed in config file). And all of the received node data is also stored in a database (see db_type and db_connection config options).

Creating dummy respondd data

  • create dummy "eth10" network interface:
sudo -s
modprobe dummy
ifconfig dummy0 hw ether 00:22:22:ff:ff:ff
ipaddr=`ipv6calc --in prefix+mac --action prefixmac2ipv6 --out ipv6addr fe80:: 00:22:22:ff:ff:ff`
ip a add dev dummy0 scope link $ipaddr/64
ip link set dummy0 up
  • edit tools/example-response.json to set network addresses for each node that are reachable with SSH (otherwise the nodes will be blacklisted immediately)
    • also, if necessary adjust the ssh_ipaddress_prefix setting in config_example.conf to match the addresses from example-response.json
  • edit config_example.conf: in [yanic] section set ifname="dummy0"
  • edit $GOPATH/src/ change port=10001
  • go to $GOPATH/src/ and run "go build"
  • start FFMan as usual (./freifunkmanager -config config_example.conf)
  • in another shell run ./tools/ -p 10001 -i dummy0 -f tools/example-response.json
  • FFMan should now display two new nodes with the example hostnames