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: name: Build Docker Images needs: create_release steps: - name: Update Docker configuration continue-on-error: true run: | mkdir -p /etc/default mkdir -p /etc/docker touch -a /etc/default/docker touch -a /etc/docker/daemon.json echo "DOCKER_OPTS=\"--insecure-registry ${{ vars.PACKAGES_REGISTRY_URL }}\"" >> /etc/default/docker echo "{\"insecure-registries\": [\"${{ vars.PACKAGES_REGISTRY_URL }}\"]}" > /etc/docker/daemon.json - 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: Log in to GitHub Container Registry uses: docker/login-action@v3 with: registry: ghcr.io username: ${{ vars.GHCR_USERNAME }} password: ${{ secrets.GHCR_TOKEN }} - name: Extract metadata (tags, labels) for Docker id: meta uses: docker/metadata-action@v5 with: images: | ghcr.io/${{ vars.GHCR_USERNAME }}/webexmemebot ${{ vars.PACKAGES_REGISTRY_URL }}/${{ gitea.repository }} tags: type=semver,pattern=v{{version}},value=${{ needs.create_release.outputs.release_name }} - name: Print metadata run: | printf "Annotations:\n${{ steps.meta.outputs.annotations }}" echo "" printf "Labels:\n${{ steps.meta.outputs.labels }}" echo "" printf "Tags:\n${{ steps.meta.outputs.tags }}" # - name: Build images # uses: docker/build-push-action@v5 # with: # context: . # push: false # annotations: ${{ steps.meta.outputs.annotations }} # labels: ${{ steps.meta.outputs.labels }} # tags: ${{ steps.meta.outputs.tags }} - name: Build images run: | bldcmd="docker buildx build" strtags="${{ steps.meta.outputs.tags }}" strlabels="${{ steps.meta.outputs.labels }}" strannotations="${{ steps.meta.outputs.annotations }}" readarray -t tags <<<"$strtags" readarray -t labels <<<"$strlabels" readarray -t annotations <<<"$strannotations" for element in "${tags[@]}"; do bldcmd="$bldcmd --tag \"$element\""; done for element in "${labels[@]}"; do bldcmd="$bldcmd --label \"$element\""; done for element in "${annotations[@]}"; do bldcmd="$bldcmd --annotation \"$element\""; done bldcmd="$bldcmd ${{ gitea.workspace }}" echo "$bldcmd" echo "" sh -c "$bldcmd" - name: Push images run: | strtags="${{ steps.meta.outputs.tags }}" readarray -t lines <<<"$strtags" for element in "${lines[@]}"; do docker push "$element"; done unset strtags lines