-
Notifications
You must be signed in to change notification settings - Fork 41
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update dev environment to work on CyberArk NG laptops
On CyberArk dev laptops, golang module dependencies are downloaded with a corporate proxy in the middle. For these connections to succeed we need to configure the proxy CA certificate in build containers. To allow build script to also work on non-CyberArk laptops where the CA certificate is not available, we copy the (potentially empty) directory into the build containers, and update container certificates based on that directory, rather than relying on the CA file itself.
- Loading branch information
Dane LeBlanc
committed
Oct 18, 2021
1 parent
57a1f6e
commit a174440
Showing
11 changed files
with
247 additions
and
94 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,23 +1,61 @@ | ||
#!/bin/bash | ||
set -euo pipefail | ||
|
||
CURRENT_DIR=$(dirname "${BASH_SOURCE[0]}") | ||
CURRENT_DIR="$(dirname "${BASH_SOURCE[0]}")" | ||
|
||
if ! oc whoami &> /dev/null; then | ||
oc login | ||
fi | ||
docker login -u _ -p "$(oc whoami -t)" "$DOCKER_REGISTRY_PATH" | ||
function main() { | ||
retrieve_cyberark_ca_cert | ||
oc_login | ||
build_docker_images | ||
} | ||
|
||
test_app_image="$DOCKER_REGISTRY_PATH/$TEST_APP_NAMESPACE_NAME/$APP_NAME:$TEST_APP_NAMESPACE_NAME" | ||
function retrieve_cyberark_ca_cert() { | ||
pushd "$CURRENT_DIR/.." | ||
# On CyberArk dev laptops, golang module dependencies are downloaded with | ||
# a corporate proxy in the middle. For these connections to succeed we | ||
# need to configure the proxy CA certificate in build containers. | ||
# | ||
# To allow this script to also work on non-CyberArk laptops where the CA | ||
# certificate is not available, we update container certificates based on | ||
# a (potentially empty) certificate directory, rather than relying on the | ||
# CA file itself. | ||
mkdir -p build_ca_certificate | ||
|
||
echo "Building and pushing image..." | ||
# Only attempt to extract the certificate if the security | ||
# command is available. | ||
# | ||
# The certificate file must have the .crt extension to be imported | ||
# by `update-ca-certificates`. | ||
if command -v security &> /dev/null | ||
then | ||
security find-certificate \ | ||
-a -c "CyberArk Enterprise Root CA" \ | ||
-p > build_ca_certificate/cyberark_root.crt | ||
fi | ||
popd | ||
} | ||
|
||
echo "Building $APP_NAME image" | ||
pushd "$CURRENT_DIR/.." | ||
docker build -t "$APP_NAME:$TEST_APP_NAMESPACE_NAME" . | ||
popd | ||
function oc_login() { | ||
if ! oc whoami &> /dev/null; then | ||
oc login | ||
fi | ||
docker login -u _ -p "$(oc whoami -t)" "$DOCKER_REGISTRY_PATH" | ||
} | ||
|
||
docker tag "$APP_NAME:$TEST_APP_NAMESPACE_NAME" "$test_app_image" | ||
function build_docker_images() { | ||
test_app_image="$DOCKER_REGISTRY_PATH/$TEST_APP_NAMESPACE_NAME/$APP_NAME:$TEST_APP_NAMESPACE_NAME" | ||
|
||
echo "Pushing $test_app_image to OpenShift..." | ||
docker push "$test_app_image" | ||
echo "Building and pushing image..." | ||
|
||
echo "Building $APP_NAME image" | ||
pushd "$CURRENT_DIR/.." | ||
docker build -t "$APP_NAME:$TEST_APP_NAMESPACE_NAME" . | ||
popd | ||
|
||
docker tag "$APP_NAME:$TEST_APP_NAMESPACE_NAME" "$test_app_image" | ||
|
||
echo "Pushing $test_app_image to OpenShift..." | ||
docker push "$test_app_image" | ||
} | ||
|
||
main |
Oops, something went wrong.