|
| 1 | +name: Publish version to AWS ECR |
| 2 | + |
| 3 | +on: |
| 4 | + workflow_dispatch: # manual trigger to publish prod/dev version |
| 5 | + workflow_run: # trigger on GH version to publish prod version |
| 6 | + workflows: ["Publish version to GitHub"] |
| 7 | + types: |
| 8 | + - completed |
| 9 | + branches: |
| 10 | + - main |
| 11 | + |
| 12 | +jobs: |
| 13 | + build-and-push: |
| 14 | + name: Build and push Docker image |
| 15 | + runs-on: ubuntu-latest |
| 16 | + |
| 17 | + steps: |
| 18 | + - name: Checkout code |
| 19 | + uses: actions/checkout@v3 |
| 20 | + with: |
| 21 | + fetch-depth: 0 |
| 22 | + |
| 23 | + - name: Set version |
| 24 | + id: set-version |
| 25 | + run: | |
| 26 | + if [ "${{ github.event_name }}" == "workflow_run" ]; then |
| 27 | + POETRY_VERSION=$(grep -E '^requires-poetry = ' pyproject.toml | sed -E 's/requires-poetry = "(.*)"/\1/') |
| 28 | + pip install poetry==$POETRY_VERSION |
| 29 | + PROD=true |
| 30 | + VERSION=$(poetry version -s) |
| 31 | + REF=refs/tags/$VERSION |
| 32 | + else |
| 33 | + REF=$GITHUB_REF |
| 34 | + if [[ "$GITHUB_REF" == refs/tags/* ]]; then |
| 35 | + PROD=true |
| 36 | + VERSION=${GITHUB_REF#refs/tags/} |
| 37 | + else |
| 38 | + PROD=false |
| 39 | + VERSION=dev-${GITHUB_REF#refs/heads/}-${GITHUB_SHA::7} |
| 40 | + fi |
| 41 | + fi |
| 42 | + echo "PROD=$PROD" >> $GITHUB_OUTPUT |
| 43 | + echo "VERSION=$VERSION" >> $GITHUB_OUTPUT |
| 44 | + echo "REF=$REF" >> $GITHUB_OUTPUT |
| 45 | +
|
| 46 | + # on main, we do not want necessarily the latest commit, but the one that was tagged |
| 47 | + - name: Checkout code |
| 48 | + uses: actions/checkout@v3 |
| 49 | + with: |
| 50 | + ref: ${{ steps.set-version.outputs.REF }} |
| 51 | + fetch-depth: 0 |
| 52 | + |
| 53 | + - name: Get Python version |
| 54 | + id: get-python-version |
| 55 | + run: | |
| 56 | + pip install toml |
| 57 | + PYTHON_VERSION=$(python -c 'import scripts.vars; scripts.vars.get_python_version()') |
| 58 | + echo "PYTHON_VERSION=$PYTHON_VERSION" >> $GITHUB_OUTPUT |
| 59 | +
|
| 60 | + - name: Configure AWS credentials |
| 61 | + uses: aws-actions/configure-aws-credentials@v2 |
| 62 | + with: |
| 63 | + aws-access-key-id: ${{ secrets.ECR_AWS_ACCESS_KEY_ID }} |
| 64 | + aws-secret-access-key: ${{ secrets.ECR_AWS_SECRET_ACCESS_KEY }} |
| 65 | + aws-region: us-east-1 # required for Public ECR |
| 66 | + |
| 67 | + - name: Login to AWS Public ECR |
| 68 | + uses: aws-actions/amazon-ecr-login@v1 |
| 69 | + with: |
| 70 | + registry-type: public |
| 71 | + |
| 72 | + - name: Build and push Docker image |
| 73 | + id: build-and-push |
| 74 | + env: |
| 75 | + VERSION: ${{ steps.set-version.outputs.VERSION }} |
| 76 | + PROD: ${{ steps.set-version.outputs.PROD }} |
| 77 | + ECR_REGISTRY: public.ecr.aws/w2b7b8c0 |
| 78 | + ECR_REPOSITORY: decode-cloud/user-api |
| 79 | + PYTHON_VERSION: ${{ steps.get-python-version.outputs.PYTHON_VERSION }} |
| 80 | + run: | |
| 81 | + IMAGE_REF=$ECR_REGISTRY/$ECR_REPOSITORY:$VERSION |
| 82 | + echo "IMAGE_REF=$IMAGE_REF" >> $GITHUB_OUTPUT |
| 83 | + if docker manifest inspect $IMAGE_REF > /dev/null 2>&1; then |
| 84 | + NEW_IMAGE=false |
| 85 | + echo "Image $IMAGE_REF already exists, nothing pushed" >> $GITHUB_STEP_SUMMARY |
| 86 | + else |
| 87 | + NEW_IMAGE=true |
| 88 | + docker build --build-arg PYTHON_VERSION=$PYTHON_VERSION -t $IMAGE_REF . |
| 89 | + docker push $IMAGE_REF |
| 90 | + echo "## 🚀 Published Docker Image: $IMAGE_REF" >> $GITHUB_STEP_SUMMARY |
| 91 | + if [[ $PROD == "true" ]]; then |
| 92 | + SET_LATEST=true |
| 93 | + LATEST_EXISTS=$(docker manifest inspect $ECR_REGISTRY/$ECR_REPOSITORY:latest > /dev/null 2>&1 && echo "true" || echo "false") |
| 94 | + if [[ $LATEST_EXISTS == "true" ]]; then |
| 95 | + LATEST_LABELS=$(docker manifest inspect $ECR_REGISTRY/$ECR_REPOSITORY:latest | grep -o '"org.opencontainers.image.version":"[^"]*"' | cut -d'"' -f4 || echo "") |
| 96 | + if printf '%s\n%s\n' "$LATEST_LABELS" "$VERSION" | sort -V | head -n1 | grep -q "^$VERSION$"; then |
| 97 | + SET_LATEST=false |
| 98 | + fi |
| 99 | + fi |
| 100 | + if [[ $SET_LATEST == "true" ]]; then |
| 101 | + docker tag $IMAGE_REF $ECR_REGISTRY/$ECR_REPOSITORY:latest |
| 102 | + docker push $ECR_REGISTRY/$ECR_REPOSITORY:latest |
| 103 | + echo "Also tagged as: \`$ECR_REGISTRY/$ECR_REPOSITORY:latest\`" >> $GITHUB_STEP_SUMMARY |
| 104 | + fi |
| 105 | + fi |
| 106 | + fi |
| 107 | + echo "NEW_IMAGE=$NEW_IMAGE" >> $GITHUB_OUTPUT |
| 108 | +
|
| 109 | + - name: Add to GH release |
| 110 | + if: steps.build-and-push.outputs.NEW_IMAGE == 'true' && steps.set-version.outputs.PROD == 'true' |
| 111 | + uses: tubone24/update_release@v1.0 |
| 112 | + env: |
| 113 | + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |
| 114 | + TAG_NAME: ${{ steps.set-version.outputs.VERSION }} |
| 115 | + with: |
| 116 | + body: "**Published image (AWS ECR Public):** `${{ steps.build-and-push.outputs.IMAGE_REF }}`" |
| 117 | + is_append_body: true |
0 commit comments