Configuring the Verba Microsoft Teams Bot and Unified Call Recorder Services

In order to complete the steps below, you must have System Administrator role in Verba.

It is recommended to co-locate the Verba Microsoft Teams Bot service and the Verba Unified Call Recorder service on the same Azure virtual machine.

Azure Active Directory is now Microsoft Entra ID.

The registration consists of the following steps:

Enabling the services

Step 1 - Log in to the Verba web interface and go to System \ Servers menu.

Step 2 - Select your Recording (Bot) Server from the list, then click on the Service Activation tab.

Step 3 - Activate the Verba Microsoft Teams Bot Service and the Verba Unified Call Recorder Service by clicking on the  icon.

Configuring the Verba Microsoft Teams Bot service

Step 4 - Click on the Change Configuration Settings tab.

Step 5 - Expand the Microsoft Teams Bot node.

Step 6 - Under General, provide a regex pattern at the Internal Tenant IDs, Numbers Pattern setting. This pattern should cover all the internal numbers and domains.

Step 7 - Under General / Recorder Connection, configure the authentication credentials for the connections with the recording service. Define the Authentication User and Authentication Passwords values. These credentials will be used later when configuring the connections in the recorder service.

Step 8 - Under Microsoft Teams, configure the following settings (see configuration reference for more details):

Setting NameDescription
Bot Service DNS NameThe FQDN of the virtual machine
Bot Service Public CNameThe CNAME DNS entry created for the server
Service CertificateThe thumbprint of the publicly signed certificate used previously for binding the ports
Bot Application IDThe App ID of the bot (see related step at Registering the Microsoft Teams Bot in Azure)
Bot Application SecretThe secret created for the bot (see related step at Registering the Microsoft Teams Bot in Azure)
Microsoft Teams Tenant IDThe ID of the Microsoft Entra tenant where the bot was created (see related step at Registering the Microsoft Teams Bot in Azure)
Query Hosting Tenant's Azure AD

Defines if the bot service will query Microsoft Entra ID for User Principal Names (UPN)

Public IP AddressThe public IP address of the virtual machine

Configuring the Verba Unified Call Recorder service

Step 9 - Expand the Unified Call Recorder \ Media Recorder \ Microsoft Teams node.

Step 10 - At the Teams Bot Servers setting, click on the  icon to add a new connection.

Step 11 - In the right panel, provide the username and password configured in the Verba Microsoft Teams Bot Service above for the connections. At the Host setting, select the Verba Recording (Bot) server from the dropdown menu. Set the Port to 10501.

Step 12 - Click on the Save button at the bottom. You will see the bot connection added to the configuration.


Step 13 - Save the changes by clicking on the  icon.

Step 14 - A notification banner will appear on the top. Click on the click here link, so you will be redirected to the Configuration Tasks tab. Click on the Execute button in order to execute the changes.

Starting the services

Step 15 - Click on the Service Control tab.

Step 16 - Start the Verba Microsoft Teams Bot Service and the Verba Unified Call Recorder Service by clicking on the  icon.


Updating the Server Certificate for Microsoft Teams Bot

Manual binding of certificates

Prior to v9.5.3.5973 (2020 June) certificates had to be manually bound to HTTPS ports. While this does not affect normal operation, during the renewal process the old binding must be removed, otherwise, the old certificate will be used.

The service automatically binds and unbinds the certificate, in order to check if the certificate is manually bound follow these steps:

Step 1 - Log in to the Verba Bot virtual machine in Azure, and open an administrator command prompt.

Step 2 -Stop the Verba Microsoft Teams service and Verba System Monitor service

Step 3 - Run the following command in the command prompt, replace the ip_address part with the public IP address of the server

show sslcert ipport=ip_address

The binding can be deleted by following these steps:

Step 1 - Log in to the Verba Bot virtual machine in Azure, and open an administrator command prompt.

Step 2 -Stop the Verba Microsoft Teams service and Verba System Monitor service

Step 3 - Remove the bound certificate to the TCP ports 9440 and 10100 with the following command. Replace the ip_address part with the public IP address of the server

 netsh http delete sslcert ipport=ip_address:port

Configuration reference


Setting NameDescription
General / Recorder ConnectionRecording Director Listening PortThe TCP/TLS port where the bot service is listening for the Recording Director connections from the Verba Unified Call Recorder Service
Media Recorder Listening PortThe TCP/TLS port where the bot service is listening for the Media Recorder connections from the Verba Unified Call Recorder Service.
Authentication UserUsername for authenticating with the Verba Unified Call Recorder Service.
Authentication PasswordPassword for authenticating with the Verba Unified Call Recorder Service.
Number of Tries to Find a New
Recorder for an Ongoing Call
Defines the number of tries after a recorder disconnects from the bot service, and the bot service tries to replace the recorder with another online Unified Call Recorder service/server.
Interval between Tries to Find a
New Recorder for an Ongoing Call
Defines the interval between tries when a recorder disconnects from the bot service, and the bot service tries to replace the recorder with another online Unified Call Recorder service/server.

General / AudioCompress RAW audio to G.711Defines if the bot service transcodes the original PCM audio stream to G.711 before sending the data to the recorder.
Bidirectional/Stereo RecordingDefines if the bot service subscribes for unmixed audio stream in the Microsoft Teams call.

General / Video


Number of Recorded Video ParticipantsDefines how many video streams are recorded per call, including the video streams of the recorded user.
Preferred Video ResolutionThe video resolution is used when the bot subscribes to the video streams of the participants. Microsoft Teams streams the video up to the resolution requested during the subscription. The resolution can be lower based on network conditions/capacity.
Preferred Screen Share ResolutionThe video resolution is used when the bot subscribes to the screen share streams of the participants. Microsoft Teams streams the video up to the resolution requested during the subscription. The resolution can be lower based on network conditions/capacity.
Separated Screen Share RecordDefines if a separate record is created for the screen share modality. The separate call includes the audio stream too.


General / Recording NotificationApply User's Recording
Announcement Configuration
Global notification setting, if turned off, the user settings won't be taken into account.
Enable Custom Audio Announcement for P2PEnables custom audio announcements for P2P calls.
Enable Custom Audio Announcement on call resumeEnables custom audio announcement on call resume.
Audit Log for Customisable AnnouncementAudit log for the customizable audio announcement, If turned on the bot service inserts audit log entries through the Web Application's HTTP API to the database.
Recording Reminder Length (milliseconds)Defines the duration of the recording reminder beep in milliseconds. The default value is 500 milliseconds, or half a second.
Recording Reminder Frequency (hertz)Defines the pitch of the recording reminder beep in hertz. The default value is 1400 hertz.
Recording Reminder Interval (seconds)Defines the repetition interval of the recording reminder in seconds. The default value is 15 seconds.


GeneralInternal Tenant IDs, Numbers Pattern

A regular expression that defines the internal Microsoft Teams tenant IDs or phone numbers to accurately identify the direction of the recorded calls.

For example:

^(b6fd8d51-3271-4896-bb8b-4d7390b51784|f4552cc7-3685-4ffb-bf68-79bb0ab4b007|[1-4]\d{4})$

This regular expression considers two tenants (b6fd8d51-3271-4896-bb8b-4d7390b51784, f4552cc7-3685-4ffb-bf68-79bb0ab4b007) and every 5 digit numbers that is starting with 1 to 4 as internal.

For more information, see Conversation direction detection using internal domain and number patterns.

In multi-tenant environments, if an internal pattern regular expression is defined in both the environment and the Microsoft Teams Bot service configuration, the pattern specified in the environment configuration is used to determine the internal values, not the pattern defined in the Microsoft Teams Bot service configuration.

Record Non-configured Extensions

Defines if the bot service has to record non-configured extensions.

Start Recording After Recorded User Joined

Defines if the bot waits for the join event of the recorded user before it starts recording a meeting. This setting is only applied for meetings, for P2P and PSTN calls, the bot always waits for the recorded user join event.

If the configuration is set to 'Yes', the bot will start the recording when it identifies the recorded user on the incoming roster updates. Also, the bot will start streaming media to the recorder after the recorded user is identified in the meeting.

If the configuration is set to 'No', the bot will trigger recording after it processed the first participant of the first roster update. The service will also stream every media packet to the recorder without waiting for the recorded user to join.

Block Calls when Recording Server UnavailableIf there is no available recorder, the bot will not join the call. If the Microsoft Teams recording policy is in strict mode then it will prevent the establishment of the call. If the bot cannot fail-over to another recorder mid-call, the bot will leave the call.
Store Additional MetadataStore additional metadata in the Microsoft Teams metadata template.


Microsoft Teams / ConnectionBot Service Public CNAMECNAME entry on the public trusted domain which points to the public IP (ILPIP) of the virtual machine hosting the bot service.
Service CertificateThe thumbprint or the file path of the public domain's certificate. If the certificate in the WCS, it has to have an exportable private key. Only CSP certificates are supported (CNG/KSP certificates are not supported!)
Service Certificate Key FileThe key file if the certificate is files based.
Service Certificate Key File PasswordPassword for the key file
Public IP AddressThe public IP address assigned to the virtual machine hosting the bot service.
Call Invite PortHTTPS port where the bot is listening for call invites from Microsoft Teams.
Call Notification PortHTTPS port where the bot is listening for call control messages from Microsoft Teams.
Media Control PortHTTPS port used by the Microsoft Media SDK for media control messages.
Media Port Range BeginBeginning of the UDP port range for the media streams.
Media Port Range EndEnd of the UDP port range for the media stream.

Microsoft Teams / AuthenticationBot Application IDThe Application ID is generated during the bot registration. Format: GUID
Bot Application SecretThe Application secret is generated during the bot registration.
Bot Application Authentication CertificateThe authentication certificate is uploaded on the Certificates and Secrets page of the Microsoft Entra App registration. If configured the application secret is ignored.
Authentication Certificate Key FileThe key file of the certificate is files based
Authentication Certificate Key File PasswordPassword for the key file

Microsoft Teams / Tenant ConfigurationHosting Tenant IDThe ID of the Microsoft Teams Tenant where the bot is hosted. Format: GUID
Hosting Tenant RecordedDefines if the bot will query the Microsoft Entra ID of the tenant for additional user information such as User Principal Name.
List of Recorded Tenant IDsLine-separated list of recorded Microsoft Teams tenants. If the hosting tenant is different from the recorded tenant(s), the recorded tenants' IDs have to be added.

Microsoft Teams / Bot GroupingBot Grouping

Turns on Microsoft Teams Bot Grouping capability. If enabled, the bot service answers the call with the configured bot group capacity. Based on the capacity, Microsoft Teams will invite the recording bot for the recorded meeting once per configured number of capacity if the recorded users share the same compliance recording policy.

Bot Group Participant CapacityDefines the capacity of the bot grouping feature

AdvancedMicrosoft API EndpointBase URL of the Microsoft Graph API. All API messages from the bot are sent to the URL.

HTTP Endpoint ValidationTurns ON/OFF the HTTP endpoint validation at the service start up.