Skip to main content

Twilio Flex Integration

note

This feature is in Preview and its behavior is likely to change based on user feedback. The feature also may have lower availability and have more maintenance windows.

You can connect multiple Twilio Flex instances to a single Salted CX account and mix data with other contact center platforms, other data sources and upload additional data using our Ingest API.

Integration between Twilio Flex and Salted CX

note

Transcripts are available for messaging channels only. Calls are available for playback in the customer journey without transcript.

We combine two data sources from Twilio to reconstruct customer journeys, conversations and turns (messages) in Salted CX:

  • Twilio Event Stream
  • Programmable Chat (Conversation API)

Configure Event Stream

In the following steps you will ask Twilio to send important events from your contact center to Salted CX:

  1. In Twilio Console go to Event StreamManageCreate Sink
  2. Choose sink Type: Amazon Kinesis Data Stream
  3. Request from Salted CX team Amazon Resource Name (ARN), External ID and Role ARN
  4. Fill those information provided by Salted CX
  5. Click Finish setup
  6. In Twilio Console go to Event StreamManageCreate Subscription
  7. Select the Sink created in step 5
  8. Use description to ensure people know what the subscription is for, for example “Integration with Salted CX”
  9. Select all events with the latest schema version from the TaskRouter section EXCEPT RateLimit (all events from reservation, task, task qeuues worker and workflow)

Create API Key

In this step you will generate token that Salted CX can use to extract data:

  1. In the right top corner click on AdminAccount Management
  2. Keys & CredentialsAPI keys & TokensCreate API Key

Provide Account Information to Salted CX

Pass the following information securely to Salted CX team:

  • Account SID
  • API key SID and secret

Twilio Flex Data in the Logical Model

We translate data from all platforms into our unified Logical Model that enables you to report on data from multiple platforms in the same way. We use unified concepts with unified naming and the same meaning in every platform.

As each platform has its own vocabulary and concepts we cannot adopt any single platform vocabulary. Platforms have different names for the same concepts (for example queues, case, issue, or task for a single customer-related request). Or different platforms use the same name for different concepts (for example “Contact” means a single conversation with a customer in one platform, but it means a customer email/phone in another platform).

This article covers how Twilio Flex concepts translate into Salted CX concepts and vocabulary.

tip

To understand Twilio Flex data in the Logical Model it is recommended to have a basic understanding of our Customer Journey and Logical Model. You can also check our Glossary to understand the naming and meaning of our concepts.

Salted CX uses TaskRouter tasks to read details about agents activities and reservations. We gather information from the tasks attributes and map them into the Salted CX Logical Model

Customers

Salted CX creates individual customers that correspond to task attributes that are relevant to the customer identification.

Salted CXTask Attribute
Customer Contact IDtask_attributes.customers.external_id
task_attributes.customers.phone
task_attributes.customers.email
task_attributes.from / to (depends on direction)
task SID
Customer Statetask_attributes.customers.state
Customer Countrytask_attributes.customers.country
Customer Categorytask_attributes.customers.category
Customer Organizationtask_attributes.customers.organization
Customer Regiontask_attributes.customers.region
Customer Segmenttask_attributes.customers.segment

Customer ID is taken from the multiple objects based on priority as mentioned in the table above. If no information about the customer is in the task then the customer is created with task SID which keeps the conversation isolated. That’s why it’s recommended always to populate any contact information into the task attributes.

Agents

Salted CX gather the agents’ information from the worker attributes that are part of the events that are generated when an agent changes the activity (ie. Offline > Available).

Salted CXWorker Attribute
Agent IDemail
Agent Namefull_name
Agent Departmentdepartment
Agent Locationlocation
Agent Managermanager
Agent Teamteam
agent_team
Agent Rolesroles
Agent Organizationorganization
Agent Cost per Hourcost_per_hour
Agent Cost per Engagementcost_per_engagement

Agent State is set to ‘Active’ when the worker is created and ‘Inactive’ if deleted.

Agent Role is set to the the highest permission (admin > supervisor > agent).

Agent Status

Activity is a detailed agent status change (AUX codes) during the day including attribution to time. Each item in the Activity data set represents a sum of time spent in a single agent status (AUX code) in a 15-minute interval.

Offline Activity is not being stored in Salted CX.

Conversations

Each TaskRouter task translates to one conversation.

Agent Engagement

Twilio Flex uses TaskRouter for assigning tasks and reservations to agents. Salted CX translates a reservation into the engagement which means that there can be multiple engagements in one conversation.

Agent engagement starts with the event of reservation accepted and ends with reservation completed.

Salted CXTask Attribute
Campaintask_attributes.conversations.campaign
Casetask_attributes.conversations.case
Categorytask_attributes.conversations.category
Channeltask_attributes.conversations.channel
task_channel_unique_name (name of the channel in Taskrouter)
Channel Vendor“Twilio”
Company Contacttask_attributes.conversations.company_contact
task_attributes.conversations.external_contact
task_attributes.from / task_attributes.to (based on direction)
Conversationtask_attributes.conversations.conversation_jd
task SID
Directiontask_attributes.conversations.direction
task_attributes.direction
’Inbound’
Engaged Departmentworker_attributes.department
Engaged Locationworker_attributes.location
Engaged Organizationworker_attributes.organization
Engaged Managerworker_attributes.manager
Engaged Roleworker_attributes.role
Engaged Teamworker_attributes.team
worker_attributes.agent_team
Engagement Attribute 1task_attributes.conversations.attribute_1
task_attributes.conversations.conversation_attribute_1
Engagement Attribute 2task_attributes.conversations.attribute_2
task_attributes.conversations.conversation_attribute_2
Engagement Attribute 3task_attributes.conversations.attribute_3
task_attributes.conversations.conversation_attribute_3
Engagement Fact 1task_attributes.conversations.fact_01
Engagement Fact 2task_attributes.conversations.fact_02
Engagement Fact 3task_attributes.conversations.fact_03
Engagement TimeDuration between reservationAccepted and reservationWrapup
Engagement Type“Agent”
Focus Timetask_attributes.conversations.focus_time
Hold Timetask_attributes.conversations.hold_time
Invitation TimeDuration between reservationCreated <> reservation Rejected/Revoked/Accepted/Missed/Cancelled
Languagetask_attributes.conversations.language
Outcometask_attributes.conversations.outcome
Outcome Categorytask_attributes.conversations.outcome_category
Platform“Flex”
Prioritytask_attributes.conversations.priority
Queuetask_attributes.conversations.queue
task_queue_sid / task_queue_name
Reasontask_attributes.conversations.reason
Start Timereservation.accepted timestamp
End Timereservation.completed timestamp
Wait TimeDuration between the last queue.entered and reservation.accepted events
Wrap Up TimeDuration between reservation.wrapup and reservation.completed

If the channel unique name is voice (default Twilio naming) then we also gather task_attributes.conversations.sgement_link with an URL to the recording so the audio file can be re-played in the customer journey.

If there is not wrapup event configured then the wrap up time is not populated.

Queue Engagement

The queue segment always starts with TaskRouter event queue.TaskQueueEntered.

The queue segments have the same attributes as the Agent Engagements but they have a different outcome type in Salted CX model based on the ending event:

Ending Event NameOutcome TypeUsage
ReservationAcceptedAcceptedFor such queue segments we also create agent engagements so all reporting can be done with this engagements where you will have populated waiting time, engagement time, invitation time and wrap up time (if wrap up exists)
TaskQueueEnteredMovedSuch queue engagements represent transfers from queue to another queue
TaskDeletedDeletedSuch queue engagements represent deleted task
TaskCanceledCustomer Left
Canceled
If the ending event is TaskCanceled then it depends on the Taskrouter value for field task_canceled_reason that is populated automatically by Twilio Taskrouter.
If it’s ‘hangup’ then we populate ‘Customer Left’ and it represents abandoned conversations.
If it’s ‘Task canceled on Workflow timeout’ then the task was ended due to timeout configuration in your Taskrouter Workflow settings.

Invitation Engagement

The invitation engagements represent situations in which agents receive a reservation (invitation to join a conversation) but they miss it or reject it. Salted CX does not create invitations for instances when agent accepts the reservation. The invitation engagement starts with the event reservation.created.

The invitation engagements are mapped to the same attributes as the Agent Engagements but they have a different outcome type in Salted CX model based on the ending event:

Ending Event NameOutcome TypeUsage
ReservationAccepted—-We do not create invitation engagement because we have already all information in agent engagement.
ReservationTimeout
ReservationCanceled
MissedSuch invitation engagements can be used to see how many reservations were missed by agent due to timeout configured in the Taskrouter workflow
ReservationRejectedRejectedSuch invitation engagements can be used to see how many reservations were actively rejected by the agents.
ReservationRescindedRevokedSuch invitation engagements represent reservations that were closed because another agent already accepted the task’s reservation. Such scenario can happen if multiple reservations are created for one task (can be configured in Twilio Taskrouter queue setting)

Turns

Each individual message in the channel from an agent or from a customer creates a new turn associated with an engagement of the currently engaged agent. The current deployment is configured to download chat transcripts via Twilio Conversation API.