Skip to content
This repository has been archived by the owner on Oct 10, 2020. It is now read-only.

Commit

Permalink
syscontainers: allow to specify the copied file name
Browse files Browse the repository at this point in the history
allow to rename a copied file to host using the variable substitution.

In the manifest.json file it is permitted to specify the destination
file name of a file copied to the host as:

    "renameFiles" : {
        "/usr/local/bin/hello-template.sh" : "/usr/local/bin/hello-template-$NAME.sh"
    },

Signed-off-by: Giuseppe Scrivano <[email protected]>
  • Loading branch information
giuseppe committed Nov 28, 2016
1 parent 03948b2 commit 198f4f5
Showing 1 changed file with 27 additions and 4 deletions.
31 changes: 27 additions & 4 deletions Atomic/syscontainers.py
Original file line number Diff line number Diff line change
Expand Up @@ -430,6 +430,7 @@ def _do_checkout(self, repo, name, img, upgrade, values, destination, unitfileou
manifest_file = os.path.join(exports, "manifest.json")
installed_files_template = []
has_container_service = True
rename_files = {}
if os.path.exists(manifest_file):
with open(manifest_file, "r") as f:
try:
Expand All @@ -442,6 +443,8 @@ def _do_checkout(self, repo, name, img, upgrade, values, destination, unitfileou
values[key] = val
if "installedFilesTemplate" in manifest:
installed_files_template = manifest["installedFilesTemplate"]
if "renameFiles" in manifest:
rename_files = manifest["renameFiles"]
if "noContainerService" in manifest and manifest["noContainerService"]:
has_container_service = False

Expand Down Expand Up @@ -490,7 +493,17 @@ def _do_checkout(self, repo, name, img, upgrade, values, destination, unitfileou
except subprocess.CalledProcessError:
pass

new_installed_files = self._rm_add_files_to_host(installed_files, exports, prefix or "/", files_template=installed_files_template, values=values)
# rename_files may contain variables that need to be replaced.
if rename_files:
for k, v in rename_files.items():
template = Template(v)
new_v = template.safe_substitute(values)
missing = {"".join(x) for x in template.pattern.findall(v) if "".join(x) not in values} # pylint: disable=no-member
if len(missing):
raise ValueError("manifest.json contains unreplaced values for: %s" % ", ".join(missing))
rename_files[k] = new_v

new_installed_files = self._rm_add_files_to_host(installed_files, exports, prefix or "/", files_template=installed_files_template, values=values, rename_files=rename_files)

missing_bind_paths = self._check_oci_configuration_file(destination_path, remote_path, True)

Expand All @@ -510,7 +523,8 @@ def _do_checkout(self, repo, name, img, upgrade, values, destination, unitfileou
"values" : values,
"has-container-service" : has_container_service,
"installed-files": new_installed_files,
"installed-files-template": installedFilesTemplate,
"installed-files-template": installed_files_template,
"rename-installed-files" : rename_files,
"remote" : remote}
info_file.write(json.dumps(info, indent=4))
info_file.write("\n")
Expand Down Expand Up @@ -614,7 +628,7 @@ def version(self, image):
return None

@staticmethod
def _rm_add_files_to_host(old_installed_files, exports, prefix="/", files_template=None, values=None):
def _rm_add_files_to_host(old_installed_files, exports, prefix="/", files_template=None, values=None, rename_files=None):
# if any file was installed on the host delete it
if old_installed_files:
for i in old_installed_files:
Expand All @@ -640,6 +654,12 @@ def _rm_add_files_to_host(old_installed_files, exports, prefix="/", files_templa
src_file = os.path.join(root, f)
dest_path = os.path.join(prefix, rel_root_path, f)
rel_dest_path = os.path.join("/", rel_root_path, f)

# If rename_files is set, rename the destination file
if rename_files and rel_dest_path in rename_files:
rel_dest_path = rename_files.get(rel_dest_path)
dest_path = os.path.join(prefix or "/", os.path.relpath(rel_dest_path, "/"))

if os.path.exists(dest_path):
for i in new_installed_files:
os.remove(new_installed_files)
Expand All @@ -652,6 +672,7 @@ def _rm_add_files_to_host(old_installed_files, exports, prefix="/", files_templa
shutil.copystat(src_file, dest_path)
else:
shutil.copy2(src_file, dest_path)

new_installed_files.append(rel_dest_path)
new_installed_files.sort() # just for an aesthetic reason in the info file output

Expand Down Expand Up @@ -710,11 +731,13 @@ def rollback(self, name):
raise ValueError("Error: Cannot find a previous deployment to rollback located at %s" % destination)

installed_files = None
rename_files = None
with open(os.path.join(self._get_system_checkout_path(), name, "info"), "r") as info_file:
info = json.loads(info_file.read())
installed_files = info["installed-files"] if "installed-files" in info else None
installed_files_template = info["installed-files-template"] if "installed-files-template" in info else None
has_container_service = info["has-container-service"] if "has-container-service" in info else True
rename_files = info["rename-installed-files"] if "rename-installed-files" in info else None

was_service_active = has_container_service and self._is_service_active(name)
unitfileout, tmpfilesout = self._get_systemd_destination_files(name)
Expand Down Expand Up @@ -744,7 +767,7 @@ def rollback(self, name):
if (os.path.exists(tmpfiles)):
shutil.copyfile(tmpfiles, tmpfilesout)

self._rm_add_files_to_host(installed_files, os.path.join(destination, "rootfs/exports"), files_template=installed_files_template)
self._rm_add_files_to_host(installed_files, os.path.join(destination, "rootfs/exports"), files_template=installed_files_template, rename_files=rename_files)

os.unlink(path)
os.symlink(destination, path)
Expand Down

0 comments on commit 198f4f5

Please sign in to comment.