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. https://www.liminix.org/development.html
2025-11-11 21:49:45 +00:00
devices treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
doc treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
examples treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
modules treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
pkgs treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
tests treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
.gitignore docs: add hardware recommendation 2024-01-04 14:35:00 +01:00
AGENTS.md chatgpt go 'way 2025-08-11 23:27:23 +01:00
boot.expect boot.expect: sleep more, for gl-ar750 2025-02-05 20:35:04 +00:00
bordervm-configuration.nix treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
bordervm.conf-example.nix cleanup whitespace and commas 2024-06-30 17:16:28 +01:00
ci.nix treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
CONTRIBUTING.md fix spelling, remove dead file 2023-02-05 22:42:41 +00:00
default.nix nixfmt-rfc-style 2025-02-10 21:55:08 +00:00
doc.nix treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
LICENSE licence: remove accidental punctuation, update copyright year 2023-01-29 16:39:50 +00:00
nat.nft example config for ppoe router 2023-02-25 23:12:55 +00:00
NEWS note dhcp client rename 2025-11-11 21:44:37 +00:00
overlay.nix treewide: nixfmt and deadnix 2025-11-11 21:49:45 +00:00
README.md README should probably not stil claim we're pre-1.0 2025-10-28 23:39:57 +00:00
shell.nix nixfmt-rfc-style 2025-02-10 21:55:08 +00:00
STYLE.md explain package/module distinction, add notes on side tracks 2022-09-27 14:11:23 +01:00
THOUGHTS.txt think 2025-11-11 21:44:37 +00:00
vanilla-configuration.nix fix bad relative path 2025-11-11 21:44:37 +00:00

Liminix

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 1.0 was released in April 2025. It works for me and I would say it has seen lots of use in the particular applications of "home wifi router" and "wireless extender".

It's not “finished” - we are still finding new and better ways to do things - but we endeavour to signal future breaking changes through the version number. This is “semver-adjacent”, in that minor bumps (1.1, 1.2 …) are used for minor new features and major bumps (2.0 …) for changes that are likely to break out-of-tree modules or configurations. It wont be semver exactly because every change breaks someones workflow, but we aspire to have the magnitude of the version delta correlate with the scale of the consequences of upgrading.

The NEWS file (available wherever you found this README) is a high-level overview of breaking changes.

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.

Documentation

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

nix-build -I liminix=`pwd`  ci.nix -A doc

Rendered documentation corresponding to the latest commit on main is published to https://www.liminix.org/doc/

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 #_oftc_#liminix:matrix.org.

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