diff options
author | Jaka Hudoklin <jakahudoklin@gmail.com> | 2014-11-21 17:20:14 +0100 |
---|---|---|
committer | Jaka Hudoklin <jakahudoklin@gmail.com> | 2014-11-22 12:16:41 +0100 |
commit | 73dc767aa0a1d4bf098fccd3a8f00024ab672912 (patch) | |
tree | d1c53a2f4a7242a965a57610246d82810b938b0d /nixos/modules/services/misc/docker-registry.nix | |
parent | 444bda19362e6b3d725b91dbcd2f2963f3fc23e8 (diff) | |
download | nixlib-73dc767aa0a1d4bf098fccd3a8f00024ab672912.tar nixlib-73dc767aa0a1d4bf098fccd3a8f00024ab672912.tar.gz nixlib-73dc767aa0a1d4bf098fccd3a8f00024ab672912.tar.bz2 nixlib-73dc767aa0a1d4bf098fccd3a8f00024ab672912.tar.lz nixlib-73dc767aa0a1d4bf098fccd3a8f00024ab672912.tar.xz nixlib-73dc767aa0a1d4bf098fccd3a8f00024ab672912.tar.zst nixlib-73dc767aa0a1d4bf098fccd3a8f00024ab672912.zip |
nixos: add docker-registry module
Diffstat (limited to 'nixos/modules/services/misc/docker-registry.nix')
-rw-r--r-- | nixos/modules/services/misc/docker-registry.nix | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/nixos/modules/services/misc/docker-registry.nix b/nixos/modules/services/misc/docker-registry.nix new file mode 100644 index 000000000000..67580a1c6277 --- /dev/null +++ b/nixos/modules/services/misc/docker-registry.nix @@ -0,0 +1,82 @@ +{ config, lib, pkgs, ... }: + +with lib; + +let + cfg = config.services.dockerRegistry; + +in { + ###### interface + + options.services.dockerRegistry = { + enable = mkOption { + description = "Whether to enable docker registry server."; + default = false; + type = types.bool; + }; + + host = 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 strorage path."; + }; + + extraConfig = mkOption { + description = '' + Docker extra registry configuration. See + <link xlink:href="https://github.com/docker/docker-registry/blob/master/config/config_sample.yml"/> + ''; + default = {}; + type = types.attrsOf types.str; + }; + }; + + config = mkIf cfg.enable { + systemd.services.docker-registry = { + description = "Docker Container Registry"; + wantedBy = [ "multi-user.target" ]; + after = [ "network.target" ]; + + environment = { + REGISTRY_HOST = cfg.host; + REGISTRY_PORT = toString cfg.port; + GUNICORN_OPTS = "[--preload]"; # see https://github.com/docker/docker-registry#sqlalchemy + STORAGE_PATH = cfg.storagePath; + } // cfg.extraConfig; + + serviceConfig = { + ExecStart = "${pkgs.pythonPackages.docker_registry}/bin/docker-registry"; + User = "docker-registry"; + Group = "docker"; + PermissionsStartOnly = true; + }; + + preStart = '' + mkdir -p ${cfg.storagePath} + if [ "$(id -u)" = 0 ]; then + chown -R docker-registry:docker ${cfg.storagePath} + fi + ''; + postStart = '' + until ${pkgs.curl}/bin/curl -s -o /dev/null 'http://${cfg.host}:${toString cfg.port}/'; do + sleep 1; + done + ''; + }; + + users.extraGroups.docker.gid = mkDefault config.ids.gids.docker; + users.extraUsers.docker-registry.uid = config.ids.uids.docker-registry; + }; +} |