1
0
Fork 0
NixOS/hosts/greatyamada/services/forgejo.nix
2025-06-21 19:49:46 +00:00

62 lines
1.7 KiB
Nix

{ pkgs, lib, ... }:
let
portDefinitions = import ./_port-definitions.nix;
arrayToSecrets = elements:
builtins.listToAttrs (map (key: {
name = "forgejo/${key}";
value.owner = "forgejo";
}) elements);
in {
services = {
forgejo = {
enable = true;
package = pkgs.forgejo;
database = {
type = "postgres";
port = portDefinitions.postgresql;
passwordFile = "/run/secrets/forgejo/database_password";
};
secrets = {
server.LFS_JWT_SECRET =
lib.mkForce "/run/secrets/forgejo/lfs_jwt_secret";
security = {
INTERNAL_TOKEN = lib.mkForce "/run/secrets/forgejo/internal_token";
SECRET_KEY = lib.mkForce "/run/secrets/forgejo/secret_key";
};
oauth2.JWT_SECRET =
lib.mkForce "/run/secrets/forgejo/oauth2_jwt_secret";
};
settings = {
server = {
DOMAIN = "git.rcia.dev";
ROOT_URL = "https://git.rcia.dev";
HTTP_PORT = portDefinitions.forgejo-http;
DISABLE_SSH = true;
LFS_START_SERVER = true;
};
service = {
DISABLE_REGISTRATION = true;
REGISTER_MANUAL_CONFIRM = true;
};
security = { INSTALL_LOCK = true; };
};
};
nginx.virtualHosts."git.rcia.dev" = {
locations."/" = {
proxyPass = "http://127.0.0.1:${toString portDefinitions.forgejo-http}";
};
forceSSL = true;
useACMEHost = "rcia.dev";
};
};
# systemd.services.forgejo.preStart = ''
# ${pkgs.forgejo}/bin/gitea migrate
# '';
sops.secrets = arrayToSecrets [
"database_password"
"internal_token"
"lfs_jwt_secret"
"oauth2_jwt_secret"
"secret_key"
];
}