name: Docker Image CI on: workflow_call: # Org Secrets are available on push event. Not pull_request event. env: REPO: ${{ github.repository }} REPO_SHORT_NAME: ${{ github.event.repository.name }} jobs: s3-push: 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 PUBLIC_BUILD_VERSION=${{ steps.get-id.outputs.BUILD_ID }} \ --file fab/d/actions-build.Dockerfile \ --tag ${{ steps.get-id.outputs.DOCKER_IMAGE }} \ .; - name: Extract cloud files run: | image=${{ steps.get-id.outputs.DOCKER_IMAGE }} source_path=/cloud destination_path=cloud container_id=$(docker create "$image") docker cp "$container_id:$source_path" "$destination_path" docker rm "$container_id" echo "Running: ls $destination_path" ls $destination_path - name: Upload cloud files uses: sahil87/aws-cli-action@v1.3 env: AWS_ACCESS_KEY_ID: ${{ secrets.aws_access_key_id }} AWS_SECRET_ACCESS_KEY: ${{ secrets.aws_secret_access_key }} AWS_DEFAULT_REGION: ${{ vars.aws_default_region }} with: args: > s3 cp \ --recursive \ --cache-control max-age=31536000\ --storage-class 'STANDARD_IA' \ cloud/ s3://${{ vars.aws_upload_bucket }}/${{ env.REPO_SHORT_NAME }}/${{ steps.get-id.outputs.BUILD_ID }}