#!/busybox/sh set -euo pipefail concatenate_strings() { _STR1=${1} _STR2=${2} if [ -n "${_STR1}" ]; then _STR1="${_STR1} ${_STR2}" else _STR1="${_STR2}" fi echo ${_STR1} } export PATH="$PATH:/kaniko/" REGISTRY=${PLUGIN_REGISTRY:-https://index.docker.io/v1/} if [ -f "${PWD}/${PLUGIN_ENV_FILE:-}" ]; then export $(cat "${PWD}/${PLUGIN_ENV_FILE}" | xargs) fi if [ "${PLUGIN_USERNAME:-}" ] || [ "${PLUGIN_PASSWORD:-}" ]; then DOCKER_AUTH=$(echo -n "${PLUGIN_USERNAME}:${PLUGIN_PASSWORD}" | base64 | tr -d "\n") cat > /kaniko/.docker/config.json < /kaniko/gcr.json export GOOGLE_APPLICATION_CREDENTIALS=/kaniko/gcr.json fi DOCKERFILE=${PLUGIN_DOCKERFILE:-Dockerfile} CONTEXT=${PLUGIN_CONTEXT:-$PWD} LOG=${PLUGIN_LOG_LEVEL:-info} EXTRA_OPTS="" if [[ -n "${PLUGIN_TARGET:-}" ]]; then TARGET="--target=${PLUGIN_TARGET}" fi if [[ "${PLUGIN_SKIP_TLS_VERIFY:-}" == "true" ]]; then EXTRA_OPTS=$(concatenate_strings "${EXTRA_OPTS}" "--skip-tls-verify=true") fi if [[ "${PLUGIN_CACHE:-}" == "true" ]]; then CACHE="--cache=true" fi if [ -n "${PLUGIN_CACHE_REPO:-}" ]; then CACHE_REPO="--cache-repo=${REGISTRY}/${PLUGIN_CACHE_REPO}" fi if [ -n "${PLUGIN_CACHE_TTL:-}" ]; then CACHE_TTL="--cache-ttl=${PLUGIN_CACHE_TTL}" fi if [ -n "${PLUGIN_BUILD_ARGS:-}" ]; then BUILD_ARGS=$(echo "${PLUGIN_BUILD_ARGS}" | tr ',' '\n' | while read build_arg; do echo "--build-arg=${build_arg}"; done) fi BUILD_ARGS_FROM_ENV="" if [ -n "${PLUGIN_BUILD_ARGS_FROM_ENV:-}" ]; then for build_arg in $(echo "${PLUGIN_BUILD_ARGS_FROM_ENV}" | sed -e 's/,\s*/ /g'); do BUILD_ARGS_FROM_ENV=$(concatenate_strings "${BUILD_ARGS_FROM_ENV}" "--build-arg ${build_arg}=$(eval "echo \$$build_arg")") done fi # auto_tag, if set auto_tag: true, auto generate .tags file # support format Major.Minor.Release or start with `v` # docker tags: Major, Major.Minor, Major.Minor.Release and latest if [[ "${PLUGIN_AUTO_TAG:-}" == "true" ]]; then TAG=$(echo "${CI_COMMIT_TAG:-}" |sed 's/^v//g') part=$(echo "${TAG}" |tr '.' '\n' |wc -l) # expect number echo "${TAG}" |grep -E "[a-z-]" &>/dev/null && isNum=1 || isNum=0 if [ -z "${TAG:-}" ]; then echo "latest" > .tags elif [ "${isNum}" -eq 1 ] || [ "${part}" -gt 3 ]; then echo "${TAG},latest" > .tags else major=$(echo "${TAG}" |awk -F'.' '{print $1}') minor=$(echo "${TAG}" |awk -F'.' '{print $2}') release=$(echo "${TAG}" |awk -F'.' '{print $3}') major=${major:-0} minor=${minor:-0} release=${release:-0} echo "${major},${major}.${minor},${major}.${minor}.${release},latest" > .tags fi fi if [ -n "${PLUGIN_MIRRORS:-}" ]; then MIRROR="$(echo "${PLUGIN_MIRRORS}" | tr ',' '\n' | while read mirror; do echo "--registry-mirror=${mirror}"; done)" fi DESTINATIONS="" if [ -n "${PLUGIN_TAGS:-}" ]; then DESTINATIONS=$(echo "${PLUGIN_TAGS}" | tr ',' '\n' | while read tag; do echo "--destination=${REGISTRY}/${PLUGIN_REPO}:${tag} "; done) elif [ -f .tags ]; then for tag in $(sed -e 's/,\s*/ /g' .tags); do DESTINATIONS=$(concatenate_strings "${DESTINATIONS}" "--destination=${REGISTRY}/${PLUGIN_REPO}:${tag}") done elif [ -n "${PLUGIN_REPO:-}" ] && [ "${PLUGIN_DRY_RUN:-}" != "true" ]; then DESTINATIONS="--destination=${REGISTRY}/${PLUGIN_REPO}:latest" else DESTINATIONS="--no-push" # Cache is not valid with --no-push CACHE="" fi if [[ "${PLUGIN_IGNORE_VAR_RUN:-}" == "false" ]]; then EXTRA_OPTS=$(concatenate_strings "${EXTRA_OPTS}" "--ignore-var-run=false") fi /kaniko/executor -v "${LOG}" \ --context="${CONTEXT}" \ --dockerfile="${DOCKERFILE}" \ ${EXTRA_OPTS} \ ${DESTINATIONS} \ "${CACHE:-}" \ "${CACHE_TTL:-}" \ "${CACHE_REPO:-}" \ "${TARGET:-}" \ ${BUILD_ARGS:-} \ ${BUILD_ARGS_FROM_ENV:-} \ "${MIRROR:-}"