GitHub App
This feature is only available on the Pro and Enterprise plans.
Though our open source GitHub Actions provide a robust experience for smaller teams, it can become laborious to repeatedly configure these actions if your organization has many repositories.
The Buf GitHub App offers an easy way to seamlessly synchronize source control and your private instance of the Buf Schema Registry (BSR).
Once enabled, the app discovers repositories that have buf.yaml
files inside and reacts to pull requests against those modules with a variety of checks:
-
Breaking: The breaking check performs breaking changes detection between the current branch and the latest BSR commit to
main
. Breaking changes are displayed as file annotations on the pull request. -
Format: The format check displays formatting violations as file annotations on the pull request, and recommends running
buf format -w
to resolve them. -
Lint: The lint check performs linting of
proto
files and displays lint violations as file annotations on the pull request. -
Push: The push check pushes
buf push
a branch commit to the BSR and adds a comment to the pull request informing readers about how to consume generated code.
The app also performs a push to the BSR main
branch when pull requests are merged in GitHub, tagging the commit with
the Git SHA.
Authorizing the app
The app uses the BSR credentials of the developer who has created the pull request. It requires them to sign into the BSR, which they're prompted to do via a comment:
Hey @example-dev! You're not connected to the Buf Schema Registry (BSR). Please click here to connect.
Configuration file
The GitHub App configures the behaviour of both the lint
and breaking
checks from the buf.yaml
in each module.
Each check can be customized further by providing a .github/buf.github.yaml
file in the repository.
The buf.github.yaml
config file below demonstrates all default values being explicitly set.
This file is the equivalent of no buf.github.yaml
being present in your repository.
version: v1beta1
checks:
format:
ignore: []
skip: false
breaking:
ignore: []
skip: false
lint:
ignore: []
skip: false
push:
branches: []
version
Required. Defines the current configuration version.
The only accepted value is v1beta1
.
checks
The checks
key is a map of checks, and the accepted values are format
, lint
and breaking
.
check
configuration
ignore
The ignore
key is a list of file paths within the repository that this check should ignore.
If a directory is ignored, then all files and subfolders of the directory are also ignored.
The specified directory or file paths must be relative to the root of the repository.
skip
The skip
key is a boolean flag, if true
then this check is skipped entirely and won't run in this repository.
push
configuration
branches
The branches
key is a list of branch names or GitHub branch selection patterns.
For example, both main
and releases/*
are valid.
If empty, the app defaults to the default branch.
Setup
You can use the following URL to skip most of the configuration steps (only steps 7 and 10-13 are necessary).
Note
We use example-org
and buf.example.com
as placeholder values, but they should be substituted with your GitHub organization and private BSR instance, respectively.
https://github.com/organizations/example-org/settings/apps/new?name=buf&url=https%3A%2F%2Fbuf.example.com&callback_url=https%3A%2F%2Fbuf.example.com%2Fapp%2Fgithub%2Fcallback&webhook_url=https%3A%2F%2Fbuf.example.com%2Fapp%2Fgithub%2Fwebhook&webhook_active=true&events[]=check_run&events[]=check_suite&events[]=deployment&events[]=deployment_status&events[]=pull_request&events[]=push&checks=write&statuses=write&deployments=write&pull_requests=write&issues=write&contents=read
-
Navigate to
https://github.com/organizations/example-org/settings/apps/new
. -
Set the GitHub App name—we recommend
buf
-
Set the Homepage URL to your private BSR instance address, such as
https://buf.example.com
. -
Set the Callback URL to
https://buf.example.com/app/github/callback
. -
Under Webhook, check Active.
-
Set the Webhook URL to
https://buf.example.com/app/github/webhook
. -
Set the Webhook secret to a random generated value, and store it for later use.
-
Under Repository Permissions, configure the following:
- Checks -
Read and write
- Commit statuses -
Read and write
- Contents -
Read-only
- Deployments -
Read and write
- Issues -
Read and write
- Metadata -
Read-only
- Pull requests -
Read and write
- Checks -
-
Subscribe to the following events:
- Check run
- Check Suite
- Deployment
- Deployment Status
- Pull Request
- Push
-
If your organization is hosted on https://github.com, then make sure Where can this GitHub App be installed? is set to Only on this account. For private instances, Any Account can be selected.
-
Click Create GitHub App.
-
Once the app is created, from the app’s setting page, click on Generate a new client secret and store it for later use.
-
Click on Generate a private key and store it for later use.
Share the App ID, Client ID, Client Secret, Private Key and Webhook Secret with your Buf representative.