Skip to contentSkip to navigationSkip to topbar
On this page

Known Agent Routing


Your customer, Charlie, called in yesterday and spoke with an agent, Ricky. She had a good experience with Ricky, and said so yesterday. Today, Charlie is calling back in to follow up.

In many contact centers, Charlie might end up speaking to a new agent. This means she spends time discussing her issue once again, and telling the new agent about her call with Ricky. With Known Agent Routing, however, you can provide Ricky's Worker SID and attempt to match Charlie with Ricky again. Both Charlie and Ricky are able to pick up where they left off, and get her issue solved.

Use cases where Known Agent Routing can be used include 'last agent routing' or 'preferred agent routing', and the feature can also be leveraged to support extension dialing use cases. All of these use cases have in common that the agent who should be targeted first is already known.

(information)

Info

Known Agent Routing offers significant performance improvements over the general evaluation logic in those use cases. To prevent latencies e.g. during times when there is a spike in Task volume, we recommend that you always utilize Known Agent Routing when implementing such use cases, and update your existing Workflows to leverage Known Agent Routing as well.


Writing Workflows with Known Agent Routing

writing-workflows-with-known-agent-routing page anchor

You can choose one of two fields to designate an agent as the target of the Workflow.

To identify the known agent based on Worker SID:

"known_worker_sid": "task.agent_sid"

To identify the known agent based on Worker friendly name:

"known_worker_friendly_name": "task.agent_friendly_name"

You can use the known_worker_sid OR the known_worker_friendly_name as a key. The value should be an attribute in the Task attributes that references the appropriate agent information.

For example, the preceding snippets might use the following process:

  1. The agent's SID is added to the Task as a new attribute during Task Creation.
  2. The Task is evaluated against the Workflow.
  3. The Workflow references the Task attribute to populate the known_worker_sid in the Workflow Target. This pattern is also used for the Worker friendly name, which is required when known_worker_friendly_name is used in the Workflow Target instead.
  4. Finally, the Workflow will try to target the Worker whose SID matches the Task's agent SID or the agent's friendly name (depending on your chosen key).

Events created using Known Agent routing will contain a known_worker_sid, which you can use to infer that Taskrouter used Known Agent Routing for handling a given Task.

Example Workflow

example-workflow page anchor
1
{
2
"filters": [
3
{
4
"filter_friendly_name": "sample workflow filter",
5
"expression": "category == 'some_category'",
6
"targets": [
7
{
8
"queue": "WQ00000000000000000000000000000001",
9
"priority": "100",
10
"timeout": "10",
11
"known_worker_sid": "task.agent_sid",
12
"expression": "worker.activity_name in ['Generally Available', 'High Value Tasks']"
13
},
14
{
15
"queue": "WQ00000000000000000000000000000002",
16
"priority": "20",
17
"expression": "worker.activity_name in ['Generally Available']"
18
}
19
]
20
}
21
]
22
}

Creating a fallback when the Worker isn't available

creating-a-fallback-when-the-worker-isnt-available page anchor

In the best-case scenario, the agent will be in the Task Queue and will be available. But if either of these conditions isn't true, you can use additional Workflow Target fields - like timeout, priority, and expression - to ensure that your customer is helped in a timely manner. TaskRouter will evaluate the general worker expression in addition to the Known Agent Routing field, but the use of a general worker expression or workflow fields is optional.

Note that if the known agent is not part of the specified TaskQueue OR the inherited TaskQueue in the Workflow Target, you will receive a debugger error (Error 40152 - Invalid Queue for Known Worker).


Updating and Editing Known Agent Routing Workflows

updating-and-editing-known-agent-routing-workflows page anchor
Routing steps UI.

Example JSON

1
{
2
"task_routing": {
3
"filters": [
4
{
5
"filter_friendly_name": "Attempt 1",
6
"expression": "1==1",
7
"targets": [
8
{
9
"queue": "WQf4b9e3942acb4b62fdda09e84971e98e",
10
"timeout": 10,
11
"known_worker_sid": "task.agent_sid"
12
},
13
{
14
"queue": "WQf4b9e3942acb4b62fdda09e84971e98e"
15
}
16
]
17
}
18
],
19
"default_filter": {
20
"queue": "WQf4b9e3942acb4b62fdda09e84971e98e"
21
}
22
}
23
}
24

You can specify known worker logic in the Twilio Console. The field is optional, and can either be known_worker_sid or known_worker_friendly_name, but not both. When known_worker_sid or known_worker_friendly_name is selected, you can enter a string that corresponds to a field on the task as your value (e.g., task.agent_sid or task.agent_friendly_name). If the chosen worker key holds an incorrect value, TaskRouter will emit a debugger error message.

For those tasks without an actual known worker reference, you can use the null value assigned to the Known Worker field on the task to avoid debugger log messages:

1
{
2
"agent_sid": null
3
}
4
(warning)

Warning

Do not wrap the known worker null value in quotation marks.

A task that flows through a known worker filter target will, even if the known worker key is null or incorrect, stay in that target until any of the following conditions is satisfied:

  • Timeout of the target is met
  • skip_if condition is met
  • The Task's TTL is reached and the Task is cancelled

For more information, see Lifecycle of a Task: Workflows and Assignment.


Need some help?

Terms of service

Copyright © 2025 Twilio Inc.