Create Channel
Effortlessly set up an API channel inbox in Bevatel, allowing you to send and receive messages using Bevatel APIs with simple configuration steps.
How to create an API channel inbox?
Setting up an API channel consists of the following steps.
- Create API Channel inbox
- Send messages using Bevatel APIs
- Receive webhooks on new messages from Bevatel
This document allows you to create and configure an API channel inbox in Bevatel installations.
Step 1: Go to Settings > Channels and click on "Add Channel".
Step 2: Select API from the list of channels.
Step 3: Provide a name for the channel and a callback URL (the events and corresponding payload are defined in
the subsequent articles)
data:image/s3,"s3://crabby-images/2af13/2af13dbd91ac175482fa0ef8a74c2a8f3b7f8865" alt=""
Step 4: Add agents to the channel
data:image/s3,"s3://crabby-images/0196c/0196c6d08130e05d9b70f00800727c924941607b" alt=""
Step 5: Hooray!! The inbox setup is complete.
data:image/s3,"s3://crabby-images/84e30/84e307ec7c74f65e390088206e3f77b2a2915b76" alt=""
data:image/s3,"s3://crabby-images/0dc3c/0dc3c7b22f5d13ef0bfb4e9e731b3221239e1b3f" alt=""
Now the channel setup is complete, let us try to send a message using Bevatel APIs.
When the user tries to edit the inbox configuration
In the inbox configuration's collaborators section:
- When you add an agent in the Agent field, any user designated as an agent can see and access this inbox from the Conversation module. They can manage conversations in this inbox.
- However, when you add a team in the Team field, users attempting to assign conversations to a specific team from the Conversation module will only see the teams that have been added to the related inbox. This restricts conversation assignment options to the teams associated with the particular inbox, ensuring that conversations are appropriately distributed among the specified teams.
data:image/s3,"s3://crabby-images/7b057/7b057ffd1d00c3a9596d89616a0c6ec7ed1a5a67" alt=""
Send messages
Learn how to send messages in an API channel within Bevatel by creating contacts, conversations, and messages with the help of API access tokens and structured payloads for efficient communication.
Send messages to the API channel
To send messages to the API channel, you need to have a basic understanding of the models and nomenclature used in Bevatel. Let us try to understand these first.
- Channel: You can create multiple sources of conversations that are of the same channel type. For eg: You can have more than one Facebook page connected to Bevatel account. Each page is called as the channel in Bevatel.
- Conversation: A Conversation is a collection of messages.
- Contact: Each conversation has a real-life person associated with it, this person is called a contact.
- Contact Inboxes: This is the session for each contact on an inbox. A contact can have multiple sessions and multiple conversations in the same inbox.
How to send a message in an API Channel?
To send a message in an API channel, you have to create a contact, then create a conversation, and then send a message.
APIs require api_access_token in the request header. You can get this token by visiting your Profile settings > Access Token
1. Create a contact
Pass the inbox ID of the API channel along with other parameters specified. This would create a session for you automatically. A sample response would look like the one below.
- {
- "email": "string",
- "name": "string",
- "phone_number": "string",
- "thumbnail": "string",
- "additional_attributes": {},
- "contact_inboxes": [
- {
- "source_id": "string",
- "inbox": {
- "id": 0,
- "name": "string",
- "website_url": "string",
- "channel_type": "string",
- "avatar_url": "string",
- "widget_color": "string",
- "website_token": "string",
- "enable_auto_assignment": true,
- "web_widget_script": "string",
- "welcome_title": "string",
- "welcome_tagline": "string",
- "greeting_enabled": true,
- "greeting_message": "string"
- }
- }
- ],
- "id": 0,
- "availability_status": "string"
}
As you can see in the payload, you will be able to see the contact_inboxes and each contact_inbox will have a source_id. Source ID can be seen as the session identifier. You will use this source_id to create a new conversation as defined below.
2. Create a conversation
Use the source_id received in the previous API call.
You will receive a conversation ID, which can be used to create a message.
- {
- "id": 0
- }
3. Create a new message
There are 2 types of messages.
- Incoming: Messages sent by the end user is classified as an incoming message.
- Outgoing: Messages sent by the agent is classified as an outgoing message.
If you call the API with the correct content, you will receive a payload similar to the one below
- {
- "id": 0,
- "content": "This is a incoming message from API Channel",
- "inbox_id": 0,
- "conversation_id": 0,
- "message_type": 0,
- "content_type": null,
- "content_attributes": {},
- "created_at": 0,
- "private": false,
- "sender": {
- "id": 0,
- "name": "Pranav",
- "type": "contact"
- }
- }.
If everything is successful, you will see the conversation on the dashboard as follows.
data:image/s3,"s3://crabby-images/d285c/d285cd5afd42d6e015353de89d44328022ecea58" alt=""
You will be notified when a new message is created on the URL specified while creating the API channel.
Receive messages
Effortlessly receive new messages in your API channel through a POST request to the specified Callback URL, providing detailed payload information for effective message handling.
Receive messages using callback URL
When a new message is created in the API channel, you will get a POST request to the Callback URL specified while creating the API channel. The payload would look like this.
Event type: message_created
- {
- "id": 0,
- "content": "This is a incoming message from API Channel",
- "created_at": "2020-08-30T15:43:04.000Z",
- "message_type": "incoming",
- "content_type": null,
- "content_attributes": {},
- "source_id": null,
- "sender": {
- "id": 0,
- "name": "contact-name",
- "avatar": "",
- "type": "contact"
- },
- "inbox": {
- "id": 0,
- "name": "API Channel"
- },
- "conversation": {
- "additional_attributes": null,
- "channel": "Channel::Api",
- "id": 0,
- "inbox_id": 0,
- "status": "open",
- "agent_last_seen_at": 0,
- "contact_last_seen_at": 0,
- "timestamp": 0
- },
- "account": {
- "id": 1,
- "name": "API testing"
- },
- "event": "message_created"
- }
Client APIs
Leverage Bevatel's client APIs to create customized customer interfaces, including chat widgets, mobile app integrations, platform extensions, for efficient customer data and interaction management.
Create Interfaces using client APIs
Note: These APIs are still in alpha, and there might be changes in the implementation in future.
Client APIs available for the API channel will help you build customer-facing interfaces for Bevatel.
These APIs are useful for cases similar to the ones described below.
- Use a custom chat interface instead of the Bevatel chat widget
- Build conversational interfaces into your mobile apps
- Add Bevatel to other platforms for which Bevatel doesn't have an official SDK
Creating customer objects
You can create and retrieve customer data objects using the inbox_identifier and customer_identifier.
Inbox Identifier
You can obtain the inbox_identifier from your API channel -> Settings -> Configuration
Customer Identifier
The customer_identifier or the source_id can be obtained when creating the customer using the create API. You will need to store this identifier on your client side to make further requests on behalf of the customer. This can be done in cookies, local storage, etc.
Available APIs
Some of the things you can do via the APIs are
- Create, View and Update Contact
- Create and List Conversations
- Create, List and Update Messages
HMAC Authentication
The Client APIs also support HMAC Authentication. The HMAC token for the Channel can be obtained via running the following on your rails console.
- # replace api_inbox_id with your inbox id
- Inbox.find(api_inbox_id).channel.hmac_token
Connecting to the Bevatel WebSockets
To receive real-time updates from the agent dashboard, You can connect to the Bevatel WebSockets. Bevatel WebSockets connecting can be made at the following URL
- <your installation url>/cable
Authenticating your WebSocket connection
You will start receiving the events directed towards your customer object after subscribing using the customer pubsub_token. pubsub_token is provided during the customer-created API call.
Example
- const connection = new WebSocket('ws://localhost:3000/cable');
- connection.send(JSON.stringify({ command:"subscribe", identifier: "{\"channel\":\"RoomChannel\",\"pubsub_token\":\""+ customer_pubsub_token+"\"}" }));