RFC2833 and KPML Interworking
Keypad Markup Language (KPML) is used to indicate DTMF tones in SIP messaging. KPML is used by the Key Press Stimulus Package as a SIP Event Notification Package, transmitting DTMF tone indications via NOTIFY messages. You can configure the Oracle Communications Session Border Controller (OCSBC) to perform Event Notification with an endpoint on one call leg and perform digit encapsulation to RFC 2833 telephone-events on the other call leg.
KPML to RFC2833
- A session agent with kpml-interworking set to enabled
- A session agent with kpml-interworking set to inherited from the SIP interface (with kpml-interworking set to enabled)
- A previous hop that is not a session agent, and the SIP interface the message received on has kpml-interworking set to enabled.
The egress side of the call must have rfc2833-mode set to preferred in either the SIP interface or session agent, so that the OCSBC inserts telephone-event in the SDP. Setting rfc2833-mode to dual is unsupported for KPML interworking. The answerer must respond to the invite, accepting the telephone-event media. The Allow-Event: kpml header is removed from the INVITE request or response when KPML-interworking is not set to enabled on the next hop.
If the INVITE succeeds, the OCSBC replies with a SUBSCRIBE request for the KPML event to the caller.
If the caller replies to the SUBSCRIBE with a 2xx, all subsequent NOTIFY request received on the dialog are processed and replied to with a 200 OK. Each digit in the NOTIFY request will generate a telephone-event on the egress side of the call.
The OCSBC generates a refresh SUBSCRIBE before the subscription expires.
If the call negotiates to RFC 2833, no KPML interworking is performed.
The following diagram shows the standard case where KPML to RFC 2833 interworking is performed.
RFC 2833 to KPML
- A session agent with kpml-interworking set to enabled
- A session agent with kpml-interworking set to inherited from the SIP interface (with kpml-interworking set to enabled)
- Not a session agent, and the SIP interface the message is sent from has kpml-interworking set to enabled.
If the scenario passes the above test and the Allow-Event: kpml header is added to the INVITE:
- The INVITE dialog is terminated due to a BYE;
- The subscription expires; or
- The subscription is terminated with a subscribe request Expires: 0.
- While the example has SDP in the INVITE, delayed offer scenarios where the SDP exchange occurs in the 20 0OK and the ACK are supported
- The rfc2833-mode parameter in the in either the SIP interface or session agent, is considered in the interworking. See next section:
- If the call negotiates to RFC 2833 to RFC 2833, no KPML interworking is performed.
- In RFC 2833 to KPML scenarios, if the SUBSCRIBE is not received quickly enough, RFC 2833 digits are dropped.
| Originator | Terminator | SBC Behavior | 
|---|---|---|
| rfc2833-mode=transparent, offers 2833 SDP | rfc2833-mode=transparent, answers NO 2833 SDP | Forwards 2833 offer, Adds Allow-Event: kpml, passes non-2833 capability to Originator (no 2833 support) | 
| rfc2833-mode=preferred, offers 2833 SDP | rfc2833-mode=transparent, answers NO 2833 SDP | Forwards 2833 offer, Adds Allow-Event: kpml, inserts 2833 capability to Originator, performs 2833 to KPML translation | 
| rfc2833-mode=transparent, offers 2833 SDP | rfc2833-mode=preferred, answers NO 2833 SDP | Forwards 2833 offer, Adds Allow-Event: kpml, passes non-2833 capability to Originator (no 2833 support) | 
| rfc2833-mode=preferred, offers 2833 SDP | rfc2833-mode=preferred, answers NO 2833 SDP | Forwards 2833 offer, Adds Allow-Event: kpml, inserts 2833 capability to Originator, performs 2833 to KPML translation | 
Additional Configuration Consideration
If using a session agent to establish this interworking on the DTMF/RDC2833 side, check the rfc2833-payload and rfc2833-mode values in your session-agent and sip-interface. The payload type used for RFC 2833 and mode must be the same on both the session-agent and sip-interface.
The RFC default for rfc2833 payload type is 101, but you may have configured a media profile with a different payload type. If not, you can set to rfc2833-payload to 101.
Specific configuration on the session-agent on the sip-interface that is supporting DTMF/RFC2833 includes:
- rfc2833-payload—Set this parameter either to 101, if using the default on your sip-interface, or to a value that is the same on both the session-agent and the sip-interface.
- rfc2833-mode—Set this parameter to transparent.