CallRouting
m (removed needs revising tag) |
|||
(16 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
− | Routing is important for gateway applications | + | {{DISPLAYTITLE:Call Routing}} |
− | call attributes and | + | |
− | + | Call routing is an important feature for gateway applications. Call routing is in charge of assigning call routes for incoming | |
+ | call attributes and this may change based on external factors like the time of the day or congestion. Call routes are responsible | ||
+ | for providing call attributes for incoming and outgoing legs; they contain common routing information like the called | ||
number, the calling number and the network access point. | number, the calling number and the network access point. | ||
Line 12: | Line 14: | ||
<li>Forced: always transcode. | <li>Forced: always transcode. | ||
<li>Only as a fallback: to try to save hardware resources. | <li>Only as a fallback: to try to save hardware resources. | ||
− | <li>Disabled: if the the | + | <li>Disabled: if the the hardware resources are not available. |
</ul> | </ul> | ||
Line 18: | Line 20: | ||
== Usage == | == Usage == | ||
− | The default routing implementation routes on only three | + | The default routing implementation routes on only three optional criteria (there must be at least one per rule): |
<ul> | <ul> | ||
<li>Called number. | <li>Called number. | ||
Line 28: | Line 30: | ||
route that is returned to the application. Remapping can be done on: | route that is returned to the application. Remapping can be done on: | ||
<ul> | <ul> | ||
− | <li>Called number | + | <li>Called number |
− | <li>Calling number | + | <li>Calling number |
− | <li>Destination network access point | + | <li>Destination network access point |
</ul> | </ul> | ||
In the default route implementation, the media profile is also changed depending on the transcoding type. This is done | In the default route implementation, the media profile is also changed depending on the transcoding type. This is done | ||
− | by the route in GetIncomingAttributes and GetOutgoingAttributes which will | + | by the route in GetIncomingAttributes and GetOutgoingAttributes, which will instantiate the attribute based on the |
transcoding type. This works fine for this initial profile but the leg’s profile may be changed during the call’s life and | transcoding type. This works fine for this initial profile but the leg’s profile may be changed during the call’s life and | ||
that change must be handled depending on the transcoding type. The attribute class is the one that is aware of the | that change must be handled depending on the transcoding type. The attribute class is the one that is aware of the | ||
Line 40: | Line 42: | ||
occurs. | occurs. | ||
− | < | + | <code> |
− | switch( mRoutingEntry.TranscodingType ) | + | { |
− | { | + | switch( mRoutingEntry.TranscodingType ) |
− | case TBCAF_ROUTING_TRANSCODING_TYPE_NORMAL: | + | { |
− | { | + | case TBCAF_ROUTING_TRANSCODING_TYPE_NORMAL: |
− | pAttributes = tbnew CTBCMC_CALL_LEG_ATTRIBUTE; | + | { |
− | }break; | + | pAttributes = tbnew CTBCMC_CALL_LEG_ATTRIBUTE; |
− | case TBCAF_ROUTING_TRANSCODING_TYPE_FORCED: | + | }break; |
− | { | + | case TBCAF_ROUTING_TRANSCODING_TYPE_FORCED: |
− | pAttributes = tbnew CTBCMC_CALL_LEG_FT_ATTRIBUTE; | + | { |
− | }break; | + | pAttributes = tbnew CTBCMC_CALL_LEG_FT_ATTRIBUTE; |
− | case TBCAF_ROUTING_TRANSCODING_TYPE_NEVER: | + | }break; |
− | { | + | case TBCAF_ROUTING_TRANSCODING_TYPE_NEVER: |
− | pAttributes = tbnew CTBCMC_CALL_LEG_NT_ATTRIBUTE; | + | { |
− | }break; | + | pAttributes = tbnew CTBCMC_CALL_LEG_NT_ATTRIBUTE; |
− | default: | + | }break; |
− | { | + | |
− | TBX_EXIT_ERROR( TBX_RESULT_INVALID_STATE, 0, "Invalid transcoding type." ); | + | default: |
− | } | + | { |
− | } | + | TBX_EXIT_ERROR( TBX_RESULT_INVALID_STATE, 0, "Invalid transcoding type." ); |
− | }</ | + | } |
+ | } | ||
+ | }</code> | ||
+ | |||
+ | |||
+ | == Caveats == | ||
+ | For now only forced transcoding is supported by the CMC server but this might change in the future. Video support in CMC might force the issue because video transcoding is not cheap. |
Latest revision as of 09:01, 8 March 2018
Call routing is an important feature for gateway applications. Call routing is in charge of assigning call routes for incoming
call attributes and this may change based on external factors like the time of the day or congestion. Call routes are responsible
for providing call attributes for incoming and outgoing legs; they contain common routing information like the called
number, the calling number and the network access point.
The media profile may be changed by a route so that a route can also change the media of a leg. This can be used to force specific codecs to be used for certain routes or to specify the transcoding type. The transcoding type is only important for VOIP calls since it indicates when the adapter should include itself in the media path. Transcoding is limited limited to the following type:
- Forced: always transcode.
- Only as a fallback: to try to save hardware resources.
- Disabled: if the the hardware resources are not available.
Usage
The default routing implementation routes on only three optional criteria (there must be at least one per rule):
- Called number.
- Calling number.
- Incoming network access point.
When it finds a route matching the call attribute’s criteria, it applies remapping on the desired fields and creates a route that is returned to the application. Remapping can be done on:
- Called number
- Calling number
- Destination network access point
In the default route implementation, the media profile is also changed depending on the transcoding type. This is done by the route in GetIncomingAttributes and GetOutgoingAttributes, which will instantiate the attribute based on the transcoding type. This works fine for this initial profile but the leg’s profile may be changed during the call’s life and that change must be handled depending on the transcoding type. The attribute class is the one that is aware of the transcoding type because it is stored in the leg, and will be queried (through SetMediaProfile) when a profile change occurs.
{ switch( mRoutingEntry.TranscodingType ) { case TBCAF_ROUTING_TRANSCODING_TYPE_NORMAL: { pAttributes = tbnew CTBCMC_CALL_LEG_ATTRIBUTE; }break; case TBCAF_ROUTING_TRANSCODING_TYPE_FORCED: { pAttributes = tbnew CTBCMC_CALL_LEG_FT_ATTRIBUTE; }break; case TBCAF_ROUTING_TRANSCODING_TYPE_NEVER: { pAttributes = tbnew CTBCMC_CALL_LEG_NT_ATTRIBUTE; }break; default: { TBX_EXIT_ERROR( TBX_RESULT_INVALID_STATE, 0, "Invalid transcoding type." ); } } }
Caveats
For now only forced transcoding is supported by the CMC server but this might change in the future. Video support in CMC might force the issue because video transcoding is not cheap.