2021-02-05 17:12:51 +00:00
|
|
|
{ lib, pkgs, config, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
|
|
cfg = config.services.hledger-web;
|
|
|
|
in {
|
|
|
|
options.services.hledger-web = {
|
|
|
|
|
|
|
|
enable = mkEnableOption "hledger-web service";
|
|
|
|
|
|
|
|
serveApi = mkEnableOption "Serve only the JSON web API, without the web UI.";
|
|
|
|
|
|
|
|
host = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "127.0.0.1";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-02-05 17:12:51 +00:00
|
|
|
Address to listen on.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
port = mkOption {
|
|
|
|
type = types.port;
|
|
|
|
default = 5000;
|
2021-10-06 13:57:05 +00:00
|
|
|
example = 80;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-02-05 17:12:51 +00:00
|
|
|
Port to listen on.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-03-20 04:20:00 +00:00
|
|
|
capabilities = {
|
|
|
|
view = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = true;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-03-20 04:20:00 +00:00
|
|
|
Enable the view capability.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
add = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-03-20 04:20:00 +00:00
|
|
|
Enable the add capability.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
manage = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-03-20 04:20:00 +00:00
|
|
|
Enable the manage capability.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
stateDir = mkOption {
|
|
|
|
type = types.path;
|
|
|
|
default = "/var/lib/hledger-web";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-03-20 04:20:00 +00:00
|
|
|
Path the service has access to. If left as the default value this
|
|
|
|
directory will automatically be created before the hledger-web server
|
|
|
|
starts, otherwise the sysadmin is responsible for ensuring the
|
|
|
|
directory exists with appropriate ownership and permissions.
|
2021-02-05 17:12:51 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-03-20 04:20:00 +00:00
|
|
|
journalFiles = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [ ".hledger.journal" ];
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
|
|
|
Paths to journal files relative to {option}`services.hledger-web.stateDir`.
|
2021-02-05 17:12:51 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
baseUrl = mkOption {
|
|
|
|
type = with types; nullOr str;
|
|
|
|
default = null;
|
|
|
|
example = "https://example.org";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-02-05 17:12:51 +00:00
|
|
|
Base URL, when sharing over a network.
|
|
|
|
'';
|
|
|
|
};
|
2021-03-20 04:20:00 +00:00
|
|
|
|
|
|
|
extraOptions = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [];
|
|
|
|
example = [ "--forecast" ];
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-03-20 04:20:00 +00:00
|
|
|
Extra command line arguments to pass to hledger-web.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2021-02-05 17:12:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2021-03-20 04:20:00 +00:00
|
|
|
|
|
|
|
users.users.hledger = {
|
|
|
|
name = "hledger";
|
|
|
|
group = "hledger";
|
|
|
|
isSystemUser = true;
|
|
|
|
home = cfg.stateDir;
|
|
|
|
useDefaultShell = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
users.groups.hledger = {};
|
|
|
|
|
|
|
|
systemd.services.hledger-web = let
|
|
|
|
capabilityString = with cfg.capabilities; concatStringsSep "," (
|
|
|
|
(optional view "view")
|
|
|
|
++ (optional add "add")
|
|
|
|
++ (optional manage "manage")
|
|
|
|
);
|
|
|
|
serverArgs = with cfg; escapeShellArgs ([
|
|
|
|
"--serve"
|
|
|
|
"--host=${host}"
|
|
|
|
"--port=${toString port}"
|
|
|
|
"--capabilities=${capabilityString}"
|
|
|
|
(optionalString (cfg.baseUrl != null) "--base-url=${cfg.baseUrl}")
|
|
|
|
(optionalString (cfg.serveApi) "--serve-api")
|
|
|
|
] ++ (map (f: "--file=${stateDir}/${f}") cfg.journalFiles)
|
|
|
|
++ extraOptions);
|
|
|
|
in {
|
2021-02-05 17:12:51 +00:00
|
|
|
description = "hledger-web - web-app for the hledger accounting tool.";
|
2021-12-06 16:07:01 +00:00
|
|
|
documentation = [ "https://hledger.org/hledger-web.html" ];
|
2021-02-05 17:12:51 +00:00
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
after = [ "networking.target" ];
|
2021-03-20 04:20:00 +00:00
|
|
|
serviceConfig = mkMerge [
|
|
|
|
{
|
|
|
|
ExecStart = "${pkgs.hledger-web}/bin/hledger-web ${serverArgs}";
|
|
|
|
Restart = "always";
|
|
|
|
WorkingDirectory = cfg.stateDir;
|
|
|
|
User = "hledger";
|
|
|
|
Group = "hledger";
|
|
|
|
PrivateTmp = true;
|
|
|
|
}
|
|
|
|
(mkIf (cfg.stateDir == "/var/lib/hledger-web") {
|
|
|
|
StateDirectory = "hledger-web";
|
|
|
|
})
|
|
|
|
];
|
2021-02-05 17:12:51 +00:00
|
|
|
};
|
2021-03-20 04:20:00 +00:00
|
|
|
|
2021-02-05 17:12:51 +00:00
|
|
|
};
|
|
|
|
|
2021-03-20 04:20:00 +00:00
|
|
|
meta.maintainers = with lib.maintainers; [ marijanp erictapen ];
|
2021-02-05 17:12:51 +00:00
|
|
|
}
|