2021-07-18 06:49:36 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.hockeypuck;
|
|
|
|
settingsFormat = pkgs.formats.toml { };
|
|
|
|
in {
|
|
|
|
meta.maintainers = with lib.maintainers; [ etu ];
|
|
|
|
|
|
|
|
options.services.hockeypuck = {
|
|
|
|
enable = lib.mkEnableOption "Hockeypuck OpenPGP Key Server";
|
|
|
|
|
|
|
|
port = lib.mkOption {
|
|
|
|
default = 11371;
|
|
|
|
type = lib.types.port;
|
2022-07-28 21:19:15 +00:00
|
|
|
description = lib.mdDoc "HKP port to listen on.";
|
2021-07-18 06:49:36 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
settings = lib.mkOption {
|
|
|
|
type = settingsFormat.type;
|
|
|
|
default = { };
|
2021-10-03 16:06:03 +00:00
|
|
|
example = lib.literalExpression ''
|
2021-07-18 06:49:36 +00:00
|
|
|
{
|
|
|
|
hockeypuck = {
|
|
|
|
loglevel = "INFO";
|
|
|
|
logfile = "/var/log/hockeypuck/hockeypuck.log";
|
|
|
|
indexTemplate = "''${pkgs.hockeypuck-web}/share/templates/index.html.tmpl";
|
|
|
|
vindexTemplate = "''${pkgs.hockeypuck-web}/share/templates/index.html.tmpl";
|
|
|
|
statsTemplate = "''${pkgs.hockeypuck-web}/share/templates/stats.html.tmpl";
|
|
|
|
webroot = "''${pkgs.hockeypuck-web}/share/webroot";
|
|
|
|
|
|
|
|
hkp.bind = ":''${toString cfg.port}";
|
|
|
|
|
|
|
|
openpgp.db = {
|
|
|
|
driver = "postgres-jsonb";
|
|
|
|
dsn = "database=hockeypuck host=/var/run/postgresql sslmode=disable";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
description = ''
|
|
|
|
Configuration file for hockeypuck, here you can override
|
|
|
|
certain settings (<literal>loglevel</literal> and
|
|
|
|
<literal>openpgp.db.dsn</literal>) by just setting those values.
|
|
|
|
|
|
|
|
For other settings you need to use lib.mkForce to override them.
|
|
|
|
|
|
|
|
This service doesn't provision or enable postgres on your
|
|
|
|
system, it rather assumes that you enable postgres and create
|
|
|
|
the database yourself.
|
|
|
|
|
|
|
|
Example:
|
2022-08-30 11:08:40 +00:00
|
|
|
<programlisting>
|
2021-07-18 06:49:36 +00:00
|
|
|
services.postgresql = {
|
|
|
|
enable = true;
|
|
|
|
ensureDatabases = [ "hockeypuck" ];
|
|
|
|
ensureUsers = [{
|
|
|
|
name = "hockeypuck";
|
|
|
|
ensurePermissions."DATABASE hockeypuck" = "ALL PRIVILEGES";
|
|
|
|
}];
|
|
|
|
};
|
2022-08-30 11:08:40 +00:00
|
|
|
</programlisting>
|
2021-07-18 06:49:36 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
services.hockeypuck.settings.hockeypuck = {
|
|
|
|
loglevel = lib.mkDefault "INFO";
|
|
|
|
logfile = "/var/log/hockeypuck/hockeypuck.log";
|
|
|
|
indexTemplate = "${pkgs.hockeypuck-web}/share/templates/index.html.tmpl";
|
|
|
|
vindexTemplate = "${pkgs.hockeypuck-web}/share/templates/index.html.tmpl";
|
|
|
|
statsTemplate = "${pkgs.hockeypuck-web}/share/templates/stats.html.tmpl";
|
|
|
|
webroot = "${pkgs.hockeypuck-web}/share/webroot";
|
|
|
|
|
|
|
|
hkp.bind = ":${toString cfg.port}";
|
|
|
|
|
|
|
|
openpgp.db = {
|
|
|
|
driver = "postgres-jsonb";
|
|
|
|
dsn = lib.mkDefault "database=hockeypuck host=/var/run/postgresql sslmode=disable";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
users.users.hockeypuck = {
|
|
|
|
isSystemUser = true;
|
2021-08-08 12:00:00 +00:00
|
|
|
group = "hockeypuck";
|
2021-07-18 06:49:36 +00:00
|
|
|
description = "Hockeypuck user";
|
|
|
|
};
|
2021-08-08 12:00:00 +00:00
|
|
|
users.groups.hockeypuck = {};
|
2021-07-18 06:49:36 +00:00
|
|
|
|
|
|
|
systemd.services.hockeypuck = {
|
|
|
|
description = "Hockeypuck OpenPGP Key Server";
|
|
|
|
after = [ "network.target" "postgresql.target" ];
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
serviceConfig = {
|
|
|
|
WorkingDirectory = "/var/lib/hockeypuck";
|
|
|
|
User = "hockeypuck";
|
|
|
|
ExecStart = "${pkgs.hockeypuck}/bin/hockeypuck -config ${settingsFormat.generate "config.toml" cfg.settings}";
|
|
|
|
Restart = "always";
|
|
|
|
RestartSec = "5s";
|
|
|
|
LogsDirectory = "hockeypuck";
|
|
|
|
LogsDirectoryMode = "0755";
|
|
|
|
StateDirectory = "hockeypuck";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|