dotfiles/modules/nixos/services/mosquitto/default.nix
2023-11-30 20:05:14 -08:00

49 lines
1.1 KiB
Nix

{
options,
config,
lib,
pkgs,
format,
...
}:
with lib; let
cfg = config.aa.services.mosquitto;
mosquitto_cfg = config.services.mosquitto;
in {
options.aa.services.mosquitto = with types; {
enable = mkEnableOption "home assistant";
};
config = mkIf cfg.enable {
age.secrets = {
hass_mqtt.file = ../../../../secrets/hass_mqtt.age;
theengs_ble_mqtt.file = ../../../../secrets/theengs_ble_mqtt.age;
};
services.mosquitto = {
enable = true;
listeners = [
{
users = {
hass = {
acl = [
"readwrite home/#"
"readwrite homeassistant/#"
];
passwordFile = config.age.secrets.hass_mqtt.path;
};
theengs_ble_gateway = {
acl = [
"readwrite home/#"
"readwrite homeassistant/#"
];
passwordFile = config.age.secrets.theengs_ble_mqtt.path;
};
};
}
];
};
networking.firewall.allowedTCPPorts = [1883];
};
}