30 lines
1.1 KiB
Text
Executable file
30 lines
1.1 KiB
Text
Executable file
STAGE=${stage:-"dev"}
|
|
SHA_SHORT="$(git rev-parse --short HEAD)"
|
|
CUR_DATE="$(date +%Y%m%d%H%M%S)"
|
|
VERSION="$STAGE-$CUR_DATE-$SHA_SHORT"
|
|
IMAGE_NAME=${image_name:-promethai-${STAGE}-promethai-backend-memory}
|
|
|
|
REPO_NAME="${AWS_REPOSITORY}/${IMAGE_NAME}"
|
|
FULL_IMAGE_NAME="${REPO_NAME}:${VERSION}"
|
|
APP_DIR=${app_dir:-"./level_2/"} # Updated this line
|
|
|
|
PUBLISH=${publish:-false}
|
|
|
|
echo "Building docker image ${FULL_IMAGE_NAME} located in dir ${app_dir}"
|
|
|
|
pushd "${APP_DIR}" &&
|
|
docker buildx build --platform linux/amd64 \
|
|
--build-arg STAGE=${STAGE} \
|
|
-t "${FULL_IMAGE_NAME}" . &&
|
|
echo "${VERSION}" >/tmp/.DOCKER_IMAGE_VERSION &&
|
|
echo "Successfully built docker image ${FULL_IMAGE_NAME}"
|
|
|
|
if [ "${PUBLISH}" = true ]; then
|
|
echo "Pushing docker image ${FULL_IMAGE_NAME} to ECR repository to AWS account ${AWS_DEPLOYMENT_ACCOUNT}"
|
|
if [ "${PUBLISH}" = true ]; then
|
|
echo "logging in"
|
|
aws ecr get-login-password --region "${AWS_REGION}" | docker login --username AWS --password-stdin "${AWS_REPOSITORY}"
|
|
fi
|
|
docker push "${FULL_IMAGE_NAME}" &&
|
|
echo "Successfully pushed docker image ${FULL_IMAGE_NAME} to ECR repository"
|
|
fi
|