mirror of
https://git.disroot.org/pranav/pybatmesh.git
synced 2025-01-13 02:02:06 +05:30
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:
parent
8aeacb0ecb
commit
715f4b7308
13
Makefile
13
Makefile
@ -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
|
||||||
|
45
README.md
45
README.md
@ -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.
|
||||||
|
79
naxalnet
79
naxalnet
@ -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")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user