nix-config/modules/nixos/services/woodpecker/server/default.nix

68 lines
1.6 KiB
Nix
Raw Normal View History

{ config, lib, ... }:
2023-03-18 12:51:12 +01:00
let
cfg = config.my.services.woodpecker;
in
{
config = lib.mkIf cfg.enable {
services.woodpecker-server = {
enable = true;
environment = {
WOODPECKER_OPEN = "true";
WOODPECKER_HOST = "https://woodpecker.${config.networking.domain}";
WOODPECKER_DATABASE_DRIVER = "postgres";
WOODPECKER_DATABASE_DATASOURCE = "postgres:///woodpecker?host=/run/postgresql";
WOODPECKER_ADMIN = cfg.admin;
2023-03-18 12:51:12 +01:00
WOODPECKER_SERVER_ADDR = ":${toString cfg.port}";
WOODPECKER_GRPC_ADDR = ":${toString cfg.rpcPort}";
WOODPECKER_GITEA = "true";
WOODPECKER_GITEA_URL = config.services.${cfg.forge}.settings.server.ROOT_URL;
2023-03-18 12:51:12 +01:00
WOODPECKER_LOG_LEVEL = "debug";
};
};
systemd.services.woodpecker-server = {
after = [ "postgresql.service" ];
requires = [ "postgresql.service" ];
2023-03-18 12:51:12 +01:00
serviceConfig = {
# Set username for DB access
User = "woodpecker";
BindPaths = [
# Allow access to DB path
"/run/postgresql"
];
EnvironmentFile = [
cfg.secretFile
cfg.sharedSecretFile
];
};
};
services.postgresql = {
enable = true;
ensureDatabases = [ "woodpecker" ];
ensureUsers = [{
name = "woodpecker";
ensureDBOwnership = true;
2023-03-18 12:51:12 +01:00
}];
};
my.services.nginx.virtualHosts = {
woodpecker = {
2023-03-18 12:51:12 +01:00
inherit (cfg) port;
};
2023-03-18 12:51:12 +01:00
# I might want to be able to RPC from other hosts in the future
woodpecker-rpc = {
2023-03-18 12:51:12 +01:00
port = cfg.rpcPort;
};
};
# FIXME: persistence
2023-03-18 12:51:12 +01:00
};
}