[Serusers] mediaproxy module: RTP packet mapping after reINVITE with new SDP
Joel Rosenfield
joelrosenfield at yahoo.com
Tue Nov 15 17:31:00 CET 2005
As I am new to this list, please tell me if there is a more appropriate list to
which I should post this question.
Does the mediaproxy handle changes in the media description within the same
call dialog? If not, are there plans to do so?
Here is what I have done:
I am using the SER mediaproxy module v1.4.2 and a co-located proxydispatcher
and mediaproxy to accomplish NAT traversal between a 3PCC and an remote ATA.
All basic call scenarios work fine. However, when the module receives a
reINVITE to reconnect the ATA to a different party, the mediaserver fails to
forward the RTP packets between the ATA and party described in the new SDP.
I saw in the mediaproxy logs that RTP packets had been received from both
sides, but the signIn method was being invoked as "called" for both parties.
I explored the rtphandler.py and saw that the "catchall" clause at the end of
RTPStream.handle_read was being invoked as you can see by the debug statement
that I added to the code. It appears that this is invoked because both parties
had already signed in based upon the previous media description, so none of the
other mapping/forwarding clauses are invoked.
It seems that there needs to be a mechanism to clear the mappings when the
mediaproxy receives a "request" command for the same session (based upon the
SIP Call-ID) but a new SDP. I got it work by adding code to the beginning of
RTPSession.updateStreams() that clears the list "mediaStreams" and letting the
rest of the code in that method recreate the mappings from scratch. See the
attached file containing the code, a mediaproxy log before the change, and a
log from after the change.
Although this works, the solution is a bit incomplete since it can cause brief
interruptions in the RTP stream when a reINVITE is received that does not
include an SDP change, etc.
Please let me know if there is something I am missing with respect to how I
should using the mediaproxy.
Thanks,
- Joel Rosenfield
__________________________________
Yahoo! FareChase: Search multiple travel sites in one click.
http://farechase.yahoo.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: mediaproxyissue.log
Type: application/octet-stream
Size: 7356 bytes
Desc: 637290987-mediaproxyissue.log
URL: <http://lists.sip-router.org/pipermail/sr-users/attachments/20051115/660c689a/attachment.obj>
More information about the sr-users
mailing list