The expected format of phone numbers in SIP INVITE requests can sometimes differ between on-premise equipment and providers. For example, some private branch exchanges (PBXs) might send numbers in a format other than E.164, the format that Twilio requires. In order to address this issue, Twilio provides a feature called SIP Header Manipulation.
SIP Header Manipulation allows you to automatically modify the user fields in a SIP INVITE for Elastic SIP Trunking termination and/or origination calls. (For Elastic SIP Trunking customers, user fields often contain phone numbers. This page will refer to phone numbers and user fields interchangeably.)
This feature is accessible in the Twilio Console under Elastic SIP Trunking > Settings > SIP Header Manipulation.
The following section will describe the main components of Manipulation Policies, the set of rules that describe if, how, and when a SIP header should be modified.
If you prefer, you can jump down to the Create a Manipulation Policy section to view the steps for implementing this feature.
In order to manipulate phone numbers within SIP INVITEs, you will need to create a Manipulation Policy and assign it to one or more of your SIP Trunks.
Manipulation Policies consist of:
You can check that your Manipulation Policy is working as expected by running a test on it in the Console.
The maximum number of Manipulation Policies per account is 1000. For each Trunk, you can assign one Manipulation Policy for termination and one for origination.
Request Rules contain the logic that determines if and how an INVITE's headers should be manipulated.
An Action specifies which phone numbers (user fields) you want to change and how you want to change them.
An Action is associated with a Request Rule, and a Request Rule can contain up to 20 Actions.
What phone numbers to change
When creating an Action, you will choose the phone numbers you want to modify when the Action executes.
Phone numbers (the user fields in SIP URIs) tend to repeat across several SIP headers within a SIP message. This means that if you need to change a phone number/user in one SIP header, it's likely that it needs to change elsewhere. To minimize the work you need to do to manipulate phone numbers/users in SIP INVITEs, Twilio has grouped related URI user fields together into To Number
fields and From Number
fields.
To Number
fields represent the user who will receive the INVITE:
From Number
fields represent the user who initiated the INVITE:
When an Action is executed on To Number
fields, the To header's user field will be manipulated first, then copied into the Request-URI's user field.
When an Action is executed on From Number
fields the From header's user field will be manipulated first, then copied into the P-Asserted-Identity, Remote-Party-ID, and Contact headers' user fields.
How to change the phone numbers
After choosing which phone numbers to change, you will specify how the phone numbers should change by selecting an action (a text modification) and a value to be used with the text modification.
You can choose from the following text modification actions:
Add prefix
Add suffix
Remove prefix
Remove suffix
Remove number of prefix
Remove number of suffix
Replace with
The Action's value is the value you want to use with the chosen action. Values are case-sensitive.
There are restricted and reserved characters within each SIP field. Keep this in mind when defining values in your Actions.
For SIP user fields, only the characters below are allowed. You can refer to RFC 3261 for guidelines on what characters should be escaped for the user fields. Be sure to escape other special characters.
Allowed characters for SIP users |
---|
A-Z | a-z | 0-9 | "-" | "." | "_" | "~" | "!" | "$" | "&" | "'" | "(" | ")" | "*" | "+" | "," | ";" | "=" | "?" | "/" |
And escaped versions of special characters |
Action Execution:
You can conditionally execute the Action(s) in a given Request Rule by defining a group of Conditions and an execution type that determines how to evaluate the Conditions.
The execution type can be:
If any of these conditions are met
(this is the default)
If all of these conditions are met
If none of these conditions are met
Each Condition consists of:
The evaluation of Conditions is case-sensitive.
The order of the Conditions (as they appear in the Console) is the order in which they will be evaluated. You can, however, reorder or delete them.
SIP header fields
The SIP header fields that can be evaluated are listed below. Click on a header field or go to the SIP INVITE Glossary page to learn more.
Logical operators
The logical operators that can be used when creating a Condition are:
Equals
Does not equal
Starts with
Does not start with
Contains
Does not contain
Ends with
Does not end with
Keep in mind that Twilio will evaluate the SIP header exactly as it is presented and will not encode or decode special characters when comparing the SIP header to the value you have set in your Condition.
For example, if the SIP header contains the example%40company.com
as the To user
, and the value in your Condition contains example@company.com
, Twilio will not equate these strings.
You can refer to RFC 3261 for guidelines on what characters should be escaped within each field type of the SIP header. Below is a summary of the characters allowed within each SIP field.
SIP field type | Allowed characters |
---|---|
user | A-Z | a-z | 0-9 | "-" | "." | "_" | "~" | "!" | "$" | "&" | "'" | "(" | ")" | "*" | "+" | "," | ";" | "=" | "?" | "/" And escaped versions of other special characters. |
host | A-Z | a-z | 0-9 | "-" | "." | ":" | "[" | "]" |
URI | A-Z | a-z | 0-9 | "-" | "." | "_" | "~" | "!" | "$" | "&" | "'" | "(" | ")" | "*" | "+" | "," | ";" | "=" | ":" | "[" | "]" | "?" | "#" | "/" | "@" | "%" | "`" And escaped versions of other special characters. |
display name | Ascii characters with decimal values of 0 to 253. |
This section will walk through creating an example Manipulation Policy in the Console.
On the "SIP header manipulations" page, click on the blue Create a policy button (in the top right corner).
Give your new Manipulation Policy a Friendly Name that helps you remember what the policy does and click on the Create button.
On the "Manipulation policy details" page, find the "Request rules" heading. Click on the + Add request rule button to the right of the heading.
On the Add request rule page, give the rule a name that helps you remember what it does (i.e. when and how the rule should change a SIP header)
Add Conditions (optional)
Under the "Conditions" heading, click on the + Add condition button
Select the operator and fill in the value to use with the operator
Add Actions
Fill in the Value that will be used with the action you chose
Click on the blue Add rule button to add the rule to your policy.
Test the policy
You can either paste in your own SIP message in the SIP message input box, or you can click on the "Populate with example" button.
Assign the policy to a Trunk
You should now be on the "General Settings" Page. In the left hand navigation select either Termination or Origination (depending on which direction you want your Manipulation Policy to apply to).
Find the "Header Manipulation" heading and enter the Friendly Name of the Manipulation Policy you just created.
Scroll to the bottom of the page and click on the blue Save button.
Verify the policy has been applied.
Navigate to Elastic SIP Trunking > Settings > SIP Header Manipulations. The policy should now have an "Associated SIP trunk".
After you create a Manipulation Policy, you can test it in the Console before using it in production.
If you want to delete a Manipulation Policy that is not associated with any SIP Trunks, complete the following steps:
On the "Manipulation policy details page", click on Delete policy (next to the Cancel button).
If you want to delete a Manipulation Policy that is associated with a SIP Trunk, you must first remove the Manipulation Policy from the SIP Trunk before deleting.
Change the Header Manipulations input box to (no header manipulation)
.
On the "Manipulation policy details page", click on Delete policy (next to the Cancel button).