Switch to tab indentation
ci/woodpecker/push/build_and_release Pipeline was successful Details

This commit is contained in:
Kevin Dorner 2022-09-09 14:44:02 +02:00
parent 0df83c3d31
commit 450d13dce9
1 changed files with 57 additions and 51 deletions

104
plugin.sh
View File

@ -7,22 +7,22 @@ export PATH=$PATH:/kaniko/
REGISTRY=${PLUGIN_REGISTRY:-docker.io} REGISTRY=${PLUGIN_REGISTRY:-docker.io}
if [ "${PLUGIN_USERNAME:-}" ] || [ "${PLUGIN_PASSWORD:-}" ]; then if [ "${PLUGIN_USERNAME:-}" ] || [ "${PLUGIN_PASSWORD:-}" ]; then
REGISTRY_AUTH=`echo -n "${PLUGIN_USERNAME}:${PLUGIN_PASSWORD}" | base64 | tr -d "\n"` REGISTRY_AUTH=`echo -n "${PLUGIN_USERNAME}:${PLUGIN_PASSWORD}" | base64 | tr -d "\n"`
cat > /kaniko/.docker/config.json <<EOF cat > /kaniko/.docker/config.json <<EOF
{ {
"auths": { "auths": {
"${REGISTRY}": { "${REGISTRY}": {
"auth": "${REGISTRY_AUTH}" "auth": "${REGISTRY_AUTH}"
} }
} }
} }
EOF EOF
fi fi
if [ "${PLUGIN_JSON_KEY:-}" ];then if [ "${PLUGIN_JSON_KEY:-}" ];then
echo "${PLUGIN_JSON_KEY}" > /kaniko/gcr.json echo "${PLUGIN_JSON_KEY}" > /kaniko/gcr.json
export GOOGLE_APPLICATION_CREDENTIALS=/kaniko/gcr.json export GOOGLE_APPLICATION_CREDENTIALS=/kaniko/gcr.json
fi fi
DOCKERFILE=${PLUGIN_DOCKERFILE:-Dockerfile} DOCKERFILE=${PLUGIN_DOCKERFILE:-Dockerfile}
@ -31,31 +31,31 @@ LOG=${PLUGIN_LOG:-info}
EXTRA_OPTS="" EXTRA_OPTS=""
if [[ -n "${PLUGIN_TARGET:-}" ]]; then if [[ -n "${PLUGIN_TARGET:-}" ]]; then
TARGET="--target=${PLUGIN_TARGET}" TARGET="--target=${PLUGIN_TARGET}"
fi fi
if [[ "${PLUGIN_SKIP_TLS_VERIFY:-}" == "true" ]]; then if [[ "${PLUGIN_SKIP_TLS_VERIFY:-}" == "true" ]]; then
EXTRA_OPTS="--skip-tls-verify=true" EXTRA_OPTS="--skip-tls-verify=true"
fi fi
if [[ "${PLUGIN_CACHE:-}" == "true" ]]; then if [[ "${PLUGIN_CACHE:-}" == "true" ]]; then
CACHE="--cache=true" CACHE="--cache=true"
fi fi
if [ -n "${PLUGIN_CACHE_REPO:-}" ]; then if [ -n "${PLUGIN_CACHE_REPO:-}" ]; then
CACHE_REPO="--cache-repo=${REGISTRY}/${PLUGIN_CACHE_REPO}" CACHE_REPO="--cache-repo=${REGISTRY}/${PLUGIN_CACHE_REPO}"
fi fi
if [ -n "${PLUGIN_CACHE_TTL:-}" ]; then if [ -n "${PLUGIN_CACHE_TTL:-}" ]; then
CACHE_TTL="--cache-ttl=${PLUGIN_CACHE_TTL}" CACHE_TTL="--cache-ttl=${PLUGIN_CACHE_TTL}"
fi fi
if [ -n "${PLUGIN_BUILD_ARGS:-}" ]; then 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) BUILD_ARGS=$(echo "${PLUGIN_BUILD_ARGS}" | tr ',' '\n' | while read build_arg; do echo "--build-arg=${build_arg}"; done)
fi fi
if [ -n "${PLUGIN_BUILD_ARGS_FROM_ENV:-}" ]; then if [ -n "${PLUGIN_BUILD_ARGS_FROM_ENV:-}" ]; then
BUILD_ARGS_FROM_ENV=$(echo "${PLUGIN_BUILD_ARGS_FROM_ENV}" | tr ',' '\n' | while read build_arg; do echo "--build-arg ${build_arg}=$(eval "echo \$$build_arg")"; done) BUILD_ARGS_FROM_ENV=$(echo "${PLUGIN_BUILD_ARGS_FROM_ENV}" | tr ',' '\n' | while read build_arg; do echo "--build-arg ${build_arg}=$(eval "echo \$$build_arg")"; done)
fi fi
# TODO: Test auto_tag behavior; potential bugs might still be here # TODO: Test auto_tag behavior; potential bugs might still be here
@ -63,48 +63,54 @@ fi
# support format Major.Minor.Release or start with `v` # support format Major.Minor.Release or start with `v`
# docker tags: Major, Major.Minor, Major.Minor.Release and latest # docker tags: Major, Major.Minor, Major.Minor.Release and latest
if [[ "${PLUGIN_AUTO_TAG:-}" == "true" ]]; then if [[ "${PLUGIN_AUTO_TAG:-}" == "true" ]]; then
TAG=$(echo "${CI_COMMIT_TAG:-}" |sed 's/^v//g') TAG=$(echo "${CI_COMMIT_TAG:-}" |sed 's/^v//g')
tag_part_count=$(echo "${TAG}" | tr '.' '\n' |wc -l) tag_part_count=$(echo "${TAG}" | tr '.' '\n' |wc -l)
# expect number # expect number
echo ${TAG} | grep -E "[a-z-]" &>/dev/null && isNum=1 || isNum=0 echo ${TAG} | grep -E "[a-z-]" &>/dev/null && isNum=1 || isNum=0
if [ ! -n "${TAG:-}" ]; then if [ ! -n "${TAG:-}" ]; then
echo "latest" > .tags echo "latest" > .tags
elif [ ${isNum} -eq 1 -o ${tag_part_count} -gt 3 ]; then elif [ ${isNum} -eq 1 -o ${tag_part_count} -gt 3 ]; then
echo "${TAG},latest" > .tags echo "${TAG},latest" > .tags
else else
major=$(echo "${TAG}" | awk -F'.' '{print $1}') major=$(echo "${TAG}" | awk -F'.' '{print $1}')
minor=$(echo "${TAG}" | awk -F'.' '{print $2}') minor=$(echo "${TAG}" | awk -F'.' '{print $2}')
release=$(echo "${TAG}" | awk -F'.' '{print $3}') release=$(echo "${TAG}" | awk -F'.' '{print $3}')
major=${major:-0} major=${major:-0}
minor=${minor:-0} minor=${minor:-0}
release=${release:-0} release=${release:-0}
echo "${major},${major}.${minor},${major}.${minor}.${release},latest" > .tags echo "${major},${major}.${minor},${major}.${minor}.${release},latest" > .tags
fi fi
fi fi
if [ -n "${PLUGIN_TAGS:-}" ]; then if [ -n "${PLUGIN_TAGS:-}" ]; then
DESTINATIONS=$(echo "${PLUGIN_TAGS}" | tr ',' '\n' | while read tag; do echo "--destination=${REGISTRY}/${PLUGIN_REPO}:${tag} "; done) DESTINATIONS=$(echo "${PLUGIN_TAGS}" | tr ',' '\n' | while read tag; do echo "--destination=${REGISTRY}/${PLUGIN_REPO}:${tag} "; done)
elif [ -f .tags ]; then elif [ -f .tags ]; then
DESTINATIONS=$(cat .tags| tr ',' '\n' | while read tag; do echo "--destination=${REGISTRY}/${PLUGIN_REPO}:${tag} "; done) DESTINATIONS=$(cat .tags| tr ',' '\n' | while read tag; do echo "--destination=${REGISTRY}/${PLUGIN_REPO}:${tag} "; done)
elif [ -n "${PLUGIN_REPO:-}" ]; then elif [ -n "${PLUGIN_REPO:-}" ]; then
DESTINATIONS="--destination=${REGISTRY}/${PLUGIN_REPO}:latest" DESTINATIONS="--destination=${REGISTRY}/${PLUGIN_REPO}:latest"
else else
DESTINATIONS="--no-push" DESTINATIONS="--no-push"
# Cache is not valid with --no-push # Cache is not valid with --no-push
CACHE="" CACHE=""
fi fi
COMMAND=$(cat <<-EOF
/kaniko/executor -v ${LOG} \ /kaniko/executor -v ${LOG} \
--context=${CONTEXT} \ --context=${CONTEXT} \
--dockerfile=${DOCKERFILE} \ --dockerfile=${DOCKERFILE} \
${EXTRA_OPTS} \ ${EXTRA_OPTS} \
${DESTINATIONS} \ ${DESTINATIONS} \
${CACHE:-} \ ${CACHE:-} \
${CACHE_TTL:-} \ ${CACHE_TTL:-} \
${CACHE_REPO:-} \ ${CACHE_REPO:-} \
${TARGET:-} \ ${TARGET:-} \
${BUILD_ARGS:-} \ ${BUILD_ARGS:-} \
${BUILD_ARGS_FROM_ENV:-} ${BUILD_ARGS_FROM_ENV:-}"
EOF
)
echo "+ ${COMMAND}"
eval "${COMMAND}"