4.4.0 #84
Workflow file for this run
This file contains 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: Release Tasks | |
on: | |
release: | |
types: | |
- published | |
- edited | |
- deleted | |
- released # See: https://github.community/t5/GitHub-API-Development-and/Webhook-ReleaseEvent-prerelease-gt-release-notification/m-p/22612 | |
concurrency: release_tasks | |
jobs: | |
trigger-site-update: | |
name: 'Trigger Site Update' | |
permissions: | |
contents: read | |
runs-on: ubuntu-latest | |
if: (github.repository == 'Warzone2100/warzone2100') | |
environment: update_dispatch | |
# For this job to work, the following secrets must be set in the 'update_dispatch' environment: | |
# SITE_DISPATCH_ACCESS_TOKEN | |
# DEPLOY_DISPATCH_ACCESS_TOKEN | |
steps: | |
- name: 'Trigger wz2100.net update' | |
run: | | |
curl -X POST https://api.github.com/repos/Warzone2100/wz2100.net/dispatches \ | |
-H 'Accept: application/vnd.github.everest-preview+json' \ | |
-u ${{ secrets.SITE_DISPATCH_ACCESS_TOKEN }} \ | |
--data '{"event_type": "github_release_update", "client_payload": { "repository": "'"$GITHUB_REPOSITORY"'" }}' | |
- name: 'Trigger updates.json update' | |
run: | | |
curl -X POST https://api.github.com/repos/Warzone2100/update-data/dispatches \ | |
-H 'Accept: application/vnd.github.everest-preview+json' \ | |
-u ${{ secrets.SITE_DISPATCH_ACCESS_TOKEN }} \ | |
--data '{"event_type": "github_release_update", "client_payload": { "repository": "'"$GITHUB_REPOSITORY"'" }}' | |
- name: 'Trigger itch.io deployment' | |
run: | | |
curl -X POST https://api.github.com/repos/Warzone2100/itch-build/dispatches \ | |
-H 'Accept: application/vnd.github.everest-preview+json' \ | |
-u ${{ secrets.DEPLOY_DISPATCH_ACCESS_TOKEN }} \ | |
--data '{"event_type": "github_release_update", "client_payload": { "repository": "'"$GITHUB_REPOSITORY"'" }}' | |
- name: 'Trigger MSIX deployment' | |
if: (github.event.action == 'published') || (github.event.action == 'released') | |
run: | | |
curl -X POST https://api.github.com/repos/wz-packaging/wz-ms-packaging/dispatches \ | |
-H 'Accept: application/vnd.github.everest-preview+json' \ | |
-u ${{ secrets.DEPLOY_DISPATCH_ACCESS_TOKEN }} \ | |
--data '{"event_type": "github_release_update", "client_payload": { "repository": "'"$GITHUB_REPOSITORY"'" }}' | |
sentry-release-commit-info: | |
name: 'Upload Release Commit Info' | |
permissions: | |
contents: read | |
runs-on: ubuntu-latest | |
if: ((github.event.action == 'published') || (github.event.action == 'released')) && (github.repository == 'Warzone2100/warzone2100') | |
environment: upload_symbols | |
# For this job to work, the following secrets must be set in the 'upload_symbols' environment: | |
# SENTRY_AUTH_TOKEN | |
steps: | |
- name: Prep Environment | |
run: | | |
mkdir empty-folder | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
path: 'src' | |
- name: Prepare Git Repo for autorevision | |
working-directory: '${{ github.workspace }}/src' | |
run: cmake -P .ci/githubactions/prepare_git_repo.cmake | |
- name: 'List tags' | |
working-directory: '${{ github.workspace }}/src' | |
run: | | |
git tag --list | |
- name: 'Collect release info' | |
working-directory: '${{ github.workspace }}/src' | |
run: | | |
CURRENT_TAG="${GITHUB_REF#refs/tags/}" | |
echo "CURRENT_TAG=${CURRENT_TAG}" | |
SENTRY_VERSION="warzone2100@${CURRENT_TAG}" | |
echo "SENTRY_VERSION=${SENTRY_VERSION}" | |
# Get commit of prior release tag | |
PRIOR_TAG="$(git describe --abbrev=0 ${GITHUB_REF}^)" | |
echo "PRIOR_TAG=${PRIOR_TAG}" | |
PRIOR_TAG_COMMIT="$(git rev-list -n 1 "refs/tags/${PRIOR_TAG}")" | |
echo "PRIOR_TAG_COMMIT=${PRIOR_TAG_COMMIT}" | |
# Get commit of current release tag | |
CURRENT_TAG_COMMIT="$(git rev-list -n 1 "${GITHUB_REF}")" | |
echo "CURRENT_TAG_COMMIT=${CURRENT_TAG_COMMIT}" | |
echo "SENTRY_VERSION=${SENTRY_VERSION}" >> $GITHUB_ENV | |
echo "PRIOR_TAG_COMMIT=${PRIOR_TAG_COMMIT}" >> $GITHUB_ENV | |
echo "CURRENT_TAG_COMMIT=${CURRENT_TAG_COMMIT}" >> $GITHUB_ENV | |
- name: 'Upload Sentry release info' | |
if: (github.repository == 'Warzone2100/warzone2100') | |
working-directory: '${{ github.workspace }}/empty-folder' | |
env: | |
SENTRY_AUTH_TOKEN: '${{ secrets.SENTRY_AUTH_TOKEN }}' | |
SENTRY_ORG: 'warzone2100' | |
run: | | |
if [[ -z "${SENTRY_AUTH_TOKEN}" ]]; then | |
echo "No SENTRY_AUTH_TOKEN - skipping" | |
exit 0 | |
fi | |
if [[ -z "${SENTRY_VERSION}" ]]; then | |
echo "No SENTRY_VERSION - skipping" | |
exit 0 | |
fi | |
docker pull getsentry/sentry-cli | |
# Check if release already exists | |
echo "Checking if release exists: ${SENTRY_VERSION}" | |
if ! docker run --rm -e SENTRY_AUTH_TOKEN -e SENTRY_ORG -v "$(pwd):/work" getsentry/sentry-cli releases info "${SENTRY_VERSION}" -q; then | |
# Create the release | |
echo "Creating the release: ${SENTRY_VERSION}" | |
docker run --rm -e SENTRY_AUTH_TOKEN -e SENTRY_ORG -v "$(pwd):/work" getsentry/sentry-cli releases new -p warzone2100 "${SENTRY_VERSION}" || echo "Failed to create the release?" | |
fi | |
# Associate commits with the release | |
echo "Associate commits with the release: ${SENTRY_VERSION}" | |
docker run --rm -e SENTRY_AUTH_TOKEN -e SENTRY_ORG -v "$(pwd):/work" getsentry/sentry-cli releases set-commits "${SENTRY_VERSION}" --commit "Warzone2100/warzone2100@${PRIOR_TAG_COMMIT}..${CURRENT_TAG_COMMIT}" |