summary refs log tree commit diff
path: root/services/matrix.nix
blob: 3586cc8e0036a7eafc40c16ecd0b7bea2d52610d (plain)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
{
  config,
  pkgs,
  unstablePkgs,
  auxiliaryPkgs,
  ...
}:

let
  inherit (pkgs) dockerTools;
  inherit (unstablePkgs) matrix-continuwuity;
  inherit (auxiliaryPkgs) common;

  continuwuityLocalPort = 2123;
  continuwuityDir = "/srv/matrix";

  continuwuityImage = dockerTools.streamLayeredImage {
    name = "continuwuity";
    tag = matrix-continuwuity.version;
    fromImage = common.alpine.base;

    contents = [ matrix-continuwuity ];
  };

in
{
  age.secrets.continuwuity-registration-token = {
    file = ../secrets/continuwuity-registration-token.age;
  };

  foundation.service.continuwuity = {
    continuwuity = {
      image = continuwuityImage;
      ports = [ continuwuityLocalPort ];

      volumes = [
        [
          "${continuwuityDir}/db"
          "/var/lib/continuwuity"
        ]
        [
          "${continuwuityDir}/continuwuity.toml"
          "/etc/continuwuity/continuwuity.toml"
        ]
        [
          "${config.age.secrets.continuwuity-registration-token.path}"
          "/etc/continuwuity/registration-token"
        ]
      ];

      environment = {
        CONDUWUIT_CONFIG = "/etc/continuwuity/continuwuity.toml";
      };

      entrypoint = "${matrix-continuwuity}/bin/conduwuit";
    };
  };

  services.nginx.virtualHosts = {
    "matrix.rnrd.eu" =
      let
        proxySettings = {
          proxyPass = "http://127.0.0.1:${toString continuwuityLocalPort}";
        };
      in
      {
        useACMEHost = "rnrd.eu";
        forceSSL = true;

        locations."/" = proxySettings;
        locations."/_matrix" = proxySettings;
        locations."/_conduwuit" = proxySettings;
        locations."/_continuwuity" = proxySettings;

        extraConfig = ''
          client_max_body_size 20M;

          proxy_connect_timeout 600;
          proxy_send_timeout 600;
          proxy_read_timeout 600;
          send_timeout 600;

          access_log /var/log/nginx/matrix.access.log json_combined;
        '';
      };
  };
}