Merge pull request #115791 from lbpdt/feature/docker-tools-nix-store-dir

dockerTools.buildLayeredImage: configurable store root
This commit is contained in:
Benjamin Hipple 2021-03-11 14:56:39 -05:00 committed by GitHub
commit f707104092
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 5 deletions

View File

@ -841,12 +841,14 @@ rec {
cat ${baseJson} | jq ' cat ${baseJson} | jq '
. + { . + {
"store_dir": $store_dir,
"store_layers": $store_layers, "store_layers": $store_layers,
"customisation_layer", $customisation_layer, "customisation_layer", $customisation_layer,
"repo_tag": $repo_tag, "repo_tag": $repo_tag,
"created": $created "created": $created
} }
' --argjson store_layers "$store_layers" \ ' --arg store_dir "${storeDir}" \
--argjson store_layers "$store_layers" \
--arg customisation_layer ${customisationLayer} \ --arg customisation_layer ${customisationLayer} \
--arg repo_tag "$imageName:$imageTag" \ --arg repo_tag "$imageName:$imageTag" \
--arg created "$created" | --arg created "$created" |

View File

@ -130,12 +130,13 @@ class ExtractChecksum:
LayerInfo = namedtuple("LayerInfo", ["size", "checksum", "path", "paths"]) LayerInfo = namedtuple("LayerInfo", ["size", "checksum", "path", "paths"])
def add_layer_dir(tar, paths, mtime): def add_layer_dir(tar, paths, store_dir, mtime):
""" """
Appends given store paths to a TarFile object as a new layer. Appends given store paths to a TarFile object as a new layer.
tar: 'tarfile.TarFile' object for the new layer to be added to. tar: 'tarfile.TarFile' object for the new layer to be added to.
paths: List of store paths. paths: List of store paths.
store_dir: the root directory of the nix store
mtime: 'mtime' of the added files and the layer tarball. mtime: 'mtime' of the added files and the layer tarball.
Should be an integer representing a POSIX time. Should be an integer representing a POSIX time.
@ -143,9 +144,9 @@ def add_layer_dir(tar, paths, mtime):
the layer added. the layer added.
""" """
invalid_paths = [i for i in paths if not i.startswith("/nix/store/")] invalid_paths = [i for i in paths if not i.startswith(store_dir)]
assert len(invalid_paths) == 0, \ assert len(invalid_paths) == 0, \
"Expecting absolute store paths, but got: {invalid_paths}" f"Expecting absolute paths from {store_dir}, but got: {invalid_paths}"
# First, calculate the tarball checksum and the size. # First, calculate the tarball checksum and the size.
extract_checksum = ExtractChecksum() extract_checksum = ExtractChecksum()
@ -245,6 +246,7 @@ def main():
else datetime.fromisoformat(conf["created"]) else datetime.fromisoformat(conf["created"])
) )
mtime = int(created.timestamp()) mtime = int(created.timestamp())
store_dir = conf["store_dir"]
with tarfile.open(mode="w|", fileobj=sys.stdout.buffer) as tar: with tarfile.open(mode="w|", fileobj=sys.stdout.buffer) as tar:
layers = [] layers = []
@ -253,7 +255,7 @@ def main():
"Creating layer", num, "Creating layer", num,
"from paths:", store_layer, "from paths:", store_layer,
file=sys.stderr) file=sys.stderr)
info = add_layer_dir(tar, store_layer, mtime=mtime) info = add_layer_dir(tar, store_layer, store_dir, mtime=mtime)
layers.append(info) layers.append(info)
print("Creating the customisation layer...", file=sys.stderr) print("Creating the customisation layer...", file=sys.stderr)