nixfiles/hosts/hetzner-vm/containers/social/profiles/gotosocial.nix

65 lines
1.5 KiB
Nix
Raw Normal View History

2023-09-18 03:56:58 +01:00
{
hostPath,
hostSecrets,
...
}: let
containerAddresses = import "${hostPath}/data/containerAddresses.nix";
hostIP = containerAddresses.host;
containerIP = containerAddresses.containers.social;
2023-09-02 18:17:03 +01:00
2023-09-18 03:56:58 +01:00
secrets = hostSecrets;
in {
services.gotosocial = {
enable = true;
setupPostgresqlDB = true;
environmentFile = secrets.social_env_secrets.path;
2023-09-02 18:17:03 +01:00
settings = {
application-name = "chaos-gts";
host = "gts-01.owo.monster";
bind-address = "0.0.0.0";
2023-09-02 18:17:03 +01:00
log-level = "info";
log-client-ip = false;
trusted-proxies = [
"127.0.0.1/32"
"::1"
hostIP
containerIP
];
port = 8080;
letsencrypt-enabled = false;
accounts-registration-open = false;
2023-09-02 18:17:03 +01:00
smtp-host = "mail.owo.monster";
smtp-port = 587;
smtp-username = "gotosocial@owo.monster";
smtp-password = ""; # set via env variables
smtp-from = "gotosocial@owo.monster";
media-remote-cache-days = 2;
media-image-max-size = 1000000 * 64; # MB
media-video-max-size = 1000000 * 1024; # MB
media-description-max-chars = 4000;
media-emoji-local-max-size = 102400;
media-emoji-remote-max-size = 102400;
statuses-cw-max-chars = 150;
statuses-poll-max-options = 10;
statuses-media-max-files = 8;
# only enable when testing out mastodon-api applications
# that use instance version for api compatibility checks
# instance-inject-mastodon-version = true;
cache = {
memory-target = "256MiB";
};
};
};
}