2024-09-10 15:15:08 -04:00
|
|
|
{pkgs, outputs, ...}: {
|
2024-08-26 13:07:59 -04:00
|
|
|
services = {
|
2024-08-24 22:16:51 -04:00
|
|
|
# Synapse Matrix server
|
2024-09-10 15:07:31 -04:00
|
|
|
matrix-synapse = {
|
2024-08-24 22:16:51 -04:00
|
|
|
enable = true;
|
|
|
|
settings = {
|
2024-08-30 01:17:50 -04:00
|
|
|
server_name = "${outputs.secrets.jimDomain}";
|
|
|
|
public_baseurl = "https://matrix.${outputs.secrets.jimDomain}";
|
2024-08-24 22:16:51 -04:00
|
|
|
suppress_key_server_warning = true;
|
|
|
|
|
|
|
|
# Set the network config
|
|
|
|
listeners = [{
|
|
|
|
port = 8008;
|
|
|
|
bind_addresses = [ "::" "0.0.0.0" ];
|
|
|
|
resources = [ { compress = false; names = [ "client" "federation" ]; } ];
|
|
|
|
type = "http";
|
|
|
|
tls = false;
|
|
|
|
x_forwarded = true;
|
|
|
|
}];
|
|
|
|
|
|
|
|
# Enable smtp for password resets
|
|
|
|
email = {
|
2024-08-30 01:17:50 -04:00
|
|
|
notif_from = "Jimbo's Matrix <noreply@${outputs.secrets.jimDomain}>";
|
|
|
|
smtp_host = "mx.${outputs.secrets.jimDomain}";
|
|
|
|
smtp_user = "noreply@${outputs.secrets.jimDomain}";
|
|
|
|
smtp_pass = outputs.secrets.noreplyPassword;
|
2024-08-24 22:16:51 -04:00
|
|
|
enable_tls = true;
|
|
|
|
smtp_port = 587;
|
|
|
|
require_transport_security = true;
|
|
|
|
};
|
|
|
|
|
2024-08-27 05:14:19 -04:00
|
|
|
# Allows a Discord/Matrix bridge, comment on first use and copy using instructions
|
|
|
|
app_service_config_files = [
|
|
|
|
# cp /var/lib/matrix-appservice-discord/discord-registration.yaml /var/lib/matrix-synapse/
|
|
|
|
# chown matrix-synapse:matrix-synapse /var/lib/matrix-synapse/discord-registration.yaml
|
|
|
|
"/var/lib/matrix-synapse/discord-registration.yaml"
|
|
|
|
];
|
|
|
|
|
2024-08-24 22:16:51 -04:00
|
|
|
# Disable registration without email
|
|
|
|
registrations_require_3pid = [ "email" ];
|
|
|
|
|
|
|
|
# Allow only this range of emails
|
|
|
|
allowed_local_3pids = [{
|
|
|
|
medium = "email";
|
|
|
|
pattern = "^[^@]+@jimbosfiles\\.com$";
|
|
|
|
}];
|
|
|
|
|
|
|
|
# Set the type of database
|
|
|
|
database.name = "sqlite3";
|
|
|
|
|
|
|
|
# Allow account registration
|
|
|
|
enable_registration = true;
|
|
|
|
|
|
|
|
# General settings
|
|
|
|
url_preview_enabled = true;
|
|
|
|
max_upload_size = "50M";
|
|
|
|
report_stats = false;
|
|
|
|
|
|
|
|
# Ratelimiting
|
|
|
|
burst_count = 15;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# Sliding sync proxy for Matrix
|
|
|
|
matrix-sliding-sync = let
|
|
|
|
matrixSecretFile = pkgs.writeText "matrixsecret" ''
|
2024-08-30 01:17:50 -04:00
|
|
|
SYNCV3_SECRET=${outputs.secrets.matrixSecret}
|
2024-08-24 22:16:51 -04:00
|
|
|
'';
|
|
|
|
in {
|
|
|
|
enable = true;
|
|
|
|
settings = {
|
2024-08-30 01:17:50 -04:00
|
|
|
SYNCV3_SERVER = "https://matrix.${outputs.secrets.jimDomain}";
|
2024-08-24 22:16:51 -04:00
|
|
|
SYNCV3_BINDADDR = "0.0.0.0:8009";
|
|
|
|
};
|
|
|
|
environmentFile = "${matrixSecretFile}";
|
|
|
|
};
|
|
|
|
|
2024-09-10 15:07:31 -04:00
|
|
|
# Proxy for both Synapse and Sliding Sync
|
|
|
|
nginx.virtualHosts."matrix.${outputs.secrets.jimDomain}" = {
|
|
|
|
enableACME = true;
|
|
|
|
forceSSL = true;
|
|
|
|
locations = {
|
|
|
|
"/".extraConfig = ''return 403;'';
|
|
|
|
"/client".proxyPass = "http://127.0.0.1:8009";
|
|
|
|
"/_matrix".proxyPass = "http://127.0.0.1:8008";
|
|
|
|
"/_matrix/client/unstable/org.matrix.msc3575/sync".proxyPass = "http://127.0.0.1:8009";
|
|
|
|
"/_synapse/client".proxyPass = "http://127.0.0.1:8008";
|
2024-08-26 13:07:59 -04:00
|
|
|
};
|
|
|
|
};
|
2024-08-24 22:16:51 -04:00
|
|
|
};
|
|
|
|
}
|