123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- #!/usr/bin/env bash
- #
- # SPDX-License-Identifier: GPL-2.0
- #
- # Copyright (c) 2013-2023 Igor Pecovnik, igor@armbian.com
- #
- # This file is a part of the Armbian Build Framework
- # https://github.com/armbian/build/
- function cli_artifact_pre_run() {
- case "${ARMBIAN_COMMAND}" in
- download-artifact)
- display_alert "download-only mode:" "won't build '${WHAT}'" "info"
- DONT_BUILD_ARTIFACTS="${WHAT}"
- ;;
- esac
- initialize_artifact "${WHAT}"
- # Run the pre run adapter
- artifact_cli_adapter_pre_run
- }
- function cli_artifact_run() {
- : "${chosen_artifact:?chosen_artifact is not set}"
- : "${chosen_artifact_impl:?chosen_artifact_impl is not set}"
- if [[ "${CONFIG_DEFS_ONLY}" != "yes" ]]; then
- # Make sure ORAS tooling is installed before starting.
- run_tool_oras
- fi
- display_alert "artifact" "${chosen_artifact}" "debug"
- display_alert "artifact" "${chosen_artifact} :: ${chosen_artifact_impl}()" "debug"
- declare -g artifact_version_requires_aggregation="no" # marker
- artifact_cli_adapter_config_prep # only if in cli.
- # if asked by _config_prep to aggregate, and HOSTRELEASE is not set, obtain it.
- if [[ "${artifact_version_requires_aggregation}" == "yes" ]] && [[ -z "${HOSTRELEASE}" ]]; then
- obtain_hostrelease_only # Sets HOSTRELEASE
- fi
- # When run in GHA, assume we're checking/updating the remote cache only.
- # Local cache is ignored, and if found, it's not unpacked, either from local or remote.
- # If remote cache is found, does nothing.
- declare default_update_remote_only="no"
- if [[ "${CI}" == "true" ]] && [[ "${GITHUB_ACTIONS}" == "true" ]]; then
- display_alert "Running in GitHub Actions, assuming we're updating remote cache only" "GHA remote-only" "info"
- default_update_remote_only="yes"
- fi
- declare skip_unpack_if_found_in_caches="${skip_unpack_if_found_in_caches:-"${default_update_remote_only}"}"
- declare ignore_local_cache="${ignore_local_cache:-"${default_update_remote_only}"}"
- declare deploy_to_remote="${deploy_to_remote:-"${default_update_remote_only}"}"
- case "${ARMBIAN_COMMAND}" in
- download-artifact)
- display_alert "Running in download-artifact mode" "download-artifact" "ext"
- skip_unpack_if_found_in_caches="no"
- ignore_local_cache="no"
- deploy_to_remote="no"
- ;;
- *)
- # @TODO: rpardini: i'm braindead. I really can't make sense of my own code!
- # If OCI_TARGET_BASE is explicitly set, ignore local, skip if found in remote, and deploy to remote after build.
- if [[ -n "${OCI_TARGET_BASE}" ]]; then
- skip_unpack_if_found_in_caches="yes"
- ignore_local_cache="yes"
- deploy_to_remote="yes"
- # Pass ARTIFACT_USE_CACHE=yes to actually use the cache versions, but don't deploy to remote.
- # @TODO this is confusing. each op should be individually controlled...
- # what we want is:
- # 1: - check remote, if not found, check local, if not found, build, then deploy to remote
- # - if remote found, do nothing.
- # - if local found, deploy it to remote (for switching targets)
- # 2: - get from remote -> get local -> build, then DON'T deploy to remote
- if [[ "${ARTIFACT_USE_CACHE}" == "yes" ]]; then
- skip_unpack_if_found_in_caches="no"
- ignore_local_cache="no"
- deploy_to_remote="no"
- fi
- fi
- ;;
- esac
- # Force artifacts download we need to populate repository
- if [[ "${FORCE_ARTIFACTS_DOWNLOAD}" == "yes" ]]; then
- skip_unpack_if_found_in_caches="no"
- fi
- # display a summary of the 3 vars above: skip_unpack_if_found_in_caches, ignore_local_cache, deploy_to_remote
- display_alert "CLI Artifact summary" "skip_unpack_if_found_in_caches=${skip_unpack_if_found_in_caches}, ignore_local_cache=${ignore_local_cache}, deploy_to_remote=${deploy_to_remote}" "info"
- if [[ "${ARTIFACT_BUILD_INTERACTIVE}" == "yes" ]]; then # Set by `kernel-config`, `kernel-patch`, `uboot-config`, `uboot-patch`, etc.
- display_alert "Running artifact build in interactive mode" "log file will be incomplete" "info"
- do_with_default_build obtain_complete_artifact
- else
- do_with_default_build obtain_complete_artifact < /dev/null
- fi
- }
|