name: Build and push Docker image permissions: contents: read on: push: tags: - "v*" env: REGISTRY_IMAGE: hamster1963/nezha-dash ALIYUN_REGISTRY_IMAGE: registry.cn-guangzhou.aliyuncs.com/hamster-home/nezha-dash jobs: build-and-push: name: Build and push Docker image runs-on: ubuntu-latest environment: Production steps: - name: Checkout code uses: actions/checkout@v4 with: fetch-depth: 0 - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 with: driver-opts: network=host - name: Login to Docker Hub uses: docker/login-action@v3 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKERHUB_TOKEN }} - name: Login to AliYun Container Registry uses: docker/login-action@v3 with: registry: registry.cn-guangzhou.aliyuncs.com username: ${{ secrets.ALI_USERNAME }} password: ${{ secrets.ALI_TOKEN }} - name: Extract metadata (tags, labels) for Docker id: meta uses: docker/metadata-action@v5 with: images: | ${{ env.REGISTRY_IMAGE }} ${{ env.ALIYUN_REGISTRY_IMAGE }} tags: | type=raw,value=latest type=ref,event=tag - name: Build and push Docker image uses: docker/build-push-action@v6 with: context: . platforms: linux/amd64,linux/arm64 push: true tags: ${{ steps.meta.outputs.tags }} labels: ${{ steps.meta.outputs.labels }} - name: Set up Bun uses: oven-sh/setup-bun@v1 with: bun-version: "latest" - name: Changelog run: bun x changelogithub env: GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}