forked from dan/liminix
Fork 0
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Daniel Barlow be044cb59e doc: print headline for modules with no preamble 2 months ago
devices rename config.outputs to config.system.outputs 2 months ago
doc doc: print headline for modules with no preamble 2 months ago
examples convert ntp to serviceDefn 2 months ago
kernel delete unused file 7 months ago
modules add preamble text to each service-providing-module 2 months ago
pkgs move module-based-service parameter types into service 2 months ago
tests update hostapd to "build" syntax 2 months ago
.gitignore extract secrets for extneder 7 months ago link to CoC, mention IRC 7 months ago fix spelling, remove dead file 8 months ago
LICENSE licence: remove accidental punctuation, update copyright year 8 months ago markup 2 months ago explain package/module distinction, add notes on side tracks 1 year ago
THOUGHTS.txt thunk 2 months ago
bordervm-configuration.nix bordervm: add sshd, usbutils 4 months ago
bordervm.conf-example.nix support USB ethernet in bordervm 5 months ago
ci.nix extract module top-level comment to docs 2 months ago
default.nix rename config.outputs to config.system.outputs 2 months ago
nat.nft example config for ppoe router 7 months ago
overlay.nix move typeChecked into pkgs.liminix.lib 2 months ago
shell.nix shell.nix: set FENNEL_PATH for interactive convenience 3 months ago
vanilla-configuration.nix convert ntp to serviceDefn 2 months ago


A Nix-based system for configuring consumer wifi routers or IoT device devices, of the kind that OpenWrt or DD-WRT or Gargoyle or Tomato run on. It's a reboot/restart/rewrite of NixWRT.

This is not NixOS-on-your-router: it's aimed at devices that are underpowered for the full NixOS experience. It uses busybox tools, musl instead of GNU libc, and s6-rc instead of systemd.

The Liminix name comes from Liminis, in Latin the genitive declension of "limen", or "of the threshold". Your router stands at the threshold of your (online) home and everything you send to/receive from the outside word goes across it.

Current status (does it work yet?)

Liminix is pre-1.0. We are still finding new and better ways to do things, and there is no attempt to maintain backward compatibility with the old ways. This will change when it settles down.

In general: development mostly happens on the main branch, which is therefore not guaranteed to build or to work on every commit. For the latest functioning version, see the CI system and pick a revision with all jobs green.

In particular: as of July 2023, a significant re-arrangement of modules and services is ongoing:

  • if you are using out-of-tree configurations created before commit 2e50368, especially if they reference things under pkgs.liminix, they will need updating. Look at changes to examples/rotuer.nix for guidance

  • the same is intermittently true for examples/{extensino,arhcive}.nix where I've updated rotuer and not updated them to match.


Documentation is in the doc directory. You can build it by running

nix-shell -p sphinx --run "make -C doc html"

Rendered documentation corresponding to the latest commit on main is published to

Extremely online

There is a #liminix IRC channel on the OFTC network in which you are welcome. You can also connect with a Matrix client by joining the room

In the IRC channel, as in all Liminix project venues, please conduct yourself according to the Liminix Code of Conduct.