2021-10-07 14:46:35 +00:00
|
|
|
{ config, pkgs, lib, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.mautrix-facebook;
|
|
|
|
settingsFormat = pkgs.formats.json {};
|
|
|
|
settingsFile = settingsFormat.generate "mautrix-facebook-config.json" cfg.settings;
|
|
|
|
|
|
|
|
puppetRegex = concatStringsSep
|
|
|
|
".*"
|
|
|
|
(map
|
|
|
|
escapeRegex
|
|
|
|
(splitString
|
|
|
|
"{userid}"
|
|
|
|
cfg.settings.bridge.username_template));
|
|
|
|
in {
|
|
|
|
options = {
|
|
|
|
services.mautrix-facebook = {
|
2022-09-09 14:08:57 +00:00
|
|
|
enable = mkEnableOption (lib.mdDoc "Mautrix-Facebook, a Matrix-Facebook hybrid puppeting/relaybot bridge");
|
2021-10-07 14:46:35 +00:00
|
|
|
|
|
|
|
settings = mkOption rec {
|
|
|
|
apply = recursiveUpdate default;
|
|
|
|
type = settingsFormat.type;
|
|
|
|
default = {
|
|
|
|
homeserver = {
|
|
|
|
address = "http://localhost:8008";
|
2022-10-30 15:09:59 +00:00
|
|
|
software = "standard";
|
2021-10-07 14:46:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
appservice = rec {
|
2023-07-15 17:15:38 +00:00
|
|
|
id = "facebook";
|
2021-10-07 14:46:35 +00:00
|
|
|
address = "http://${hostname}:${toString port}";
|
|
|
|
hostname = "localhost";
|
|
|
|
port = 29319;
|
|
|
|
|
|
|
|
database = "postgresql://";
|
|
|
|
|
|
|
|
bot_username = "facebookbot";
|
|
|
|
};
|
|
|
|
|
|
|
|
metrics.enabled = false;
|
|
|
|
manhole.enabled = false;
|
|
|
|
|
|
|
|
bridge = {
|
|
|
|
encryption = {
|
|
|
|
allow = true;
|
|
|
|
default = true;
|
2022-09-09 14:08:57 +00:00
|
|
|
|
|
|
|
verification_levels = {
|
|
|
|
receive = "cross-signed-tofu";
|
|
|
|
send = "cross-signed-tofu";
|
|
|
|
share = "cross-signed-tofu";
|
|
|
|
};
|
2021-10-07 14:46:35 +00:00
|
|
|
};
|
|
|
|
username_template = "facebook_{userid}";
|
|
|
|
};
|
|
|
|
|
|
|
|
logging = {
|
|
|
|
version = 1;
|
|
|
|
formatters.journal_fmt.format = "%(name)s: %(message)s";
|
|
|
|
handlers.journal = {
|
|
|
|
class = "systemd.journal.JournalHandler";
|
|
|
|
formatter = "journal_fmt";
|
|
|
|
SYSLOG_IDENTIFIER = "mautrix-facebook";
|
|
|
|
};
|
|
|
|
root = {
|
|
|
|
level = "INFO";
|
|
|
|
handlers = ["journal"];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
example = literalExpression ''
|
|
|
|
{
|
|
|
|
homeserver = {
|
|
|
|
address = "http://localhost:8008";
|
|
|
|
domain = "mydomain.example";
|
|
|
|
};
|
|
|
|
|
|
|
|
bridge.permissions = {
|
|
|
|
"@admin:mydomain.example" = "admin";
|
|
|
|
"mydomain.example" = "user";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
'';
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
|
|
|
{file}`config.yaml` configuration as a Nix attribute set.
|
2021-10-07 14:46:35 +00:00
|
|
|
Configuration options should match those described in
|
2022-08-12 12:06:08 +00:00
|
|
|
[example-config.yaml](https://github.com/mautrix/facebook/blob/master/mautrix_facebook/example-config.yaml).
|
2021-10-07 14:46:35 +00:00
|
|
|
|
2022-08-12 12:06:08 +00:00
|
|
|
Secret tokens should be specified using {option}`environmentFile`
|
2021-10-07 14:46:35 +00:00
|
|
|
instead of this world-readable attribute set.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
environmentFile = mkOption {
|
|
|
|
type = types.nullOr types.path;
|
|
|
|
default = null;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2023-02-22 10:55:15 +00:00
|
|
|
File containing environment variables to be passed to the mautrix-facebook service.
|
2021-10-07 14:46:35 +00:00
|
|
|
|
2022-08-12 12:06:08 +00:00
|
|
|
Any config variable can be overridden by setting `MAUTRIX_FACEBOOK_SOME_KEY` to override the `some.key` variable.
|
2021-10-07 14:46:35 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
configurePostgresql = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = true;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
|
|
|
Enable PostgreSQL and create a user and database for mautrix-facebook. The default `settings` reference this database, if you disable this option you must provide a database URL.
|
2021-10-07 14:46:35 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
registrationData = mkOption {
|
|
|
|
type = types.attrs;
|
|
|
|
default = {};
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2021-10-07 14:46:35 +00:00
|
|
|
Output data for appservice registration. Simply make any desired changes and serialize to JSON. Note that this data contains secrets so think twice before putting it into the nix store.
|
|
|
|
|
2022-08-12 12:06:08 +00:00
|
|
|
Currently `as_token` and `hs_token` need to be added as they are not known to this module.
|
2021-10-07 14:46:35 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2022-09-09 14:08:57 +00:00
|
|
|
users.groups.mautrix-facebook = {};
|
|
|
|
|
2021-10-07 14:46:35 +00:00
|
|
|
users.users.mautrix-facebook = {
|
|
|
|
group = "mautrix-facebook";
|
|
|
|
isSystemUser = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
services.postgresql = mkIf cfg.configurePostgresql {
|
|
|
|
ensureDatabases = ["mautrix-facebook"];
|
|
|
|
ensureUsers = [{
|
|
|
|
name = "mautrix-facebook";
|
2024-01-02 11:29:13 +00:00
|
|
|
ensureDBOwnership = true;
|
2021-10-07 14:46:35 +00:00
|
|
|
}];
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services.mautrix-facebook = rec {
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
wants = [
|
|
|
|
"network-online.target"
|
2023-11-16 04:20:00 +00:00
|
|
|
] ++ optional config.services.matrix-synapse.enable config.services.matrix-synapse.serviceUnit
|
2021-10-07 14:46:35 +00:00
|
|
|
++ optional cfg.configurePostgresql "postgresql.service";
|
|
|
|
after = wants;
|
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "simple";
|
|
|
|
Restart = "always";
|
|
|
|
|
|
|
|
User = "mautrix-facebook";
|
|
|
|
|
|
|
|
ProtectSystem = "strict";
|
|
|
|
ProtectHome = true;
|
|
|
|
ProtectKernelTunables = true;
|
|
|
|
ProtectKernelModules = true;
|
|
|
|
ProtectControlGroups = true;
|
|
|
|
PrivateTmp = true;
|
|
|
|
|
|
|
|
EnvironmentFile = cfg.environmentFile;
|
|
|
|
|
|
|
|
ExecStart = ''
|
|
|
|
${pkgs.mautrix-facebook}/bin/mautrix-facebook --config=${settingsFile}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services.mautrix-facebook = {
|
|
|
|
registrationData = {
|
2023-07-15 17:15:38 +00:00
|
|
|
id = cfg.settings.appservice.id;
|
2021-10-07 14:46:35 +00:00
|
|
|
|
|
|
|
namespaces = {
|
|
|
|
users = [
|
|
|
|
{
|
|
|
|
exclusive = true;
|
|
|
|
regex = escapeRegex "@${cfg.settings.appservice.bot_username}:${cfg.settings.homeserver.domain}";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
exclusive = true;
|
|
|
|
regex = "@${puppetRegex}:${escapeRegex cfg.settings.homeserver.domain}";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
aliases = [];
|
|
|
|
};
|
|
|
|
|
|
|
|
url = cfg.settings.appservice.address;
|
|
|
|
sender_localpart = "mautrix-facebook-sender";
|
|
|
|
|
|
|
|
rate_limited = false;
|
|
|
|
"de.sorunome.msc2409.push_ephemeral" = true;
|
|
|
|
push_ephemeral = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
meta.maintainers = with maintainers; [ kevincox ];
|
|
|
|
}
|