Chat Client
Installation
npm install @botpress/chat
yarn add @botpress/chat
pnpm add @botpress/chat
Usage
API Queries
The @botpress/chat
package exports a Client
class that can be used to interact with the Botpress Chat API.
import _ from 'lodash'
import * as chat from '@botpress/chat'
const main = async () => {
const webhookId = process.env.WEBHOOK_ID
if (!webhookId) {
throw new Error('WEBHOOK_ID is required')
}
const apiUrl = `https://chat.botpress.cloud/${webhookId}`
const client = await chat.Client.connect({ apiUrl })
const { conversation } = await client.createConversation({})
await client.createMessage({
conversationId: conversation.id,
payload: {
type: 'text',
text: 'hello world',
},
})
await new Promise((resolve) => setTimeout(resolve, 2000))
const { messages } = await client
.listConversationMessages({
id: conversation.id,
})
.then(({ messages }) => ({
messages: _.sortBy(messages, (m) => new Date(m.createdAt).getTime()),
}))
const botResponse = messages[1]
console.log("Bot's response:", botResponse.payload)
}
void main()
.then(() => {
console.log('done')
process.exit(0)
})
.catch((err) => {
console.error(err)
process.exit(1)
})
Realtime Events
You can also listen for messages and events in real-time.
const listener = await client.listenConversation({
id: conversationId,
})
const botResponse = await new Promise<chat.Message>((resolve) => {
const onMessage = (ev: chat.Events['message_created']) => {
if (ev.userId === client.user.id) {
return
}
listener.off('message_created', onMessage)
resolve(ev)
}
listener.on('message_created', onMessage)
})
console.log("Bot's response:", botResponse.payload)
Reconnection
The Client
class does not automatically reconnect to the server if the connection is lost. This allow's you to handle reconnection in a way that makes sense for your application. To be notified when the connection is lost, you can listen for the error
event:
const state = { messages }
const onDisconnection = async () => {
try {
await listener.connect()
const { messages } = await client.listConversationMessages({ id: conversationId })
state.messages = messages
} catch (thrown) {
console.error('failed to reconnect, retrying...', thrown)
setTimeout(onDisconnection, 1000)
}
}
listener.on('error', (err) => {
console.error('connection lost', err)
void onDisconnection()
})