name: Reusable container push workflow on: workflow_call: env: REPO: ${{ github.repository }} jobs: push-container: runs-on: ubuntu-22.04 steps: - id: get-id name: Get a unique tag for this build run: | SHA=${{ github.sha }}; BRANCH_NAME=${{ github.base_ref || github.ref_name }}; BUILD_ID=$BRANCH_NAME-${SHA:0:8}; DOCKER_IMAGE=${{ vars.docker_repo2_registry }}/$REPO:$BUILD_ID; echo "BUILD_ID=$BUILD_ID" >> "$GITHUB_OUTPUT"; echo "DOCKER_IMAGE=$DOCKER_IMAGE" >> "$GITHUB_OUTPUT"; - name: Print build id and image name run: | echo "BUILD_ID: ${{ steps.get-id.outputs.BUILD_ID }}"; echo "DOCKER_IMAGE: ${{ steps.get-id.outputs.DOCKER_IMAGE }}"; - uses: actions/checkout@v4 - name: Login to docker container registry uses: docker/login-action@v3 with: registry: ${{ vars.docker_repo2_registry }} username: ${{ secrets.docker_repo2_username }} password: ${{ secrets.docker_repo2_password }} - name: Build the container image run: | docker build \ --build-arg BUILD_STEP=container \ --build-arg PUBLIC_BUILD_VERSION=${{ steps.get-id.outputs.BUILD_ID }} \ --file fab/d/actions-build.Dockerfile \ --tag ${{ steps.get-id.outputs.DOCKER_IMAGE }} \ .; - name: Container details run: | IMAGE_SIZE=`docker inspect -f "{{ .Size }}" ${{ steps.get-id.outputs.DOCKER_IMAGE }} | numfmt --to=si`; echo "$IMAGE_SIZE container ${{ steps.get-id.outputs.DOCKER_IMAGE }}"; - name: Push the container image run: docker push ${{ steps.get-id.outputs.DOCKER_IMAGE }} push-container-gcp: runs-on: ubuntu-22.04 steps: - id: get-id name: Get a unique tag for this build run: | SHA=${{ github.sha }}; BRANCH_NAME=${{ github.base_ref || github.ref_name }}; BUILD_ID=$BRANCH_NAME-${SHA:0:8}; DOCKER_IMAGE="${{vars.GCP_DOCKER_REGISTRY}}/$REPO:$BUILD_ID" echo "BUILD_ID=$BUILD_ID" >> "$GITHUB_OUTPUT"; echo "DOCKER_IMAGE=$DOCKER_IMAGE" >> "$GITHUB_OUTPUT"; - name: Print build id and image name run: | echo "BUILD_ID: ${{ steps.get-id.outputs.BUILD_ID }}"; echo "DOCKER_IMAGE: ${{ steps.get-id.outputs.DOCKER_IMAGE }}"; - uses: actions/checkout@v4 # ✅ 1) Auth to GCP (this is where your SA key is used) - name: Auth to GCP uses: google-github-actions/auth@v2 with: # using your existing secret that contains the SA JSON credentials_json: ${{ secrets.GCP_SA_KEY }} # ✅ 2) Install gcloud (no creds here) - name: Set up gcloud uses: google-github-actions/setup-gcloud@v2 with: project_id: ${{ vars.GCP_PROJECT_ID }} export_default_credentials: true - name: Configure Docker for GAR run: | gcloud auth configure-docker $GCP_REGION-docker.pkg.dev - name: Build the container image run: | docker build \ --build-arg BUILD_STEP=container \ --build-arg PUBLIC_BUILD_VERSION=${{ steps.get-id.outputs.BUILD_ID }} \ --file fab/d/actions-build.Dockerfile \ --tag ${{ steps.get-id.outputs.DOCKER_IMAGE }} \ .; - name: Container details run: | IMAGE_SIZE=`docker inspect -f "{{ .Size }}" ${{ steps.get-id.outputs.DOCKER_IMAGE }} | numfmt --to=si`; echo "$IMAGE_SIZE container ${{ steps.get-id.outputs.DOCKER_IMAGE }}"; - name: Push the container image run: docker push ${{ steps.get-id.outputs.DOCKER_IMAGE }}