forked from danio/nixos-matrix-modules
Compare commits
6 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
e1a0bd8054
|
|||
|
31baa00922
|
|||
|
4c5ef718fe
|
|||
|
543b50dcf5
|
|||
|
114ca192c1
|
|||
|
318538066f
|
@@ -70,6 +70,14 @@ in
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
withJemalloc = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = true;
|
||||||
|
description = ''
|
||||||
|
Whether to preload jemalloc to reduce memory fragmentation and overall usage.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
dataDir = mkOption {
|
dataDir = mkOption {
|
||||||
type = types.path;
|
type = types.path;
|
||||||
default = "/var/lib/matrix-synapse";
|
default = "/var/lib/matrix-synapse";
|
||||||
@@ -400,7 +408,6 @@ in
|
|||||||
group = "matrix-synapse";
|
group = "matrix-synapse";
|
||||||
home = cfg.dataDir;
|
home = cfg.dataDir;
|
||||||
createHome = true;
|
createHome = true;
|
||||||
shell = "${pkgs.bash}/bin/bash";
|
|
||||||
uid = config.ids.uids.matrix-synapse;
|
uid = config.ids.uids.matrix-synapse;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -426,22 +433,31 @@ in
|
|||||||
partOf = [ "matrix-synapse.target" ];
|
partOf = [ "matrix-synapse.target" ];
|
||||||
wantedBy = [ "matrix-synapse.target" ];
|
wantedBy = [ "matrix-synapse.target" ];
|
||||||
|
|
||||||
preStart = let
|
environment = lib.optionalAttrs cfg.withJemalloc {
|
||||||
flags = lib.cli.toCommandLineShellGNU {} {
|
LD_PRELOAD = "${pkgs.jemalloc}/lib/libjemalloc.so";
|
||||||
config-path = [ matrix-synapse-common-config ] ++ cfg.extraConfigFiles;
|
PYTHONMALLOC = "malloc";
|
||||||
keys-directory = cfg.dataDir;
|
};
|
||||||
generate-keys = true;
|
|
||||||
};
|
|
||||||
in "${cfg.package}/bin/synapse_homeserver ${flags}";
|
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Type = "notify";
|
Type = "notify";
|
||||||
User = "matrix-synapse";
|
User = "matrix-synapse";
|
||||||
Group = "matrix-synapse";
|
Group = "matrix-synapse";
|
||||||
Slice = "system-matrix-synapse.slice";
|
Slice = "system-matrix-synapse.slice";
|
||||||
|
|
||||||
|
Restart = "always";
|
||||||
|
RestartSec = 3;
|
||||||
|
|
||||||
WorkingDirectory = cfg.dataDir;
|
WorkingDirectory = cfg.dataDir;
|
||||||
StateDirectory = "matrix-synapse";
|
StateDirectory = "matrix-synapse";
|
||||||
RuntimeDirectory = "matrix-synapse";
|
RuntimeDirectory = "matrix-synapse";
|
||||||
|
|
||||||
|
ExecStartPre = let
|
||||||
|
flags = lib.cli.toCommandLineShellGNU {} {
|
||||||
|
config-path = [ matrix-synapse-common-config ] ++ cfg.extraConfigFiles;
|
||||||
|
keys-directory = cfg.dataDir;
|
||||||
|
generate-keys = true;
|
||||||
|
};
|
||||||
|
in "${cfg.package}/bin/synapse_homeserver ${flags}";
|
||||||
ExecStart = let
|
ExecStart = let
|
||||||
flags = lib.cli.toCommandLineShellGNU {} {
|
flags = lib.cli.toCommandLineShellGNU {} {
|
||||||
config-path = [ matrix-synapse-common-config ] ++ cfg.extraConfigFiles;
|
config-path = [ matrix-synapse-common-config ] ++ cfg.extraConfigFiles;
|
||||||
@@ -449,7 +465,45 @@ in
|
|||||||
};
|
};
|
||||||
in "${wrapped}/bin/synapse_homeserver ${flags}";
|
in "${wrapped}/bin/synapse_homeserver ${flags}";
|
||||||
ExecReload = "${lib.getExe' pkgs.coreutils "kill"} -HUP $MAINPID";
|
ExecReload = "${lib.getExe' pkgs.coreutils "kill"} -HUP $MAINPID";
|
||||||
Restart = "on-failure";
|
|
||||||
|
CapabilityBoundingSet = [ "" ];
|
||||||
|
LockPersonality = true;
|
||||||
|
NoNewPrivileges = true;
|
||||||
|
PrivateDevices = true;
|
||||||
|
PrivateTmp = true;
|
||||||
|
PrivateUsers = true;
|
||||||
|
ProcSubset = "pid";
|
||||||
|
ProtectClock = true;
|
||||||
|
ProtectControlGroups = true;
|
||||||
|
ProtectHome = true;
|
||||||
|
ProtectHostname = true;
|
||||||
|
ProtectKernelLogs = true;
|
||||||
|
ProtectKernelModules = true;
|
||||||
|
ProtectKernelTunables = true;
|
||||||
|
ProtectProc = "invisible";
|
||||||
|
ProtectSystem = "strict";
|
||||||
|
ReadWritePaths = [
|
||||||
|
cfg.dataDir
|
||||||
|
cfg.settings.media_store_path
|
||||||
|
]
|
||||||
|
++ (map (listener: dirOf listener.path) (
|
||||||
|
lib.filter (listener: listener.path != null) cfg.settings.listeners
|
||||||
|
));
|
||||||
|
RemoveIPC = true;
|
||||||
|
RestrictAddressFamilies = [
|
||||||
|
"AF_INET"
|
||||||
|
"AF_INET6"
|
||||||
|
"AF_UNIX"
|
||||||
|
];
|
||||||
|
RestrictNamespaces = true;
|
||||||
|
RestrictRealtime = true;
|
||||||
|
RestrictSUIDSGID = true;
|
||||||
|
SystemCallArchitectures = "native";
|
||||||
|
SystemCallFilter = [
|
||||||
|
"@system-service"
|
||||||
|
"~@resources"
|
||||||
|
"~@privileged"
|
||||||
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -24,6 +24,7 @@ in
|
|||||||
~^/_matrix/client/(api/v1|r0|v3)/rooms/[^/]+/initialSync$ synapse_initial_sync;
|
~^/_matrix/client/(api/v1|r0|v3)/rooms/[^/]+/initialSync$ synapse_initial_sync;
|
||||||
|
|
||||||
# Federation requests
|
# Federation requests
|
||||||
|
~^/_matrix/federation/v1/version$ synapse_federation;
|
||||||
~^/_matrix/federation/v1/event/ synapse_federation;
|
~^/_matrix/federation/v1/event/ synapse_federation;
|
||||||
~^/_matrix/federation/v1/state/ synapse_federation;
|
~^/_matrix/federation/v1/state/ synapse_federation;
|
||||||
~^/_matrix/federation/v1/state_ids/ synapse_federation;
|
~^/_matrix/federation/v1/state_ids/ synapse_federation;
|
||||||
@@ -35,6 +36,8 @@ in
|
|||||||
~^/_matrix/federation/v1/make_leave/ synapse_federation;
|
~^/_matrix/federation/v1/make_leave/ synapse_federation;
|
||||||
~^/_matrix/federation/(v1|v2)/send_join/ synapse_federation;
|
~^/_matrix/federation/(v1|v2)/send_join/ synapse_federation;
|
||||||
~^/_matrix/federation/(v1|v2)/send_leave/ synapse_federation;
|
~^/_matrix/federation/(v1|v2)/send_leave/ synapse_federation;
|
||||||
|
~^/_matrix/federation/v1/make_knock/ synapse_federation;
|
||||||
|
~^/_matrix/federation/v1/send_knock/ synapse_federation;
|
||||||
~^/_matrix/federation/(v1|v2)/invite/ synapse_federation;
|
~^/_matrix/federation/(v1|v2)/invite/ synapse_federation;
|
||||||
~^/_matrix/federation/v1/event_auth/ synapse_federation;
|
~^/_matrix/federation/v1/event_auth/ synapse_federation;
|
||||||
~^/_matrix/federation/v1/timestamp_to_event/ synapse_federation;
|
~^/_matrix/federation/v1/timestamp_to_event/ synapse_federation;
|
||||||
@@ -56,17 +59,23 @@ in
|
|||||||
~^/_matrix/client/v1/rooms/.*/hierarchy$ synapse_client_interaction;
|
~^/_matrix/client/v1/rooms/.*/hierarchy$ synapse_client_interaction;
|
||||||
~^/_matrix/client/(v1|unstable)/rooms/.*/relations/ synapse_client_interaction;
|
~^/_matrix/client/(v1|unstable)/rooms/.*/relations/ synapse_client_interaction;
|
||||||
~^/_matrix/client/v1/rooms/.*/threads$ synapse_client_interaction;
|
~^/_matrix/client/v1/rooms/.*/threads$ synapse_client_interaction;
|
||||||
~^/_matrix/client/unstable/org.matrix.msc2716/rooms/.*/batch_send$ synapse_client_interaction;
|
|
||||||
~^/_matrix/client/unstable/im.nheko.summary/rooms/.*/summary$ synapse_client_interaction;
|
~^/_matrix/client/unstable/im.nheko.summary/rooms/.*/summary$ synapse_client_interaction;
|
||||||
~^/_matrix/client/(r0|v3|unstable)/account/3pid$ synapse_client_interaction;
|
~^/_matrix/client/(r0|v3|unstable)/account/3pid$ synapse_client_interaction;
|
||||||
~^/_matrix/client/(r0|v3|unstable)/account/whoami$ synapse_client_interaction;
|
~^/_matrix/client/(r0|v3|unstable)/account/whoami$ synapse_client_interaction;
|
||||||
~^/_matrix/client/(r0|v3|unstable)/devices$ synapse_client_interaction;
|
~^/_matrix/client/(r0|v3|unstable)/account/deactivate$ synapse_client_interaction;
|
||||||
|
~^/_matrix/client/(r0|v3)/delete_devices$ synapse_client_interaction;
|
||||||
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/devices(/|$) synapse_client_interaction;
|
||||||
~^/_matrix/client/versions$ synapse_client_interaction;
|
~^/_matrix/client/versions$ synapse_client_interaction;
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/voip/turnServer$ synapse_client_interaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/voip/turnServer$ synapse_client_interaction;
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/event/ synapse_client_interaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/event/ synapse_client_interaction;
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/joined_rooms$ synapse_client_interaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/joined_rooms$ synapse_client_interaction;
|
||||||
~^/_matrix/client/v1/rooms/.*/timestamp_to_event$ synapse_client_interaction;
|
~^/_matrix/client/v1/rooms/.*/timestamp_to_event$ synapse_client_interaction;
|
||||||
|
~^/_matrix/client/(api/v1|r0|v3|unstable/.*)/rooms/.*/aliases synapse_client_interaction;
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/search$ synapse_client_interaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/search$ synapse_client_interaction;
|
||||||
|
~^/_matrix/client/(r0|v3|unstable)/user/.*/filter(/|$) synapse_client_interaction;
|
||||||
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/directory/room/.*$ synapse_client_interaction;
|
||||||
|
~^/_matrix/client/(r0|v3|unstable)/capabilities$ synapse_client_interaction;
|
||||||
|
~^/_matrix/client/(r0|v3|unstable)/notifications$ synapse_client_interaction;
|
||||||
|
|
||||||
# Encryption requests
|
# Encryption requests
|
||||||
~^/_matrix/client/(r0|v3|unstable)/keys/query$ synapse_client_encryption;
|
~^/_matrix/client/(r0|v3|unstable)/keys/query$ synapse_client_encryption;
|
||||||
@@ -74,11 +83,15 @@ in
|
|||||||
~^/_matrix/client/(r0|v3|unstable)/keys/claim$ synapse_client_encryption;
|
~^/_matrix/client/(r0|v3|unstable)/keys/claim$ synapse_client_encryption;
|
||||||
~^/_matrix/client/(r0|v3|unstable)/room_keys/ synapse_client_encryption;
|
~^/_matrix/client/(r0|v3|unstable)/room_keys/ synapse_client_encryption;
|
||||||
~^/_matrix/client/(r0|v3|unstable)/keys/upload/ synapse_client_encryption;
|
~^/_matrix/client/(r0|v3|unstable)/keys/upload/ synapse_client_encryption;
|
||||||
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/keys/device_signing/upload$ synapse_client_encryption;
|
||||||
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/keys/signatures/upload$ synapse_client_encryption;
|
||||||
|
|
||||||
# Registration/login requests
|
# Registration/login requests
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/login$ synapse_client_login;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/login$ synapse_client_login;
|
||||||
~^/_matrix/client/(r0|v3|unstable)/register$ synapse_client_login;
|
~^/_matrix/client/(r0|v3|unstable)/register$ synapse_client_login;
|
||||||
|
~^/_matrix/client/(r0|v3|unstable)/register/available$ synapse_client_login;
|
||||||
~^/_matrix/client/v1/register/m.login.registration_token/validity$ synapse_client_login;
|
~^/_matrix/client/v1/register/m.login.registration_token/validity$ synapse_client_login;
|
||||||
|
~^/_matrix/client/(r0|v3|unstable)/password_policy$ synapse_client_login;
|
||||||
|
|
||||||
# Event sending requests
|
# Event sending requests
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/redact synapse_client_transaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/redact synapse_client_transaction;
|
||||||
@@ -86,6 +99,7 @@ in
|
|||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/state/ synapse_client_transaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/state/ synapse_client_transaction;
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/(join|invite|leave|ban|unban|kick)$ synapse_client_transaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/rooms/.*/(join|invite|leave|ban|unban|kick)$ synapse_client_transaction;
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/join/ synapse_client_transaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/join/ synapse_client_transaction;
|
||||||
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/knock/ synapse_client_transaction;
|
||||||
~^/_matrix/client/(api/v1|r0|v3|unstable)/profile/ synapse_client_transaction;
|
~^/_matrix/client/(api/v1|r0|v3|unstable)/profile/ synapse_client_transaction;
|
||||||
|
|
||||||
# Account data requests
|
# Account data requests
|
||||||
|
|||||||
@@ -74,6 +74,16 @@ in {
|
|||||||
description = "Listener configuration for the worker, similar to the main synapse listener";
|
description = "Listener configuration for the worker, similar to the main synapse listener";
|
||||||
default = [ ];
|
default = [ ];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
worker_log_config = mkOption {
|
||||||
|
type = types.path;
|
||||||
|
description = ''
|
||||||
|
A yaml python logging config file as described by
|
||||||
|
https://docs.python.org/3.7/library/logging.config.html#configuration-dictionary-schema
|
||||||
|
'';
|
||||||
|
default = pkgs.writeText "log_config.yaml" cfg.mainLogConfig;
|
||||||
|
defaultText = "A config file generated from ${cfgText}.mainLogConfig";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -374,14 +384,25 @@ in {
|
|||||||
wantedBy = [ "matrix-synapse.target" ];
|
wantedBy = [ "matrix-synapse.target" ];
|
||||||
after = [ "matrix-synapse.service" ];
|
after = [ "matrix-synapse.service" ];
|
||||||
requires = [ "matrix-synapse.service" ];
|
requires = [ "matrix-synapse.service" ];
|
||||||
|
|
||||||
|
environment = lib.optionalAttrs cfg.withJemalloc {
|
||||||
|
LD_PRELOAD = "${pkgs.jemalloc}/lib/libjemalloc.so";
|
||||||
|
PYTHONMALLOC = "malloc";
|
||||||
|
};
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Type = "notify";
|
Type = "notify";
|
||||||
User = "matrix-synapse";
|
User = "matrix-synapse";
|
||||||
Group = "matrix-synapse";
|
Group = "matrix-synapse";
|
||||||
Slice = "system-matrix-synapse.slice";
|
Slice = "system-matrix-synapse.slice";
|
||||||
|
|
||||||
|
Restart = "always";
|
||||||
|
RestartSec = 3;
|
||||||
|
|
||||||
WorkingDirectory = cfg.dataDir;
|
WorkingDirectory = cfg.dataDir;
|
||||||
RuntimeDirectory = "matrix-synapse";
|
RuntimeDirectory = "matrix-synapse";
|
||||||
StateDirectory = "matrix-synapse";
|
StateDirectory = "matrix-synapse";
|
||||||
|
|
||||||
ExecStartPre = pkgs.writers.writeBash "wait-for-synapse" ''
|
ExecStartPre = pkgs.writers.writeBash "wait-for-synapse" ''
|
||||||
# From https://md.darmstadt.ccc.de/synapse-at-work
|
# From https://md.darmstadt.ccc.de/synapse-at-work
|
||||||
while ! systemctl is-active -q matrix-synapse.service; do
|
while ! systemctl is-active -q matrix-synapse.service; do
|
||||||
@@ -394,6 +415,45 @@ in {
|
|||||||
keys-directory = cfg.dataDir;
|
keys-directory = cfg.dataDir;
|
||||||
};
|
};
|
||||||
in "${wrapped}/bin/synapse_worker ${flags}";
|
in "${wrapped}/bin/synapse_worker ${flags}";
|
||||||
|
|
||||||
|
CapabilityBoundingSet = [ "" ];
|
||||||
|
LockPersonality = true;
|
||||||
|
NoNewPrivileges = true;
|
||||||
|
PrivateDevices = true;
|
||||||
|
PrivateTmp = true;
|
||||||
|
PrivateUsers = true;
|
||||||
|
ProcSubset = "pid";
|
||||||
|
ProtectClock = true;
|
||||||
|
ProtectControlGroups = true;
|
||||||
|
ProtectHome = true;
|
||||||
|
ProtectHostname = true;
|
||||||
|
ProtectKernelLogs = true;
|
||||||
|
ProtectKernelModules = true;
|
||||||
|
ProtectKernelTunables = true;
|
||||||
|
ProtectProc = "invisible";
|
||||||
|
ProtectSystem = "strict";
|
||||||
|
ReadWritePaths = [
|
||||||
|
cfg.dataDir
|
||||||
|
cfg.settings.media_store_path
|
||||||
|
]
|
||||||
|
++ (map (listener: dirOf listener.path) (
|
||||||
|
lib.filter (listener: listener.path != null) cfg.settings.listeners
|
||||||
|
));
|
||||||
|
RemoveIPC = true;
|
||||||
|
RestrictAddressFamilies = [
|
||||||
|
"AF_INET"
|
||||||
|
"AF_INET6"
|
||||||
|
"AF_UNIX"
|
||||||
|
];
|
||||||
|
RestrictNamespaces = true;
|
||||||
|
RestrictRealtime = true;
|
||||||
|
RestrictSUIDSGID = true;
|
||||||
|
SystemCallArchitectures = "native";
|
||||||
|
SystemCallFilter = [
|
||||||
|
"@system-service"
|
||||||
|
"~@resources"
|
||||||
|
"~@privileged"
|
||||||
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}));
|
}));
|
||||||
|
|||||||
Reference in New Issue
Block a user