{ pkgs, ... }: let misskeyDomain = "social.owo.monster"; misskeyPort = 3020; redisPort = 3019; # USE NPX YARN misskeyBuildDeps = with pkgs; [ gccStdenv nodePackages.node-gyp-build python3 pkg-config vips nodePackages.npm ]; misskeyPackages = with pkgs; [ git jq nodejs nodePackages.npm ffmpeg ] ++ misskeyBuildDeps; in { users.users."misskey" = { isNormalUser = true; createHome = true; }; home-manager.users."misskey".home.packages = misskeyPackages; # make .config/default.yml a symlink to /etc/misskey.yml environment.etc."misskey.yml".text = pkgs.lib.generators.toYAML {} { url = "https://${misskeyDomain}/"; port = misskeyPort; db = { host = "localhost"; port = "5432"; db = "misskey"; user = "misskey"; pass = "a"; }; redis = { host = "127.0.0.1"; port = redisPort; }; }; services.nginx.virtualHosts."${misskeyDomain}" = { forceSSL = true; enableACME = true; locations = { "/" = { proxyPass = "http://127.0.0.1:${toString misskeyPort}"; proxyWebsockets = true; }; }; }; services.postgresql = { enable = true; ensureUsers = [{ name = "misskey"; ensurePermissions."DATABASE misskey" = "ALL PRIVILEGES"; }]; ensureDatabases = [ "misskey" ]; }; services.redis.servers."misskey" = { enable = true; port = redisPort; }; }