The RaBe CloudEvents specification defines the required, URI
and URI-reference
based, type
and source
attributes of the CloudEvents specification.
- Overview
- Notations and Terminology
- Versioning
- Type System
- Attribute Naming Convention
- REQUIRED Attributes
- Example
- Event Type Registry
Events occur all over the place and all the time, having a common understanding of how to communicate events allows us to capture them in a meaningful way ensuring they can be leveraged in protocol and implementation agnostic scenarios by a range of consumers and producers across the diverse landscape of the RaBe IT stack.
This specification is heavily inspired by the work done by the maintainers of the CloudEvents v1.0.1 Spec.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119.
This document SHALL adhere to the Notational Conventions and Terminology described in the the CloudEvents v1.0.1 Spec.
This specification is versioned using git tag. It uses go-semantic-release for tagging new versions following the Conventional Commits v1.0.0 specification.
This specification defines types from the CloudEvents Type System.
URI
- Absolute uniform resource identifier.- String encoding:
Absolute URI
as defined in RFC 3986 Section 4.3.
- String encoding:
URI-reference
- Uniform resource identifier reference.- String encoding:
URI-reference
as defined in RFC 3986 Section 4.1.
- String encoding:
All attributes MUST follow the CloudEvents Naming Convention.
Any extension attribute defined by this spec SHALL be prefixed with the string rabe
to reduce the chances
of name collisions with extension attributes external to RaBe.
The following attributes MUST follow these constaints in addition to the CloudEvents REQUIRED Attributes.
-
Type:
URI-reference
-
Description: Identifies the context in which an event happened. Often this will include information such as the type of the event source, the organization publishing the event or the process that produced the event. The exact syntax and semantics behind the data encoded in the URI is defined by the event producer.
An application SHOULD use the RECOMMENDED unique, internet-wide, absolute URI format.
It is RECOMMENDED to use the GitHub page of the project as
source
.An application MAY assign a unique
source
to each distinct producer by appending a fragment to the URI. It is RECOMMENDED that the unique part is based on a UUID to aid with tracing efforts or similar requirements.An application MAY use UUID, URN or application-specific schemes to create unique
source
identifiers but this is NOT RECOMMENDED. -
Constraints:
- SHOULD be a based on the event producers project page.
-
Examples
https://github.com/radiorabe/rabemimimi
https://github.com/LibreTime/libretime#<event-id-for-tracing>
https://github.com/radiorabe/raar_show_descriptor
-
Type:
String
-
Description: This attribute contains a value describing the type of event related to the originating occurrence. Often this attribute is used for routing, observability, policy enforcement, etc. The format of this is producer defined and might include information such as the version of the
type
- see Versioning of CloudEvents in the Primer for more information.The RaBe DNS authority
events.api.rabe.ch
SHALL be used for reverse-DNS naming purposes.An event producer MAY use a subdomain indicate which component an event originated from. Types SHOULD contain versioning information. They MAY take the RaBe CloudEvents Event Type Registry into account and are strongly encouraged to do so.
-
Constraints:
- SHOULD be prefixed with a reverse-DNS name.
- if used, the reverse-DNS name SHALL be
ch.rabe.api.events
-
Examples
- Such event, much type, very version:
- ch.rabe.api.events.rabemimimi.v1alpha.mimimi.created
- ch.rabe.api.events.rabemimimi.v1alpha.mimimi.updated
- Simple unversioned events:
- ch.rabe.api.events.libretime.onair
- Such event, much type, very version:
The following example shows a paired down RaBe CloudEvent serialized as JSON:
{
"type" : "ch.rabe.api.events.events-spec.v1.such.event",
"source" : "https://github.com/radiorabe/events-spec"
}
This event type registry is non-normative. It SHOULD be taken into consideration when creating new events but it MUST NOT be considered as the authority on RaBe CloudEvents event types. Please register new event types as necessary.
This event SHOULD be emitted by audio players. Subscribers MAY use it for a wide range of purposes, nowplaying might use it for updating the current track from Klangbecken, but it could also trigger other workflows depending on the source of the track.
The data
field MUST contain item.artist
and item.title
. If an ISRC is available, it SHALL be included as descriptor.identifier
in the data
field. It SHOULD contain item.length
which MAY be used to generate internal ch.rabe.api.events.track.v1.trackFinished
events in case it misses the event from the player or none gets sent. The data
field MAY contain additional fields based on nowplaypadgen.dlplus.CONTENT_TYPES
.
Example:
{
"specversion": "1.0",
"type": "ch.rabe.api.events.track.v1.trackStarted",
"source": "https://github.com/radiorabe/klangbecken",
"id": "<id>",
"time": "2021-12-28T19:31:00Z",
"datacontenttype": "application/json",
"data": {
"item.artist": "hairmare fusion sounds collective",
"item.title": "C L O U D E V E N T W A V E",
"item.length": 36000,
"descriptor.identifier": "isrc, if available"
}
}
This specification is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
Copyright (c) 2021 Radio Bern RaBe