Getting Started
Getting the Data
Learn how to receive meeting data through webhooks
Getting Meeting Data
Your webhook URL will receive two types of data:
- Live meeting events during the meeting
- Final meeting data after completion
These events will start flowing in after sending a bot to a meeting.
1. Live Meeting Events
Status Event Fields
event
: The key-value pair for bot status events. Alwaysbot.status_change
.data.bot_id
: The identifier of the bot.data.status.code
: The code of the event. One of:joining_call
: The bot has acknowledged the request to join the call.in_waiting_room
: The bot is in the "waiting room" of the meeting.in_call_not_recording
: The bot has joined the meeting, however it is not recording yet.in_call_recording
: The bot is in the meeting and recording the audio and video.recording_paused
: The recording has been temporarily paused.recording_resumed
: The recording has resumed after being paused.call_ended
: The bot has left the call.bot_rejected
: The bot was rejected from joining the meeting.bot_removed
: The bot was removed from the meeting.waiting_room_timeout
: The bot timed out while waiting to be admitted.invalid_meeting_url
: The provided meeting URL was invalid.meeting_error
: An unexpected error occurred during the meeting.
data.status.created_at
: An ISO string of the datetime of the event.
When receiving an in_call_recording
event, additional data is provided:
data.status.start_time
: The timestamp when the recording started.
For meeting_error
events, additional error details are provided:
data.status.error_message
: A description of the error that occurred.data.status.error_type
: The type of error encountered.
2. Final Meeting Data
You'll receive either a complete
or failed
event.
Success Response (complete
)
IMPORTANT: The mp4 URL is a pre-signed AWS S3 URL that is only valid for 2 hours. Make sure to download the recording promptly or generate a new URL through the API if needed.
Complete Response Fields
bot_id
: The identifier of the bot.mp4
: A private AWS S3 URL of the mp4 recording of the meeting. Valid for two hours only.speakers
: The list of speakers in this meeting. Currently requires transcription to be enabled.transcript
(optional): The meeting transcript. Only given whenspeech_to_text
is set when asking for a bot. An array containing:transcript.speaker
: The speaker name.transcript.words
: The list of words, each containing:transcript.words.start
: The start time of the wordtranscript.words.end
: The end time of the wordtranscript.words.word
: The word itself
Failure Response (failed
)
Error Types
Error | Description |
---|---|
CannotJoinMeeting | The bot could not join the meeting URL provided. In most cases, this is because the meeting URL was only accessible for logged-in users invited to the meeting. |
TimeoutWaitingToStart | The bot has quit after waiting to be accepted. By default this is 10 minutes, configurable via automatic_leave.waiting_room_timeout or automatic_leave.noone_joined_timeout (both default to 600 seconds). |
BotNotAccepted | The bot has been refused in the meeting. |
BotRemoved | The bot was removed from the meeting by a participant. |
InternalError | An unexpected error occurred. Please contact us if the issue persists. |
InvalidMeetingUrl | The meeting URL provided is not a valid (Zoom, Meet, Teams) URL. |
Recording End Reasons
Reason | Description |
---|---|
bot_removed | Bot removed by participant |
no_attendees | No participants present |
no_speaker | Extended silence |
recording_timeout | Maximum duration reached |
api_request | Bot removed via API |
meeting_error | An error occurred during the meeting (e.g., connection issues) |