name: Release on: schedule: - cron: "0 9 * * 0" issue_comment: types: [created] jobs: manual_trigger: name: Manual Trigger Cleanup runs-on: ubuntu-latest if: ${{ gitea.event_name == 'issue_comment' }} steps: - name: Log event metadata run: | echo "Issue: ${{ gitea.event.issue.number }}" echo "Comment: ${{ gitea.event.comment.body }}" echo "User: ${{ gitea.event.comment.user.login }}" - name: Stop workflow if required conditions are not met if: ${{ !contains(gitea.event.issue.number, '436') || !contains(gitea.event.comment.body, '/trigger-release') || !contains(gitea.event.comment.user.login, 'luke') }} run: exit 1 - name: Delete issue comment run: | curl -X DELETE \ -H "Authorization: token ${{ gitea.token }}" \ "${{ gitea.server_url }}/api/v1/repos/${{ gitea.repository }}/issues/comments/${{ gitea.event.comment.id }}" # test: # name: Unit Test # uses: https://git.tainton.uk/public/webexmemebot/.gitea/workflows/ci.yml@main # continue-on-error: true create_release: name: Create Release runs-on: ubuntu-latest # needs: test outputs: release_name: ${{ steps.get_next_version.outputs.tag }} steps: - name: Check out repository uses: actions/checkout@v4.2.2 with: fetch-depth: 0 - name: Changes since last tag id: changes run: | rm -f .changes git log $(git describe --tags --abbrev=0)..HEAD --no-merges --oneline >> .changes cat .changes - name: Check for changes run: | if [[ -z $(grep '[^[:space:]]' .changes) ]] ; then echo "changes=false" echo "changes=false" >> "$GITEA_OUTPUT" else echo "changes=true" echo "changes=true" >> "$GITEA_OUTPUT" fi - name: Cancel if no changes if: steps.changes.outputs.changes == 'false' run: exit 1 - name: Set server URL id: set_srvurl run: | SRVURL=$(echo "${{ gitea.server_url }}" | sed 's/https:\/\/\(.*\)/\1/') echo "srvurl=$SRVURL" >> "$GITEA_OUTPUT" - name: Get next version uses: TriPSs/conventional-changelog-action@v6 id: get_next_version with: git-url: ${{ steps.set_srvurl.outputs.srvurl }} github-token: ${{ gitea.token }} skip-commit: true release-count: 1 output-file: false create-summary: true skip-on-empty: true skip-version-file: true skip-tag: true - name: Create release run: | curl -s -X POST \ -H "Authorization: token ${{ secrets.ACTIONS_TOKEN }}" \ -H "accept: application/json" \ -H "Content-Type: application/json" \ -d "{\"tag_name\": \"${{ steps.get_next_version.outputs.tag }}\", \"name\": \"${{ steps.get_next_version.outputs.tag }}\", \"body\": \"${{ steps.get_next_version.outputs.changelog }}\"}" \ "${{ gitea.server_url }}/api/v1/repos/${{ gitea.repository }}/releases" build_docker_ghcr: name: Build GHCR Docker Images needs: create_release steps: - name: Check out repository uses: actions/checkout@v4 with: fetch-depth: 0 ref: ${{ needs.create_release.outputs.release_name }} - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Log in to GitHub Container Registry uses: docker/login-action@v3 with: registry: ghcr.io username: luketainton password: ${{ secrets.GHCR_TOKEN }} - name: Extract metadata (tags, labels) for Docker id: meta uses: docker/metadata-action@v5 with: images: ghcr.io/luketainton/webexmemebot tags: type=semver,pattern=v{{version}},value=${{ needs.create_release.outputs.release_name }} - name: Build and push images id: build_push uses: docker/build-push-action@v6 with: context: . push: true labels: ${{ steps.meta.outputs.labels }} tags: | ghcr.io/luketainton/webexmemebot:latest ghcr.io/luketainton/webexmemebot:${{ needs.create_release.outputs.release_name }} - name: Generate artifact attestation uses: actions/attest-build-provenance@v2 with: subject-name: ghcr.io/luketainton/webexmemebot subject-digest: ${{ steps.build_push.outputs.digest }} push-to-registry: true build_docker_gitea: name: Build Gitea Docker Images needs: create_release steps: - name: Check out repository uses: actions/checkout@v4 with: fetch-depth: 0 ref: ${{ needs.create_release.outputs.release_name }} - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Log in to Gitea Container Registry uses: docker/login-action@v3 with: registry: ${{ vars.PACKAGES_REGISTRY_URL }} username: ${{ vars.ACTIONS_USERNAME }} password: ${{ secrets.ACTIONS_TOKEN }} - name: Build Gitea image(s) uses: docker/build-push-action@v6 with: context: . push: false labels: ${{ steps.meta.outputs.labels }} tags: | ${{ vars.PACKAGES_REGISTRY_URL }}/${{ gitea.repository }}:latest ${{ vars.PACKAGES_REGISTRY_URL }}/${{ gitea.repository }}:${{ needs.create_release.outputs.release_name }} - name: Push Gitea image(s) run: | docker push ${{ vars.PACKAGES_REGISTRY_URL }}/${{ gitea.repository }}:latest docker push ${{ vars.PACKAGES_REGISTRY_URL }}/${{ gitea.repository }}:${{ needs.create_release.outputs.release_name }}