Skip to main content

Delivering webhooks to private systems

In order to limit exposure of your private system to the internet, you can use a reverse proxy to forward webhooks from GitHub to your private system.

About integrating with private systems via reverse proxy

You may want to deliver GitHub webhooks to private systems that are not directly accessible from the internet, such as CI systems, work management tools, and custom apps. You can use a reverse proxy to receive webhook payloads from GitHub and deliver them to the your private system.

A reverse proxy is a web server that sits between a client and an application. The reverse proxy receives requests from the client and forwards them to the application. This ensures no direct communication occurs between clients on the internet and the underlying application. A variety of systems can serve a reverse proxy, including:

  • Web servers, like nginx
  • API gateways
  • Free, open-source overlay networks, like OpenZiti
  • Commercial ingress management tools, like ngrok
  • Free, open-source ingress management tools, like zrok

How you configure your reverse proxy varies based on the system you're using.

Securing traffic to your reverse proxy

When deploying a reverse proxy, you should follow all practices recommended by your reverse proxy provider to secure the underlying proxy server. Additionally, you should take the following steps to verify that only requests from GitHub are forwarded to your application.

Limiting inbound traffic to GitHub webhooks

You should configure your reverse proxy to only allow HTTPS POST requests from the subset of GitHub IP ranges that are used to deliver webhooks. This ensures that your reverse proxy does not process or forward other requests.

The /meta endpoint returns a JSON object listing GitHub's IP ranges. IP ranges used to deliver webhooks are listed in the hooks element.

Validating webhook payloads

If your webhook is configured with a secret token, GitHub will include a cryptographic hash of each webhook payload. You should use this hash to validate the payload received from GitHub before any action is taken by your private system. For more information, see Validating webhook deliveries.

You can implement payload validation either on the reverse proxy or on your private system.