499e30cdd7
The default hostapd disable too many things, we need a bit more for RADIUS. Signed-off-by: Raito Bezarius <masterancpp@gmail.com>
38 lines
1 KiB
Nix
38 lines
1 KiB
Nix
{
|
|
liminix
|
|
, writeText
|
|
, lib
|
|
}:
|
|
{ package, interface, params } :
|
|
let
|
|
inherit (liminix.services) longrun;
|
|
inherit (lib) concatStringsSep mapAttrsToList;
|
|
inherit (liminix.lib) typeChecked;
|
|
inherit (lib) mkOption types;
|
|
|
|
# This is not a friendly interface to configuring a wireless AP: it
|
|
# just passes everything straight through to the hostapd config.
|
|
# When we've worked out what the sensible options are to expose,
|
|
# we'll add them as top-level attributes and rename params to
|
|
# extraParams
|
|
|
|
name = "${interface.name}.hostapd";
|
|
defaults = {
|
|
driver = "nl80211";
|
|
logger_syslog = "-1";
|
|
logger_syslog_level = 1;
|
|
ctrl_interface = "/run/hostapd";
|
|
ctrl_interface_group = 0;
|
|
};
|
|
|
|
conf = writeText "hostapd.conf"
|
|
(concatStringsSep
|
|
"\n"
|
|
(mapAttrsToList
|
|
(name: value: "${name}=${toString value}")
|
|
(defaults // params)));
|
|
in longrun {
|
|
inherit name;
|
|
dependencies = [ interface ];
|
|
run = "${package}/bin/hostapd -i $(output ${interface} ifname) -P /run/${name}.pid -S ${conf}";
|
|
}
|