forked from mirrors/nixpkgs
67 lines
1.8 KiB
Nix
67 lines
1.8 KiB
Nix
{ config, lib, pkgs, options }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
cfg = config.services.prometheus.exporters.mikrotik;
|
|
in
|
|
{
|
|
port = 9436;
|
|
extraOpts = {
|
|
configFile = mkOption {
|
|
type = types.nullOr types.path;
|
|
default = null;
|
|
description = ''
|
|
Path to a mikrotik exporter configuration file. Mutually exclusive with
|
|
<option>configuration</option> option.
|
|
'';
|
|
example = literalExample "./mikrotik.yml";
|
|
};
|
|
|
|
configuration = mkOption {
|
|
type = types.nullOr types.attrs;
|
|
default = null;
|
|
description = ''
|
|
Mikrotik exporter configuration as nix attribute set. Mutually exclusive with
|
|
<option>configFile</option> option.
|
|
|
|
See <link xlink:href="https://github.com/nshttpd/mikrotik-exporter/blob/master/README.md"/>
|
|
for the description of the configuration file format.
|
|
'';
|
|
example = literalExample ''
|
|
{
|
|
devices = [
|
|
{
|
|
name = "my_router";
|
|
address = "10.10.0.1";
|
|
user = "prometheus";
|
|
password = "changeme";
|
|
}
|
|
];
|
|
features = {
|
|
bgp = true;
|
|
dhcp = true;
|
|
routes = true;
|
|
optics = true;
|
|
};
|
|
}
|
|
'';
|
|
};
|
|
};
|
|
serviceOpts = let
|
|
configFile = if cfg.configFile != null
|
|
then cfg.configFile
|
|
else "${pkgs.writeText "mikrotik-exporter.yml" (builtins.toJSON cfg.configuration)}";
|
|
in {
|
|
serviceConfig = {
|
|
# -port is misleading name, it actually accepts address too
|
|
ExecStart = ''
|
|
${pkgs.prometheus-mikrotik-exporter}/bin/mikrotik-exporter \
|
|
-config-file=${escapeShellArg configFile} \
|
|
-port=${cfg.listenAddress}:${toString cfg.port} \
|
|
${concatStringsSep " \\\n " cfg.extraFlags}
|
|
'';
|
|
};
|
|
};
|
|
}
|