modules: services: add woodpecker
This commit is contained in:
parent
c857e4cd2e
commit
020a32b9e8
5 changed files with 231 additions and 0 deletions
48
modules/services/woodpecker/agent-docker/default.nix
Normal file
48
modules/services/woodpecker/agent-docker/default.nix
Normal file
|
|
@ -0,0 +1,48 @@
|
|||
{ config, lib, pkgs, ... }:
|
||||
let
|
||||
cfg = config.my.services.woodpecker;
|
||||
|
||||
hasRunner = (name: builtins.elem name cfg.runners);
|
||||
in
|
||||
{
|
||||
# TODO
|
||||
config = lib.mkIf (cfg.enable && hasRunner "docker") {
|
||||
services.woodpecker-agents = {
|
||||
agents.docker = {
|
||||
enable = true;
|
||||
|
||||
package = pkgs.ambroisie.woodpecker-agent;
|
||||
|
||||
environment = {
|
||||
WOODPECKER_SERVER = "localhost:${toString cfg.rpcPort}";
|
||||
WOODPECKER_MAX_WORKFLOWS = "10";
|
||||
WOODPECKER_BACKEND = "docker";
|
||||
WOODPECKER_FILTER_LABELS = "type=docker";
|
||||
WOODPECKER_HEALTHCHECK = "false";
|
||||
};
|
||||
|
||||
environmentFile = [ cfg.sharedSecretFile ];
|
||||
|
||||
extraGroups = [ "docker" ];
|
||||
};
|
||||
};
|
||||
|
||||
# Make sure it is activated in that case
|
||||
virtualisation.docker.enable = true;
|
||||
|
||||
# FIXME: figure out the issue
|
||||
services.unbound.resolveLocalQueries = false;
|
||||
|
||||
# Adjust runner service for nix usage
|
||||
systemd.services.woodpecker-agent-docker = {
|
||||
after = [ "docker.socket" ]; # Needs the socket to be available
|
||||
# might break deployment
|
||||
restartIfChanged = false;
|
||||
serviceConfig = {
|
||||
BindPaths = [
|
||||
"/var/run/docker.sock"
|
||||
];
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue