-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathbuild_deploy.sh
executable file
·119 lines (103 loc) · 3.92 KB
/
build_deploy.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#!/bin/bash -ex
#
# Copyright (c) 2018 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# This script builds and deploys the Kafka Service Fleet Manager. In order to
# work, it needs the following variables defined in the CI/CD configuration of
# the project:
#
# QUAY_USER - The name of the robot account used to push images to
# 'quay.io', for example 'openshift-unified-hybrid-cloud+jenkins'.
#
# QUAY_TOKEN - The token of the robot account used to push images to
# 'quay.io'.
#
# The machines that run this script need to have access to internet, so that
# the built images can be pushed to quay.io.
#
# Final step (optional) is to create new release of kas-fleet-manager
# in the managed-kafka-versions repo, given that required environment
# variables are provided and the config is different than previously
set -e
# The version should be the short hash from git. This is what the deployent process expects.
VERSION="$(git rev-parse --short=7 HEAD)"
# Set the variable required to login and push images to the registry
QUAY_USER=${QUAY_USER_NAME:-$RHOAS_QUAY_USER}
QUAY_TOKEN=${QUAY_USER_PASSWORD:-$RHOAS_QUAY_TOKEN}
QUAY_ORG=${QUAY_ORG_NAME:-rhoas}
# Set the directory for docker configuration:
DOCKER_CONFIG="${PWD}/.docker"
# Set the Go path:
export GOPATH="${PWD}/.gopath"
export PATH="${PATH}:${GOPATH}/bin"
LINK="${GOPATH}/src/github.com/bf2fc6cc711aee1a0c2a/kas-fleet-manager"
# print go version
go version
mkdir -p "$(dirname "${LINK}")"
ln -sf "${PWD}" "${LINK}"
cd "${LINK}"
# Log in to the image registry:
if [ -z "${QUAY_USER}" ]; then
echo "The quay.io push user name hasn't been provided."
echo "Make sure to set the QUAY_USER_NAME environment variable."
exit 1
fi
if [ -z "${QUAY_TOKEN}" ]; then
echo "The quay.io push token hasn't been provided."
echo "Make sure to set the QUAY_USER_PASSWORD environment variable."
exit 1
fi
# Set up the docker config directory
mkdir -p "${DOCKER_CONFIG}"
BRANCH="main"
if [[ ! -z "$GITHUB_REF" ]]; then
BRANCH="$(echo $GITHUB_REF | awk -F/ '{print $NF}')"
echo "GITHUB_REF is defined. Set image tag to $BRANCH."
elif [[ ! -z "$GIT_BRANCH" ]]; then
BRANCH="$(echo $GIT_BRANCH | awk -F/ '{print $NF}')"
echo "GIT_BRANCH is defined. Set image tag to $BRANCH."
else
echo "No git branch env var found. Set image tag to $BRANCH."
fi
# Push the image:
echo "Quay.io user and token is set, will push images to $QUAY_ORG org"
make \
DOCKER_CONFIG="${DOCKER_CONFIG}" \
QUAY_USER="${QUAY_USER}" \
QUAY_TOKEN="${QUAY_TOKEN}" \
version="${VERSION}" \
external_image_registry="quay.io" \
internal_image_registry="quay.io" \
image_repository="$QUAY_ORG/kas-fleet-manager" \
docker/login \
image/push
make \
DOCKER_CONFIG="${DOCKER_CONFIG}" \
QUAY_USER="${QUAY_USER}" \
QUAY_TOKEN="${QUAY_TOKEN}" \
version="${BRANCH}" \
external_image_registry="quay.io" \
internal_image_registry="quay.io" \
image_repository="$QUAY_ORG/kas-fleet-manager" \
docker/login \
image/push
# create new relaase in managed-kafka-versions repo for kas-fleet-manager
if [[ -n "$AUTHOR_EMAIL" ]] && [[ -n "$AUTHOR_NAME" ]] && [[ -n "$GITLAB_TOKEN" ]]; then
LATEST_COMMIT=$(git rev-parse HEAD)
export IMAGE_NAME="kas-fleet-manager/create_release"
docker build --pull -t "$IMAGE_NAME" -f "$PWD"/docker/Dockerfile .
docker run -e AUTHOR_EMAIL="$AUTHOR_EMAIL" -e AUTHOR_NAME="$AUTHOR_NAME" -e GITLAB_TOKEN="$GITLAB_TOKEN" \
-e VERSION="$VERSION" -e LATEST_COMMIT="$LATEST_COMMIT" -i "$IMAGE_NAME"
fi