Python SDK for CloudEvents
Go to file
Denis Makogon 9b5152546a Docs, CI, etc.
Signed-off-by: Denis Makogon <lildee1991@gmail.com>
2018-11-19 11:52:09 +02:00
.github Docs, CI, etc. 2018-11-19 11:52:09 +02:00
cloudevents Getter/Setters with some tests 2018-11-19 11:52:09 +02:00
.gitignore Initial release: CloudEvents Python SDK 0.0.1a0 2018-11-19 11:52:09 +02:00
LICENSE Initial commit 2018-09-21 18:42:34 -04:00
README.md Docs, CI, etc. 2018-11-19 11:52:09 +02:00
circle.yml Docs, CI, etc. 2018-11-19 11:52:09 +02:00
release.sh Initial release: CloudEvents Python SDK 0.0.1a0 2018-11-19 11:52:09 +02:00
release_doc.md Initial release: CloudEvents Python SDK 0.0.1a0 2018-11-19 11:52:09 +02:00
requirements.txt Few more tests 2018-11-19 11:52:09 +02:00
setup.cfg Initial release: CloudEvents Python SDK 0.0.1a0 2018-11-19 11:52:09 +02:00
setup.py Initial release: CloudEvents Python SDK 0.0.1a0 2018-11-19 11:52:09 +02:00
test-requirements.txt Initial release: CloudEvents Python SDK 0.0.1a0 2018-11-19 11:52:09 +02:00
tox.ini Initial release: CloudEvents Python SDK 0.0.1a0 2018-11-19 11:52:09 +02:00

README.md

Python SDK for CloudEvents

NOTE: This SDK is still considered work in progress, things might (and will) break with every update.

Package cloudevents provides primitives to work with CloudEvents specification: https://github.com/cloudevents/spec.

Parsing upstream Event from HTTP Request:

from cloudevents.sdk.event import upstream
from cloudevents.sdk import marshaller

data = "<this is where your CloudEvent comes from>"
m = marshaller.NewDefaultHTTPMarshaller(upstream.Event)
event = m.FromRequest({"Content-Type": "application/cloudevents+json"}, data)

Creating a minimal CloudEvent in version 0.1:

from cloudevents.sdk.event import v01

event = (
    v01.Event().
    WithContentType("application/json").
    WithData('{"name":"john"}').
    WithEventID("my-id").
    WithSource("from-galaxy-far-far-away").
    WithEventTime("tomorrow").
    WithEventType("cloudevent.greet.you")
)

Creating HTTP request from CloudEvent:

from cloudevents.sdk import converters
from cloudevents.sdk import marshaller
from cloudevents.sdk.converters import structured
from cloudevents.sdk.event import v01

event = (
    v01.Event().
    WithContentType("application/json").
    WithData('{"name":"john"}').
    WithEventID("my-id").
    WithSource("from-galaxy-far-far-away").
    WithEventTime("tomorrow").
    WithEventType("cloudevent.greet.you")
)
m = marshaller.NewHTTPMarshaller(
    [
        structured.NewJSONHTTPCloudEventConverter(type(event))
    ]
)

headers, body = m.ToRequest(event, converters.TypeStructured, lambda x: x)

The goal of this package is to provide support for all released versions of CloudEvents, ideally while maintaining the same API. It will use semantic versioning with following rules:

  • MAJOR version increments when backwards incompatible changes is introduced.
  • MINOR version increments when backwards compatible feature is introduced INCLUDING support for new CloudEvents version.
  • PATCH version increments when a backwards compatible bug fix is introduced.