Sets up your Raspberry Pi with a wireless access point, BATMAN-ADV mesh point and Lighttpd server.
Shell
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
scripts
.DS_Store
LICENSE.md
README.md
add_mesh.sh
install.sh
subnodes.config
uninstall.sh

README.md

subnodes-lighttpd

Subnodes is an open source project that turns your Linux device running the latest Raspbian release (as of this writing, Stretch Lite) into an offline mesh node and wireless access point.

This project is an initiative focused on streamlining the process of setting up a Raspberry Pi as a wireless access point for distributing content, media, and shared digital experiences. The device becomes a web server, creating its own local area network, and does not connect with the internet. This is key for the sake of offering a space where people can communicate anonymously and freely, as well as maximizing the portability of the network (no dependibility on an internet connection means the device can be taken and remain active anywhere).

The device can also be configured as a BATMAN Advanced mesh node, enabling it to join with other nearby BATMAN nodes into a greater mesh network, extending the access point range and making it possible to exchange information with each other. Support for Subnodes has been provided by Eyebeam. This code is published under the AGPLv3.

How to Install

Assuming you are starting with a fresh Raspbian Stretch Lite (Latest tested version: November 2018) installed on your SD card, these are the steps for setting up subnodes on your Raspberry Pi. It is also assumed that you have two wireless USB adapters attached to your RPi. They both must be running the nl80211 driver. If you are running a Raspberry Pi 3 or Pi Zero W, you only need one additional radio for the mesh point. The access point will be set up utilizing the Pi's internal wireless radio.

Also, if this is your first time connecting to your Raspberry Pi headlessly (i.e. via SSH), you must first enable SSH by placing an empty file with no filename extension simple called ssh in the root of your SD card.

  • set up your Raspberry Pi with a basic configuration

      sudo raspi-config
    
  • update apt-get

      sudo apt-get update
    
  • install git

      sudo apt-get install git
    
  • clone the repository into your home folder (assuming /home/pi)

      git clone https://github.com/chootka/subnodes-lighttpd.git
    
  • configure your wireless access point and mesh network in subnodes.config in any text editor, or in the command line you can use nano

      nano subnodes.config
    
  • run the installation script

      cd subnodes
      sudo ./install.sh
    

The installation process takes about 15 minutes. After it has completed, you will have a running lighttpd php7 web server, wireless access point, and BATMAN Advanced mesh node. Connecting to the network and navigating to a browser page will redirect you to your new captive portal page. It's only going to be a boilerplate (aka, default) lighttpd web page, so head into /var/www/html and create a new index.html file and go nuts.

From here, fork, build, share your ideas, and have fun!

references