From e1c71327c5286443f01ab69f94c09526ba75bd44 Mon Sep 17 00:00:00 2001 From: fkwp Date: Mon, 15 Apr 2024 08:53:42 +0000 Subject: [PATCH] refactored to reuse the build workflow --- .github/workflows/publish.yaml | 84 +++++++++++++--------------------- 1 file changed, 32 insertions(+), 52 deletions(-) diff --git a/.github/workflows/publish.yaml b/.github/workflows/publish.yaml index c35a4cea..f5d76393 100644 --- a/.github/workflows/publish.yaml +++ b/.github/workflows/publish.yaml @@ -3,17 +3,31 @@ name: Build & publish images to the package registry for tags on: release: types: [published] - push: + workflow_run: + workflows: ["Build"] branches: [livekit] + types: + - completed env: REGISTRY: ghcr.io IMAGE_NAME: ${{ github.repository }} jobs: - build: - name: Build & publish + build_element_call: + if: ${{ github.event.workflow_run.event == 'release' }} + uses: ./.github/workflows/element-call.yaml + secrets: + SENTRY_ORG: ${{ secrets.SENTRY_ORG }} + SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }} + SENTRY_URL: ${{ secrets.SENTRY_URL }} + SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} + vite_app_version: ${{ github.event.release.tag_name || github.sha }} + publish_tarball: + name: Publish tarball runs-on: ubuntu-latest + outputs: + unix_time: ${{steps.current-time.outputs.unix_time}} permissions: contents: write # required to upload release asset packages: write @@ -21,64 +35,30 @@ jobs: - name: Get current time id: current-time run: echo "unix_time=$(date +'%s')" >> $GITHUB_OUTPUT - - - name: Check it out - uses: actions/checkout@v4 - - - name: Log in to container registry - uses: docker/login-action@5f4866a30a54f16a52d2ecb4a3898e9e424939cf + - name: 📥 Download artifact + uses: actions/download-artifact@v4 with: - registry: ${{ env.REGISTRY }} - username: ${{ github.actor }} - password: ${{ secrets.GITHUB_TOKEN }} - - - name: Yarn cache - uses: actions/setup-node@v4 - with: - cache: "yarn" - - name: Install dependencies - run: "yarn install" - - name: Build - run: "yarn run build" - env: - SENTRY_ORG: ${{ secrets.SENTRY_ORG }} - SENTRY_PROJECT: ${{ secrets.SENTRY_PROJECT }} - SENTRY_URL: ${{ secrets.SENTRY_URL }} - SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} - VITE_APP_VERSION: ${{ github.event.release.tag_name || github.sha }} - + github-token: ${{ secrets.GITHUB_TOKEN }} + run-id: ${{ github.event.workflow_run.id }} + name: build-output + path: dist - name: Create Tarball env: TARBALL_VERSION: ${{ github.event.release.tag_name || github.sha }} run: | tar --numeric-owner --transform "s/dist/element-call-${TARBALL_VERSION}/" -cvzf element-call-${TARBALL_VERSION}.tar.gz dist - - name: Upload uses: actions/upload-artifact@ef09cdac3e2d3e60d8ccadda691f4f1cec5035cb env: GITHUB_TOKEN: ${{ github.token }} with: path: "./element-call-*.tar.gz" - - - name: Extract metadata (tags, labels) for Docker - id: meta - uses: docker/metadata-action@1294d94f8ee362ab42b6da04c35f4cd03a0e6af7 - with: - images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} - tags: | - type=sha,format=short,event=branch - type=semver,pattern=v{{version}} - type=raw,value=latest-ci,enable={{is_default_branch}} - type=raw,value=latest-ci_${{steps.current-time.outputs.unix_time}},enable={{is_default_branch}} - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@d70bba72b1f3fd22344832f00baa16ece964efeb - - - name: Build and push Docker image - uses: docker/build-push-action@f8bc7f46003ef0cf98b715743d86c2f1ccd01436 - with: - context: . - platforms: linux/amd64,linux/arm64 - push: true - tags: ${{ steps.meta.outputs.tags }} - labels: ${{ steps.meta.outputs.labels }} + publish_docker: + needs: publish_tarball + uses: ./.github/workflows/docker.yaml + with: + docker_tags: | + type=sha,format=short,event=branch + type=semver,pattern=v{{version}} + type=raw,value=latest-ci,enable={{is_default_branch}} + type=raw,value=latest-ci_${{needs.publish_tarball.outputs.unix_time}},enable={{is_default_branch}}