Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
This quickstart gets you started with Bring your own Azure storage for Call Recording. To start using Bring your own Azure Storage functionality, make sure you're familiar with the Call Recording APIs.
Prerequisite: Setting up Managed Identity and Role Based Access Controls(RBAC) role assignments
1. Enable system assigned managed identity for Azure Communication Services

- Open your Azure Communication Services resource. Navigate to Identity on the left.
- Enabled System Assigned Managed Identity and click on Save.
- Once completed, you're able to see the Object principal ID of the newly created identity.

- Once the identity is successfully created, click on Azure role assignments to start adding role assignments.
2. Add role assignment
- Click on "Add role assignment"

- On the "Add role assignment" panel, select the following values
- Scope: Storage
- Subscription: Choose your subscription
- Resource: Choose your storage account
- Role: Azure Communication Services needs "Storage Blob Data Contributor" to be able to write to your storage account.
 

- Click on Save.
- Once completed, you see the newly added role assignment in the "Azure role assignment" window.

Start recording session with external storage specified
Use the server call ID received during initiation of the call.
Using Azure blob storage for external storage
StartRecordingOptions recordingOptions = new StartRecordingOptions(new ServerCallLocator("<serverCallId>"))
{
    //...
    ExternalStorage = new BlobStorage(new Uri("<Insert Container / Blob Uri>"))
};
               
Response<RecordingStateResult> startRecordingWithResponse = await callAutomationClient.GetCallRecording()
        .StartRecordingAsync(options: recordingOptions);
Using Azure blob storage for external storage
StartRecordingOptions recordingOptions = new StartRecordingOptions(new ServerCallLocator("<serverCallId>"))
                .setExternalStorage(new BlobStorage("<Insert Container / Blob Uri>"));
Response<StartCallRecordingResult> response = callAutomationClient.getCallRecording()
.startRecordingWithResponse(recordingOptions, null);
Notification on successful export
To notify your services when the recorded media is ready and exported to the external storage location, use an Azure Event Grid web hook, or other triggered action.
Refer to this example of the event schema.
{
    "id": "string", // Unique guid for event
    "topic": "string", // /subscriptions/{subscription-id}/resourceGroups/{group-name}/providers/Microsoft.Communication/communicationServices/{communication-services-resource-name}
    "subject": "string", // /recording/call/{call-id}/serverCallId/{serverCallId}
    "data": {
        "storageType": "string", // AzureBlob etc.
        "recordingId": "string", // unique ID for recording
        "recordingStorageInfo": {
            "recordingChunks": [
                {
                    "documentId": "string", // Document ID for the recording chunk
                    "contentLocation": "string", //Azure Communication Services URL where the content is located
                    "metadataLocation": "string", // Azure Communication Services URL where the metadata for this chunk is located
                    "deleteLocation": "string", // Azure Communication Services URL to use to delete all content, including recording and metadata.
                    "index": "int", // Index providing ordering for this chunk in the entire recording
                    "endReason": "string", // Reason for chunk ending: "SessionEnded", "ChunkMaximumSizeExceeded”, etc.
                }
            ]
        },
        "recordingStartTime": "string", // ISO 8601 date time for the start of the recording
        "recordingDurationMs": "int", // Duration of recording in milliseconds
        "sessionEndReason": "string" // Reason for call ending: "CallEnded", "InitiatorLeft”, etc.
    },
    "eventType": "string", // "Microsoft.Communication.RecordingFileStatusUpdated"
    "dataVersion": "string", // "1.0"
    "metadataVersion": "string", // "1"
    "eventTime": "string" // ISO 8601 date time for when the event was created
}
Notification and Action for recording export failure.
Failure to export recording file can occur due to incorrect configuration settings or service outages. In both cases, the failure notification includes the download url to obtain recordings. Download recordings from the location in failure notification within 24 hours.
Folder Structure for Call Recording
Recordings are stored in the following format as shown in the diagram.
- /YYYYMMDD/callId/first_8_of_recordingId + '-' + unique guid/[chunk-id]-acsmetadata.documentId.json
- /YYYYMMDD/callId/first_8_of_recordingId + '-' + unique guid/[chunk-id]-audiomp3.documentId.mp3

Next steps
For more information, see the following articles:
- Download our Java call recording sample app
- Learn more about Call Recording
- Learn more about Call Automation