nixos-config/config/services/invtracker.nix

45 lines
1.3 KiB
Nix

{ pkgs, invtracker, ... }:
let
port = 19689;
configFile = builtins.toFile "config.xml" ''
<?xml version="1.0" encoding="UTF-8"?>
<config>
<server host="127.0.0.1" port="${toString port}" />
<database url="jdbc:sqlite:test.db />
</config>
'';
in {
systemd.services.invtracker = {
enable = true;
description = "InvTracker";
script = "${invtracker.packages.${pkgs.system}.invtracker-server}/bin/server ${configFile}";
serviceConfig = {
User = "invtracker";
Group = "invtracker";
WorkingDirectory = "/var/lib/invtracker";
Restart = "always";
};
wantedBy = ["multi-user.target"];
environment = {
JAVA_HOME = "${pkgs.openjdk_headless}";
};
};
services.nginx.virtualHosts."invtracker.chir.rs" = {
sslCertificate = "/var/lib/acme/chir.rs/cert.pem";
sslCertificateKey = "/var/lib/acme/chir.rs/key.pem";
locations."/" = {
proxyPass = "http://localhost:${toString port}/";
};
};
users.users.invtracker = {
description = "InvTracker";
home = "/var/lib/invtracker";
useDefaultShell = true;
group = "invtracker";
isSystemUser = true;
};
users.groups.invtracker = {};
systemd.tmpfiles.rules = [
"d '/var/lib/invtracker' 0750 invtracker invtracker - -"
];
}