2023-05-30 22:45:14 +00:00
|
|
|
{ lib, config, pkgs, ... }:
|
|
|
|
let
|
|
|
|
cfg = config.services.sitespeed-io;
|
|
|
|
format = pkgs.formats.json { };
|
|
|
|
in
|
|
|
|
{
|
|
|
|
options.services.sitespeed-io = {
|
2024-04-13 12:54:15 +00:00
|
|
|
enable = lib.mkEnableOption "Sitespeed.io";
|
2023-05-30 22:45:14 +00:00
|
|
|
|
|
|
|
user = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
default = "sitespeed-io";
|
2024-04-13 12:54:15 +00:00
|
|
|
description = "User account under which sitespeed-io runs.";
|
2023-05-30 22:45:14 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
package = lib.mkOption {
|
|
|
|
type = lib.types.package;
|
|
|
|
default = pkgs.sitespeed-io;
|
|
|
|
defaultText = "pkgs.sitespeed-io";
|
2024-04-13 12:54:15 +00:00
|
|
|
description = "Sitespeed.io package to use.";
|
2023-05-30 22:45:14 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
dataDir = lib.mkOption {
|
|
|
|
default = "/var/lib/sitespeed-io";
|
|
|
|
type = lib.types.str;
|
2024-04-13 12:54:15 +00:00
|
|
|
description = "The base sitespeed-io data directory.";
|
2023-05-30 22:45:14 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
period = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
default = "hourly";
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2023-05-30 22:45:14 +00:00
|
|
|
Systemd calendar expression when to run. See {manpage}`systemd.time(7)`.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
runs = lib.mkOption {
|
|
|
|
default = [ ];
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2023-05-30 22:45:14 +00:00
|
|
|
A list of run configurations. The service will call sitespeed-io once
|
|
|
|
for every run listed here. This lets you examine different websites
|
|
|
|
with different sitespeed-io settings.
|
|
|
|
'';
|
|
|
|
type = lib.types.listOf (lib.types.submodule {
|
|
|
|
options = {
|
|
|
|
urls = lib.mkOption {
|
|
|
|
type = with lib.types; listOf str;
|
|
|
|
default = [];
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2023-05-30 22:45:14 +00:00
|
|
|
URLs the service should monitor.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
settings = lib.mkOption {
|
|
|
|
type = lib.types.submodule {
|
|
|
|
freeformType = format.type;
|
|
|
|
options = { };
|
|
|
|
};
|
|
|
|
default = { };
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2023-05-30 22:45:14 +00:00
|
|
|
Configuration for sitespeed-io, see
|
|
|
|
<https://www.sitespeed.io/documentation/sitespeed.io/configuration/>
|
|
|
|
for available options. The value here will be directly transformed to
|
|
|
|
JSON and passed as `--config` to the program.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
extraArgs = lib.mkOption {
|
|
|
|
type = with lib.types; listOf str;
|
|
|
|
default = [];
|
2024-04-13 12:54:15 +00:00
|
|
|
description = ''
|
2023-05-30 22:45:14 +00:00
|
|
|
Extra command line arguments to pass to the program.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
});
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
assertions = [
|
|
|
|
{
|
|
|
|
assertion = cfg.runs != [];
|
|
|
|
message = "At least one run must be configured.";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
assertion = lib.all (run: run.urls != []) cfg.runs;
|
|
|
|
message = "All runs must have at least one url configured.";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
systemd.services.sitespeed-io = {
|
|
|
|
description = "Check website status";
|
|
|
|
startAt = cfg.period;
|
|
|
|
serviceConfig = {
|
|
|
|
WorkingDirectory = cfg.dataDir;
|
|
|
|
User = cfg.user;
|
|
|
|
};
|
|
|
|
preStart = "chmod u+w -R ${cfg.dataDir}"; # Make sure things are writable
|
|
|
|
script = (lib.concatMapStrings (run: ''
|
|
|
|
${lib.getExe cfg.package} \
|
|
|
|
--config ${format.generate "sitespeed.json" run.settings} \
|
|
|
|
${lib.escapeShellArgs run.extraArgs} \
|
|
|
|
${builtins.toFile "urls.txt" (lib.concatLines run.urls)} &
|
|
|
|
'') cfg.runs) +
|
|
|
|
''
|
|
|
|
wait
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
users = {
|
|
|
|
extraUsers.${cfg.user} = {
|
|
|
|
isSystemUser = true;
|
|
|
|
group = cfg.user;
|
|
|
|
home = cfg.dataDir;
|
|
|
|
createHome = true;
|
|
|
|
homeMode = "755";
|
|
|
|
};
|
|
|
|
extraGroups.${cfg.user} = { };
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|