2020-08-20 17:08:02 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.jicofo;
|
2023-03-24 00:07:29 +00:00
|
|
|
|
2024-02-29 20:09:43 +00:00
|
|
|
format = pkgs.formats.hocon { };
|
|
|
|
|
|
|
|
configFile = format.generate "jicofo.conf" cfg.config;
|
2020-08-20 17:08:02 +00:00
|
|
|
in
|
|
|
|
{
|
|
|
|
options.services.jicofo = with types; {
|
2022-09-09 14:08:57 +00:00
|
|
|
enable = mkEnableOption (lib.mdDoc "Jitsi Conference Focus - component of Jitsi Meet");
|
2020-08-20 17:08:02 +00:00
|
|
|
|
|
|
|
xmppHost = mkOption {
|
|
|
|
type = str;
|
|
|
|
example = "localhost";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-08-20 17:08:02 +00:00
|
|
|
Hostname of the XMPP server to connect to.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
xmppDomain = mkOption {
|
|
|
|
type = nullOr str;
|
|
|
|
example = "meet.example.org";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-08-20 17:08:02 +00:00
|
|
|
Domain name of the XMMP server to which to connect as a component.
|
|
|
|
|
2022-08-12 12:06:08 +00:00
|
|
|
If null, {option}`xmppHost` is used.
|
2020-08-20 17:08:02 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
componentPasswordFile = mkOption {
|
|
|
|
type = str;
|
|
|
|
example = "/run/keys/jicofo-component";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-08-20 17:08:02 +00:00
|
|
|
Path to file containing component secret.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
userName = mkOption {
|
|
|
|
type = str;
|
|
|
|
default = "focus";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-08-20 17:08:02 +00:00
|
|
|
User part of the JID for XMPP user connection.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
userDomain = mkOption {
|
|
|
|
type = str;
|
|
|
|
example = "auth.meet.example.org";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-08-20 17:08:02 +00:00
|
|
|
Domain part of the JID for XMPP user connection.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
userPasswordFile = mkOption {
|
|
|
|
type = str;
|
|
|
|
example = "/run/keys/jicofo-user";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-08-20 17:08:02 +00:00
|
|
|
Path to file containing password for XMPP user connection.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
bridgeMuc = mkOption {
|
|
|
|
type = str;
|
|
|
|
example = "jvbbrewery@internal.meet.example.org";
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-08-20 17:08:02 +00:00
|
|
|
JID of the internal MUC used to communicate with Videobridges.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkOption {
|
2024-02-29 20:09:43 +00:00
|
|
|
type = format.type;
|
2020-08-20 17:08:02 +00:00
|
|
|
default = { };
|
2021-10-06 13:57:05 +00:00
|
|
|
example = literalExpression ''
|
2020-08-20 17:08:02 +00:00
|
|
|
{
|
2023-03-24 00:07:29 +00:00
|
|
|
jicofo.bridge.max-bridge-participants = 42;
|
2020-08-20 17:08:02 +00:00
|
|
|
}
|
|
|
|
'';
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2023-03-24 00:07:29 +00:00
|
|
|
Contents of the {file}`jicofo.conf` configuration file.
|
2020-08-20 17:08:02 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2023-03-24 00:07:29 +00:00
|
|
|
services.jicofo.config = {
|
|
|
|
jicofo = {
|
|
|
|
bridge.brewery-jid = cfg.bridgeMuc;
|
|
|
|
xmpp = rec {
|
|
|
|
client = {
|
|
|
|
hostname = cfg.xmppHost;
|
|
|
|
username = cfg.userName;
|
|
|
|
domain = cfg.userDomain;
|
2024-02-29 20:09:43 +00:00
|
|
|
password = format.lib.mkSubstitution "JICOFO_AUTH_PASS";
|
2023-03-24 00:07:29 +00:00
|
|
|
xmpp-domain = if cfg.xmppDomain == null then cfg.xmppHost else cfg.xmppDomain;
|
|
|
|
};
|
|
|
|
service = client;
|
|
|
|
};
|
|
|
|
};
|
2020-08-20 17:08:02 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
users.groups.jitsi-meet = {};
|
|
|
|
|
|
|
|
systemd.services.jicofo = let
|
|
|
|
jicofoProps = {
|
|
|
|
"-Dnet.java.sip.communicator.SC_HOME_DIR_LOCATION" = "/etc/jitsi";
|
|
|
|
"-Dnet.java.sip.communicator.SC_HOME_DIR_NAME" = "jicofo";
|
|
|
|
"-Djava.util.logging.config.file" = "/etc/jitsi/jicofo/logging.properties";
|
2023-03-24 00:07:29 +00:00
|
|
|
"-Dconfig.file" = configFile;
|
2020-08-20 17:08:02 +00:00
|
|
|
};
|
|
|
|
in
|
|
|
|
{
|
|
|
|
description = "JItsi COnference FOcus";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
after = [ "network.target" ];
|
|
|
|
|
|
|
|
restartTriggers = [
|
2023-03-24 00:07:29 +00:00
|
|
|
configFile
|
2020-08-20 17:08:02 +00:00
|
|
|
];
|
|
|
|
environment.JAVA_SYS_PROPS = concatStringsSep " " (mapAttrsToList (k: v: "${k}=${toString v}") jicofoProps);
|
|
|
|
|
|
|
|
script = ''
|
2023-03-24 00:07:29 +00:00
|
|
|
export JICOFO_AUTH_PASS="$(<${cfg.userPasswordFile})"
|
|
|
|
exec "${pkgs.jicofo}/bin/jicofo"
|
2020-08-20 17:08:02 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "exec";
|
|
|
|
|
|
|
|
DynamicUser = true;
|
|
|
|
User = "jicofo";
|
|
|
|
Group = "jitsi-meet";
|
|
|
|
|
|
|
|
CapabilityBoundingSet = "";
|
|
|
|
NoNewPrivileges = true;
|
|
|
|
ProtectSystem = "strict";
|
|
|
|
ProtectHome = true;
|
|
|
|
PrivateTmp = true;
|
|
|
|
PrivateDevices = true;
|
|
|
|
ProtectHostname = true;
|
|
|
|
ProtectKernelTunables = true;
|
|
|
|
ProtectKernelModules = true;
|
|
|
|
ProtectControlGroups = true;
|
|
|
|
RestrictAddressFamilies = [ "AF_INET" "AF_INET6" "AF_UNIX" ];
|
|
|
|
RestrictNamespaces = true;
|
|
|
|
LockPersonality = true;
|
|
|
|
RestrictRealtime = true;
|
|
|
|
RestrictSUIDSGID = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-03-24 00:07:29 +00:00
|
|
|
environment.etc."jitsi/jicofo/sip-communicator.properties".text = "";
|
2020-08-20 17:08:02 +00:00
|
|
|
environment.etc."jitsi/jicofo/logging.properties".source =
|
|
|
|
mkDefault "${pkgs.jicofo}/etc/jitsi/jicofo/logging.properties-journal";
|
|
|
|
};
|
|
|
|
|
|
|
|
meta.maintainers = lib.teams.jitsi.members;
|
|
|
|
}
|