🔥Save up to $132K/month in CI costs!Try Free
Skip to main content
← Back to workflows

How to Create a Repository Dispatch Event with GitHub Actions

peter-evans-repository-dispatch -
GitHub Action
Repository Dispatch v3.0.0
939
Contributors
Contributor - peter-evans
Categories
Usage
name: 'Usage of repository-dispatch GitHub Action'
on:
push:
branches:
- main
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Repository Dispatch
uses: peter-evans/repository-dispatch@v3
with:
event-type: my-event

repository-dispatch logo

Repository Dispatch

A GitHub action to create a repository dispatch event


What is a Repository Dispatch Event?

With this GitHub Action, you are enabled to trigger other workflows within the same repository or even in different repositories by means of the repository dispatch event.

How to Dispatch an Event to a Remote Repository using a Personal Access Token (PAT)

The following example demonstrates how a GitHub Action can dispatch a repository event by sending a webhook event to a remote repository with a Personal Access Token (PAT) for workflow execution in different repositories.

- name: Repository Dispatch
uses: peter-evans/repository-dispatch@v3
with:
token: ${{ secrets.PAT }}
repository: username/my-repo
event-type: my-event

How to Receive a Repository Dispatch Event

Example of configuring a workflow to run on repository_dispatch: Note: repository_dispatch will only run a Workflow if it is inside the default branch.

name: Repository Dispatch
on:
repository_dispatch:
types: [my-event]
jobs:
myEvent:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
ref: ${{ github.event.client_payload.ref }}
- run: echo ${{ github.event.client_payload.sha }}

How to Dispatch Events to Multiple Repositories

You can dispatch the events to more than one repository with the matrix strategy in your GitHub Actions workflow. Below is an example of matrix strategy and an event dispatched to three different repositories upon a successful build job.

jobs:
build:
# Main workflow job that builds, tests, etc.

dispatch:
needs: build
strategy:
matrix:
repo: ['my-org/repo1', 'my-org/repo2', 'my-org/repo3']
runs-on: ubuntu-latest
steps:
- name: Repository Dispatch
uses: peter-evans/repository-dispatch@v3
with:
token: ${{ secrets.PAT }}
repository: ${{ matrix.repo }}
event-type: my-event

with All Available Options

This example demonstrates how to use a GitHub Action to dispatch a repository event to a remote repository using a Personal Access Token (PAT) and set all the input parameters. This can be useful for triggering workflows in different repositories with specific payload data.

- name: Repository Dispatch
uses: peter-evans/repository-dispatch@v3
with:
token: ${{ secrets.PAT }}
repository: username/my-repo
event-type: my-event
client-payload: '{"ref": "${{ github.ref }}", "sha": "${{ github.sha }}"}'