grafana-alloy: don't build the frontend twice
[NixPkgs.git] / nixos / modules / services / monitoring / grafana-image-renderer.nix
blobe06720b153020ea2b86a992bd4097689c9b5dd1c
1 { lib, pkgs, config, ... }:
3 with lib;
5 let
6   cfg = config.services.grafana-image-renderer;
8   format = pkgs.formats.json { };
10   configFile = format.generate "grafana-image-renderer-config.json" cfg.settings;
11 in {
12   options.services.grafana-image-renderer = {
13     enable = mkEnableOption "grafana-image-renderer";
15     chromium = mkOption {
16       type = types.package;
17       description = ''
18         The chromium to use for image rendering.
19       '';
20     };
22     verbose = mkEnableOption "verbosity for the service";
24     provisionGrafana = mkEnableOption "Grafana configuration for grafana-image-renderer";
26     settings = mkOption {
27       type = types.submodule {
28         freeformType = format.type;
30         options = {
31           service = {
32             port = mkOption {
33               type = types.port;
34               default = 8081;
35               description = ''
36                 The TCP port to use for the rendering server.
37               '';
38             };
39             logging.level = mkOption {
40               type = types.enum [ "error" "warning" "info" "debug" ];
41               default = "info";
42               description = ''
43                 The log-level of the {file}`grafana-image-renderer.service`-unit.
44               '';
45             };
46           };
47           rendering = {
48             width = mkOption {
49               default = 1000;
50               type = types.ints.positive;
51               description = ''
52                 Width of the PNG used to display the alerting graph.
53               '';
54             };
55             height = mkOption {
56               default = 500;
57               type = types.ints.positive;
58               description = ''
59                 Height of the PNG used to display the alerting graph.
60               '';
61             };
62             mode = mkOption {
63               default = "default";
64               type = types.enum [ "default" "reusable" "clustered" ];
65               description = ''
66                 Rendering mode of `grafana-image-renderer`:
68                 - `default:` Creates on browser-instance
69                   per rendering request.
70                 - `reusable:` One browser instance
71                   will be started and reused for each rendering request.
72                 - `clustered:` allows to precisely
73                   configure how many browser-instances are supposed to be used. The values
74                   for that mode can be declared in `rendering.clustering`.
75               '';
76             };
77             args = mkOption {
78               type = types.listOf types.str;
79               default = [ "--no-sandbox" ];
80               description = ''
81                 List of CLI flags passed to `chromium`.
82               '';
83             };
84           };
85         };
86       };
88       default = {};
90       description = ''
91         Configuration attributes for `grafana-image-renderer`.
93         See <https://github.com/grafana/grafana-image-renderer/blob/ce1f81438e5f69c7fd7c73ce08bab624c4c92e25/default.json>
94         for supported values.
95       '';
96     };
97   };
99   config = mkIf cfg.enable {
100     assertions = [
101       { assertion = cfg.provisionGrafana -> config.services.grafana.enable;
102         message = ''
103           To provision a Grafana instance to use grafana-image-renderer,
104           `services.grafana.enable` must be set to `true`!
105         '';
106       }
107     ];
109     services.grafana.settings.rendering = mkIf cfg.provisionGrafana {
110       server_url = "http://localhost:${toString cfg.settings.service.port}/render";
111       callback_url = "http://${config.services.grafana.settings.server.http_addr}:${toString config.services.grafana.settings.server.http_port}";
112     };
114     services.grafana-image-renderer.chromium = mkDefault pkgs.chromium;
116     services.grafana-image-renderer.settings = {
117       rendering = mapAttrs (const mkDefault) {
118         chromeBin = "${cfg.chromium}/bin/chromium";
119         verboseLogging = cfg.verbose;
120         timezone = config.time.timeZone;
121       };
123       service = {
124         logging.level = mkIf cfg.verbose (mkDefault "debug");
125         metrics.enabled = mkDefault false;
126       };
127     };
129     systemd.services.grafana-image-renderer = {
130       wantedBy = [ "multi-user.target" ];
131       after = [ "network.target" ];
132       description = " A Grafana backend plugin that handles rendering of panels & dashboards to PNGs using headless browser (Chromium/Chrome)";
134       environment = {
135         PUPPETEER_SKIP_CHROMIUM_DOWNLOAD = "true";
136       };
138       serviceConfig = {
139         DynamicUser = true;
140         PrivateTmp = true;
141         ExecStart = "${pkgs.grafana-image-renderer}/bin/grafana-image-renderer server --config=${configFile}";
142         Restart = "always";
143       };
144     };
145   };
147   meta.maintainers = with maintainers; [ ma27 ];