summary refs log tree commit diff
path: root/nixos/modules/services/web-apps/jitsi-meet.xml
blob: ff44c724adf44758eb6995282ff6a84e26976a5d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<chapter xmlns="http://docbook.org/ns/docbook"
         xmlns:xlink="http://www.w3.org/1999/xlink"
         xmlns:xi="http://www.w3.org/2001/XInclude"
         version="5.0"
         xml:id="module-services-jitsi-meet">
 <title>Jitsi Meet</title>
 <para>
   With Jitsi Meet on NixOS you can quickly configure a complete,
   private, self-hosted video conferencing solution.
 </para>

 <section xml:id="module-services-jitsi-basic-usage">
 <title>Basic usage</title>
   <para>
     A minimal configuration using Let's Encrypt for TLS certificates looks like this:
<programlisting>{
  services.jitsi-meet = {
    <link linkend="opt-services.jitsi-meet.enable">enable</link> = true;
    <link linkend="opt-services.jitsi-meet.enable">hostName</link> = "jitsi.example.com";
  };
  <link linkend="opt-services.jitsi-videobridge.openFirewall">services.jitsi-videobridge.openFirewall</link> = true;
  <link linkend="opt-networking.firewall.allowedTCPPorts">networking.firewall.allowedTCPPorts</link> = [ 80 443 ];
  <link linkend="opt-security.acme.defaults.email">security.acme.email</link> = "me@example.com";
  <link linkend="opt-security.acme.acceptTerms">security.acme.acceptTerms</link> = true;
}</programlisting>
   </para>
 </section>

 <section xml:id="module-services-jitsi-configuration">
 <title>Configuration</title>
   <para>
     Here is the minimal configuration with additional configurations:
<programlisting>{
  services.jitsi-meet = {
    <link linkend="opt-services.jitsi-meet.enable">enable</link> = true;
    <link linkend="opt-services.jitsi-meet.enable">hostName</link> = "jitsi.example.com";
    <link linkend="opt-services.jitsi-meet.config">config</link> = {
      enableWelcomePage = false;
      prejoinPageEnabled = true;
      defaultLang = "fi";
    };
    <link linkend="opt-services.jitsi-meet.interfaceConfig">interfaceConfig</link> = {
      SHOW_JITSI_WATERMARK = false;
      SHOW_WATERMARK_FOR_GUESTS = false;
    };
  };
  <link linkend="opt-services.jitsi-videobridge.openFirewall">services.jitsi-videobridge.openFirewall</link> = true;
  <link linkend="opt-networking.firewall.allowedTCPPorts">networking.firewall.allowedTCPPorts</link> = [ 80 443 ];
  <link linkend="opt-security.acme.defaults.email">security.acme.email</link> = "me@example.com";
  <link linkend="opt-security.acme.acceptTerms">security.acme.acceptTerms</link> = true;
}</programlisting>
   </para>
 </section>

</chapter>