Subject: | Dual stack StatelessProxy contact rewriting |
Date: | Mon, 3 Apr 2017 17:22:43 +0000 |
To: | "bug-Net-SIP [...] rt.cpan.org" <bug-Net-SIP [...] rt.cpan.org> |
From: | Richard Carver <richard.carver [...] cloudmont.co.uk> |
When I create Legs I specify a contact which identifies the host by name instead of IP. I create two legs with the same contact, one with an IPv4 address and one with an IPv6 address. I publish an A and an AAAA for the hostname to cover both IPv4 and IPv6.
The scenario causing an issue is using the default contact rewrite function where my proxy prefers to use IPv6 when it sends a request and the remote side sometimes used IPv4 to respond depending on the exact scenario.
I wonder whether implementing dual-stack support this way is a bad idea, but if you think it is a valid scenario then I propose to update Statelessproxy.pm :: _default_rewrite_contact so that instead of comparing the leg keys it compares the leg contacts before deciding to reject the rewrite due to using a different leg. I have been using a customised version of _default_rewrite_contact on the older version of the module with the leg check removed and my scenario worked.