diff options
author | Sandro <sandro.jaeckel@gmail.com> | 2022-09-04 14:32:13 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-09-04 14:32:13 +0200 |
commit | 2f54aad5e67454db9d130b876e6ce53f991c42ee (patch) | |
tree | 980b2e0ced856e79176a1c921e96036dce12870a /nixos | |
parent | 16c8c9900fbcbbc4ccfc4c86b48f39257a2ff12b (diff) | |
parent | d8bb7ec120d2472caf84785cc5271ed899a67517 (diff) | |
download | nixlib-2f54aad5e67454db9d130b876e6ce53f991c42ee.tar nixlib-2f54aad5e67454db9d130b876e6ce53f991c42ee.tar.gz nixlib-2f54aad5e67454db9d130b876e6ce53f991c42ee.tar.bz2 nixlib-2f54aad5e67454db9d130b876e6ce53f991c42ee.tar.lz nixlib-2f54aad5e67454db9d130b876e6ce53f991c42ee.tar.xz nixlib-2f54aad5e67454db9d130b876e6ce53f991c42ee.tar.zst nixlib-2f54aad5e67454db9d130b876e6ce53f991c42ee.zip |
Merge pull request #156813 from JQ-Networks/master
Diffstat (limited to 'nixos')
-rw-r--r-- | nixos/modules/services/monitoring/prometheus/exporters.nix | 1 | ||||
-rw-r--r-- | nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix | 29 | ||||
-rw-r--r-- | nixos/tests/prometheus-exporters.nix | 61 |
3 files changed, 91 insertions, 0 deletions
diff --git a/nixos/modules/services/monitoring/prometheus/exporters.nix b/nixos/modules/services/monitoring/prometheus/exporters.nix index 3447fe1bd2e0..1f31c1f6ca1b 100644 --- a/nixos/modules/services/monitoring/prometheus/exporters.nix +++ b/nixos/modules/services/monitoring/prometheus/exporters.nix @@ -72,6 +72,7 @@ let "unbound" "unifi" "unifi-poller" + "v2ray" "varnish" "wireguard" "flow" diff --git a/nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix b/nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix new file mode 100644 index 000000000000..185506cfc2b7 --- /dev/null +++ b/nixos/modules/services/monitoring/prometheus/exporters/v2ray.nix @@ -0,0 +1,29 @@ +{ config, lib, pkgs, options }: + +with lib; + +let + cfg = config.services.prometheus.exporters.v2ray; +in +{ + port = 9299; + extraOpts = { + v2rayEndpoint = mkOption { + type = types.str; + default = "127.0.0.1:54321"; + description = '' + v2ray grpc api endpoint + ''; + }; + }; + serviceOpts = { + serviceConfig = { + ExecStart = '' + ${pkgs.prometheus-v2ray-exporter}/bin/v2ray-exporter \ + --v2ray-endpoint ${cfg.v2rayEndpoint} \ + --listen ${cfg.listenAddress}:${toString cfg.port} \ + ${concatStringsSep " \\\n " cfg.extraFlags} + ''; + }; + }; +} diff --git a/nixos/tests/prometheus-exporters.nix b/nixos/tests/prometheus-exporters.nix index 4fdff7dbdab8..3b9ca4f0aa6a 100644 --- a/nixos/tests/prometheus-exporters.nix +++ b/nixos/tests/prometheus-exporters.nix @@ -1256,6 +1256,67 @@ let ''; }; + v2ray = { + exporterConfig = { + enable = true; + }; + + metricProvider = { + systemd.services.prometheus-nginx-exporter.after = [ "v2ray.service" ]; + services.v2ray = { + enable = true; + config = { + stats = {}; + api = { + tag = "api"; + services = [ "StatsService" ]; + }; + inbounds = [ + { + port = 1080; + listen = "127.0.0.1"; + protocol = "http"; + } + { + listen = "127.0.0.1"; + port = 54321; + protocol = "dokodemo-door"; + settings = { address = "127.0.0.1"; }; + tag = "api"; + } + ]; + outbounds = [ + { + protocol = "freedom"; + } + { + protocol = "freedom"; + settings = {}; + tag = "api"; + } + ]; + routing = { + strategy = "rules"; + settings = { + rules = [ + { + inboundTag = [ "api" ]; + outboundTag = "api"; + type = "field"; + } + ]; + }; + }; + }; + }; + }; + exporterTest = '' + wait_for_unit("prometheus-v2ray-exporter.service") + wait_for_open_port(9299) + succeed("curl -sSf localhost:9299/scrape | grep 'v2ray_up 1'") + ''; + }; + varnish = { exporterConfig = { enable = true; |