97 lines
2.4 KiB
Nix
97 lines
2.4 KiB
Nix
oldPkgs: { config, lib, ... }:
|
|
let
|
|
domain = config.selfprivacy.domain;
|
|
cfg = config.selfprivacy.modules.jitsi-meet;
|
|
in
|
|
{
|
|
options.selfprivacy.modules.jitsi-meet = {
|
|
enable =
|
|
(lib.mkOption {
|
|
default = false;
|
|
type = lib.types.bool;
|
|
description = "Enable JitsiMeet";
|
|
})
|
|
// {
|
|
meta = {
|
|
type = "enable";
|
|
};
|
|
};
|
|
subdomain =
|
|
(lib.mkOption {
|
|
default = "meet";
|
|
type = lib.types.strMatching "[A-Za-z0-9][A-Za-z0-9\-]{0,61}[A-Za-z0-9]";
|
|
description = "Subdomain";
|
|
})
|
|
// {
|
|
meta = {
|
|
widget = "subdomain";
|
|
type = "string";
|
|
regex = "[A-Za-z0-9][A-Za-z0-9\-]{0,61}[A-Za-z0-9]";
|
|
weight = 0;
|
|
};
|
|
};
|
|
appName =
|
|
(lib.mkOption {
|
|
default = "Jitsi Meet";
|
|
type = lib.types.str;
|
|
description = "The name displayed in the web interface";
|
|
})
|
|
// {
|
|
meta = {
|
|
type = "string";
|
|
weight = 1;
|
|
};
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
nixpkgs.overlays = [
|
|
(final: prev: {
|
|
jicofo = oldPkgs.jicofo;
|
|
jitsi-meet = oldPkgs.jitsi-meet.overrideAttrs (old: {
|
|
meta = old.meta // { knownVulnerabilities = [ ]; };
|
|
});
|
|
jitsi-videobridge = oldPkgs.jitsi-videobridge;
|
|
jitsi-meet-prosody = oldPkgs.jitsi-meet-prosody;
|
|
})
|
|
];
|
|
|
|
services.jitsi-meet = {
|
|
enable = true;
|
|
hostName = "${cfg.subdomain}.${domain}";
|
|
nginx.enable = true;
|
|
interfaceConfig = {
|
|
SHOW_JITSI_WATERMARK = false;
|
|
SHOW_WATERMARK_FOR_GUESTS = false;
|
|
APP_NAME = cfg.appName;
|
|
};
|
|
config = {
|
|
prejoinConfig = {
|
|
enabled = true;
|
|
};
|
|
e2ee.disabled = true; # libolm is vulnerable and E2E is generally broken.
|
|
};
|
|
};
|
|
services.prosody.extraConfig = ''
|
|
log = {
|
|
info = "*syslog";
|
|
}
|
|
'';
|
|
services.nginx.virtualHosts."${cfg.subdomain}.${domain}" = {
|
|
forceSSL = true;
|
|
useACMEHost = domain;
|
|
enableACME = false;
|
|
};
|
|
systemd = {
|
|
services = {
|
|
jicofo.serviceConfig.Slice = "jitsi_meet.slice";
|
|
jitsi-videobridge2.serviceConfig.Slice = "jitsi_meet.slice";
|
|
prosody.serviceConfig.Slice = "jitsi_meet.slice";
|
|
};
|
|
slices.jitsi_meet = {
|
|
description = "Jitsi Meet service slice";
|
|
};
|
|
};
|
|
};
|
|
}
|