OVOS Messagebus Client
Project description
OpenVoiceOS Bus Client
This module is a simple interface for the OVOS messagebus and can be used to connect to OVOS, send messages and react to messages sent by the OpenVoiceOS system.
MycroftBusClient()
The MycroftBusClient()
object can be setup to connect to any host and port as well as any endpont on that host. this makes it quite versitile and will work on the main bus as well as on a gui bus. If no arguments are provided it will try to connect to a local instance of OVOS on the default endpoint and port.
NOTE: we kept the original pre-fork class name for compatibility reasons
Message()
The Message
object is a representation of the messagebus message, this will always contain a message type but can also contain data and context. Data is usually real information while the context typically contain information on where the message originated or who the intended recipient is.
Message('MESSAGE_TYPE', data={'meaning': 42}, context={'origin': 'A.Dent'})
Examples
Below are some a couple of simple cases for sending a message on the bus as well as reacting to messages on the bus
Sending a message on the bus.
from ovos_bus_client import MessageBusClient, Message
print('Setting up client to connect to a local OVOS instance')
client = MessageBusClient()
client.run_in_thread()
print('Sending speak message...')
client.emit(Message('speak', data={'utterance': 'Hello World'}))
Catching a message on the messagebus
from ovos_bus_client import MessageBusClient, Message
print('Setting up client to connect to a local OVOS instance')
client = MessageBusClient()
def print_utterance(message):
print('OVOS said "{}"'.format(message.data.get('utterance')))
print('Registering handler for speak message...')
client.on('speak', print_utterance)
client.run_forever()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ovos-bus-client-1.0.4.tar.gz
.
File metadata
- Download URL: ovos-bus-client-1.0.4.tar.gz
- Upload date:
- Size: 44.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c61f0a15d3b6a846685fd95b9de9740f41af86fc55c730b4a854f935797a34a1 |
|
MD5 | 9fca3c36863ccf2edbe37b2c661b2d1e |
|
BLAKE2b-256 | c57ed37525371e160d8dbf997cd2c7b9b115a6e5bef7201fbc7c2d8a8a3ee42d |
File details
Details for the file ovos_bus_client-1.0.4-py3-none-any.whl
.
File metadata
- Download URL: ovos_bus_client-1.0.4-py3-none-any.whl
- Upload date:
- Size: 50.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8a2a8eb65bdcf6c2a210d7f76942547fa321b84debf72348dbbd1f45947b2448 |
|
MD5 | 075e9db139052c1a4fb2130a92944820 |
|
BLAKE2b-256 | 6b0da25adf5164abbe2b981db5d4b6b294f49739a39a6d2072beaf9cc15ba2f3 |