cache-apt-pkgs-action/install_and_cache_pkgs.sh

97 lines
3 KiB
Bash
Raw Normal View History

2021-10-13 21:11:27 -07:00
#!/bin/bash
2021-10-16 21:17:55 -07:00
# Fail on any error.
set -e
# Include library.
script_dir="$(dirname -- "$(realpath -- "${0}")")"
2022-03-26 12:48:16 -07:00
source "${script_dir}/lib.sh"
2021-10-13 21:11:27 -07:00
# Directory that holds the cached packages.
2022-07-19 20:42:48 -07:00
cache_dir="${1}"
2021-10-13 21:11:27 -07:00
# List of the packages to use.
input_packages="${@:2}"
# Trim commas, excess spaces, and sort.
2022-07-19 20:42:48 -07:00
normalized_packages="$(normalize_package_list "${input_packages}")"
2021-10-13 21:11:27 -07:00
2022-07-19 20:42:48 -07:00
package_count=$(wc -w <<< "${normalized_packages}")
log "Clean installing and caching ${package_count} package(s)."
log_empty_line
manifest_main=""
2022-07-19 20:42:48 -07:00
log "Package list:"
for package in ${normalized_packages}; do
read package_name package_ver < <(get_package_name_ver "${package}")
manifest_main="${manifest_main}${package_name}:${package_ver},"
log "- ${package_name}:${package_ver}"
2021-10-16 21:45:24 -07:00
done
write_manifest "main" "${manifest_main}" "${cache_dir}/manifest_main.log"
2021-10-16 21:45:24 -07:00
log_empty_line
log "Installing apt-fast for optimized installs..."
# Install apt-fast for optimized installs.
/bin/bash -c "$(curl -sL https://git.io/vokNn)"
log "done"
log_empty_line
2022-07-19 20:42:48 -07:00
log "Updating APT package list..."
sudo apt-fast update > /dev/null
log "done"
log_empty_line
2021-10-21 12:41:47 -07:00
2022-07-19 20:42:48 -07:00
# Strictly contains the requested packages.
manifest_main=""
# Contains all packages including dependencies.
manifest_all=""
install_log_filepath="${cache_dir}/install.log"
2022-07-19 20:42:48 -07:00
log "Clean installing ${package_count} packages..."
# Zero interaction while installing or upgrading the system via apt.
sudo DEBIAN_FRONTEND=noninteractive apt-fast --yes install ${normalized_packages} > "${install_log_filepath}"
log "done"
log "Installation log written to ${install_log_filepath}"
log_empty_line
installed_packages=$(get_installed_packages "${install_log_filepath}")
log "Installed package list:"
for installed_package in ${installed_packages}; do
log "- ${installed_package}"
done
log_empty_line
installed_package_count=$(wc -w <<< "${installed_packages}")
log "Caching ${installed_package_count} installed packages..."
for installed_package in ${installed_packages}; do
cache_filepath="${cache_dir}/${installed_package}.tar.gz"
# Sanity test in case APT enumerates duplicates.
if test ! -f "${cache_filepath}"; then
read installed_package_name installed_package_ver < <(get_package_name_ver "${installed_package}")
log " * Caching ${installed_package_name} to ${cache_filepath}..."
# Pipe all package files (no folders) to Tar.
dpkg -L "${installed_package_name}" |
while IFS= read -r f; do
if test -f $f || test -L $f; then echo "${f:1}"; fi; #${f:1} removes the leading slash that Tar disallows
done |
xargs tar -czf "${cache_filepath}" -C /
log " done (compressed size $(du -h "${cache_filepath}" | cut -f1))."
fi
# Comma delimited name:ver pairs in the all packages manifest.
manifest_all="${manifest_all}${installed_package_name}:${installed_package_ver},"
done
log "done (total cache size $(du -h ${cache_dir} | tail -1 | awk '{print $1}'))"
log_empty_line
2021-10-13 21:11:27 -07:00
2022-07-19 20:42:48 -07:00
write_manifest "all" "${manifest_all}" "${cache_dir}/manifest_all.log"