This feature is not currently available when using Twilio Regions Ireland (IE1) or Australia (AU1). It is currently only supported with the default US1 region. A full list of unsupported products and features with Twilio Regions is documented in the Global Infrastructure docs.
The BulkExport API provides an efficient mechanism for retrieving all of your activity logs from the Twilio platform on an ongoing basis, or for one-off downloads. Using BulkExport, you can access daily dumps of the previous day's Messages, Calls, Conferences, or conference Participants, eliminating the need to iterate through the list resource one page at a time to download your records. The BulkExport files are automatically removed after seven days. You can also use BulkExport to generate a set of historical daily dumps over a range of dates.
When a BulkExport completes, it can fire a webhook and/or send an email. This applies to the daily export if configured and to custom jobs. In both cases, successful exports will generate a Day resource for each day requested.
BulkExport is useful if you have:
Control over BulkExports and the data exported is available under the following URL:
https://bulkexports.twilio.com/v1/Exports/<resource_type>
There are four parts to BulkExport:
The ExportConfiguration resource lets you specify if you have a Twilio Editions product, and whether exports will take place automatically every day. This makes getting the data much more simple: you just configure the webhook. This will be called when the day's file is available, and you can then download and process your data.
Jobs lets you choose a range of dates to export data for. One data file will be generated for each day in the range. A parent account and all associated subaccounts can request data for up to a total of 366 days within a UTC calendar day. If requesting a subaccount, the parent account will be used to determine the number of days being requested within a UTC calendar day. For instance, if you submit requests across several subaccounts, and the aggregate number of requested days exceeds 366 within 24 hours, your request will be rejected. In this instance, you'll need to wait until the next UTC calendar day to make any further requests. The result data for the requested days will be visible using the Day resource. You will receive a callback and/or email for each job that is completed. When a custom job completes, it will generate one Day resource for each day in the requested period.
By default, the system will send bulk export job initiation notifications to account Owners and Admins, so they can keep a tab on the export requests, and flag/delete unwanted requests. Admins will be able to unsubscribe to these notifications from the notification center on the console.
Get a list of jobs in progress or that have recently been completed. Completed jobs will appear on the job list for seven days. You can delete jobs before they are complete.
The Days resource lets you examine the list of exported days available, either because they have been already generated by an export job or an automatic daily export. Each day file is named with the ISO 8601 date, and days are listed in order of generation.
There is no way to delete completed Day files, but they will be deleted automatically seven days after their creation.
Resource | Description |
---|---|
ExportConfiguration | Configure export webhooks. Twilio Enterprise Edition customers can also set daily exports. |
ExportCustomJob | Create new jobs to export data, and list current jobs and their status. Running a job will create the corresponding Days. |
Jobs | View the status of current jobs, and delete incomplete custom jobs. |
Days | List and fetch the exported message data for given days. |
There are two ways to use BulkExport:
You can then use the Day resource to list all completed exports by day and to download the message data for any of those days.
You can also delete Call records; see the delete BulkExport Call records section below to learn how.
All Day files are stored and returned as compressed GZIP JSON files with one record per line.
All records have timestamps in UTC in ISO 8601 format.
Records differ slightly from their associated API resources. This section outlines the differences for Messages, Calls, Conferences, and Participants resources.
BulkExport Message records are similar to the Message resource. The differences are:
price_units
api_version
error_message
(but
error_code
is)
uri
subresource_uris
(containing the media URLs)
BulkExport Call records are similar to the Calls resource. The differences are:
uri
subresource_uris
You can delete BulkExport Call records. See the Delete archived Calls section below for more information.
BulkExport Conference records are similar to the Conferences resource. The differences are:
api_version
uri
subresource_uris
BulkExport Participant records are similar to the Participants resource. The differences are:
uri
label
You can delete BulkExport Call records using the DELETE
request shown below.
The BulkExport Call record is separate from the Call resource. Therefore:
DELETE
request does not delete the associated
Call resource
for Calls that are less than 13 months old. (However, If you delete a
Call Resource
, the Call's BulkExport record is also deleted.)
DELETE
request deletes the Call record.
Twilio handles BulkExport Call record deletions asynchronously and in batches. It may take up to one week for a BulkExport Call record to be removed.
The Twilio-provided Call SID that uniquely identifies the Call resource to delete
^CA[0-9a-fA-F]{32}$
Min length: 34
Max length: 34
1// Download the helper library from https://www.twilio.com/docs/node/install2const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";34// Find your Account SID and Auth Token at twilio.com/console5// and set the environment variables. See http://twil.io/secure6const accountSid = process.env.TWILIO_ACCOUNT_SID;7const authToken = process.env.TWILIO_AUTH_TOKEN;8const client = twilio(accountSid, authToken);910async function deleteArchivedCall() {11await client.voice.v112.archivedCalls("2022-02-27", "CAXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX")13.remove();14}1516deleteArchivedCall();