2021-01-11 18:09:34 +04:00
|
|
|
{ pkgs, config, lib, ... }: {
|
2020-02-17 17:00:59 +04:00
|
|
|
services.matrix-synapse = {
|
|
|
|
enable = true;
|
2022-04-27 18:22:28 +04:00
|
|
|
settings = {
|
|
|
|
allow_guest_access = false;
|
|
|
|
listeners = [{
|
|
|
|
# bind_address = "0.0.0.0";
|
|
|
|
port = 13748;
|
|
|
|
resources = [
|
|
|
|
{
|
|
|
|
compress = true;
|
|
|
|
names = [ "client" ];
|
|
|
|
}
|
|
|
|
{
|
|
|
|
compress = false;
|
|
|
|
names = [ "federation" ];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
type = "http";
|
|
|
|
tls = false;
|
|
|
|
x_forwarded = true;
|
|
|
|
}];
|
|
|
|
public_baseurl = "https://balsoft.ru";
|
|
|
|
server_name = "balsoft.ru";
|
|
|
|
turn_uris =
|
|
|
|
[ "turn:balsoft.ru?transport=udp" "turn:balsoft.ru?transport=tcp" ];
|
|
|
|
extraConfigFiles = [
|
|
|
|
config.secrets-envsubst.coturn.substituted
|
|
|
|
config.secrets-envsubst.matrix.substituted
|
2020-02-17 17:00:59 +04:00
|
|
|
];
|
2022-04-27 18:22:28 +04:00
|
|
|
app_service_config_files =
|
|
|
|
[ config.secrets-envsubst.mautrix-telegram-registration.substituted ];
|
|
|
|
};
|
2021-10-02 19:42:17 +04:00
|
|
|
};
|
|
|
|
|
2022-02-28 23:25:34 +04:00
|
|
|
services.postgresql.enable = true;
|
2020-08-04 15:51:37 +04:00
|
|
|
|
|
|
|
services.mautrix-telegram = {
|
|
|
|
enable = true;
|
2021-01-11 18:09:34 +04:00
|
|
|
environmentFile = toString config.secrets-envsubst.mautrix-telegram;
|
|
|
|
settings = {
|
|
|
|
appservice = {
|
|
|
|
address = "http://localhost:29317";
|
|
|
|
bot_avatar = "mxc://maunium.net/tJCRmUyJDsgRNgqhOgoiHWbX";
|
|
|
|
id = "telegram";
|
|
|
|
max_body_size = 1;
|
|
|
|
port = 29317;
|
|
|
|
};
|
|
|
|
bridge = {
|
|
|
|
alias_template = "tg_{groupname}";
|
|
|
|
allow_matrix_login = true;
|
|
|
|
bot_messages_as_notices = true;
|
|
|
|
catch_up = true;
|
|
|
|
command_prefix = "!tg";
|
|
|
|
image_as_file_size = 10;
|
|
|
|
max_document_size = 100;
|
|
|
|
max_initial_member_sync = -1;
|
|
|
|
max_telegram_delete = 10;
|
|
|
|
permissions = {
|
|
|
|
"*" = "relaybot";
|
|
|
|
"@balsoft:balsoft.ru" = "admin";
|
|
|
|
};
|
|
|
|
plaintext_highlights = true;
|
|
|
|
startup_sync = true;
|
|
|
|
username_template = "tg_{userid}";
|
2022-11-25 10:15:07 +04:00
|
|
|
relay_user_distinguishers = [ ];
|
|
|
|
state_event_formats = {
|
|
|
|
leave = "";
|
|
|
|
name_change = "";
|
|
|
|
};
|
2021-01-11 18:09:34 +04:00
|
|
|
};
|
|
|
|
homeserver = {
|
|
|
|
address = "https://matrix.balsoft.ru";
|
|
|
|
domain = "balsoft.ru";
|
|
|
|
verify_ssl = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
secrets-envsubst.mautrix-telegram = {
|
2022-11-25 10:15:07 +04:00
|
|
|
secrets = [ "as_token" "hs_token" "api_id" "api_hash" "bot_token" ];
|
2021-01-11 18:09:34 +04:00
|
|
|
template = ''
|
|
|
|
MAUTRIX_TELEGRAM_APPSERVICE_AS_TOKEN=$as_token
|
|
|
|
MAUTRIX_TELEGRAM_APPSERVICE_HS_TOKEN=$hs_token
|
|
|
|
MAUTRIX_TELEGRAM_TELEGRAM_API_ID=$api_id
|
|
|
|
MAUTRIX_TELEGRAM_TELEGRAM_API_HASH=$api_hash
|
2022-11-25 10:15:07 +04:00
|
|
|
MAUTRIX_TELEGRAM_TELEGRAM_BOT_TOKEN=$bot_token
|
2021-01-11 18:09:34 +04:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
secrets-envsubst.mautrix-telegram-registration = {
|
|
|
|
directory = "mautrix-telegram";
|
2021-01-11 21:51:09 +04:00
|
|
|
secrets = [ "as_token" "hs_token" ];
|
2021-01-11 18:09:34 +04:00
|
|
|
owner = "matrix-synapse";
|
|
|
|
template = builtins.toJSON {
|
|
|
|
as_token = "$as_token";
|
|
|
|
hs_token = "$hs_token";
|
|
|
|
id = "telegram";
|
|
|
|
namespaces = {
|
|
|
|
aliases = [{
|
|
|
|
exclusive = true;
|
|
|
|
regex = "#tg_.+:balsoft.ru";
|
|
|
|
}];
|
|
|
|
users = [{
|
|
|
|
exclusive = true;
|
|
|
|
regex = "@tg_.+:balsoft.ru";
|
|
|
|
}];
|
|
|
|
};
|
|
|
|
rate_limited = false;
|
|
|
|
sender_localpart = "telegrambot";
|
|
|
|
url = "http://localhost:29317";
|
|
|
|
};
|
2020-02-17 17:00:59 +04:00
|
|
|
};
|
2020-08-04 15:51:37 +04:00
|
|
|
|
2023-09-12 01:16:34 +04:00
|
|
|
systemd.services.mautrix-telegram.serviceConfig = {
|
|
|
|
DynamicUser = lib.mkForce false;
|
|
|
|
Restart = "always";
|
|
|
|
RuntimeMaxSec = "1d";
|
|
|
|
};
|
2021-01-11 18:09:34 +04:00
|
|
|
|
|
|
|
systemd.services.mautrix-telegram.serviceConfig.User = "mautrix-telegram";
|
|
|
|
|
2021-10-02 19:42:17 +04:00
|
|
|
users.users.mautrix-telegram = {
|
|
|
|
group = "mautrix-telegram";
|
|
|
|
isSystemUser = true;
|
|
|
|
};
|
|
|
|
|
2022-02-28 23:25:34 +04:00
|
|
|
users.groups.mautrix-telegram = { };
|
2020-08-04 15:51:37 +04:00
|
|
|
|
2020-02-17 17:00:59 +04:00
|
|
|
users.users.matrix-synapse.name = lib.mkForce "matrix-synapse";
|
2022-03-13 00:14:34 +04:00
|
|
|
|
|
|
|
services.coturn = {
|
|
|
|
enable = true;
|
|
|
|
use-auth-secret = true;
|
|
|
|
static-auth-secret-file = config.secrets.coturn.decrypted;
|
|
|
|
no-tls = true;
|
|
|
|
realm = "balsoft.ru";
|
|
|
|
extraConfig = ''
|
|
|
|
external-ip=94.25.150.197
|
|
|
|
|
|
|
|
denied-peer-ip=10.0.0.0-10.255.255.255
|
|
|
|
denied-peer-ip=192.168.0.0-192.168.255.255
|
|
|
|
denied-peer-ip=172.16.0.0-172.31.255.255
|
|
|
|
|
|
|
|
denied-peer-ip=0.0.0.0-0.255.255.255
|
|
|
|
denied-peer-ip=100.64.0.0-100.127.255.255
|
|
|
|
denied-peer-ip=127.0.0.0-127.255.255.255
|
|
|
|
denied-peer-ip=169.254.0.0-169.254.255.255
|
|
|
|
denied-peer-ip=192.0.0.0-192.0.0.255
|
|
|
|
denied-peer-ip=192.0.2.0-192.0.2.255
|
|
|
|
denied-peer-ip=192.88.99.0-192.88.99.255
|
|
|
|
denied-peer-ip=198.18.0.0-198.19.255.255
|
|
|
|
denied-peer-ip=198.51.100.0-198.51.100.255
|
|
|
|
denied-peer-ip=203.0.113.0-203.0.113.255
|
|
|
|
denied-peer-ip=240.0.0.0-255.255.255.255
|
|
|
|
|
|
|
|
allowed-peer-ip=192.168.8.236
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
secrets.coturn = {
|
|
|
|
encrypted =
|
|
|
|
"/home/balsoft/.local/share/password-store/coturn/shared_secret.gpg";
|
|
|
|
services = [ "coturn" ];
|
|
|
|
owner = "turnserver:turnserver";
|
|
|
|
};
|
|
|
|
secrets-envsubst.coturn = {
|
|
|
|
secrets = [ "shared_secret" ];
|
|
|
|
services = [ "matrix-synapse" ];
|
|
|
|
owner = "matrix-synapse:matrix-synapse";
|
|
|
|
template = builtins.toJSON { turn_shared_secret = "$shared_secret"; };
|
|
|
|
};
|
|
|
|
secrets-envsubst.matrix = {
|
|
|
|
secrets = [ "registration_shared_secret" ];
|
|
|
|
services = [ "matrix-synapse" ];
|
|
|
|
owner = "matrix-synapse:matrix-synapse";
|
|
|
|
template = builtins.toJSON {
|
|
|
|
registration_shared_secret = "$registration_shared_secret";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
networking.firewall = rec {
|
|
|
|
allowedTCPPorts = [ 3478 5349 ];
|
|
|
|
allowedUDPPorts = allowedTCPPorts;
|
|
|
|
allowedUDPPortRanges = [{
|
|
|
|
from = 49152;
|
|
|
|
to = 65535;
|
|
|
|
}];
|
|
|
|
};
|
|
|
|
|
2020-02-17 17:00:59 +04:00
|
|
|
}
|