Callflow Dynamic CID

About Dynamic CID

The Dynamic CID callflow enables you to dynamically change the Caller ID (CID). There are different methods for doing that:

  • manual: dial the new Caller ID on the keypad when prompted, this way you can set the Caller ID number only. This works with and without a capture group
  • list: setting Caller ID name and number based on the configuration on the specified document in the database. This requires a capture group
  • lists: almost the same as list mode but you can use account’s lists feature to configure entries
  • static set the caller id to a value in a caller_id.name and caller_id.number property in the data object. This works with and without a capture group

Callflow fields

Schema

Validator for the dynamic_cid callflow data object

KeyDescriptionTypeDefaultRequiredSupport Level
actionWhat action to performstring('list' | 'lists' | 'manual' | 'static')false
caller_id.nameCaller ID Namestring()false
caller_id.numberCaller ID Numberstring()false
caller_idStatic Caller ID settingsobject()false
enforce_call_restrictionCheck classification restrictions against endpointboolean()truefalse
idList ID for caller IDs when ‘action’ is ‘list’string()false
idx_nameNamed capture group to usestring()false
interdigit_timeoutHow long, in seconds, to wait for keypressesinteger()false
max_digitsMax number of digits allowed when collecting Caller ID Numberinteger()false
media_idPrompt to play to caller to enter Caller ID Numberstring()false
min_digitsMinimum number of digits that must match the regex to collected DTMFinteger()false
permit_custom_callflowPermit a custom callflow to be accepted instead of restricting to no_match only when looking up callflowsboolean()falsefalse
skip_moduleWhen set to true this callflow action is skipped, advancing to the wildcard branch (if any)boolean()false
whitelist_regexRegex to match collected Caller ID Numberstring()false

Manual action mode

In this method user is prompted to dial a new Caller ID number. The length of the dialed new Caller ID is checked to be in the default(or configured) boundary and it is also matched against the default(or configured) regex, if these checks are passed the call will proceed.

Notes You can only set the Caller ID number with this method.

Example Scenario

User dial *212223332222 (assuming you set the feature code to *2 by setting callflow patterns to "^\\*2([0-9]{2,})$") and prompted to dial the new Caller ID number, then the call will send onto real destination which in this case is 12223332222.

Manual callflow settings

You may want to customize manual behavior in system_configs/callflow.dynamic_cid.

Schema

Schema for callflow.dynamic_cid system_config

KeyDescriptionTypeDefaultRequiredSupport Level
accept_promptcallflow.dynamic_cid accept promptstring()tone_stream://%(250,50,440)false
default_promptcallflow.dynamic_cid default promptstring()dynamic-cid-enter_cidfalse
max_digitscallflow.dynamic_cid max digitsinteger()10false
min_digitscallflow.dynamic_cid min digitsinteger()10false
reject_promptcallflow.dynamic_cid reject promptstring()dynamic-cid-invalid_using_defaultfalse
whitelist_regexcallflow.dynamic_cid whitelist regexstring()\d+false

List action mode

In this method you have flexibility to define multiple Caller ID, each assign to a specific number using account’s list. You can set both the Caller ID name and number in a document in database. This callflow’s module use that information to set new Caller ID. You can create your list and list’s entries using List API.

This done by first getting group capture which populate by callflow automatically (feature code is removed from the beginning) then get a specific length of numbers starting from the beginning of the dialed number (by default 2 numbers). This number is it the key (or index) in a list of Caller ID entry list. For and example how this works, see the example section.

This behavior is exactly same as lists action, the only difference is that you can define the index of the matching number (entry index) in the callflow data in idx_name.

Notes You can set both the Caller ID number and name with this method.

List of contacts document fields

Schema

Schema for a list of contacts

KeyDescriptionTypeDefaultRequiredSupport Level
capture_group.keyThe number which is used to select this contact, length should be same as capture_group_lengthstring()false
capture_group.lengthLength of the numbers in the contacts for which it used to select desire Caller IDinteger()false
capture_groupThe capture group informationobject(){}false
contactsA list of contact informationarray([#/definitions/contacts](#contacts))true
favoriteWhether the contact is a favoriteboolean()falsefalse
first_nameThe first name of the contactstring()true
historyThe history of contact usagearray([#/definitions/history](#history))[]false
last_nameThe last name of the contactstring()false
organization.nameThe name of the organizationstring()false
organizationThe organization this entity belongs toobject(){}false
patternMatch patternstring()false
tags.[]string()false
tagsTags that contact belong toarray(string())false

contacts

Schema for a contact.

KeyDescriptionTypeDefaultRequiredSupport Level
contactThe phone number or email associated with the contact (Ex: +14158867903, user@2600hz.com)string()true
device_typeThe type of the devicestring('work', 'home', 'mobile', 'personal', 'fax')false
email_typeThe type of the emailstring('work', 'home')false
extThe extension of the user (Ex: 356, 622)string()false
primaryIf this is the primary contact for this contact type.boolean()true
typeThe type of this contactstring('voice', 'email', 'sms')true

history

Schema for a history.

KeyDescriptionTypeDefaultRequiredSupport Level
contactThe contact that was used#/definitions/contactstrue
notesNotes from the communicationstring()false
timestampThe gregorian timestampinteger()false

Example 1: Two digits as CID selector

Consider that the user wants to call number 5149072508 using the caller id 16139999999. We assume that callflow patterns set as follow:

    "patterns": [
        "^\\*2([0-9]{2,})$"
    ]

and the list of contacts document is:

{
    "capture_group": {
            "key": "01",
            "length": 2
    },
    "contacts": [
            {
                "type": "voice",
                "contact": "19058888888",
                "primary": "true"
            }
    ],
    "first_name": "Awesome Inc."
}

These are the steps will happen if a user dial *2015149072508 in handset:

  1. This pattern above means that *2 is the “feature code”. Callflow will use this module to handle the call
  2. 01 will be used to select the Caller ID with number “19058888888” and name “Awesome Inc.”. Consider that it’s length is 2 digits as specified in capture_group_length field
  3. Selected CID will be set for the call
  4. 5149072508 becomes +15149072508 and gets dialed as such

Example 2: One digits as CID selector

Another example which uses number with length of 1 to select the Caller ID:

{
    "capture_group": {
            "key": "0",
            "length": 1
    },
    "contacts": [
            {
                "type": "voice",
                "contact": "16139999999",
                "primary": "true"
            }
    ],
    "first_name": "Awesome Co."
}

Dialing number *205149072508 will cause number “5149072508” gets dialed with CID number set to “16139999999” CID name to “Awesome Co.”.

Lists action mode

Almost the same as list mode using account’s lists feature to configure entries.

Static action mode

In this method the new Caller ID number and name would be set to caller_id value sets in the callflow Data object.

Example Callflow Data

{
    "data": {
        "action": "static",
        "caller_id": {
            "name": "CALL_ME",
            "number": "5555555555"
        }
    },
    "module": "dynamic_cid"
}

Permit Custom Callflow

The config parameter permit_custom_callflow is used in the lists action type case. When attempting to fetch the callflow, the default behavior is to reject any callflow returned which is not the no_match callflow. If a callflow is defined which matches the resultant destination number, this setting allows that callflow to be used, bypassing the no_match restriction.