Skip to content

Latest commit

 

History

History
213 lines (110 loc) · 15.7 KB

File metadata and controls

213 lines (110 loc) · 15.7 KB

🌟 Features

🎨 Mixing & matching models

You can use different models in different rooms (e.g. OpenAI GPT-4o alongside Llama running on Groq, etc.)

You can also use different models within the same room (e.g. 💬 text-generation handled by one 🤖 agent, 🦻 speech-to-text handled by another, 🗣️ text-to-speech by a 3rd, etc.)

The bot supports the following use-purposes:

In a given room, each different purpose can be served by a different ☁️ provider and model. This combination of provider and model configuration is called an 🤖 agent. Each purpose can be served by a different handler agent.

See a 🖼️ Screenshot of an example room configuration.

For more information about configuring handlers, see the 🤝 Handlers / Configuring documentation section.

💬 Text Generation

Text Generation is the bot's ability to respond to users' messages with text.

Screenshot of Text Generation - a user sends a message and the bot replies in a new conversation thread

Some models also support vision and document understanding, so you may be able to mix text, images, and files (PDFs, text documents, etc.) in the same conversation. Note that certain providers may not support all file types or may have issues with specific files (e.g. scanned/image-based PDFs). If a file is rejected by the provider, the conversation thread may become unusable — start a new thread to work around this.

In multi-user (group) rooms, to avoid disturbing the normal conversation between people, the bot is auto-configured to only respond to messages starting with the command prefix (!bai) or direct mentions via the 💬 Text Generation / 🗟 Prefix Requirement Type setting.

Normally, the bot only responds to allowed 👥 Users. In certain cases, it's useful for an allowed user to provoke the bot to respond even in foreign threads or reply chains. You can learn more about this feature in the On-demand involvement section below.

If needed, the bot can also attach sender metadata to conversation messages before sending them to the model, which can help the model distinguish between participants in multi-user rooms. See 🛠️ Configuration / 💬 Text Generation / 👤 Sender Context Mode.

A few other features (like 🗣️ Text-to-Speech and 🦻 Speech-to-Text) combine well with Text Generation, so you don't necessarily need to communicate with the bot via text (with Seamless voice interaction, you can communicate only with voice).

You may also wish to see:

🛠️ Built-in Tools (OpenAI only)

The OpenAI provider supports built-in tools that extend the model's capabilities:

These tools are disabled by default and need to be explicitly enabled in the agent's text_generation.tools configuration. See the OpenAI sample configuration for reference.

To enable tools on an existing dynamically-created agent, you need to update the agent to re-create it with the text_generation.tools section added and enable the tools you need

💡 Note: These tools run on OpenAI's infrastructure and may incur additional costs. Web search results include citations that are incorporated into the response.

On-demand involvement

In the following 2 cases, it's useful to involve the bot in conversations on-demand:

  1. In multi-user rooms (with the 🗟 Prefix Requirement setting set to "required")
  2. In rooms with foreign users (users that are not authorized bot 👥 users)

In these instances, an allowed 👥 user can also provoke the bot to respond to any thread or reply chain by mentioning the bot (e.g. @baibot Hello!). The following screenshots demonstrate this behavior:

💡 NOTE: Normally, the bot only considers messages from allowed 👥 Users and ignores all other messages when responding. However, when the bot is explicitly invoked (via mention) in a thread or reply chain, it will consider all messages in the thread and reply chain (even those from foreign users) as part of the conversation context.

🗣️ Text-to-Speech

Text-to-Speech is the bot's ability to turn text messages into voice messages.

It can be performed on the bot's own text messages (responses to yours due to 💬 Text Generation) and/or on your own text messages.

Text-to-Speech can be enabled to be done automatically or on-demand (only after reacting to a message with 🗣️), and is configurable for different message types (🪄 Bot Messages Flow Type vs 🪄 User Messages Flow Type).

By default, the bot doesn't perform text-to-speech. It can be configured for Seamless voice interaction, where you can speak to the bot (instead of typing) and then hear its responses.

Another use-case is to have the bot operate in Text-to-Speech-only mode.

You may also wish to see:

Text-to-Speech-only mode

You may wish to have the bot automatically turn your text messages into voice messages, but without doing 💬 Text Generation.

Screenshot of Text-to-Speech-only mode - text messages are turned to audio and posted as a reply, without Text Generation happening

This could be useful in a room with others, where you'd like to post text messages and have people in the room consume them more easily (by listening to audio).

To allow for this use-case, you can:

🦻 Speech-to-Text

Speech-to-Text is the bot's ability to turn voice messages into text.

Default flow for Speech-to-Text and Text-Generation - your voice messages are transcribed to text and then answered via Text Generation

The default flow is shown in the screenshot above: your voice messages are transcribed to text and 💬 Text Generation is performed. By default, the bot offers 🗣️ Text-to-Speech for its answers via a 🗣️ emoji. You can click it to trigger text-to-speech on-demand.

You may also configure the bot for Seamless voice interaction or Transcribe-only mode, etc.

You may also wish to see:

Seamless voice interaction

The bot can perform seamless voice interaction (🗣️-to-🗣️), allowing you to speak to the bot (instead of typing) and then hear its responses.

Screenshot of the Seamless voice interaction mode - your voice messages are transcribed to text, then answered via Text Generation, and finally the answer is turned into a voice message

The flow is like this:

  1. 👤 You sending a voice message
  2. 🤖 The bot:
  • (default) first turning your voice message into text (🦻 Speech-to-Text) and posting it as a reply. This lets you you see what the bot heard.
  • (default) then answering in text (💬 Text Generation). This lets you read/skim text, if you so prefer.
  • (can be enabled) finally turning the answer's text into a voice message (🗣️ Text-to-Speech)
  1. 👤 You continuing the conversation via text or voice messages

⚠️ Certain clients (like Element) only support sending voice messages as top-level room messages, not as thread replies. Until this client limitation is fixed, Element users can only send the 1st message as a voice message - subsequent replies in the same conversation thread will need to be sent as text messages.

By default, the last part of the aforementioned flow is not enabled, because we assume a saner default is to reply with text and merely offer text-to-speech to those who want it. Offering is done by the bot reacting to its own message with 🗣️, and letting you click this emoji to trigger text-to-speech on-demand.

To enable automatic text-to-speech for the bot's messages, set the 🗣️ Text-to-Speech / 🪄 Bot Messages Flow Type setting to only_for_voice or always (e.g. !bai config room text-to-speech set-bot-msgs-flow-type only_for_voice).

Transcribe-only mode

If you'd like to have the bot only turn voice messages into text (without generating text messages or voice messages), you can configure the bot for that.

Screenshot of Transcribe-only-mode for Speech-to-Text - your voice messages are transcribed to text, and the bot does not generate text messages or voice messages

To operate in this mode, you can:

Image Generation

🖌️ Image Creation

Image creation is the bot's ability to create images based on text prompts.

See a 🖼️ Screenshot of the Image Creation feature.

You may also wish to see:

🎨 Image Editing

Image editing is the bot's ability to edit images based on a prompt and one or more existing images.

See a 🖼️ Screenshot of the Image Editing feature (manipulating a single image) and a 🖼️ Screenshot of the Image Editing feature (manipulating multiple images).

You may also wish to see:

🫵 Sticker Creation

Sticker generation is the bot's ability to generate sticker images based on text prompts. It's a special case of 🖌️ Image Creation.

See a 🖼️ Screenshot of the Sticker Creation feature.

See 📖 Usage / Image Generation / 🫵 Creating Stickers for details.

🔒 Encryption

Message exchange

The bot works in both unencrypted and encrypted Matrix rooms.

If configured, the bot can make use of Matrix's Secure Storage (Recovery) feature, so that it can restore its encryption keys even its local database gets lost.

Configuration

The bot also stores its 🛠️ configuration (both 📍 per-room and 🌐globally) in Matrix Account Data, which is generally stored as plain-text in the server.

To overcome this Matrix limitation, the bot can optionally encrypt the configuration data before storing it in Account Data. This allows for the bot to be used securely even against untrusted servers, without leaking sensitive configuration data to them.