Library webhooks
data:image/s3,"s3://crabby-images/c596a/c596a56a7781ba2ee8b86ed22e5c0b2c30a0ce6e" alt=""
data:image/s3,"s3://crabby-images/35d7a/35d7a21175d06d1222074ac862245bce64f48e30" alt="Project status"
[data:image/s3,"s3://crabby-images/33cc9/33cc939f88a0a26bc4c89eb40b952334e7ceb53c" alt="Build Status"](https://semaphoreci.com/joeybloggs/webhooks)
[data:image/s3,"s3://crabby-images/10411/104111234499d9da55cc882a28c5925ea6a26dca" alt="Coverage Status"](https://coveralls.io/github/go-playground/webhooks?branch=v2)
[data:image/s3,"s3://crabby-images/17413/174135f2bda80c781e7ca2f47f3b9c50e92b0f10" alt="Go Report Card"](https://goreportcard.com/report/go-playground/webhooks)
[data:image/s3,"s3://crabby-images/053b7/053b7fdf175bfb41e0d5dad18f60c1e900438d47" alt="GoDoc"](https://godoc.org/gopkg.in/go-playground/webhooks.v2)
data:image/s3,"s3://crabby-images/5e2e4/5e2e4566fe93c0ee198efffd3b316e2611b7a6b6" alt="License"
Library webhooks allows for easy recieving and parsing of GitHub & Bitbucket Webhook Events
Features:
- Parses the entire payload, not just a few fields.
- Fields + Schema directly lines up with webhook posted json
Notes:
- Github - Currently only accepting json payloads.
Installation
Use go get.
go get -u gopkg.in/go-playground/webhooks.v2
Then import the validator package into your own code.
import "gopkg.in/go-playground/webhooks.v2"
Usage and documentation
Please see http://godoc.org/gopkg.in/go-playground/webhooks.v2 for detailed usage docs.
Examples:
Multiple Handlers for each event you subscribe to
package main
import (
"fmt"
"strconv"
"gopkg.in/go-playground/webhooks.v2"
"gopkg.in/go-playground/webhooks.v2/github"
)
const (
path = "/webhooks"
port = 3016
)
func main() {
hook := github.New(&github.Config{Secret: "MyGitHubSuperSecretSecrect...?"})
hook.RegisterEvents(HandleRelease, github.ReleaseEvent)
hook.RegisterEvents(HandlePullRequest, github.PullRequestEvent)
err := webhooks.Run(hook, ":"+strconv.Itoa(port), path)
if err != nil {
fmt.Println(err)
}
}
// HandleRelease handles GitHub release events
func HandleRelease(payload interface{}, header webhooks.Header) {
fmt.Println("Handling Release")
pl := payload.(github.ReleasePayload)
// only want to compile on full releases
if pl.Release.Draft || pl.Release.Prelelease || pl.Release.TargetCommitish != "master" {
return
}
// Do whatever you want from here...
fmt.Printf("%+v", pl)
}
// HandlePullRequest handles GitHub pull_request events
func HandlePullRequest(payload interface{}, header webhooks.Header) {
fmt.Println("Handling Pull Request")
pl := payload.(github.PullRequestPayload)
// Do whatever you want from here...
fmt.Printf("%+v", pl)
}
Single receiver for events you subscribe to
package main
import (
"fmt"
"strconv"
"gopkg.in/go-playground/webhooks.v2"
"gopkg.in/go-playground/webhooks.v2/github"
)
const (
path = "/webhooks"
port = 3016
)
func main() {
hook := github.New(&github.Config{Secret: "MyGitHubSuperSecretSecrect...?"})
hook.RegisterEvents(HandleMultiple, github.ReleaseEvent, github.PullRequestEvent) // Add as many as you want
err := webhooks.Run(hook, ":"+strconv.Itoa(port), path)
if err != nil {
fmt.Println(err)
}
}
// HandleMultiple handles multiple GitHub events
func HandleMultiple(payload interface{}, header webhooks.Header) {
fmt.Println("Handling Payload..")
switch payload.(type) {
case github.ReleasePayload:
release := payload.(github.ReleasePayload)
// Do whatever you want from here...
fmt.Printf("%+v", release)
case github.PullRequestPayload:
pullRequest := payload.(github.PullRequestPayload)
// Do whatever you want from here...
fmt.Printf("%+v", pullRequest)
}
}
Contributing
Pull requests for other service like BitBucket are welcome!
There will always be a development branch for each version i.e. v1-development
. In order to contribute,
please make your pull requests against those branches.
If the changes being proposed or requested are breaking changes, please create an issue, for discussion
or create a pull request against the highest development branch for example this package has a
v1 and v1-development branch however, there will also be a v2-development branch even though v2 doesn't exist yet.
License
Distributed under MIT License, please see license file in code for more details.