forked from envoyproxy/envoy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup_cache.sh
executable file
·40 lines (34 loc) · 1.56 KB
/
setup_cache.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
#!/bin/bash
set -e
if [[ ! -z "${GCP_SERVICE_ACCOUNT_KEY}" ]]; then
# mktemp will create a tempfile with u+rw permission minus umask, it will not be readable by all
# users by default.
GCP_SERVICE_ACCOUNT_KEY_FILE=$(mktemp -t gcp_service_account.XXXXXX.json)
gcp_service_account_cleanup() {
echo "Deleting service account key file..."
rm -rf "${GCP_SERVICE_ACCOUNT_KEY_FILE}"
}
trap gcp_service_account_cleanup EXIT
echo "${GCP_SERVICE_ACCOUNT_KEY}" | base64 --decode > "${GCP_SERVICE_ACCOUNT_KEY_FILE}"
fi
if [[ "${BAZEL_REMOTE_CACHE}" =~ ^http ]]; then
if [[ ! -z "${GCP_SERVICE_ACCOUNT_KEY}" ]]; then
export BAZEL_BUILD_EXTRA_OPTIONS="${BAZEL_BUILD_EXTRA_OPTIONS} \
--remote_http_cache=${BAZEL_REMOTE_CACHE} \
--google_credentials=${GCP_SERVICE_ACCOUNT_KEY_FILE}"
echo "Set up bazel HTTP read/write cache at ${BAZEL_REMOTE_CACHE}."
else
export BAZEL_BUILD_EXTRA_OPTIONS="${BAZEL_BUILD_EXTRA_OPTIONS} \
--remote_http_cache=${BAZEL_REMOTE_CACHE} --noremote_upload_local_results"
echo "Set up bazel HTTP read only cache at ${BAZEL_REMOTE_CACHE}."
fi
elif [[ ! -z "${BAZEL_REMOTE_CACHE}" ]]; then
export BAZEL_BUILD_EXTRA_OPTIONS="${BAZEL_BUILD_EXTRA_OPTIONS} \
--remote_cache=${BAZEL_REMOTE_CACHE} \
--remote_instance_name=${BAZEL_REMOTE_INSTANCE} \
--google_credentials=${GCP_SERVICE_ACCOUNT_KEY_FILE} \
--auth_enabled=true"
echo "Set up bazel remote read/write cache at ${BAZEL_REMOTE_CACHE} instance: ${BAZEL_REMOTE_INSTANCE}."
else
echo "No remote cache bucket is set, skipping setup remote cache."
fi