Realtime extension combines application events into streams according to defined routes. Clients may consume these streams via Exposition.
If stream is idle for 16 seconds, a heartbeat
message is sent.
Static route specifies an event that should be combined into a stream using specified property of event's payload as a stream key or an array of stream keys.
Static routes may be defined in Component manifest or the Context annotation.
# manifest.toa.yaml
name: users
realtime:
updated: id
# context.toa.yaml
realtime:
users.updated: id
orders.created: customer_id
In case of conflict, the Context annotation takes precedence.
Multiple stream keys may be defined for a single event.
# manifest.toa.yaml
name: messages
realtime:
updated: [sender_id, recipient_id]
Given two rules: users.updated: id
and orders.created: customer_id
,
the following events will be routed into a stream with a4b8e7e8
key:
# users.updated
id: a4b8e7e8 # id property is used as a stream key
name: John Doe
# orders.created
id: 1
customer_id: a4b8e7e8 # customer_id property is used as a stream key
amount: 100
Dynamic routes address the cases when a stream key is not a property of an event.
Among with an event
and a stream
key, a dynamic route has property
and value
properties,
which define a condition that should be met for an event to be combined into a stream with the
specified key.
For instance, when there are chat rooms with a list of users, and a user joins or leaves the room.
When a message is sent to a room, an event will have a room_id
property, but not a user_id
.
In this case, when the user a4b8e7e8
enters the room with id general
,
a dynamic route may be created as follows:
event: message.sent
property: room_id
value: general
stream: a4b8e7e8
Each time the message is sent to the room with id general
, the event will be routed into a
stream with a4b8e7e8
key.
Dynamic routes are managed by the realtime.routes
component, running in the Realtime extension.
Streams are exposed by the realtime.streams
component, running in the
Realtime extension, and are
accessible via the /realtime/streams/:key/
resource with
the auth:id: key
authorization rule.
Refer to the Exposition extension for more details: