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;
'';
};
};
}
|