gitcommitshow / rudder-github-app

A GitHub app for better Open Source collaboration on GitHub
MIT License
0 stars 1 forks source link

Rudder GitHub App

A Node.js server for GitHub app to assist external contributors and save maintainers' time

Roadmap

Requirements

Development setup

  1. Clone this repository.
  2. Create a .env file similar to .env.example and set actual values. If you are using GitHub Enterprise Server, also include a ENTERPRISE_HOSTNAME variable and set the value to the name of your GitHub Enterprise Server instance.
  3. Install dependencies with npm install.
  4. Start the server with npm run server.
  5. Ensure your server is reachable from the internet.
    • If you're using smee, run smee -u <smee_url> -t http://localhost:3000/api/webhook.
  6. Ensure your GitHub App includes at least one repository on its installations.

Deployment

Using Docker

  1. Register a GitHub app for your GitHub organization. Make sure to activate the webhook with webhook url https://YOUR_WEBSITE/api/webhook in your app with a secret. Enable Permissions & Events as you may need, at minimum pull_request and issue related events should be enabled.
  2. Install your GitHub app in all the repos where you need this app.
  3. Clone this repo OR download the build/docker-compose.yml to install via dockerhub image
  4. Update docker-compose.yml environment variables with the details received from the step 2

    To convert GitHub App's private key to base64, use this command - openssl base64 -in /path/to/original-private-key.pem -out ./base64EncodedKey.txt -A

  5. Run docker-componse build to build the service
  6. Run docker-compose up to create and start the container
  7. Test by visiting http://localhost:3000 OR whatever WEBSITE_ADDRESS environment variable you've configured

Usage

With your server running, you can now create a pull request on any repository that your app can access. GitHub will emit a pull_request.opened event and will deliver the corresponding Webhook payload to your server.

The server in this example listens for pull_request.opened events and acts on them by creating a comment on the pull request, with the message in message.md, using the octokit.js rest methods.

Security considerations

To keep things simple, this example reads the GITHUB_APP_PRIVATE_KEY from the environment. A more secure and recommended approach is to use a secrets management system like Vault, or one offered by major cloud providers: Azure Key Vault, AWS Secrets Manager, Google Secret Manager, etc.

References