Skip to content

chan_motif: Jingle Channel Driver

This configuration documentation is for functionality provided by chan_motif.

Overview

Transports

There are three different transports and protocol derivatives supported by 'chan_motif'. They are in order of preference: Jingle using ICE-UDP, Google Jingle, and Google-V1.

Jingle as defined in XEP-0166 supports the widest range of features. It is referred to as 'ice-udp'. This is the specification that Jingle clients implement.

Google Jingle follows the Jingle specification for signaling but uses a custom transport for media. It is supported by the Google Talk Plug-in in Gmail and by some other Jingle clients. It is referred to as 'google' in this file.

Google-V1 is the original Google Talk signaling protocol which uses an initial preliminary version of Jingle. It also uses the same custom transport as Google Jingle for media. It is supported by Google Voice, some other Jingle clients, and the Windows Google Talk client. It is referred to as 'google-v1' in this file.

Incoming sessions will automatically switch to the correct transport once it has been determined.

Outgoing sessions are capable of determining if the target is capable of Jingle or a Google transport if the target is in the roster. Unfortunately it is not possible to differentiate between a Google Jingle or Google-V1 capable resource until a session initiate attempt occurs. If a resource is determined to use a Google transport it will initially use Google Jingle but will fall back to Google-V1 if required.

If an outgoing session attempt fails due to failure to support the given transport 'chan_motif' will fall back in preference order listed previously until all transports have been exhausted.

Dialing and Resource Selection Strategy

Placing a call through an endpoint can be accomplished using the following dial string:

Motif/[endpoint name]/[target]

When placing an outgoing call through an endpoint the requested target is searched for in the roster list. If present the first Jingle or Google Jingle capable resource is specifically targeted. Since the capabilities of the resource are known the outgoing session initiation will disregard the configured transport and use the determined one.

If the target is not found in the roster the target will be used as-is and a session will be initiated using the transport specified in this configuration file. If no transport has been specified the endpoint defaults to 'ice-udp'.

Video Support

Support for video does not need to be explicitly enabled. Configuring any video codec on your endpoint will automatically enable it.

DTMF

The only supported method for DTMF is RFC2833. This is always enabled on audio streams and negotiated if possible.

Incoming Calls

Incoming calls will first look for the extension matching the name of the endpoint in the configured context. If no such extension exists the call will automatically fall back to the 's' extension.

CallerID

The incoming caller id number is populated with the username of the caller and the name is populated with the full identity of the caller. If you would like to perform authentication or filtering of incoming calls it is recommended that you use these fields to do so.

Outgoing caller id can not be set.

Warning

Multiple endpoints using the same connection is NOT supported. Doing so may result in broken calls.

Configuration File: motif.conf

[endpoint]: The configuration for an endpoint.

Configuration Option Reference

Option Name Type Default Value Regular Expression Description
accountcode Accout code for CDR purposes
allow Codecs to allow
callgroup A callgroup to assign to this endpoint.
connection Connection to accept traffic on and on which to send traffic out
context Default dialplan context that incoming sessions will be routed to
disallow Codecs to disallow
language The default language for this endpoint.
maxicecandidates Maximum number of ICE candidates to offer
maxpayloads Maximum number of payloads to offer
musicclass Default music on hold class for this endpoint.
parkinglot Default parking lot for this endpoint.
pickupgroup A pickup group to assign to this endpoint.
transport The transport to use for the endpoint.

Configuration Option Descriptions

transport

The default outbound transport for this endpoint. Inbound messages are inferred. Allowed transports are 'ice-udp', 'google', or 'google-v1'. Note that 'chan_motif' will fall back to transport preference order if the transport value chosen here fails.

  • ice-udp - The Jingle protocol, as defined in XEP 0166.

  • google - The Google Jingle protocol, which follows the Jingle specification for signaling but uses a custom transport for media.

  • google-v1 - Google-V1 is the original Google Talk signaling protocol which uses an initial preliminary version of Jingle. It also uses the same custom transport as 'google' for media.

Generated Version

This documentation was generated from Asterisk branch 21 using version GIT