diff options
Diffstat (limited to '')
-rw-r--r-- | flora/services/akkoma.nix (renamed from flora/services/pleroma.nix) | 70 |
1 files changed, 39 insertions, 31 deletions
diff --git a/flora/services/pleroma.nix b/flora/services/akkoma.nix index dd75b43..244351f 100644 --- a/flora/services/pleroma.nix +++ b/flora/services/akkoma.nix @@ -3,6 +3,7 @@ let unstable = import inputs.nixpkgs-unstable { inherit system; }; + staticDir = "/var/lib/akkoma/static"; in { @@ -30,11 +31,6 @@ in services.akkoma = { enable = true; - # this is barely necessary at this point — all that's - # set in here is the default_signer for joken, and the - # secret_key_base and signing_salt for phoenix. - # secretConfigFile = "/var/lib/pleroma/secrets.exs"; - package = unstable.akkoma; frontends = { primary = { @@ -52,7 +48,7 @@ in config = { ":pleroma"."Pleroma.Web.Endpoint" = { "url" = { host = "pleroma.stuebinm.eu"; scheme = "https"; port = 443; }; - "http" = {ip = "0.0.0.0"; port = 4000; }; + "http" = { ip = "::"; port = 4000; }; secret_key_base._secret = "/secret/secret_key_base"; signing_salt._secret = "/secret/signing_salt"; }; @@ -80,7 +76,7 @@ in "Pleroma.Upload.Filter.Dedupe" ]; }; - "Pleroma.Uploaders.Local".uploads = "/var/lib/pleroma/uploads"; + "Pleroma.Uploaders.Local".uploads = "/var/lib/akkoma/uploads"; "Pleroma.Repo" = { adapter = "Ecto.Adapters.Postgres"; username = "pleroma"; @@ -93,14 +89,40 @@ in }; ":database".run_enabled = false; ":configurable_from_database" = false; - # ":instance".static_dir = "/var/lib/pleroma/static"; - + ":instance".static_dir = "/var/lib/akkoma/static"; }; }; }; - # otherwise, the exiftool will fail to run - systemd.services.akkoma.path = [ pkgs.exiftool ]; + systemd.services.akkoma = { + path = [ pkgs.exiftool ]; + bindsTo = [ "akkoma-static.service" ]; + after = [ "akkoma-static.service" ]; + }; + + # symlink the parts of the static dir that are inside the nix store, + # so I can still have imperatively defined emojis etc. + # (for some reason the module doesn't do that) + systemd.services.akkoma-static = { + description = "Akkoma static dir wrangling"; + unitConfig.PropagatesReloadTo = [ "akkoma.service" ]; + path = [ pkgs.coreutils ]; + serviceConfig = { + Type = "oneshot"; + RemainAfterExit = true; + }; + script = with pkgs.lib; '' + ${concatStringsSep "\n" (mapAttrsToList (key: val: '' + mkdir -p ${staticDir}/frontends/${escapeShellArg val.name}/ + ln -sfT ${escapeShellArg val.package} ${staticDir}/frontends/${escapeShellArg val.name}/${escapeShellArg val.ref} + '') config.services.akkoma.frontends)} + ${optionalString (config.services.akkoma.extraStatic != null) + (concatStringsSep "\n" (mapAttrsToList (key: val: '' + mkdir -p "${staticDir}/$(dirname ${escapeShellArg key})" + ln -sfT ${escapeShellArg val} ${staticDir}/${escapeShellArg key} + '') config.services.akkoma.extraStatic))} + ''; + }; services.postgresql = { enable = true; @@ -119,14 +141,8 @@ in host pleroma akkoma ::1/128 trust ''; - # pleroma wants to do some initial config on startup, which it - # can't do by itself since those needs superuser access - # - # unfortunatly, this is executed /before/ the database is created, - # i.e. we have to create user and database by hand, even though - # they would otherwise created by ensureUsers / ensureDatabse. - # Using those does still prevent us from accidentally deleting - # them, though (but not from deleting the database's content!) + # this is basically legacy. even if I ever reset the database, + # the initDb option of the akkoma module probably does about this. initialScript = pkgs.writeScript "postgres-pleroma-initial" '' CREATE USER pleroma; CREATE DATABASE pleroma OWNER pleroma; @@ -138,16 +154,10 @@ in ''; }; - networking.firewall.allowedTCPPorts = [ 4000 10022 ]; + networking.firewall.allowedTCPPorts = [ 4000 ]; - services.coredns = { - enable = true; - config = '' - .:53 { - forward . 1.1.1.1 - } - ''; - }; + environment.etc."resolv.conf".text = + "nameserver 1.1.1.1"; }; }; @@ -158,16 +168,14 @@ in enable = true; internalInterfaces = [ "ve-pleroma" ]; externalInterface = "ens3"; - }; - networking.firewall.allowedTCPPorts = [ 10022 ]; services.nginx.virtualHosts."pleroma.stuebinm.eu" = { forceSSL = true; enableACME = true; locations."/" = { - proxyPass = "http://${config.containers.pleroma.localAddress}:4000"; + proxyPass = "http://[${config.containers.pleroma.localAddress6}]:4000"; proxyWebsockets = true; # these headers are in the example config in the NixOS manual. # take some time to figure out what they all do, and if these |