mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-13 00:14:43 +00:00
6afb255d97
these changes were generated with nixq 0.0.2, by running nixq ">> lib.mdDoc[remove] Argument[keep]" --batchmode nixos/**.nix nixq ">> mdDoc[remove] Argument[keep]" --batchmode nixos/**.nix nixq ">> Inherit >> mdDoc[remove]" --batchmode nixos/**.nix two mentions of the mdDoc function remain in nixos/, both of which are inside of comments. Since lib.mdDoc is already defined as just id, this commit is a no-op as far as Nix (and the built manual) is concerned.
61 lines
1.5 KiB
Nix
61 lines
1.5 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
|
|
let
|
|
cfg = config.services.blackfire-agent;
|
|
|
|
agentConfigFile = lib.generators.toINI {} {
|
|
blackfire = cfg.settings;
|
|
};
|
|
|
|
agentSock = "blackfire/agent.sock";
|
|
in {
|
|
meta = {
|
|
maintainers = pkgs.blackfire.meta.maintainers;
|
|
doc = ./blackfire.md;
|
|
};
|
|
|
|
options = {
|
|
services.blackfire-agent = {
|
|
enable = lib.mkEnableOption "Blackfire profiler agent";
|
|
settings = lib.mkOption {
|
|
description = ''
|
|
See https://blackfire.io/docs/up-and-running/configuration/agent
|
|
'';
|
|
type = lib.types.submodule {
|
|
freeformType = with lib.types; attrsOf str;
|
|
|
|
options = {
|
|
server-id = lib.mkOption {
|
|
type = lib.types.str;
|
|
description = ''
|
|
Sets the server id used to authenticate with Blackfire
|
|
|
|
You can find your personal server-id at https://blackfire.io/my/settings/credentials
|
|
'';
|
|
};
|
|
|
|
server-token = lib.mkOption {
|
|
type = lib.types.str;
|
|
description = ''
|
|
Sets the server token used to authenticate with Blackfire
|
|
|
|
You can find your personal server-token at https://blackfire.io/my/settings/credentials
|
|
'';
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
environment.etc."blackfire/agent".text = agentConfigFile;
|
|
|
|
services.blackfire-agent.settings.socket = "unix:///run/${agentSock}";
|
|
|
|
systemd.packages = [
|
|
pkgs.blackfire
|
|
];
|
|
};
|
|
}
|