Updated rewrite and README.md

The rewrite is partly over, with only the iwd
part remaining. The README was updated and a commented-out
section which had no comment closing tag was fixed.
This commit is contained in:
Pranav Jerry 2021-06-04 22:27:54 +05:30
parent 8aeacb0ecb
commit 715f4b7308
3 changed files with 85 additions and 52 deletions

View File

@ -3,7 +3,14 @@ PREFIX := /usr
install: naxalnet install: naxalnet
install -d $(DESTDIR)$(PREFIX)/bin install -d $(DESTDIR)$(PREFIX)/bin
install -d $(DESTDIR)$(PREFIX)/lib/systemd/system/ install -d $(DESTDIR)$(PREFIX)/lib/systemd/system/
install naxalnet@.service $(DESTDIR)$(PREFIX)/lib/systemd/system/ install naxalnet.service $(DESTDIR)$(PREFIX)/lib/systemd/system/
install naxalnet $(DESTDIR)$(PREFIX)/bin/ install naxalnet $(DESTDIR)$(PREFIX)/bin/
install -d $(DESTDIR)$(PREFIX)/share/naxalnet install -d $(DESTDIR)$(PREFIX)/share/naxalnet/networkd
install systemd-networkd/* $(DESTDIR)$(PREFIX)/share/naxalnet/ install systemd-networkd/* $(DESTDIR)$(PREFIX)/share/naxalnet/networkd
testdeps:
@for i in networkctl systemctl python3; do \
echo "Checking for $$i"; \
which $$i > /dev/null && echo " $$i found" || \
(echo " $$i not found"; exit 1); \
done

View File

@ -31,17 +31,18 @@ into networkd's runtime configuration directory. It uses iwctl to start
an ad-hoc network named "Hello World". The wireless interface is linked to an ad-hoc network named "Hello World". The wireless interface is linked to
`bat0`, the batman interface. A bridge `bridge0` is created so that other `bat0`, the batman interface. A bridge `bridge0` is created so that other
devices such as wired connections and wireless ap can be bridged. `bat0` is devices such as wired connections and wireless ap can be bridged. `bat0` is
added to the bridge, and the bridge gets an ip address (link-local, or DHCP if added to the bridge, and the bridge gets an ip address (link-local, or
any of the computers have a DHCP server configured). If these were successful, DHCP if any of the computers have a DHCP server configured). If these
an intranet is created. You can now use services like [IPFS](https://ipfs.io), were successful, an intranet is created. You can now use services
[Jami](https://jami.net), [Secure Scuttlebutt](https://scuttlebutt.nz) like [IPFS](https://ipfs.io), [Jami](https://jami.net),
and others which can work without internet access. [Secure Scuttlebutt](https://scuttlebutt.nz) and others which can work
without internet access.
## Requirements ## Requirements
- systemd v248 or more (for batman support) - systemd v248 or more (for batman support)
- Linux kernel with batman-adv module (if `modinfo batman-adv` shows no error - Linux kernel with batman-adv module (if `modinfo batman-adv` shows
then you already have it) no error then you already have it)
- iwd (for starting ad-hoc network) - iwd (for starting ad-hoc network)
- wifi adapter with ad-hoc support - wifi adapter with ad-hoc support
- two or more computers with wifi adapter - two or more computers with wifi adapter
@ -55,12 +56,10 @@ Clone the repo and cd into it.
Run `sudo make install` to install naxalnet. This will install naxalnet in Run `sudo make install` to install naxalnet. This will install naxalnet in
`/usr/{bin/naxalnet,share/naxalnet/,lib/systemd/system/naxalnet@.service}`. `/usr/{bin/naxalnet,share/naxalnet/,lib/systemd/system/naxalnet@.service}`.
<!-- commented out as you'll have to edit the systemd service for this to work
To install in /usr/local instead, use `sudo make install PREFIX=/usr/local`.
After installing, reload systemd so that you can enable `naxalnet@.service` After installing, reload systemd so that you can enable `naxalnet@.service`
without rebooting: without rebooting:
```
```sh
sudo systemctl daemon-reload sudo systemctl daemon-reload
``` ```
@ -76,24 +75,28 @@ sudo systemctl disable --now NetworkManager
Enable the naxalnet service on the device `wlan0` (iwd replaces interface Enable the naxalnet service on the device `wlan0` (iwd replaces interface
names like wlp1s0 with wlan0): names like wlp1s0 with wlan0):
``` ```
sudo systemctl enable --now naxalnet@wlan0.service sudo systemctl enable --now naxalnet.service
``` ```
Now naxalnet will configure a batman interface on every boot. Now naxalnet will configure a batman interface on every boot.
## Uninstalling ## Uninstalling
Currently there is now way to uninstall naxalnet than to manually removing Currently there is now way to uninstall naxalnet than manually removing
the files: the files:
```sh
sudo rm -rf /usr/{bin,share}/naxalnet \
/usr/lib/systemd/system/naxalnet.service
``` ```
sudo rm -r /usr/{bin/naxalnet,share/naxalnet/,lib/systemd/system/naxalnet@.service}
If you were using NetworkManager before, enable it:
```sh
sudo systemctl enable --now NetworkManager.service
``` ```
<!--
Or if you installed naxalnet in /usr/local:
```
sudo rm -r /usr/local/{bin/naxalnet,share/naxalnet/,lib/systemd/system/naxalnet@.service}
```
-->
## TODO ## TODO
@ -101,4 +104,4 @@ sudo rm -r /usr/local/{bin/naxalnet,share/naxalnet/,lib/systemd/system/naxalnet@
Add list of things here. Add list of things here.
This project is in pre-alpha stage. Documentation is incomplete. This project is in alpha stage. Documentation is incomplete.

View File

@ -5,44 +5,67 @@ Setup a working BATMAN Advanced network
with systemd-networkd and iwd with systemd-networkd and iwd
""" """
# for linking resolv.conf import sys
from pathlib import Path from pathlib import Path
from shutil import copy
from dasbus.connection import SystemMessageBus from dasbus.connection import SystemMessageBus
SYSTEMD_RESOLVED_STUB_RESOLVE = "/run/systemd/resolve/stub-resolv.conf" NETWORKD_CONFIGS = "/usr/share/naxalnet/networkd"
NETWORKD_VOLATILE_DIR = "/run/systemd/network"
RESOLVED_STUB_RESOLVE = "/run/systemd/resolve/stub-resolv.conf"
RESOLV_CONF = "/etc/resolv.conf" RESOLV_CONF = "/etc/resolv.conf"
def get_all_devices(proxy): # Copy networkd configs to volatile dir.
""" # See man:systemd.networkm(5)
Returns d-bus object path of all devices as a list of strings.
proxy: usually what is returned by bus.get_proxy('net.connman.iwd','/')
"""
# Gets all D-Bus objects in the proxy.
objects = proxy.GetManagedObjects()
# Now find out which of them are devices
devices = []
for name, obj in objects.items():
if "net.connman.iwd.Device" in obj:
# add all devices to the list
devices.append(name)
return devices
# Copy networkd configs
# syslink resolvd
try: try:
Path(RESOLV_CONF).symlink_to(SYSTEMD_RESOLVED_STUB_RESOLVE) print("Copying network config files")
except FileExistsError: dest = Path(NETWORKD_VOLATILE_DIR)
print("Resolv.conf already exists") src = Path(NETWORKD_CONFIGS)
# Create the volatile directory if it doesn't exist
dest.mkdir(parents=True, exist_ok=True)
# Copy all files in src to dest
for i in src.iterdir():
copy(i, dest)
except:
sys.exit("An error occured")
# Symlink resolvd.conf to systemd's stub-resolvd.conf
# This is needed for DNS resolution to work.
# see https://wiki.archlinux.org/title/Systemd-resolved#DNS
try:
print("Checking resolv.conf")
r = Path(RESOLV_CONF)
if r.exists():
print(r, "already exists. Removing it")
r.unlink()
print("Linking resolv.conf")
r.symlink_to(RESOLVED_STUB_RESOLVE)
except:
sys.exit("An error occured while linking resolv.conf")
# connect to the System bus # connect to the System bus
bus = SystemMessageBus() bus = SystemMessageBus()
# iwd proxy # iwd proxy
proxy = bus.get_proxy("net.connman.iwd", "/") iwd = bus.get_proxy("net.connman.iwd", "/")
# Get list of all devices
print("Finding connected devices")
objects = iwd.GetManagedObjects()
device_paths = []
for name, obj in objects.items():
if "net.connman.iwd.Device" in obj:
# add all devices to the list
print("Found device:", obj["net.connman.iwd.Device"]["Name"])
device_paths.append(name)
# TODO: On first devices, start ad-hoc
# If there is a second device, start AP
# in it
print("Bye") print("Bye")