CommuniGate Pro
Version 6.3
 

Automated Signal Processing Rules

The CommuniGate Pro Server can automatically process Signals using sets of Automated Rules. Rules are not applied to Signal Requests sent inside already established Dialogs.

The system-wide (Server-Wide and Cluster-wide) Rules are applied to all Signals sent to the Server and/or to the Cluster.

When a Signal request is directed to a CommuniGate Pro Server Account, the Account-level Rules are applied.
The Account-level Rules are the Rules specified for the particular Account along with the Rules specified for the Account Domain.



Applying Signal Rules

Each signal Rules has its stage and priority. The stage specifies when the Rule should be applied:

  • immediately when the Signal is received
  • after the Signal is being processed for some time
  • when the Signal fails with the No Answer, Busy, or some other error condition.

Within each stage the Rules are applied according to their priority.

When Server, Cluster, Domain, and Account Rules are "merged", they are grouped based on the stage value. Within each stage, the Rules are applied in the following order:

  • the Server and Cluster Rules with the priority > 5
  • the Domain Rules with the priority > 5
  • all Account Rules
  • the Domain Rules with the priority <= 5
  • the Server and Cluster Rules with the priority <= 5

Note: when Signal processing starts, all Server and Cluster Rules for the "immediate" stage are applied first, and only then processing continues. The Signal can be directed to a local Account, and the Account and Account Domain Rules are "merged" with the Server and Cluster Rules. But at that moment all Server and Cluster Rules for the "immediate" stage have been already applied and removed from the "merged" set.

Specifying Signal Rules

System administrators can specify Server-wide and Cluster-wide Signal Rules. Use the WebAdmin Interface to open the Real-Time pages in the Settings realm, and click the Rules link.

System and Domain Administrators can specify Account Rules using links on the Account Settings WebAdmin Interface pages.

Account users can specify their Rules themselves, using the WebUser Interface. System or Domain Administrators can limit the set of Rule actions a user is allowed to specify.

System and Domain Administrators can specify Domain-Wide Rules using the Rules links on the Domain Settings pages.

See the generic Automated Rules section to learn how to set Rules.


Rule Conditions

Each Rule can use universal conditions specified in the Rules section.
Additionally, the following Rule conditions can be used in Signal processing Rules:

Operation [is | is not | in | not in] string
This condition checks if the Request method is or is not equal to the specified string.
Sample:
This condition will be met for all INVITE Requests.
CallType [is | is not | in | not in] string
This condition checks if the Request SDP type is (or is not) equal to the specified string.
The SDP type is AV if the request method is INVITE and it contains at least one audio or video media channel;
The SDP type is IM if the request method is MESSAGE or if the request method is INVITE and it contains an IM channel.
The SDP type is an empty string in all other cases.
Sample:
This condition will be met for all audio/video INVITE Requests.
Target Address [is | is not | in | not in] string
This condition checks if the Request URI is (or is not) equal to the specified string.
Sample:
This condition will be met for all signals coming to on any vm.communigatepro.ru account.
From [is | is not | in | not in] string
This condition checks if the Request From address is (or is not) equal to the specified string.
Sample:
This condition will be met for all signals coming from any account of any of communigatepro.ru subdomains.
To [is | is not | in | not in] string
The same as above, but the Request To field address is checked.
'From' Name [is | is not | in | not in] string
The same as above, but the instead of the address, the "address comment" (the real name) included in the From address is checked.
Sample:
This condition will be met for Requests with the following From: addresses:
From: <sip:jsmith@company.com> (John J. Smith)
From: "Bill J. Smith" <sip:b.smith@othercompany.com>
From: Susan J. Smith <sips:susan@thirdcompany.com>
Authenticated [is | is not | in | not in] string
This condition checks the Request authentication. If the Request has been authenticated by this CommuniGate Pro Server, the authenticated Account name (account@domain) is compared with the specified string.
Sample:
This condition will be met for all signals coming from any account on any of communigatepro.ru subdomains.
Presence [is | is not | in | not in] string
This condition checks the aggregated presence of the request target. This condition can be used in the Domain- and Account- level Rules only.
The Presence is one of the strings online, busy, away. The Presence is an empty string when the call target is offline.
Sample:
Active Devices [is | is not | less than | greater than | in | not in] number-string
This condition checks the total number of Registered Devices for the request target. This condition can be used in the Domain- and Account- level Rules only.
When a call is forked to a different destination, the total number of Registered Device is increased by the number of registered devices for the new request target.
When a call is redirect to a different destination, the total number of Registered Device is reset to zero, and then it is increased by the number of registered devices for the new request target.
Device Type [is | is not | in | not in] string
This condition checks the type of device sending the request (the User-Agent request field).
Request Field [is | is not | in | not in] string
The string must contain the Request field name and the field data picture, separated with the colon (:) symbol. This condition compares the specified request field data with the data picture. Only simple, unstructured request fields can be compared.
Sample:

Rule Actions

Each Rule can have zero, one, or several actions. If a Request meets all the Rule conditions, the Rule actions are performed.

You can use all universal actions described in the Rules section. This section describes the Rule actions that can be used in Signal Rules:

Stop Processing
This action should be the last one in a Rule. Execution of this Rule stops and no other (lower-priority) Rules are checked for this Signal at this time. Signal processing proceeds.
Discard Rules
This action should be the last one in a Rule. Execution of this Rule stops and no other (lower-priority) Rules are checked for this Signal, and all remaining Rules (scheduled to apply at later times or if the Signal fails) are removed, too. Signal processing proceeds.
Redirect to addresses
The Signal is redirected to one or several specified addresses: the current Signal "destination set" is cleared, and the specified addresses form the new "destination set".
Each address should be specified as a sip:, sips:, or tel: URI. If several addresses are specified, they should be separated with the comma (,) sign.
To redirect the Signal into a PBX application you can use the address #myProgram to run the application myProgram on behalf of the Signal authenticated source.
Sample:

This Rule will direct all INVITE Signals to the adManager@domain.com address, unless the Signal authenticated source is adManager@domain.com.
You can use this Rule to implement an advertising server: the adManager@domain.com Account can start a PBX application that will play some media to the caller, and then, acting as a B2BUA, will connect the caller with the original destination. The calls made by that application will have adManager@domain.com as their authenticated source, so this Rule will not redirect them.
Fork to addresses
Same as Redirect to, but the specified addresses are added to the current "destination set" without clearing it first.
ParlayDirect parameters
ParlayNotify parameters
These actions implement the "CallDirection" and "CallNotification" ParlayX Interfaces. The parameters setings specifies the request operation to use, the Parlay "correlator", and the URL to send the request to.

Macro Substitution

Parameter strings for SendURL, Send IM, Send Push, Write To Log actions can include "macro" - symbol combinations that are substituted with actual data before the parameter is used with the Signal Rule action.

The following symbol combinations are available:

^F is substituted with the request From address (including the "Real name" part, decoded and converted to UTF-8)
^E is substituted with the request From address (the E-mail address only)
^t is substituted with the RFC822-formatted current-time.
^I is substituted with the request Call-ID.
^R is substituted with the request To address (the E-mail address only)
^M is substituted with the request Method.
^U is substituted with the request URL.
^^ is substituted with a single ^ symbol.

Logging Rules Activity

The Signal component records system-wide Rules activity in the Log. Set the Signal Log Level to Low-Level or All Info to see the Rules checked and the actions executed.

CommuniGate Pro Guide. Copyright © 2024, AO SBK