1
0
Commit Graph

81 Commits

Author SHA1 Message Date
3f889c7119 default firewall zones in gateway profile 2025-02-10 21:21:08 +00:00
6587813577 WIP add zones to firewall module
- zones are an attrset of name -> [interface-service]

- the firewall will create empty "ifname" sets for each zone name
 in each address family (ip, ip6)

- then watch the interface services, and add the "ifname" outputs
to the corresponding sets when they appear

This commit only adds the empty sets
2025-02-10 21:21:08 +00:00
7f9cae9d5c generalise profile.gateway.wan so not just pppoe 2024-07-23 09:31:34 +01:00
3012c91b47 executive decision: rotuer example should build on gl-ar750 2024-07-23 09:31:34 +01:00
3df1ec76ff cleanup whitespace and commas
* [] is now [ ]
* {} is now { }
* commas in arglists go at end of line not beginning

In short, I ran the whole thing through nixfmt-rfc-style but only
accepted about 30% of its changes. I might grow accustomed to more
of it over time
2024-06-30 17:16:28 +01:00
e94bf62ec1 remove dead code (run deadnix) 2024-06-29 22:59:27 +01:00
1a314e55b7 firewall module: provide default rules and merge extraRules
a firewall with no configuration will get a relatively sane ruleset. a
firewall with `extraRules` will get them deep merged into the default
rules.  Specifying `rules` will override the defaults
2024-03-21 12:00:34 +00:00
9263b21faa create gateway profile by extracting from rotuer example 2024-03-21 10:04:42 +00:00
175db9f604 tail -F for rotuer 2024-02-16 18:30:24 +00:00
57aece0709 rotuer: don't forward queries for local domain 2024-02-11 23:32:46 +00:00
c1d285a220 rotuer: network debugging tools 2024-02-11 23:32:46 +00:00
1206d02200 rotuer-secrets: remove root_password, add wifi ssid and domainName
this is step one towards getting rid of rotuer-secrets completely and
turning rotuer into a "profile" module that can be less hackily
customised for other people's networks
2024-02-11 15:56:14 +00:00
7c196bf9b4 rotuer: make 5GHz wifi faster
VHT doesn't work unless HT is enabled, apparently
2024-02-11 15:38:19 +00:00
92b0bec038 rotuer: add schnapps and the rest of the lan interfaces 2024-02-07 23:48:10 +00:00
29e61be26c rotuer: get lan rfc1918 prefix from secrets 2024-02-07 23:46:16 +00:00
c1101d3af5 make extlinux work with liminix-rebuild
add /boot to the systemConfiguration closure
2024-01-08 18:58:07 +00:00
228c0a1668 pass rootOptions config as rootflags= kernel cmdline opt 2024-01-08 18:54:49 +00:00
3c941b4ce2 partial btrfs support
doesn't actually know how to make the filesystem, just
kernel config and accept it as a valid option
2024-01-07 16:43:43 +00:00
55fa9992d4 WIP 2023-12-13 21:54:15 +00:00
5eeb277564 move output module imports example -> device
The outputs available are a characteristic of the device, not
the example.
2023-12-10 16:38:53 +00:00
c81e7c4d35 move all output modules to subdirectory, trash standard.nix
standard.nix isn't, is the essence here. Not all devices
support flashimage as it is currently defined - some
have diskimage, some have neither
2023-12-10 15:23:12 +00:00
a896c4e31c rename wlan services for devices with > 1 radio
let's standardise on having 2.4GHz radio be "wlan", and
5GHz as "wlan5"
2023-10-07 22:28:57 +01:00
c59a228955 this is the dhcp6c service we want 2023-09-26 16:43:03 +01:00
f7b30939b5 remove service-state when service exits 2023-09-13 22:49:00 +01:00
91e957ced7 static leases for rotuer 2023-09-04 23:07:13 +01:00
a24c2a23a0 whitespace 2023-09-04 22:06:15 +01:00
9e52faa0b6 remove unused imports 2023-09-04 22:05:42 +01:00
6805e0090d working down the TODOs 2023-09-01 17:57:22 +01:00
7ad848cb77 add service to enable packet forwarding
might be worth looking into adding RA config to this
2023-09-01 17:34:47 +01:00
3609d8d5ee implement route as module-based-service 2023-08-31 23:24:23 +01:00
aecbe08f08 add o+x permission on service-state directories
this is needed for resolvconf, which writes resolv.conf as
an output and wants to make it world-readable
2023-08-28 22:02:28 +01:00
ff2d3e1a63 TODO comments 2023-08-28 22:02:28 +01:00
8688d47c65 rotuer: create resolv.conf 2023-08-28 22:02:28 +01:00
e86daf9bbc default value for services.default
as a default default target, start all the services
2023-08-28 22:02:28 +01:00
31f0213b6f convert network link/address to module-based-service
... and make bridge use it.

We also had to convert bridge back into a pair of services.
Downstreams want to depend on the bridge it self being configured
even if not necessarily all the members are up. e.g. don't want
to break ssh on lan if there's a misconfigured wlan device
2023-08-28 22:02:28 +01:00
540a1dfd76 remove interface.device
build-time uses can mostly be replaced with interface.name

for runtime uses, switch to $(output ${interface} name)
2023-08-28 22:02:28 +01:00
6f92f8fa8b merge bridge services into one 2023-08-16 23:29:53 +01:00
3ea40f95dc convert pppoe to serviceDefn 2023-08-10 22:53:45 +01:00
2942c465b9 add ssh module 2023-08-10 22:53:21 +01:00
2414dd4b55 convert ntp to serviceDefn 2023-08-05 14:16:54 +01:00
93e04bb834 convert bridge service to serviceDefn 2023-08-05 14:10:14 +01:00
f82501d278 update hostapd to "build" syntax 2023-08-05 12:21:18 +01:00
90c1d59aca convert firewall service to new serviceDefn
this is a bit kludgey with dependencies, need to
come back and look at that
2023-08-05 12:07:35 +01:00
fbb2c04132 move module-based-service parameter types into service
This is in preparation for writing something that extracts them
into documentation.

user configurations now call config.system.service.foo.build { ...params }
instead of config.system.service.foo

the parameter type definitions themselves now move into the
config stanza of the module referencing the service

new helper function  liminix.callService

The only service moved so far is dnsmasq
2023-08-04 20:39:29 +01:00
9994c161d4 DRY up wireless config 2023-07-22 23:37:01 +01:00
bf1d9beec1 add first version of ntp module 2023-07-22 23:25:25 +01:00
4396afa97b inline excessive lets 2023-07-20 12:05:36 +01:00
9b70fd62f6 extract bridge to module-based services 2023-07-20 12:02:09 +01:00
86e73317ee alias config.system.service 2023-07-20 11:28:45 +01:00
648ea5613b use module-based-service for hostapd 2023-07-16 17:51:50 +01:00