jitsi-roomsv2/nixos.nix

61 lines
1.3 KiB
Nix

{
lib,
pkgs,
config,
...
}:
with lib;
let
cfg = config.services.jitsi-rooms;
backendPort = 8081;
wsPort = 9160;
address = "127.0.0.1";
backend = (pkgs.callPackage ./backend/default.nix { });
frontend = (pkgs.callPackage ./frontend/default.nix { });
prodsodyPackage = (pkgs.callPackage ./prodsody/default.nix { });
in
{
options.services.jitsi-rooms = {
enable = mkEnableOption "jitsi-rooms service";
nginxHostname = mkOption {
type = types.str;
default = "treffen.filefighter.de";
};
};
config = mkIf cfg.enable {
systemd.services.jitsi-rooms = {
description = "jitsi-rooms";
wantedBy = [ "multi-user.target" ];
after = [ "network.target" ];
serviceConfig = {
ExecStart = "${backend}/bin/jitsi-rooms-exe";
DynamicUser = true;
User = "jitsi-rooms-backend";
};
};
services.nginx.virtualHosts.${cfg.nginxHostname} = {
forceSSL = true;
enableACME = true;
locations = {
"/" = {
root = frontend;
tryFiles = "$uri $uri/ /index.html";
};
"/ws" = {
proxyPass = "http://${address}:${toString wsPort}";
};
};
};
services.prosody = {
extraPluginPaths = [ "${prodsodyPackage}/share" ];
extraModules = [ "jitsi_rooms" ];
};
};
}