zaphyra's git: nixfiles

zaphyra and void's nixfiles

1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
{
  povSelf,
  pkgs,
  lib,
  config,
  hostConfig,
  ...
}:
let
  inherit (lib) types;
  cfg = lib.getAttrFromPath povSelf config;

in
{

  option = {
    type = types.bool;
    default = false;
  };

  config = lib.mkIf cfg {
    systemd.services = {
      mosquitto.requires = [ "mosquittoFixPerms.service" ];
      mosquittoFixPerms.script = ''
        chown -R mosquitto:mosquitto /etc/mosquitto;
      '';
    };

    services.mosquitto = {
      enable = true;
      persistence = false;
      settings.max_keepalive = 60;
      listeners = [
        {
          port = 1883;
          omitPasswordAuth = true;
          users = { };
          settings = {
            allow_anonymous = true;
          };
          acl = [
            "topic readwrite #"
            "pattern readwrite #"
          ];
        }

        {
          address = "::1";
          port = 9005;
          omitPasswordAuth = true;
          users = { };
          settings = {
            protocol = "websockets";
            allow_anonymous = true;
          };
          acl = [
            "topic readwrite #"
            "pattern readwrite #"
          ];
        }
      ];
    };
  };

}