summary refs log tree commit diff
path: root/nixos/modules/services/monitoring/prometheus/exporters/pihole.nix
blob: 4bc27ebc32f8a2684897ae1c625708c02df4215c (plain) (blame)
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
66
67
68
69
70
71
72
73
74
{ config, lib, pkgs, options }:

with lib;

let
  cfg = config.services.prometheus.exporters.pihole;
in
{
  port = 9617;
  extraOpts = {
    apiToken = mkOption {
      type = types.str;
      default = "";
      example = "580a770cb40511eb85290242ac130003580a770cb40511eb85290242ac130003";
      description = ''
        pi-hole API token which can be used instead of a password
      '';
    };
    interval = mkOption {
      type = types.str;
      default = "10s";
      example = "30s";
      description = ''
        How often to scrape new data
      '';
    };
    password = mkOption {
      type = types.str;
      default = "";
      example = "password";
      description = ''
        The password to login into pihole. An api token can be used instead.
      '';
    };
    piholeHostname = mkOption {
      type = types.str;
      default = "pihole";
      example = "127.0.0.1";
      description = ''
        Hostname or address where to find the pihole webinterface
      '';
    };
    piholePort = mkOption {
      type = types.port;
      default = 80;
      example = 443;
      description = ''
        The port pihole webinterface is reachable on
      '';
    };
    protocol = mkOption {
      type = types.enum [ "http" "https" ];
      default = "http";
      example = "https";
      description = ''
        The protocol which is used to connect to pihole
      '';
    };
  };
  serviceOpts = {
    serviceConfig = {
      ExecStart = ''
        ${pkgs.bash}/bin/bash -c "${pkgs.prometheus-pihole-exporter}/bin/pihole-exporter \
          -interval ${cfg.interval} \
          ${optionalString (cfg.apiToken != "") "-pihole_api_token ${cfg.apiToken}"} \
          -pihole_hostname ${cfg.piholeHostname} \
          ${optionalString (cfg.password != "") "-pihole_password ${cfg.password}"} \
          -pihole_port ${toString cfg.piholePort} \
          -pihole_protocol ${cfg.protocol} \
          -port ${toString cfg.port}"
      '';
    };
  };
}