Kiana Sheibani
475017cf87
The `_module.args` option can't be used to pass modules to import, since it can only be used during the config phase, not the import phase. |
||
---|---|---|
aether | ||
deploy/rpi5 | ||
modules | ||
flake.lock | ||
flake.nix | ||
LICENSE | ||
README.md |
Aἰθήρ
[Aither] as a whole neither came into being nor admits of destruction, but is one and eternal, with no end or beginning of its total duration, containing and embracing in itself the infinity of time ...
— Aristotle, On the Heavens 1
Aether is a fully automated web server configured via pure and declarative package management, powered by NixOS. This allows for all aspects of the server's operation, including config files, software dependencies, and site content to be deployed and provisioned automatically.
In short, it's my personal web server.
Deployment
Aether is designed to separate deployment from the logical specification of the system, and thus to support any machine that can run NixOS.
Currently, I deploy it physically to a Raspberry Pi 5 running a modified UEFI bootloader to provide Linux support.
Modules
As with all NixOS configurations, Aether is split into several independent modules that provide different functionality. These are stored in the modules/
directory.
Module Checklist
forgejo
- Code forgeacme
- TLS certificatesfail2ban
- IP moderationsite
- Personal websitemail
- Mail serverbackup
- Automated backup systemcachix
- Nix build caching