|
| 1 | +#! /bin/bash |
| 2 | + |
| 3 | +sonic_version="" |
| 4 | +sonic_platform="" |
| 5 | + |
| 6 | +while getopts ":v:p:" opt |
| 7 | +do |
| 8 | + case ${opt} in |
| 9 | + v ) # SONiC image version |
| 10 | + sonic_version=${OPTARG} |
| 11 | + ;; |
| 12 | + p ) # Platform info |
| 13 | + sonic_platform=${OPTARG} |
| 14 | + ;; |
| 15 | + \? ) echo "\ |
| 16 | +Usage: [-v <version> ] [ -p <platform> ] <DOCKER_IMAGE_FILE> <REGISTRY_SERVER> <REGISTRY_PORT> \ |
| 17 | +<REGISTRY_USERNAME> <REGISTRY_PASSWD> [<DOCKER_IMAGE_TAG>]" |
| 18 | + ;; |
| 19 | + esac |
| 20 | +done |
| 21 | + |
| 22 | +shift $((OPTIND -1)) |
| 23 | + |
1 | 24 | DOCKER_IMAGE_FILE=$1 |
2 | 25 | REGISTRY_SERVER=$2 |
3 | 26 | REGISTRY_PORT=$3 |
4 | 27 | REGISTRY_USERNAME=$4 |
5 | 28 | REGISTRY_PASSWD=$5 |
6 | 29 | DOCKER_IMAGE_TAG=$6 |
| 30 | +REGISTRY_SERVER_WITH_PORT=${REGISTRY_SERVER}${REGISTRY_PORT:+:$REGISTRY_PORT} |
7 | 31 |
|
8 | | -set -e |
9 | | -docker load < $DOCKER_IMAGE_FILE |
| 32 | +push_it() { |
| 33 | + # $1 - Given image name |
| 34 | + # $2 - Remote image name |
10 | 35 |
|
11 | | -## Fetch the Jenkins build number if inside it |
12 | | -[ ${BUILD_NUMBER} ] || { |
13 | | - echo "No BUILD_NUMBER found, setting to 0." |
14 | | - BUILD_NUMBER="0" |
| 36 | + docker tag $1 $2 |
| 37 | + echo "Pushing $2" |
| 38 | + image_sha=$(docker push $2 | sed -n "s/.*: digest: sha256:\([0-9a-f]*\).*/\\1/p") |
| 39 | + echo "Remove $2" |
| 40 | + docker rmi $2 || true |
| 41 | + echo "Image sha256: $image_sha" |
15 | 42 | } |
16 | 43 |
|
17 | | -## Prepare tag |
18 | | -docker_image_name=$(basename $DOCKER_IMAGE_FILE | cut -d. -f1) |
19 | | -remote_image_name=$REGISTRY_SERVER:$REGISTRY_PORT/$docker_image_name:$DOCKER_IMAGE_TAG |
20 | | -timestamp="$(date -u +%Y%m%d)" |
21 | | -build_version="${timestamp}.bld-${BUILD_NUMBER}" |
22 | | -build_remote_image_name=$REGISTRY_SERVER:$REGISTRY_PORT/$docker_image_name:$build_version |
| 44 | +set -e |
23 | 45 |
|
24 | | -## Add registry information as tag, so will push as latest |
25 | | -## Add additional tag with build information |
26 | | -docker tag $docker_image_name $remote_image_name |
27 | | -docker tag $docker_image_name $build_remote_image_name |
| 46 | +echo "Loading image ${DOCKER_IMAGE_FILE}" |
| 47 | +docker load < ${DOCKER_IMAGE_FILE} |
28 | 48 |
|
29 | 49 | ## Login the docker image registry server |
30 | 50 | ## Note: user name and password are passed from command line |
31 | | -docker login -u $REGISTRY_USERNAME -p "$REGISTRY_PASSWD" $REGISTRY_SERVER:$REGISTRY_PORT |
32 | | - |
33 | | -## Push image to registry server |
34 | | -## And get the image digest SHA256 |
35 | | -echo "Pushing $remote_image_name" |
36 | | -image_sha=$(docker push $remote_image_name | sed -n "s/.*: digest: sha256:\([0-9a-f]*\).*/\\1/p") |
37 | | -docker rmi $remote_image_name || true |
38 | | -echo "Image sha256: $image_sha" |
39 | | -echo "Pushing $build_remote_image_name" |
40 | | -docker push $build_remote_image_name |
41 | | -docker rmi $build_remote_image_name || true |
| 51 | +docker login -u ${REGISTRY_USERNAME} -p "${REGISTRY_PASSWD}" ${REGISTRY_SERVER_WITH_PORT} |
| 52 | + |
| 53 | +## Get Docker image name |
| 54 | +docker_image_name=$(basename ${DOCKER_IMAGE_FILE} | cut -d. -f1) |
| 55 | +remote_image_name=${REGISTRY_SERVER_WITH_PORT}/${docker_image_name} |
| 56 | + |
| 57 | +[ -z "${DOCKER_IMAGE_TAG}" ] || { |
| 58 | + push_it ${docker_image_name} ${remote_image_name}:${DOCKER_IMAGE_TAG} |
| 59 | +} |
| 60 | + |
| 61 | +if [ -n "${sonic_version}" ] && [ -n "${sonic_platform}" ] |
| 62 | +then |
| 63 | + remote_image_name=${REGISTRY_SERVER_WITH_PORT}/sonic-dockers/${sonic_platform}/${docker_image_name}:${sonic_version} |
| 64 | + push_it ${docker_image_name} ${remote_image_name} |
| 65 | +else |
| 66 | + ## Fetch the Jenkins build number if inside it |
| 67 | + [ ${BUILD_NUMBER} ] || { |
| 68 | + echo "No BUILD_NUMBER found, setting to 0." |
| 69 | + BUILD_NUMBER="0" |
| 70 | + } |
| 71 | + |
| 72 | + timestamp="$(date -u +%Y%m%d)" |
| 73 | + build_version="${timestamp}.bld-${BUILD_NUMBER}" |
| 74 | + push_it ${docker_image_name} ${remote_image_name}:${build_version} |
| 75 | +fi |
| 76 | + |
42 | 77 | docker rmi $docker_image_name || true |
| 78 | +echo "Job completed" |
| 79 | + |
0 commit comments