Bus#
The Tryton server listens on POST requests on the routes matching
/<database_name>/bus and replies with JSON dictionary containing:
channelThe channel on which this message has been received.
messageA dictionary that is the message the client must handle. The specification of the message depends of its type.
All messages should at least content a unique identifier in the key
message_idand their type in the key of the same name.
Client sending their requests on the route must be authenticated. The request must submit a JSON dictionary containing:
last_messageA value identifying the last message received by the client. This value can be
null.channelsA list of strings denoting the channels the client is listening to.
- class trytond.bus.Bus#
Expose two methods that are used by the framework:
publishandsubscribe.
- classmethod Bus.publish(channel, message)#
Send a message to a specific channel.
Implemented messages are:
- classmethod Bus.subscribe(database, channels[, last_message])#
Subscribe a user client to some
channelsof messages.The
message_idparameter defines the last message id received by the client. It defaults toNonewhen not provided.
The default implementation provides an helper method to construct the response:
- classmethod Bus.create_response(channel, message)#
Create a dictionary suitable as a response from a message and a timestamp.
channelis the channel on which the message has been received.messageis the content of the message sent to the client.
Note
The implementation relies on the fact that the order of the messages received is consistent across different trytond instances allowing to dispatch the request to any trytond server running.
Notification#
Tryton provides a shortcut to send a notification with the notify function.
- trytond.bus.notify(title[, body[, priority[, user[, client]]]])#
Send a text message to a user’s client to be displayed using a notification popup. The meaning of
title,bodyandpriorityis defined in Notification message.If
useris not set, the currentuseris used. Otherwiseuseris the user id to notify.If
clientis not set then every client of the user receives the message. Ifclientanduserare not set, the system send the notification to the current user client. Otherwise the notification is sent to the client whose id matchesclient.
Notification message#
Notification messages are composed of four parts:
kindThe string
notification.titleA string containing a one-line summary of the message.
bodyA string containing a short informative message for the user. It can span multiple lines but no markup is allowed.
priorityAn integer between 0 (low priority) to 3 (urgent). The notification priority on the platform supporting it.