fix: fix ci RCE via pull_request_target
#33
Workflow file for this run
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: dockerize-runtime-exporter | |
| on: | |
| workflow_dispatch: | |
| pull_request: | |
| branches: [main] | |
| types: [opened, synchronize, reopened] | |
| paths: | |
| - "services/runtime-exporter/**" | |
| - ".github/workflows/dockerize-runtime-exporter.yml" | |
| - "!**/*.md" | |
| - "!services/runtime-exporter/package-lock.json" | |
| push: | |
| branches: [main] | |
| paths: | |
| - "services/runtime-exporter/**" | |
| - ".github/workflows/dockerize-runtime-exporter.yml" | |
| - "!**/*.md" | |
| - "!services/runtime-exporter/package-lock.json" | |
| # permissions: | |
| # pull-requests: write | |
| # packages: write | |
| # contents: read | |
| concurrency: | |
| group: dockerize-runtime-exporter-${{ github.ref }} | |
| cancel-in-progress: true | |
| jobs: | |
| dockerize-runtime-exporter: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v3 | |
| with: | |
| fetch-depth: 0 | |
| - name: Cache node modules | |
| id: cache-node-modules | |
| uses: actions/cache@v3 | |
| with: | |
| path: services/runtime-exporter/node_modules | |
| key: ${{ runner.os }}-node-${{ hashFiles('services/runtime-exporter/package-lock.json') }} | |
| - name: Use Node | |
| uses: actions/setup-node@v3 | |
| with: | |
| node-version: 18.x | |
| - name: Install Package | |
| working-directory: services/runtime-exporter | |
| if: steps.cache-node-modules.outputs.cache-hit != 'true' | |
| run: npm ci | |
| - name: Build runtime-exporter | |
| working-directory: services/runtime-exporter | |
| run: npm run build | |
| - name: Docker meta | |
| id: meta | |
| uses: docker/metadata-action@v4 | |
| with: | |
| images: | | |
| ghcr.io/${{ github.repository_owner }}/laf-runtime-exporter | |
| docker.io/${{ secrets.DOCKER_USERNAME }}/laf-runtime-exporter | |
| # https://github.com/docker/metadata-action#typesemver | |
| tags: | | |
| type=ref,event=pr | |
| type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'main') && github.event_name != 'pull_request' }} | |
| type=sha,format=short,enable=${{ github.ref == format('refs/heads/{0}', 'main') && github.event_name != 'pull_request' }} | |
| type=raw,value={{branch}}-{{sha}},enable=${{ github.ref != format('refs/heads/{0}', 'main') && !startsWith(github.ref, 'refs/tags/') && github.event_name != 'pull_request' }} | |
| - name: Set up QEMU | |
| uses: docker/setup-qemu-action@v2 | |
| - name: Set up Docker Buildx | |
| uses: docker/setup-buildx-action@v2 | |
| - name: Login to DockerHub | |
| if: github.event_name != 'pull_request' | |
| uses: docker/login-action@v2 | |
| with: | |
| username: ${{ secrets.DOCKER_USERNAME }} | |
| password: ${{ secrets.DOCKER_PASSWORD }} | |
| - name: Login to Github Container Hub | |
| if: github.event_name != 'pull_request' | |
| uses: docker/login-action@v2 | |
| with: | |
| registry: ghcr.io | |
| username: ${{ github.repository_owner }} | |
| password: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Build and push | |
| id: docker-build | |
| uses: docker/build-push-action@v3 | |
| with: | |
| context: ./services/runtime-exporter | |
| file: ./services/runtime-exporter/Dockerfile | |
| push: ${{ github.event_name != 'pull_request' }} | |
| tags: ${{ steps.meta.outputs.tags }} | |
| labels: ${{ steps.meta.outputs.labels }} | |
| platforms: linux/amd64, linux/arm64 | |
| - name: Comment docker image tags to PR | |
| if: github.event_name == 'pull_request' | |
| uses: mshick/add-pr-comment@v2 | |
| with: | |
| message-id: "dockerize-runtime-exporter" | |
| message: | | |
| **:boom: laf runtime-exporter built successfully for pr ${{ github.event.pull_request.number }}** | |
| ``` | |
| Docker image built (not pushed in PR) | |
| ``` | |
| trigger-workflow-build-cluster-image: | |
| needs: [dockerize-runtime-exporter] | |
| if: github.ref == format('refs/heads/{0}', 'main') && github.event_name != 'pull_request' | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: trigger cluster image workflow | |
| uses: peter-evans/repository-dispatch@v2 | |
| with: | |
| event-type: docker_build_success | |
| client-payload: '{"ref": "${{ github.ref }}", "sha": "${{ github.sha }}", "version": "latest"}' |