GitHub Integration

Brigade provides GitHub integration for triggering Brigade builds from GitHub events.

Brigade integrates with GitHub by providing GitHub webhook implementations for the following events:

You must be running brigade-github-gateway in a way that makes it available to GitHub. (For example, assign it a publicly routable IP and domain name.)

Configuring Your Project

Brigade uses projects to tie repositories to builds. You may want to check out the project documentation if you haven’t already. This section explains what parts of your project are required for GitHub integration to function.

In your project’s values.yaml file, you should make sure the following are set for GitHub integration to work:

# Set to your github user/project or org/project
project: "technosophos/coffeesnob"

# The full name of the repository
repository: "github.com/technosophos/coffeesnob"

# The URL to use to clone. You can use any supported GitHub URL scheme
cloneURL: "https://github.com/technosophos/coffeesnob.git"

# A long shared secret. In the "Configuring GitHub" section, this is simply called
# Secret.
# You get to make this up. It should be a long string of arbitrary alphanumeric
# characters.
sharedSecret: 09879879879879879879879871

# Your GitHub OAuth2 token.
github:
   token: "1111111111111111111112222222222222111111"

You can learn more about generating OAuth2 tokens from the official GitHub documentation.

Make sure you run helm upgrade if you changed any parameters above (or helm install if you are creating a new project).

Configuring GitHub

To add a Brigade project to GitHub:

  1. Go to “Settings”
  2. Click “Webhooks”
  3. Click the “Add webhook” button
  4. For “Payload URL”, add the URL: “http://YOUR_HOSTNAME:7744/events/github”
  5. For “Content type”, choose “application/json”
  6. For “Secret”, use the secret you configured in your Helm config.
  7. Choose “Just the push event” or choose specific events you want to receive, such as “push” and “pull_request”.

Each event you select here will increase the number of events that fire within the Brigade system. We recommend only enabling the events that you are using, as enabling unused events will merely result in extra load on your system.

GitHub Webhook Config

You may use GitHub’s testing page to verify that GitHub can successfully send an event to the Brigade gateway.

Finding Your Gateway’s URL

To find your “Payload URL” IP address, you can run this command on your Kubernetes cluster:

$ kubectl get service
NAME                  TYPE           CLUSTER-IP   EXTERNAL-IP   PORT(S)          AGE
brigade-brigade-api   ClusterIP      10.0.0.57    <none>        7745/TCP         8h
brigade-brigade-gw    LoadBalancer   10.0.0.157   10.21.77.9    7744:31946/TCP   8h

The EXTERNAL-IP for the brigade-gw service is the one you will use. You can map this to a DNS name if you wish.

The gateway listens on port 7744, so the URL for the above will be http://10.21.77.9:7744/events/github

Protectecting Your Gateway with SSL/TLS

You may optionally use the Kube LEGO Helm chart and set up an NGINX SSL proxy in front of your Brigade Gateway (brigade-gw) service.

In this case, once the NGINX proxy is set up with SSL, you can point your GitHub “Payload URL” to the proxy instead of directly at the brigade-gw service.

Configuring the GitHub Gateway

Running Pull Requests from untrusted parties is dangerous. It can consume your Brigade resources, or even (in some cases) allow access to private information like your project.secrets.

For that reason, the Brigade GitHub gateway tries to protect your repo by default.

  1. By default, when you install Brigade, the GitHub gateway is configured to ignore pull requests that come from forks.

  2. By default, your Brigade GitHub gateway is configured to ONLY build PRs that were submitted by authors with trusted roles:

    • OWNER: The repo owner
    • COLLABORATOR: Someone who is an invited collaborator on the project
    • MEMBER: Someone who is a member of the organization that this repo belongs to

There are two configuration options that can alter these defaults:

Here is an example that upgrades Brigade to allow forked builds, but only from the OWNER and COLLABORATOR author roles:

$ helm upgrade brigade brigade/brigade \
  --set gw.buildForkedPullRequests=true \
  --set gw.allowedAuthorRoles=COLLABORATOR\,OWNER \
  --reuse-values

Note that this configuration will not eliminate all possibilities of mis-use (a comprimized GitHub account is still a vector of attack). But it will restrict PRs to only accounts that are owners or collaborators (invited contributors) on the main repository.

Connecting to Private GitHub Repositories (or Using SSH)

Sometimes it is better to configure Brigade to interact with GitHub via SSH. For example, if your repository is private and you don’t want to allow anonymous Git clones, you may need to use an SSH GitHub URL. To use GitHub with SSH, you will also need to create a Deployment Key.

To create a new GitHub Deployment Key, generate an SSH key. On UNIX-like systems, this is done with ssh-keygen -f ./github_deployment_key. When prompted to set a passphrase, do not set a passphrase.

ssh-keygen -f ./github_deployment_key
Generating public/private rsa key pair.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in ./github_deployment_key.
Your public key has been saved in ./github_deployment_key.pub.
...

In GitHub, navigate to your project, choose Settings (the gear icon), then choose Depoyment Keys from the left-hand navigation. Click the Add deploy key button.

The Title field should be something like brigade-checkout, though the intent of this field is just to help you remember that this key was used by Brigade.

The Key field should be the content of the ./github_deployment_key.pub file generated by ssh-keygen above.

Save that key.

Inside of your project configuration for your brigade-project, make sure to add your key:

myvalues.yaml:

project: "my/brigade-project"
repository: "github.com/my/brigade-project"
# This is an SSH clone URL
cloneURL: "git@github.com:my/brigade-project.git"
# paste your entire key here:
sshKey: |-
  -----BEGIN RSA PRIVATE KEY-----
  MIIEowIBAAKCAQEAupolYH/x2+V+L15ci3PU75GX8aKTWZzCPkX3qNqRqiO5q0LV
  nMIVeMSqrLDHSGnbUF6DN3EgKuwdv0bfiq3Cz1rjtszQX6ti50ICObGphU+6dTwO
  # removed some lines
  9KjBbQKBgA23dOOF98EjLcCZm/lky+Ifu2ZSbi+5N8MlbP3+5rWIgw74iAo6KHFb
  v/mHCUT7SWguIdNGzdAD+wYHG2W14fu+IQCWQ6oaZauHHqlxGrXH
  -----END RSA PRIVATE KEY-----
# The rest of your config...

Then you can install (or upgrade) your project:

$ helm install -n my-project brigade/brigade-project -f myvalues.yaml

Now your project is configured to clone via SSH using the deployment key we generated.