2016-09-18 18:57:01 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.dockerRegistry;
|
|
|
|
|
2018-06-05 09:26:02 +00:00
|
|
|
configFile = pkgs.writeText "docker-registry-config.yml" (builtins.toJSON (recursiveUpdate registryConfig cfg.extraConfig));
|
2018-04-06 13:11:52 +00:00
|
|
|
|
2016-09-18 18:57:01 +00:00
|
|
|
in {
|
|
|
|
options.services.dockerRegistry = {
|
|
|
|
enable = mkEnableOption "Docker Registry";
|
|
|
|
|
|
|
|
listenAddress = mkOption {
|
|
|
|
description = "Docker registry host or ip to bind to.";
|
|
|
|
default = "127.0.0.1";
|
|
|
|
type = types.str;
|
|
|
|
};
|
|
|
|
|
|
|
|
port = mkOption {
|
|
|
|
description = "Docker registry port to bind to.";
|
|
|
|
default = 5000;
|
|
|
|
type = types.int;
|
|
|
|
};
|
|
|
|
|
|
|
|
storagePath = mkOption {
|
|
|
|
type = types.path;
|
|
|
|
default = "/var/lib/docker-registry";
|
|
|
|
description = "Docker registry storage path.";
|
|
|
|
};
|
|
|
|
|
2018-02-04 13:15:47 +00:00
|
|
|
enableDelete = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = "Enable delete for manifests and blobs.";
|
|
|
|
};
|
|
|
|
|
2018-04-06 13:11:52 +00:00
|
|
|
enableRedisCache = mkEnableOption "redis as blob cache";
|
2018-02-04 13:15:47 +00:00
|
|
|
|
|
|
|
redisUrl = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "localhost:6379";
|
|
|
|
description = "Set redis host and port.";
|
|
|
|
};
|
|
|
|
|
|
|
|
redisPassword = mkOption {
|
|
|
|
type = types.str;
|
2018-03-26 11:54:01 +00:00
|
|
|
default = "";
|
2018-02-04 13:15:47 +00:00
|
|
|
description = "Set redis password.";
|
|
|
|
};
|
|
|
|
|
2016-09-18 18:57:01 +00:00
|
|
|
extraConfig = mkOption {
|
|
|
|
description = ''
|
|
|
|
Docker extra registry configuration via environment variables.
|
|
|
|
'';
|
|
|
|
default = {};
|
2018-06-05 09:26:02 +00:00
|
|
|
type = types.attrs;
|
2016-09-18 18:57:01 +00:00
|
|
|
};
|
2018-04-06 13:11:52 +00:00
|
|
|
|
|
|
|
enableGarbageCollect = mkEnableOption "garbage collect";
|
|
|
|
|
|
|
|
garbageCollectDates = mkOption {
|
|
|
|
default = "daily";
|
|
|
|
type = types.str;
|
|
|
|
description = ''
|
|
|
|
Specification (in the format described by
|
|
|
|
<citerefentry><refentrytitle>systemd.time</refentrytitle>
|
|
|
|
<manvolnum>7</manvolnum></citerefentry>) of the time at
|
|
|
|
which the garbage collect will occur.
|
|
|
|
'';
|
|
|
|
};
|
2016-09-18 18:57:01 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
systemd.services.docker-registry = {
|
|
|
|
description = "Docker Container Registry";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
after = [ "network.target" ];
|
2018-04-06 13:11:52 +00:00
|
|
|
script = ''
|
2018-03-26 11:54:01 +00:00
|
|
|
${pkgs.docker-distribution}/bin/registry serve ${configFile}
|
2016-09-18 18:57:01 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
serviceConfig = {
|
|
|
|
User = "docker-registry";
|
|
|
|
WorkingDirectory = cfg.storagePath;
|
2018-06-05 09:27:03 +00:00
|
|
|
AmbientCapabilities = mkIf (cfg.port < 1024) "cap_net_bind_service";
|
2016-09-18 18:57:01 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2018-04-06 13:11:52 +00:00
|
|
|
systemd.services.docker-registry-garbage-collect = {
|
|
|
|
description = "Run Garbage Collection for docker registry";
|
|
|
|
|
|
|
|
restartIfChanged = false;
|
|
|
|
unitConfig.X-StopOnRemoval = false;
|
|
|
|
|
|
|
|
serviceConfig.Type = "oneshot";
|
|
|
|
|
|
|
|
script = ''
|
|
|
|
${pkgs.docker-distribution}/bin/registry garbage-collect ${configFile}
|
|
|
|
${pkgs.systemd}/bin/systemctl restart docker-registry.service
|
|
|
|
'';
|
|
|
|
|
|
|
|
startAt = optional cfg.enableGarbageCollect cfg.garbageCollectDates;
|
|
|
|
};
|
|
|
|
|
2018-06-29 23:58:35 +00:00
|
|
|
users.users.docker-registry = {
|
2016-09-18 18:57:01 +00:00
|
|
|
createHome = true;
|
|
|
|
home = cfg.storagePath;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|