|
| 1 | +#!/bin/bash |
| 2 | + |
| 3 | +# Multi-architecture Docker build and push script for hud environments |
| 4 | +# Usage: ./build-and-push-env.sh <environment|directory> <version> |
| 5 | +# Example: ./build-and-push-env.sh browser 0.1.8 |
| 6 | +# ./build-and-push-env.sh environments/browser 0.1.8 |
| 7 | +# ./build-and-push-env.sh /full/path/to/env 0.1.8 |
| 8 | + |
| 9 | +set -e |
| 10 | + |
| 11 | +ENV_INPUT=$1 |
| 12 | +VERSION=$2 |
| 13 | + |
| 14 | +if [ -z "$ENV_INPUT" ] || [ -z "$VERSION" ]; then |
| 15 | + echo "Error: Missing required arguments" |
| 16 | + echo "Usage: $0 <environment|directory> <version>" |
| 17 | + echo "Example: $0 browser 0.1.8" |
| 18 | + echo " $0 environments/browser 0.1.8" |
| 19 | + exit 1 |
| 20 | +fi |
| 21 | + |
| 22 | +SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)" |
| 23 | +PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)" |
| 24 | + |
| 25 | +# Check if input is a directory path or just a name |
| 26 | +if [[ "$ENV_INPUT" == *"/"* ]] || [ -d "$ENV_INPUT" ] || [ -d "$PROJECT_ROOT/$ENV_INPUT" ]; then |
| 27 | + # It's a directory path |
| 28 | + if [ -d "$ENV_INPUT" ]; then |
| 29 | + ENV_PATH="$ENV_INPUT" |
| 30 | + else |
| 31 | + ENV_PATH="$PROJECT_ROOT/$ENV_INPUT" |
| 32 | + fi |
| 33 | + ENVIRONMENT=$(basename "$ENV_PATH") |
| 34 | +else |
| 35 | + # It's just an environment name |
| 36 | + ENVIRONMENT="$ENV_INPUT" |
| 37 | + ENV_PATH="$PROJECT_ROOT/environments/${ENVIRONMENT}" |
| 38 | +fi |
| 39 | + |
| 40 | +IMAGE_NAME="hudevals/hud-${ENVIRONMENT}" |
| 41 | + |
| 42 | +echo "Building and pushing hud-${ENVIRONMENT} version ${VERSION}" |
| 43 | +echo "Environment path: $ENV_PATH" |
| 44 | + |
| 45 | +if [ ! -d "$ENV_PATH" ]; then |
| 46 | + echo "Error: Environment directory not found: $ENV_PATH" |
| 47 | + exit 1 |
| 48 | +fi |
| 49 | + |
| 50 | +if [ ! -f "$ENV_PATH/Dockerfile" ]; then |
| 51 | + echo "Error: Dockerfile not found in $ENV_PATH" |
| 52 | + exit 1 |
| 53 | +fi |
| 54 | + |
| 55 | +cd "$ENV_PATH" |
| 56 | +echo "Working directory: $(pwd)" |
| 57 | + |
| 58 | +echo "Building ARM64 image..." |
| 59 | +docker build --platform linux/arm64 -t $IMAGE_NAME:$VERSION-arm64 . |
| 60 | + |
| 61 | +echo "Building AMD64 image..." |
| 62 | +docker build --platform linux/amd64 -t $IMAGE_NAME:$VERSION-amd64 . |
| 63 | + |
| 64 | +echo "Tagging images as latest..." |
| 65 | +docker tag $IMAGE_NAME:$VERSION-arm64 $IMAGE_NAME:latest-arm64 |
| 66 | +docker tag $IMAGE_NAME:$VERSION-amd64 $IMAGE_NAME:latest-amd64 |
| 67 | + |
| 68 | +echo "Pushing ARM64 image..." |
| 69 | +docker push $IMAGE_NAME:$VERSION-arm64 |
| 70 | +docker push $IMAGE_NAME:latest-arm64 |
| 71 | + |
| 72 | +echo "Pushing AMD64 image..." |
| 73 | +docker push $IMAGE_NAME:$VERSION-amd64 |
| 74 | +docker push $IMAGE_NAME:latest-amd64 |
| 75 | + |
| 76 | +echo "Creating and pushing multi-arch manifest..." |
| 77 | +docker manifest create $IMAGE_NAME:$VERSION \ |
| 78 | + --amend $IMAGE_NAME:$VERSION-arm64 \ |
| 79 | + --amend $IMAGE_NAME:$VERSION-amd64 |
| 80 | + |
| 81 | +docker manifest create $IMAGE_NAME:latest \ |
| 82 | + --amend $IMAGE_NAME:latest-arm64 \ |
| 83 | + --amend $IMAGE_NAME:latest-amd64 |
| 84 | + |
| 85 | +echo "Pushing manifests..." |
| 86 | +docker manifest push $IMAGE_NAME:$VERSION |
| 87 | +docker manifest push $IMAGE_NAME:latest |
| 88 | + |
| 89 | +echo "Successfully built and pushed:" |
| 90 | +echo " - $IMAGE_NAME:$VERSION (multi-arch)" |
| 91 | +echo " - $IMAGE_NAME:latest (multi-arch)" |
| 92 | +echo " - $IMAGE_NAME:$VERSION-arm64" |
| 93 | +echo " - $IMAGE_NAME:$VERSION-amd64" |
| 94 | +echo " - $IMAGE_NAME:latest-arm64" |
| 95 | +echo " - $IMAGE_NAME:latest-amd64" |
| 96 | + |
| 97 | +echo "Done!" |
0 commit comments