nixos-config/config/services/mastodon.nix

75 lines
2.6 KiB
Nix
Raw Normal View History

2022-04-25 18:09:22 +00:00
{ config, lib, ... }:
2022-04-25 16:47:49 +00:00
let
sopsConfig = {
owner = "mastodon";
restartUnits = [
"mastodon-streaming.service"
"mastodon-web.service"
"mastodon-sidekiq.service"
];
};
in
{
imports = [
./elasticsearch.nix
];
services.mastodon = {
enable = true;
elasticsearch = {
host = "127.0.0.1";
};
localDomain = "chir.rs";
extraConfig = {
WEB_DOMAIN = "mastodon.darkkirb.de";
REDIS_NAMESPACE = "mastodon";
2022-04-25 17:01:55 +00:00
SINGLE_USER_MODE = "true";
REDIS_HOST = "127.0.0.1";
REDIS_PORT = toString config.services.redis.mastodon.port;
2022-04-25 16:47:49 +00:00
};
2022-04-25 17:01:55 +00:00
redis.createLocally = false;
2022-04-25 16:51:53 +00:00
otpSecretFile = config.sops.secrets."services/mastodon/otpSecret".path;
secretKeyBaseFile = config.sops.secrets."services/mastodon/secretKeyBase".path;
2022-04-25 16:47:49 +00:00
smtp = {
authenticate = true;
createLocally = false;
fromAddress = "mastodon@chir.rs";
host = "mail.chir.rs";
2022-04-25 16:51:53 +00:00
passwordFile = config.sops.secrets."services/mastodon/smtpPassword".path;
2022-04-25 16:47:49 +00:00
user = "mastodon@chir.rs";
};
2022-04-25 16:51:53 +00:00
vapidPrivateKeyFile = config.sops.secrets."services/mastodon/vapid/private".path;
vapidPublicKeyFile = config.sops.secrets."services/mastodon/vapid/public".path;
2022-04-25 16:47:49 +00:00
};
sops.secrets."services/mastodon/otpSecret" = sopsConfig;
sops.secrets."services/mastodon/secretKeyBase" = sopsConfig;
sops.secrets."services/mastodon/smtpPassword" = sopsConfig;
sops.secrets."services/mastodon/vapid/private" = sopsConfig;
sops.secrets."services/mastodon/vapid/public" = sopsConfig;
2022-04-25 16:51:21 +00:00
services.nginx.virtualHosts."mastodon.chir.rs" = {
root = "${config.services.mastodon.package}/public/";
sslCertificate = "/var/lib/acme/chir.rs/cert.pem";
sslCertificateKey = "/var/lib/acme/chir.rs/key.pem";
locations."/system/".alias = "/var/lib/mastodon/public-system/";
locations."/" = {
tryFiles = "$uri @proxy";
};
locations."@proxy" = {
proxyPass = (if config.services.mastodon.enableUnixSocket then "http://unix:/run/mastodon-web/web.socket" else "http://127.0.0.1:${toString(config.services.mastodon.webPort)}");
proxyWebsockets = true;
};
locations."/api/v1/streaming/" = {
proxyPass = (if config.services.mastodon.enableUnixSocket then "http://unix:/run/mastodon-streaming/streaming.socket" else "http://127.0.0.1:${toString(config.services.mastodon.streamingPort)}/");
proxyWebsockets = true;
};
};
2022-04-25 17:01:55 +00:00
services.redis.servers.mastodon = {
enable = true;
bind = "127.0.0.1";
databases = 1;
port = 6379;
};
2022-04-25 18:09:22 +00:00
users.users.mastodon.home = lib.mkForce (toString config.services.mastodon.package);
2022-04-25 16:47:49 +00:00
}