MediaWarp Build and Release #1
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: MediaWarp Build and Release | |
| on: | |
| workflow_dispatch: | |
| push: | |
| branches: | |
| - main | |
| tags: | |
| - v* | |
| paths: | |
| - "**.go" | |
| - "go.mod" | |
| - "go.sum" | |
| permissions: | |
| contents: write | |
| packages: write | |
| actions: write | |
| jobs: | |
| release: | |
| runs-on: ubuntu-latest | |
| env: | |
| IS_RELEASE: ${{ startsWith(github.ref, 'refs/tags/') }} | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v4 | |
| with: | |
| submodules: true | |
| fetch-depth: 0 | |
| - name: Set up Go | |
| uses: actions/setup-go@v5 | |
| with: | |
| go-version-file: "go.mod" # 使用 go.mod 文件中的 golang 版本 | |
| - name: Set up QEMU | |
| uses: docker/setup-qemu-action@v3 | |
| - name: Set up Docker Buildx | |
| uses: docker/setup-buildx-action@v3 | |
| - name: Login to DockerHub | |
| uses: docker/login-action@v3 | |
| with: | |
| username: ${{ secrets.DOCKERHUB_USERNAME }} | |
| password: ${{ secrets.DOCKERHUB_TOKEN }} | |
| - name: Run GoReleaser (tag release) | |
| if: ${{ env.IS_RELEASE == 'true' }} | |
| uses: goreleaser/goreleaser-action@v6 | |
| with: | |
| distribution: goreleaser | |
| version: "~> v2" | |
| args: release --clean | |
| env: | |
| GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Run GoReleaser (pre-release for branch push) | |
| if: ${{ env.IS_RELEASE != 'true' }} | |
| uses: goreleaser/goreleaser-action@v6 | |
| with: | |
| distribution: goreleaser | |
| version: "~> v2" | |
| args: release --clean --snapshot | |
| env: | |
| GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Prepare pre-release metadata | |
| if: ${{ env.IS_RELEASE != 'true' }} | |
| id: prerelease_meta | |
| run: | | |
| branch="${GITHUB_REF_NAME//\//-}" | |
| short_sha="${GITHUB_SHA::7}" | |
| tag="pre-${branch}-${GITHUB_RUN_NUMBER}-${short_sha}" | |
| name="PreRelease ${GITHUB_REF_NAME} #${GITHUB_RUN_NUMBER} (${short_sha})" | |
| echo "branch=${branch}" >> "$GITHUB_OUTPUT" | |
| echo "short_sha=${short_sha}" >> "$GITHUB_OUTPUT" | |
| echo "tag=${tag}" >> "$GITHUB_OUTPUT" | |
| echo "name=${name}" >> "$GITHUB_OUTPUT" | |
| - name: Create GitHub pre-release and upload artifacts | |
| if: ${{ env.IS_RELEASE != 'true' }} | |
| uses: softprops/action-gh-release@v2 | |
| with: | |
| tag_name: pre-release | |
| target_commitish: ${{ github.sha }} | |
| name: ${{ steps.prerelease_meta.outputs.name }} | |
| prerelease: true | |
| generate_release_notes: true | |
| files: | | |
| dist/*.tar.gz | |
| dist/*.zip | |
| dist/*checksums*.txt | |
| dist/config.yaml | |
| env: | |
| GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Build and push Docker pre-release image | |
| if: ${{ env.IS_RELEASE != 'true' }} | |
| uses: docker/build-push-action@v6 | |
| with: | |
| context: . | |
| file: ./docker/Dockerfile | |
| platforms: | | |
| linux/amd64 | |
| linux/arm/v8 | |
| linux/arm/v7 | |
| linux/arm/v6 | |
| push: true | |
| tags: | | |
| akimio/mediawarp:prerelease-${{ steps.prerelease_meta.outputs.short_sha }} | |
| akimio/mediawarp:prerelease-${{ steps.prerelease_meta.outputs.branch }} | |
| akimio/mediawarp:prerelease-latest | |
| labels: | | |
| org.opencontainers.image.created=${{ github.run_id }} | |
| org.opencontainers.image.title=MediaWarp | |
| org.opencontainers.image.revision=${{ github.sha }} |