71 lines
2.7 KiB
YAML
71 lines
2.7 KiB
YAML
name: Publish Canary Image
|
|
|
|
# Revert to https://github.com/actions-runner-controller/releases#releases
|
|
# for details on why we use this approach
|
|
on:
|
|
push:
|
|
branches:
|
|
- master
|
|
paths-ignore:
|
|
- '**.md'
|
|
- '.github/ISSUE_TEMPLATE/**'
|
|
- '.github/workflows/validate-chart.yaml'
|
|
- '.github/workflows/publish-chart.yaml'
|
|
- '.github/workflows/publish-arc.yaml'
|
|
- '.github/workflows/runners.yaml'
|
|
- '.github/workflows/validate-entrypoint.yaml'
|
|
- '.github/renovate.*'
|
|
- 'runner/**'
|
|
- '.gitignore'
|
|
- 'PROJECT'
|
|
- 'LICENSE'
|
|
- 'Makefile'
|
|
|
|
env:
|
|
# Safeguard to prevent pushing images to registeries after build
|
|
PUSH_TO_REGISTRIES: true
|
|
TARGET_ORG: actions-runner-controller
|
|
TARGET_REPO: actions-runner-controller
|
|
|
|
# https://docs.github.com/en/rest/overview/permissions-required-for-github-apps
|
|
permissions:
|
|
contents: read
|
|
|
|
jobs:
|
|
canary-build:
|
|
name: Build and Publish Canary Image
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v3
|
|
|
|
- name: Get Token
|
|
id: get_workflow_token
|
|
uses: peter-murray/workflow-application-token-action@8e1ba3bf1619726336414f1014e37f17fbadf1db
|
|
with:
|
|
application_id: ${{ secrets.ACTIONS_ACCESS_APP_ID }}
|
|
application_private_key: ${{ secrets.ACTIONS_ACCESS_PK }}
|
|
organization: ${{ env.TARGET_ORG }}
|
|
|
|
- name: Trigger Build And Push Images To Registries
|
|
run: |
|
|
# Authenticate
|
|
gh auth login --with-token <<< ${{ steps.get_workflow_token.outputs.token }}
|
|
|
|
# Trigger the workflow run
|
|
jq -n '{"event_type": "canary", "client_payload": {"sha": "${{ github.sha }}", "push_to_registries": ${{ env.PUSH_TO_REGISTRIES }}}}' \
|
|
| gh api -X POST /repos/actions-runner-controller/releases/dispatches --input -
|
|
|
|
- name: Job summary
|
|
run: |
|
|
echo "The [publish-canary](https://github.com/actions-runner-controller/releases/blob/main/.github/workflows/publish-canary.yaml) workflow has been triggered!" >> $GITHUB_STEP_SUMMARY
|
|
echo "" >> $GITHUB_STEP_SUMMARY
|
|
echo "**Parameters:**" >> $GITHUB_STEP_SUMMARY
|
|
echo "- sha: ${{ github.sha }}" >> $GITHUB_STEP_SUMMARY
|
|
echo "- Push to registries: ${{ env.PUSH_TO_REGISTRIES }}" >> $GITHUB_STEP_SUMMARY
|
|
echo "" >> $GITHUB_STEP_SUMMARY
|
|
echo "**Status:**" >> $GITHUB_STEP_SUMMARY
|
|
echo "[https://github.com/actions-runner-controller/releases/actions/workflows/publish-canary.yaml](https://github.com/actions-runner-controller/releases/actions/workflows/publish-canary.yaml)" >> $GITHUB_STEP_SUMMARY
|