Golang SDK for CloudEvents
Official CloudEvents SDK to integrate your application with CloudEvents.
This module will help you to:
- Represent CloudEvents in memory
- Use Event Formats to serialize/deserialize CloudEvents
- Use Protocol Bindings to send/receive CloudEvents
Note: Supported CloudEvents specification: 0.3, 1.0
Get started
Add the module as dependency using go mod:
% go get github.com/cloudevents/sdk-go/v2@v2.6.0
And import the module in your code
import cloudevents "github.com/cloudevents/sdk-go/v2"
Send your first CloudEvent
To send a CloudEvent using HTTP:
func main() {
	c, err := cloudevents.NewClientHTTP()
	if err != nil {
		log.Fatalf("failed to create client, %v", err)
	}
	// Create an Event.
	event :=  cloudevents.NewEvent()
	event.SetSource("example/uri")
	event.SetType("example.type")
	event.SetData(cloudevents.ApplicationJSON, map[string]string{"hello": "world"})
	// Set a target.
	ctx := cloudevents.ContextWithTarget(context.Background(), "http://localhost:8080/")
	// Send that Event.
	if result := c.Send(ctx, event); !cloudevents.IsACK(result) {
		log.Fatalf("failed to send, %v", result)
	}
}
Receive your first CloudEvent
To start receiving CloudEvents using HTTP:
func receive(event cloudevents.Event) {
	// do something with event.
    fmt.Printf("%s", event)
}
func main() {
	// The default client is HTTP.
	c, err := cloudevents.NewClientHTTP()
	if err != nil {
		log.Fatalf("failed to create client, %v", err)
	}
	log.Fatal(c.StartReceiver(context.Background(), receive));
}
Create a CloudEvent from an HTTP Request
func handler(w http.ResponseWriter, r *http.Request) {
	event, err := cloudevents.NewEventFromHTTPRequest(r)
	if err != nil {
		log.Print("failed to parse CloudEvent from request: %v", err)
		http.Error(w, http.StatusText(http.StatusBadRequest), http.StatusBadRequest)
	}
	w.Write([]byte(*event.String()))
}
Serialize/Deserialize a CloudEvent
To marshal a CloudEvent into JSON:
event := cloudevents.NewEvent()
event.SetSource("example/uri")
event.SetType("example.type")
event.SetData(cloudevents.ApplicationJSON, map[string]string{"hello": "world"})
bytes, err := json.Marshal(event)
To unmarshal JSON back into a CloudEvent:
event :=  cloudevents.NewEvent()
err := json.Unmarshal(bytes, &event)
Supported specification features
| v0.3 | v1.0 | |
|---|---|---|
| CloudEvents Core |  |  | 
| AMQP Protocol Binding |  |  | 
| AVRO Event Format |  |  | 
| HTTP Protocol Binding |  |  | 
| JSON Event Format |  |  | 
| Sarama Kafka Protocol Binding |  |  | 
| Confluent Kafka Protocol Binding |  |  | 
| MQTT Protocol Binding |  |  | 
| NATS Protocol Binding |  |  | 
| STAN Protocol Binding |  |  | 
| Web hook |  |  | 
Go further
_. Check out the examples _. Dig into the Godoc _. Learn about the architecture and concepts of the SDK _. How to use the CloudEvent in-memory representation *. How to use/implement a Protocol Binding