diff --git a/.github/workflows/service-extensions-publish.yml b/.github/workflows/service-extensions-publish.yml index 9e0c645be0..145f682985 100644 --- a/.github/workflows/service-extensions-publish.yml +++ b/.github/workflows/service-extensions-publish.yml @@ -2,11 +2,10 @@ name: Publish Service Extensions Callout images packages on: push: + tags: + - '*' branches: - - 'flavien/service-extensions' - release: - types: - - published + - flavien/service-extensions-part2 #testing purpose workflow_dispatch: inputs: tag_name: @@ -16,44 +15,29 @@ on: commit_sha: description: 'Commit SHA to checkout' required: true + set_as_latest: + description: 'Set the tag as latest' + required: false + default: 'false' permissions: contents: read packages: write +env: + TAG_NAME: ${{ github.ref_name || github.event.inputs.tag_name }} + REF_NAME: ${{ github.ref || github.event.inputs.commit_sha }} + COMMIT_SHA: ${{ github.sha || github.event.inputs.commit_sha }} + PUSH_LATEST: ${{ github.event.inputs.set_as_latest || 'true' }} + jobs: publish-service-extensions: runs-on: ubuntu-latest steps: - - - name: Get tag name - id: get_tag_name - run: | - if [ "${{ github.event_name }}" = "release" ]; then - echo "::set-output name=tag::${{ github.event.release.tag_name }}" - echo "Here1: tag=${{ github.event.release.tag_name }}" - else - if [ -z "${{ github.event.inputs.tag_name }}" ]; then - echo "::set-output name=tag::dev" - echo "Here2: tag=dev" - else - echo "::set-output name=tag::${{ github.event.inputs.tag_name }}" - echo "Here3: tag=${{ github.event.inputs.tag_name }}" - fi - fi - echo "Finally: ${{ steps.get_tag_name.outputs.tag }}" - - - name: Checkout - uses: actions/checkout@v4 - if: github.event_name == 'release' - with: - ref: ${{ steps.get_tag_name.outputs.tag }} - - name: Checkout uses: actions/checkout@v4 - if: github.event_name != 'release' with: - ref: ${{ github.event.inputs.commit_sha || github.sha }} + ref: ${{ env.REF_NAME }} - name: Set up Go 1.22 uses: actions/setup-go@v5 @@ -71,22 +55,27 @@ jobs: shell: bash run: docker login -u publisher -p ${{ secrets.GITHUB_TOKEN }} ghcr.io - - name: Build and push [dev] - id: build-dev - if: github.event_name != 'release' + - name: Replace slashes in ref name + id: replace_ref + run: echo "TAG_NAME=${TAG_NAME//\//-}" >> $GITHUB_ENV + + - name: Build and push [with latest] + id: build-with-latest + if: ${{ env.PUSH_LATEST == 'true' }} uses: docker/build-push-action@v6 with: context: . file: ./contrib/envoyproxy/envoy/cmd/serviceextensions/Dockerfile platforms: linux/amd64,linux/arm64 push: true - tags: | # Use the commit SHA from the manual trigger or default to the SHA from the push event - ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ steps.get_tag_name.outputs.tag }} - ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ github.event.inputs.commit_sha || github.sha }} + tags: | + ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ env.TAG_NAME }} + ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ env.COMMIT_SHA }} + ghcr.io/datadog/dd-trace-go/service-extensions-callout:latest - - name: Build and push [release] - id: build-release - if: github.event_name == 'release' + - name: Build and push [without latest] + id: build-manual + if: ${{ env.PUSH_LATEST == 'false' }} uses: docker/build-push-action@v6 with: context: . @@ -94,6 +83,6 @@ jobs: platforms: linux/amd64,linux/arm64 push: true tags: | + ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ env.TAG_NAME }} + ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ env.COMMIT_SHA }} ghcr.io/datadog/dd-trace-go/service-extensions-callout:latest - ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ steps.get_tag_name.outputs.tag }} - ghcr.io/datadog/dd-trace-go/service-extensions-callout:${{ github.sha }} \ No newline at end of file