2021-10-14 04:11:27 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2021-10-17 04:17:55 +00:00
|
|
|
# Fail on any error.
|
|
|
|
set -e
|
|
|
|
|
2022-07-20 03:42:48 +00:00
|
|
|
# Include library.
|
|
|
|
script_dir="$(dirname -- "$(realpath -- "${0}")")"
|
|
|
|
source "${script_dir}/lib.sh"
|
|
|
|
|
2021-10-14 04:11:27 +00:00
|
|
|
# Directory that holds the cached packages.
|
2022-07-20 03:42:48 +00:00
|
|
|
cache_dir="${1}"
|
2021-10-22 03:57:52 +00:00
|
|
|
|
2021-10-14 04:11:27 +00:00
|
|
|
# Root directory to untar the cached packages to.
|
|
|
|
# Typically filesystem root '/' but can be changed for testing.
|
2022-07-20 03:42:48 +00:00
|
|
|
cache_restore_root="${2}"
|
2021-10-22 03:57:52 +00:00
|
|
|
|
2022-07-20 03:42:48 +00:00
|
|
|
cache_filepaths="$(ls -1 "${cache_dir}" | sort)"
|
|
|
|
log "Found $(echo ${cache_filepaths} | wc -w) files in the cache."
|
|
|
|
for cache_filepath in ${cache_filepaths}; do
|
|
|
|
log "- "$(basename ${cache_filepath})""
|
2021-10-22 05:15:05 +00:00
|
|
|
done
|
|
|
|
|
2022-07-24 00:06:17 +00:00
|
|
|
log_empty_line
|
|
|
|
|
2022-07-20 03:42:48 +00:00
|
|
|
log "Reading from main requested packages manifest..."
|
|
|
|
for logline in $(cat "${cache_dir}/manifest_main.log" | tr ',' '\n' ); do
|
|
|
|
log "- $(echo "${logline}" | tr ':' ' ')"
|
2021-10-22 05:42:51 +00:00
|
|
|
done
|
2022-07-24 00:06:17 +00:00
|
|
|
log "done"
|
|
|
|
|
|
|
|
log_empty_line
|
2021-10-22 05:42:51 +00:00
|
|
|
|
2021-10-22 04:45:37 +00:00
|
|
|
# Only search for archived results. Manifest and cache key also live here.
|
2022-07-24 00:06:17 +00:00
|
|
|
cached_pkg_filepaths=$(ls -1 "${cache_dir}"/*.tar.gz | sort)
|
|
|
|
cached_pkg_filecount=$(echo ${cached_pkg_filepaths} | wc -w)
|
|
|
|
log "Restoring ${cached_pkg_filecount} packages from cache..."
|
|
|
|
for cached_pkg_filepath in ${cached_pkg_filepaths}; do
|
|
|
|
log "- $(basename "${cached_pkg_filepath}") restoring..."
|
|
|
|
sudo tar -xf "${cached_pkg_filepath}" -C "${cache_restore_root}" > /dev/null
|
|
|
|
log " done"
|
2021-10-16 18:34:14 +00:00
|
|
|
done
|
2022-07-24 00:06:17 +00:00
|
|
|
log "done"
|