nixpkgs-suyu/nixos/modules/services/networking/hostapd.nix

183 lines
4.7 KiB
Nix
Raw Normal View History

{ config, lib, pkgs, utils, ... }:
2012-10-06 06:39:56 +02:00
# TODO:
#
# asserts
2012-10-06 06:39:56 +02:00
# ensure that the nl80211 module is loaded/compiled in the kernel
# wpa_supplicant and hostapd on the same wireless interface doesn't make any sense
with lib;
2012-10-06 06:39:56 +02:00
let
cfg = config.services.hostapd;
escapedInterface = utils.escapeSystemdPath cfg.interface;
configFile = pkgs.writeText "hostapd.conf" ''
2012-10-06 06:39:56 +02:00
interface=${cfg.interface}
driver=${cfg.driver}
ssid=${cfg.ssid}
hw_mode=${cfg.hwMode}
channel=${toString cfg.channel}
# logging (debug level)
logger_syslog=-1
logger_syslog_level=2
logger_stdout=-1
logger_stdout_level=2
2018-12-19 22:39:39 +01:00
ctrl_interface=/run/hostapd
2012-10-06 06:39:56 +02:00
ctrl_interface_group=${cfg.group}
${optionalString cfg.wpa ''
wpa=2
2012-10-06 06:39:56 +02:00
wpa_passphrase=${cfg.wpaPassphrase}
''}
${optionalString cfg.noScan "noscan=1"}
2012-10-06 06:39:56 +02:00
${cfg.extraConfig}
'' ;
2012-10-06 06:39:56 +02:00
in
{
###### interface
options = {
services.hostapd = {
enable = mkOption {
default = false;
description = ''
Enable putting a wireless interface into infrastructure mode,
allowing other wireless devices to associate with the wireless
interface and do wireless networking. A simple access point will
<option>enable hostapd.wpa</option>,
<option>hostapd.wpaPassphrase</option>, and
<option>hostapd.ssid</option>, as well as DHCP on the wireless
interface to provide IP addresses to the associated stations, and
NAT (from the wireless interface to an upstream interface).
2012-10-06 06:39:56 +02:00
'';
};
interface = mkOption {
default = "";
example = "wlp2s0";
2012-10-06 06:39:56 +02:00
description = ''
The interfaces <command>hostapd</command> will use.
2012-10-06 06:39:56 +02:00
'';
};
noScan = mkOption {
default = false;
description = ''
Do not scan for overlapping BSSs in HT40+/- mode.
Caution: turning this on will violate regulatory requirements!
'';
};
2012-10-06 06:39:56 +02:00
driver = mkOption {
default = "nl80211";
example = "hostapd";
type = types.str;
description = ''
Which driver <command>hostapd</command> will use.
Most applications will probably use the default.
'';
2012-10-06 06:39:56 +02:00
};
ssid = mkOption {
default = "nixos";
example = "mySpecialSSID";
type = types.str;
2012-10-06 06:39:56 +02:00
description = "SSID to be used in IEEE 802.11 management frames.";
};
hwMode = mkOption {
default = "g";
2016-11-16 14:36:26 +01:00
type = types.enum [ "a" "b" "g" ];
description = ''
Operation mode.
(a = IEEE 802.11a, b = IEEE 802.11b, g = IEEE 802.11g).
'';
2012-10-06 06:39:56 +02:00
};
channel = mkOption {
2012-10-06 06:39:56 +02:00
default = 7;
example = 11;
type = types.int;
description = ''
2012-10-06 06:39:56 +02:00
Channel number (IEEE 802.11)
Please note that some drivers do not use this value from
<command>hostapd</command> and the channel will need to be configured
separately with <command>iwconfig</command>.
'';
2012-10-06 06:39:56 +02:00
};
group = mkOption {
default = "wheel";
example = "network";
type = types.str;
description = ''
Members of this group can control <command>hostapd</command>.
'';
};
2012-10-06 06:39:56 +02:00
wpa = mkOption {
default = true;
description = ''
Enable WPA (IEEE 802.11i/D3.0) to authenticate with the access point.
'';
};
2012-10-06 06:39:56 +02:00
wpaPassphrase = mkOption {
default = "my_sekret";
example = "any_64_char_string";
type = types.str;
description = ''
WPA-PSK (pre-shared-key) passphrase. Clients will need this
passphrase to associate with this access point.
Warning: This passphrase will get put into a world-readable file in
the Nix store!
'';
};
2012-10-06 06:39:56 +02:00
extraConfig = mkOption {
2012-10-06 06:39:56 +02:00
default = "";
example = ''
auth_algo=0
ieee80211n=1
ht_capab=[HT40-][SHORT-GI-40][DSSS_CCK-40]
'';
2016-10-23 19:33:41 +02:00
type = types.lines;
description = "Extra configuration options to put in hostapd.conf.";
2012-10-06 06:39:56 +02:00
};
};
};
2012-10-06 06:39:56 +02:00
###### implementation
config = mkIf cfg.enable {
environment.systemPackages = [ pkgs.hostapd ];
2013-02-24 12:11:45 +01:00
systemd.services.hostapd =
{ description = "hostapd wireless AP";
path = [ pkgs.hostapd ];
after = [ "sys-subsystem-net-devices-${escapedInterface}.device" ];
bindsTo = [ "sys-subsystem-net-devices-${escapedInterface}.device" ];
requiredBy = [ "network-link-${cfg.interface}.service" ];
wantedBy = [ "multi-user.target" ];
2013-02-24 12:11:45 +01:00
serviceConfig =
2013-02-24 12:11:45 +01:00
{ ExecStart = "${pkgs.hostapd}/bin/hostapd ${configFile}";
Restart = "always";
};
2012-10-06 06:39:56 +02:00
};
};
}