fix(nix): Add empty image config to allow k8s usage

Introduce an empty runtime configuration object in each built layer.

This is required because Kubernetes expects the configuration to be
present (even if it's just empty values).

Providing an empty configuration will make Docker's API return a full
configuration struct with default (i.e. empty) values rather than
`null`, which works for Kubernetes.

This fixes issue #1. See the issue for additional details.
This commit is contained in:
Vincent Ambo 2019-07-30 23:55:28 +01:00 committed by Vincent Ambo
parent 4802727408
commit 2e4b1f85ee

View file

@ -133,6 +133,8 @@ let
os = "linux"; os = "linux";
rootfs.type = "layers"; rootfs.type = "layers";
rootfs.diff_ids = map (layer: "sha256:${layer.sha256}") allLayers; rootfs.diff_ids = map (layer: "sha256:${layer.sha256}") allLayers;
# Required to let Kubernetes import Nixery images
config = {};
}; };
configJson = writeText "${baseName}-config.json" (builtins.toJSON config); configJson = writeText "${baseName}-config.json" (builtins.toJSON config);
configMetadata = with builtins; fromJSON (readFile (runCommand "config-meta" { configMetadata = with builtins; fromJSON (readFile (runCommand "config-meta" {