= MSRP Relay =
This project implements an MSRP relay, which is an extension to the MSRP protocol. Its main role is to help NAT traversal of IM and file transfer media sessions between SIP User Agents located behind NAT.Background
A series of related instant messages between two or more parties can be viewed as part of a "message session", that is, a conversational exchange of messages with a definite beginning and end. This is in contrast to individual messages each sent independently. Messaging schemes that track only individual messages can be described as "page-mode" messaging, whereas messaging that is part of a "session" with a definite start and end is called "session-mode" messaging.
Page-mode messaging is enabled in SIP via the SIP MESSAGE method, as defined in [http://tools.ietf.org/html/rfc3428 RFC 3428]. Session-mode messaging has a number of benefits over page-mode messaging, however, such as explicit rendezvous, tighter integration with other media-types, direct client-to-client operation, and brokered privacy and security.
Message Session Relay Protocol (MSRP) is a protocol for transmitting a series of related instant messages in the context of a session. Message sessions are treated like any other media stream when set up via a rendezvous or session creation protocol such as the Session Initiation Protocol (SIP). MSRP Sessions are defined in [http://tools.ietf.org/html/rfc4975 RFC 4975].
This project implements an MSRP relay ,which is an extension to the MSRP protocol. Its main role is to help NAT traversal of media sessions between endpoints located behind NAT. This extension is defined in [http://tools.ietf.org/html/rfc4976 RFC 4976].Documentation * [wiki:MSRPRelayScenarios MSRP Relay scenarios] - This document describes several use case scenarios of how MSRP relay functionality may be deployed in the field * [wiki:MSRPRelayDesign MSRP Relay design] - The internal logic of the MSRPRelay is described as a series of message flow diagrams * [wiki:InstallationGuide Installation guide] - How to install the software Download
The software can be downloaded from:
The software is provided under GPL license.MSRP clients
One of the reasons for the development of MSRP relay was to kick start the development of MSRP clients. We are not aware of any client at the moment of writing of this wiki page. We provide a working proof-of-concept [wiki:testclients Test client] for a file transfer session between two endpoints located behind NAT.Live testbed
We provide a live SIP testbed with MSRP relay enabled. By registering a SIP account at [http://sip2sip.info http://sip2sip.info] you may use the SIP account for reserving MSRP sessions in a working MSRP relay.
_msrps._tcp.sip2sip.info. 300 IN SRV 0 0 2855 node03.dns-hosting.info.
node03.dns-hosting.info. 60 IN A 220.127.116.11
Note: Relaying traffic through http://sip2sip.info, which is free service, uses bandwidth as there is no limit for a file transfer session. The relay does not feature yet throttling of sessions. For the benefit of other test users, please refrain yourself from abusing the test bed, transfer small files or use the relay for IM sessions only.Credits * Funding: [http://www.nlnet.nl NLNet foundation] * Project management: Adrian Georgescu * Author: Ruud Klaver * Contributors: Dan Pascu's [http://cheeseshop.python.org/pypi/python-gnutls python-gnutls] * Many thanks to the IETF community for advise and support Support * The project is supported via this wiki collaboration system by [http://ag-projects.com AG Projects]. To open ticket please Register first. The ticketing support system is available only for registered users. The support is provided on a best-effort basis. * For interaction between MSRP Relay and OpenSER you may consult the [http://openser.org/pipermail/users/ OpenSER users mailing list] Commercial products
MSRPRelay is part of turnkey SIP platforms offered by AG Projects: