mirror of
https://git.disroot.org/pranav/pybatmesh.git
synced 2024-12-02 11:40:44 +05:30
381 lines
11 KiB
Markdown
381 lines
11 KiB
Markdown
# naxalnet
|
|
|
|
**naxalnet** is a program to create a wireless mesh network for
|
|
communicating with each other. It can be useful during an [internet
|
|
shutdown](#internet-shutdown), or to join [online classes](#online-class)
|
|
with a group of laptops. It uses [B.A.T.M.A.N. Advanced][batman-adv], an
|
|
implementation of the B.A.T.M.A.N. routing protocol to communicate with
|
|
peers. The name naxal comes from Naxalbari, a village in Darjeeling, West
|
|
Bengal.
|
|
|
|
**WARNING**: This program uses an **unencrypted** network. This means you do
|
|
not get any more privacy or security than with an open WiFi network.
|
|
|
|
<!-- NOTE TO ACTIVISTS
|
|
|
|
Running this program in the world's largest (partly-free) democracy
|
|
may result in you getting arrested under the Act Which Must Not Be Named,
|
|
and not getting bail because of false evidence planted in your phone by
|
|
Pegasus, or by a forensic lab in Gujarat.
|
|
|
|
The author, much like the GoI, does not wish to take responsibility in your
|
|
well-being if you get arrested under a draconian national security law.
|
|
|
|
-->
|
|
|
|
## Features
|
|
|
|
- Select best network when multiple nodes have internet access (gateway
|
|
mode)
|
|
- Detect insertion and removal of wifi adapters and reconfigure them
|
|
- Readable logs
|
|
- Supports rfkill
|
|
|
|
<!-- UNCOMMENT WHEN NECESSARY
|
|
|
|
**Disclaimer**: In case you are either 1: a complete idiot; or 2: a member
|
|
of the saffron brigade; or 3: both, please be aware that this project is
|
|
not affiliated with any human rights defenders or with anyone currently at
|
|
risk of death in overcrowded prisons.
|
|
|
|
Using the name naxal in a program will not shake the foundations of
|
|
democracy nor affect the soverignty, unity or integrity of any
|
|
nation-state. .
|
|
|
|
-->
|
|
|
|
## Requirements
|
|
|
|
- [systemd-networkd v248 or greater][batman-systemd]
|
|
- Linux kernel with [batman-adv v2021.0][batman-systemd] or greater
|
|
- [iwd][] for controlling the WiFi adapter
|
|
- python (tested only on 3.9)
|
|
- python setuptools, for building and installing naxalnet
|
|
- [python-systemd][], for logging to systemd journal
|
|
- [dasbus][], for communicating with iwd
|
|
- two or more machines with a WiFi adapter having ibss support, called
|
|
nodes or peers
|
|
- batctl (optional, for debugging)
|
|
- python3-pip (for installing dasbus on Debian-based distributions)
|
|
|
|
## Installing
|
|
|
|
This program is available in the AUR for Arch users. Users of other
|
|
distributions will have to build manually.
|
|
|
|
### Arch Linux
|
|
|
|
Install [naxalnet][aur] (or [naxalnet-git][aur-devel] for the
|
|
development version) from the AUR with your favourite helper:
|
|
|
|
```sh
|
|
yay -S naxalnet
|
|
```
|
|
|
|
Optionally, [setup systemd-resolved][arch-resolved] for DNS. [Start
|
|
naxalnet][startnx] when you need it.
|
|
|
|
### Debian or Ubuntu
|
|
|
|
naxalnet is not packaged for Debian or Ubuntu, so you will have to build
|
|
and install it manually. Currently, only Debian bookworm (testing) and
|
|
Ubuntu 21.10 comes with the required version of systemd. Therefore,
|
|
naxalnet requires **Debian testing** or **Ubuntu 21.10 or greater** to
|
|
work.
|
|
|
|
Install the requirements from the repositories:
|
|
|
|
```sh
|
|
# batctl is optional
|
|
sudo apt install python3-pip python3-systemd iwd batctl build-essential
|
|
# Now, install dasbus with pip
|
|
sudo pip3 install dasbus
|
|
```
|
|
|
|
Now follow the instructions in the
|
|
[manual installation section][install-manual]
|
|
|
|
### Fedora
|
|
|
|
naxalnet is not packaged for Fedora, so it should be installed manually.
|
|
naxalnet requires atleast systemd v248, which is only available on **Fedora
|
|
34 and above**. python-setuptools support building rpms, which are the
|
|
preferred way of installing software in Fedora. Follow the steps to
|
|
install naxalnet on Fedora:
|
|
|
|
```sh
|
|
# Install the build requirements
|
|
sudo dnf install python3-setuptools make git
|
|
|
|
# Clone the repo
|
|
git clone https://git.disroot.org/pranav/naxalnet.git
|
|
cd naxalnet
|
|
|
|
# Create an installable rpm from the source code
|
|
make rpm
|
|
|
|
# Now install it. This will also install the requirements
|
|
sudo dnf install dist/naxalnet-$(python3 -m setup --version)-1.noarch.rpm
|
|
```
|
|
|
|
### Manually
|
|
|
|
Verify that the [requirements][] are of required versions.
|
|
|
|
```sh
|
|
# Should be greater than or equal to 2021.0
|
|
batctl -v
|
|
|
|
# 248 or greater
|
|
systemctl --version
|
|
|
|
# Atleast 4.4
|
|
uname -r
|
|
|
|
# >= 3.6
|
|
python3 --version
|
|
|
|
# Check for IBSS (ad-hoc) support in your WiFi firmware or driver
|
|
iw phy | grep -iq ibss && echo "IBSS is supported" || echo "IBSS not supported"
|
|
```
|
|
|
|
Clone the naxalnet repo and cd into it.
|
|
|
|
```sh
|
|
git clone https://git.disroot.org/pranav/naxalnet.git
|
|
cd naxalnet
|
|
```
|
|
|
|
Now, build and install naxalnet:
|
|
|
|
```sh
|
|
make
|
|
sudo make install
|
|
```
|
|
|
|
After installing, reload systemd so that it detects the new
|
|
service files:
|
|
|
|
```sh
|
|
sudo systemctl daemon-reload
|
|
```
|
|
|
|
To upgrade, clean the build files, update the repo and reinstall:
|
|
|
|
```sh
|
|
make clean
|
|
git pull
|
|
make
|
|
sudo make uninstall
|
|
sudo make install
|
|
```
|
|
|
|
This will keep the configuration files.
|
|
|
|
## How to use
|
|
|
|
You need more than one machine running naxalnet for the connection to work.
|
|
|
|
### Start naxalnet
|
|
|
|
Though naxalnet can run from the command line, it was designed to be
|
|
run as a systemd service.
|
|
To start naxalnet, do the command on all the nodes:
|
|
|
|
```sh
|
|
sudo systemctl start naxalnet.service
|
|
```
|
|
|
|
This will start a mesh network and connect to all nodes. To test if it
|
|
works, run `sudo batctl n -w` and check for nodes. If there are any nodes,
|
|
your network is up. Press Ctrl+C to stop `batctl`.
|
|
|
|
### Getting internet access
|
|
|
|
Connect an ethernet cable from a router to any of the nodes. Now restart
|
|
naxalnet on the node to set `gateway_mode` to `server`. Other nodes will
|
|
take a minute or more to renew DHCP. You can optionally do this manually
|
|
if you don't want the delay. To do this, type
|
|
`sudo networkctl renew bridge0` on all nodes.
|
|
|
|
### Tethering via WiFi AP
|
|
|
|
If there are two adapters in a peer, naxalnet will start a
|
|
WiFi ap (also called WiFi hotspot) on one of them.
|
|
|
|
Connect two WiFi adapters on a node.
|
|
Now an AP will be started on one of the adapters.
|
|
Type `naxalnet --print-wifi` to get the WiFi SSID and password.
|
|
|
|
If you had set up internet access on one of the nodes, internet
|
|
can be accessed from the AP.
|
|
|
|
### Running at boot
|
|
|
|
To run naxalnet at boot, enable the service on all the nodes:
|
|
|
|
```sh
|
|
sudo systemctl enable naxalnet.service
|
|
```
|
|
|
|
Now naxalnet will start a mesh on every boot.
|
|
|
|
If you have NetworkManager enabled, which is the default in Ubuntu and
|
|
Fedora, it should be disabled:
|
|
|
|
```sh
|
|
sudo systemctl disable NetworkManager.service
|
|
```
|
|
|
|
To stop running at boot, you should disable `naxalnet.service`:
|
|
|
|
```sh
|
|
sudo systemctl disable naxalnet.service
|
|
```
|
|
|
|
If you had disabled `NetworkManager` before, enable it:
|
|
|
|
```sh
|
|
sudo systemctl enable NetworkManager.service
|
|
```
|
|
|
|
### Stopping the service
|
|
|
|
```sh
|
|
sudo systemctl stop naxalnet iwd systemd-networkd systemd-resolved
|
|
```
|
|
|
|
If your distribution uses NetworkManager, starting `naxalnet.service`
|
|
will have stopped it. Start NetworkManager again:
|
|
|
|
```sh
|
|
sudo systemctl start NetworkManager.service
|
|
```
|
|
|
|
### Configuration
|
|
|
|
naxalnet comes with a sample configuration file
|
|
`/etc/naxalnet/naxalnet.conf.example`. To change how the program
|
|
behaves, copy it to /etc/naxalnet/naxalnet.conf and edit it:
|
|
|
|
```sh
|
|
sudo cp /etc/naxalnet/naxalnet.conf{.example,}
|
|
# Now edit the file with your favourite editor as root
|
|
gedit admin:/etc/naxalnet/naxalnet.conf
|
|
```
|
|
|
|
Also, you can change its behaviour every time you run it using
|
|
arguments:
|
|
|
|
```sh
|
|
naxalnet --help
|
|
```
|
|
|
|
## Contributing or reporting bugs
|
|
|
|
Join the XMPP channel <xmpp:naxalnet@chat.disroot.org> to talk about
|
|
anything related to this program or about mesh networks in general. See
|
|
[HACKING.md](HACKING.md) to contribute to the repo.
|
|
|
|
## How it works
|
|
|
|
There are three modes commonly supported by WiFi adapters - `ap` (WiFi
|
|
hotspot), `station` (for joining WiFi networks) and `ad-hoc` (or ibss, for
|
|
decentralised networks). There are other modes supported by some WiFi
|
|
adapters too, like `p2p` (WiFi direct), but this program doesn't use them.
|
|
|
|
naxalnet uses two modes - `ad-hoc` and `ap`, for connecting to the
|
|
mesh. naxalnet uses iwd to start an `ad-hoc` network and configures
|
|
systemd-networkd to setup a BATMAN Advanced network.
|
|
If there are two WiFi adapters connected to the machine,
|
|
naxalnet starts an ad-hoc on one of them and an ap on the other.
|
|
You can use the ap for connecting mobile phones and other devices
|
|
to the mesh network.
|
|
|
|
Read the code and the documentation in the code to learn the details.
|
|
See the directory [network](network) to see how
|
|
systemd-networkd configures the network.
|
|
|
|
## Use cases
|
|
|
|
### Online class
|
|
|
|
naxalnet can be used to share connections to join online classes.
|
|
You need at least one device with internet access if you are not using a program like [Jami][].
|
|
|
|
<!--
|
|
|
|
### Malign democracies and well-established institutions
|
|
|
|
Withheld due to national security reasons.
|
|
|
|
-->
|
|
|
|
### Internet shutdown
|
|
|
|
You can communicate with neighbouring devices running naxalnet, using
|
|
services like [IPFS][], [Jami][], [Briar][] [Secure Scuttlebutt][ssb] or
|
|
similar software which can work on an intranet. They should be installed
|
|
on your machine _before_ your friendly democratic government announces an
|
|
[internet shutdown][], since you cannot download and install them during a
|
|
shutdown. When a shutdown occurs, [enable naxalnet][enablenx] and use the
|
|
installed software to communicate with anyone within range.
|
|
|
|
## Uninstalling
|
|
|
|
If you installed naxalnet manually, use make uninstall to remove
|
|
naxalnet and its data files. This requires python pip to be installed.
|
|
|
|
```sh
|
|
# Uninstall the program, keeping the config files
|
|
sudo make uninstall
|
|
# Or, to uninstall and remove config files
|
|
sudo make purge
|
|
```
|
|
|
|
## Similar projects
|
|
|
|
Many projects make setting up B.A.T.M.A.N. Advanced mesh networks with
|
|
WiFi routers easier. They are easier to setup and are more
|
|
configurable. But naxalnet is different from them. It simplifies
|
|
setting up mesh networks with _laptops or computers_, and was not
|
|
made to work with routers.
|
|
|
|
The following projects does something similar to naxalnet, but
|
|
requires special devices or routers to work. If you live in an area
|
|
where the materials are easily available, consider using them instead
|
|
of naxalnet.
|
|
|
|
- [LibreMesh][]: framework for OpenWrt-based firmwares
|
|
- [disaster.radio][]: solar-powered communications network
|
|
|
|
## License
|
|
|
|
naxalnet is [free/libre/swatantra][free-sw] and open source software;
|
|
you can redistribute it and/or modify it under the terms of the GNU
|
|
General Public License as published by the Free Software Foundation,
|
|
eitherversion 3 of the License, or (at your option) any later version.
|
|
|
|
See [LICENSE](LICENSE) for the complete version of the license.
|
|
|
|
[batman-adv]: https://www.open-mesh.org/projects/batman-adv/wiki
|
|
[internet shutdown]: https://internetshutdowns.in
|
|
[ipfs]: https://ipfs.io "InterPlanetary File System"
|
|
[jami]: https://jami.net "Peer to peer video calls"
|
|
[ssb]: https://scuttlebutt.nz "Secure Scuttlebutt"
|
|
[briar]: https://briarproject.org/
|
|
[dasbus]: https://github.com/rhinstaller/dasbus "A python D-Bus library"
|
|
[aur]: https://aur.archlinux.org/packages/naxalnet
|
|
[aur-devel]: https://aur.archlinux.org/packages/naxalnet-git
|
|
[arch-resolved]: https://wiki.archlinux.org/title/Systemd-resolved#DNS "systemd-resolved on ArchWiki"
|
|
[batman-systemd]: https://www.open-mesh.org/news/101 "systemd v248 brings support for batman advanced"
|
|
[libremesh]: https://libremesh.org
|
|
[disaster.radio]: https://disaster.radio
|
|
[startnx]: #start-naxalnet
|
|
[iwd]: https://iwd.wiki.kernel.org "WiFi daemon"
|
|
[free-sw]: https://gnu.org/philosophy/free-sw.html "What is free software?"
|
|
[enablenx]: #running-at-boot
|
|
[requirements]: #requirements
|
|
[install-manual]: #manually
|
|
[python-systemd]: https://github.com/systemd/python-systemd
|