- Python 84.8%
- Makefile 8.5%
- Shell 4.6%
- Dockerfile 2.1%
| docs/languages | ||
| rns_page_node | ||
| tests | ||
| .gitignore | ||
| CHANGELOG.md | ||
| config.example | ||
| LICENSE | ||
| Makefile | ||
| poetry.lock | ||
| pyproject.toml | ||
| README.md | ||
| requirements.txt | ||
| setup.py | ||
| Taskfile.yml | ||
RNS Page Node
Русский | 中文 | 日本語 | Italiano | Deutsch
A simple way to serve simple pages and files over the Reticulum network. Drop-in replacement for NomadNet nodes that primarily serve pages and files. For more advanced pages and setups you should use NomadNet.
This project is no longer being updated, but it is configured to use RNS >= 1.3.4 so it will always use the latest compatible network stack.
Source: GitHub (code mirror). Releases: PyPI and signed artifacts on Reticulum via rngit (origin RNS remote).
Features
- Serves simple pages and files over RNS
- Dynamic page support with environment variables
- Form data and request parameter parsing
Installation
From PyPI
pip install rns-page-node
# or
pipx install rns-page-node
From GitHub (source)
pip install git+https://github.com/Quad4-Software/rns-page-node.git
# or
pipx install git+https://github.com/Quad4-Software/rns-page-node.git
From an rngit release
If you use Reticulum and have rngit configured, fetch a release from the project RNS remote (same URL as git remote get-url origin when using RNS):
rngit release fetch v1.6.0:all
pip install dist/rns_page_node-*.whl
Usage
# will use current directory for pages and files
rns-page-node
or with command-line options:
rns-page-node --node-name "Page Node" --pages-dir ./pages --files-dir ./files --identity-dir ./node-config --announce-interval 360
or with a config file:
rns-page-node /path/to/config.conf
Configuration File
You can use a configuration file to persist settings. See config.example for an example.
Config file format is simple key=value pairs:
# Comment lines start with #
node-name=My Page Node
pages-dir=./pages
files-dir=./files
identity-dir=./node-config
announce-interval=360
Priority order: Command-line arguments > Config file > Defaults
Build
make build
Build wheels only:
make wheel
Development
poetry install
bash tests/run_tests.sh
make lint
make test runs the same script as tests/run_tests.sh.
Releases
Distribution is PyPI plus rngit (Reticulum). Pushing tags/commits uses origin, which mirrors code to GitHub and the RNS remote.
make release-dist # build dist/
make release # tag, push (GitHub + RNS), upload rngit release
make release-local # rngit release on local remote only
make publish # upload wheels to PyPI
Other targets: release-list, release-view, release-fetch, release-verify, release-delete. Override RELEASE_TAG, RNGIT_REMOTE, RNGIT_IDENTITY, or RNGIT_SIGNER as needed.
Pages
Supports dynamic executable pages with full request data parsing. Pages can receive:
- Form fields via
field_*environment variables - Link variables via
var_*environment variables - Remote identity via
remote_identityenvironment variable - Link ID via
link_idenvironment variable
This enables forums, chats, and other interactive applications compatible with NomadNet clients.
Options
Positional arguments:
node_config Path to rns-page-node config file
Optional arguments:
-c, --config Path to the Reticulum config file
-n, --node-name Name of the node
-p, --pages-dir Directory to serve pages from
-f, --files-dir Directory to serve files from
-i, --identity-dir Directory to persist the node's identity
-a, --announce-interval Interval to announce the node's presence (in minutes, default: 360 = 6 hours)
--page-refresh-interval Interval to refresh pages (in seconds, 0 = disabled)
--file-refresh-interval Interval to refresh files (in seconds, 0 = disabled)
-l, --log-level Logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL)
License
This project incorporates portions of the NomadNet codebase, which is licensed under the GNU General Public License v3.0 (GPL-3.0). As a derivative work, this project is also distributed under the terms of the GPL-3.0. See the LICENSE file for full license.