<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Sep 4, 2013 at 5:02 PM, Matthew Jordan <span dir="ltr"><<a href="mailto:mjordan@digium.com" target="_blank">mjordan@digium.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote"><div class="im">On Wed, Sep 4, 2013 at 3:41 PM, Joshua Colp <span dir="ltr"><<a href="mailto:jcolp@digium.com" target="_blank">jcolp@digium.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div>George Joseph wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
Gotcha. If you give me some naming convention guidance, I can work on<br>
both the SIP equivalents and config stuff (which would be needed to<br>
duplicate SIPPEER anyway) using PJSIP_DIAL_CONTACTS and<br>
PJSIP_MEDIA_OFFER as templates.<br>
</blockquote>
<br></div>
Changing the names is a minor thing, so just go with what feels right. Note: We have no peers though.<div><br></div></blockquote><div><br></div></div><div>My personal preference (although I'm certainly open to any alternatives):</div>
<div><br></div><div>SIPPEER -> PJSIP_ENDPOINT</div><div>SIP_HEADER -> PJSIP_HEADER (thoughts below on this)</div><div>SIPCHANINFO -> PJSIP_CHAN_INFO</div><div><br></div><div>As far as SipAddHeader/SipRemoveHeader go - it always felt a little wonky that these were dialplan applications, particularly when we have SIP_HEADER as a function. It feels like this could be easily:</div>
<div><br></div><div>${PJSIP_HEADER(X-foo)} - equivalent to SIP_HEADER</div><div>Set(PJSIP_HEADER(X-foo)=bar) - equivalent to SipAddHeader</div><div>Set(PJSIP_HEADER(X-foo)=) - equivalent to SipRemoveHeader</div>
<div><br></div><div>The last one is the most tricky, as it is debatable whether or not certain headers (such as Allow) can be empty. If we need to allow empty headers, another option would be to explicitly specify 'remove' as the second parameter to the function:</div>
<div><br></div><div>Set(PJSIP_HEADER(X-foo,remove)=)</div><div><br></div><div>Just some thoughts.</div><div><br></div><div>It'd be fantastic for someone to contribute those patches - let us know if you need any help/pointers!</div>
<div><br></div></div></div></div></blockquote><div><br></div><div style>I've spent a bit of time giving some thoughts to implementation details of PJSIP_HEADER.</div><div style><br></div><div style>The challenge is that in chan_sip.c, the initial request that started a dialog is cached on the sip_pvt struct. This can easily be queried from the dialplan. With PJSIP, the pjsip_rx_data for the initial INVITE has been freed by the time the dialplan runs.</div>
<div style><br></div><div style>My thought is to write a session supplement that is triggered on incoming INVITEs. The module that implements the session supplement would also implement the PJSIP_HEADER dialplan function.</div>
<div style><br></div><div style>On an incoming INVITE, the session supplement would use pjsip_msg_clone() in order to make a copy of the rdata->msg_info.msg. This could then be stored on a datastore on the session. When PJSIP_HEADER() is called in order to read a specific header, the datastore can be retrieved from the session and pjsip_msg_find_hdr_by_name() can be used to find the value of a specific header.</div>
<div style><br></div><div style>As for PJIPAddHeader (or making PJSIP_HEADER operate in write mode to add headers), this could be done similarly, but in reverse. When PJSIPAddHeader is called, the proposed header could be stored on the session in a datastore. On an outgoing INVITE, the session supplement could query the datastore for extra headers to add and call ast_sip_add_header() to add the headers to the outgoing request. If you look at res/res_pjsip/pjsip_global_headers.c, you can see an example of adding headers from a list onto requests and responses; however, that file does not make use of a datastore.</div>
<div style><br></div><div style>One further note: PJSIPAddHeader should not work the same way that it currently does for chan_sip.c. In chan_sip.c, you call SIPAddHeader on an incoming call and the header is then added to the outgoing call's INVITE. For PJSIP, we should only ever modify the relevant session. If people want to add headers to an outgoing INVITE, then they can use PJSIPAddHeader in a predial handler. This adds the flexibility, if desired, of adding specific headers to specific outgoing call legs without forcing the same headers on all outgoing call legs.</div>
</div><br></div></div>