forked from mirrors/nixpkgs
a560936cab
Co-Authored-By: Franz Pletz <fpletz@fnordicwalking.de> Co-Authored-By: Robin Gloster <mail@glob.in>
40 lines
982 B
Nix
40 lines
982 B
Nix
{ config, pkgs, lib, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
cfg = config.services.prometheus.exporters.openvpn;
|
|
in {
|
|
port = 9176;
|
|
extraOpts = {
|
|
statusPaths = mkOption {
|
|
type = types.listOf types.str;
|
|
description = ''
|
|
Paths to OpenVPN status files. Please configure the OpenVPN option
|
|
<literal>status</literal> accordingly.
|
|
'';
|
|
};
|
|
telemetryPath = mkOption {
|
|
type = types.str;
|
|
default = "/metrics";
|
|
description = ''
|
|
Path under which to expose metrics.
|
|
'';
|
|
};
|
|
};
|
|
|
|
serviceOpts = {
|
|
serviceConfig = {
|
|
PrivateDevices = true;
|
|
ProtectKernelModules = true;
|
|
NoNewPrivileges = true;
|
|
ExecStart = ''
|
|
${pkgs.prometheus-openvpn-exporter}/bin/openvpn_exporter \
|
|
-openvpn.status_paths "${concatStringsSep "," cfg.statusPaths}" \
|
|
-web.listen-address ${cfg.listenAddress}:${toString cfg.port} \
|
|
-web.telemetry-path ${cfg.telemetryPath}
|
|
'';
|
|
};
|
|
};
|
|
}
|