<html>
<body>
This looks like a great idea.&nbsp; However I've got some
questions.<br><br>
You indicate you are making some decision based upon whether or not an
endpoint is registered or static.&nbsp; What happens if a static endpoint
is really just a SIP UA EP?&nbsp; What happens if a softswitch you are
serving as voicemail media for is registering with you instead of being
static?<br><br>
Would it work better if you added a special argument to the
sip.conf?<br><br>
instead of <br><br>
<a href="mailto:mailbox=12895551001@suppc5cm1,12895551002@suppc5cm1,12455551000@suppc5cm1">mailbox=12895551001@suppc5cm1,12895551002@suppc5cm1,12455551000@suppc5cm1</a><br><br>
how about:<br><br>
remotemailbox<a href="mailto:mailbox=12895551001@suppc5cm1,12895551002@suppc5cm1,12455551000@suppc5cm1">=12895551001@suppc5cm1,12895551002@suppc5cm1,12455551000@suppc5cm1</a><br><br>
That way you leave the decision of whether or not the host statement is
static or dynamic to remain a functional decision versus a policy
argument.&nbsp; (I could just be misunderstanding your detailed
description as well)<br><br>
On similar another note, I've been thinking about something I think would
be valuable.<br><br>
<br><br>
How difficult would it be to create a dialplan command that could assign,
un-assign, etc. MWI pointers on the fly?&nbsp; How would this fit in with
your changes here?<br><br>
For example:<br><br>
exten =&gt; s,1,MWISet(SIP/1234,1001@office)&nbsp; ;set MWI for SIP/1234
to 1001@office&nbsp; <br><br>
exten =&gt; s,1,MWIClear(SIP/1234)&nbsp; ;remove all MWI setting for
SIP/1234<br><br>
exten =&gt; s,1,MWISet(SIP/1234,2222@softswitch,r)&nbsp; ; same as above
except r options indicates this is a remote softswitch.<br><br>
<br>
-Chris<br><br>
<br>
On 12:45 PM 4/14/2005, Jay Ray wrote:<br><br>
<blockquote type=cite class=cite cite="">Here is relevant portion of
sip.conf. for those peer softswitches....I have tested with 2 Clarent
Softswitches one with 3 and other with just one mailbox..worked fine. I
will go to bugs.digium.com..and submit a case....Thx<br>
&nbsp;<br>
I followed the NOTIFY mechanism for sending MWI as per RFC 3842....<br>
&nbsp;<br>
&nbsp;<br>
---------------------------------------------------------------sip.conf---------------------------------------<br>
[10.1.1.1:5080]&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; //This
sofswitch uses port 5080 for VoiceMail...we do have to <br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
explicitly mention the port here so that Asterisk does not loose it while
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
sending NOTIFY to Softswitches..I found out that Asterisk does loose
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
this port.<br>
type=friend<br>
username=c5cm<br>
context=clarentcm<br>
dtmfmode=rfc2833<br>
host=10.1.1.1<br>
<a href="mailto:mailbox=12895551001@suppc5cm1,12895551002@suppc5cm1,12455551000@suppc5cm1">mailbox=12895551001@suppc5cm1,12895551002@suppc5cm1,12455551000@suppc5cm1</a><br>
allow=ulaw<br>
port=5080<br>
[10.1.1.2:5080]<br>
type=friend<br>
context=JerryC5_84<br>
dtmfmode=rfc2833<br>
host=10.1.1.2<br>
<a href="mailto:mailbox=15142550001@jerryc5vm">mailbox=15142550001@jerryc5vm</a><br>
allow=ulaw<br>
port=5080<br>
--------------------------------------------------------------------------------------------------------------------------------------------<br><br>
<br>
<b><i>John Todd &lt;jtodd@loligo.com&gt;</i></b> wrote:<br>

<dl><br>

<dd>This looks interesting. Can you provide a bit more detail and some
<br>

<dd>other updates?<br><br>

<dd>1) Can you supply a diff on the sip.conf file that shows an example
<br>

<dd>of your new method (comment the section out, and use several lines of
<br>

<dd>comments to explain what the example does)<br><br>

<dd>2) On what softswitches is this known to work? I assume you've <br>

<dd>tested with SER, as a baseline?<br><br>

<dd>3) Have you signed a disclaimer with Digium?<br><br>

<dd>4) Can you submit this as an addition to bugs.digium.com so that it
<br>

<dd>will be included in future Asterisk releases if it meets approval and
<br>

<dd>functionality criteria (as nebulous as both of those
are...)?<br><br>

<dd>JT<br><br>
<br>

<dd>At 11:05 AM -0700 on 4/14/05, Jay Ray wrote:<br>

<dd>&gt;Hi All,<br>

<dd>&gt;<br>

<dd>&gt; I had proposed the changes to be able to support Asterisk <br>

<dd>&gt;VoiceMail for 3rd Party Softswitches. Here is what I have changed
o n <br>

<dd>&gt;Asterisk in chan_sip.c<br>

<dd>&gt;<br>

<dd>&gt;While in function sip_send_mwi_to_peer() . in case
peer-&gt;tohost has <br>

<dd>&gt;a value which means that its not a registered EP - but a static
<br>

<dd>&gt;peer, I call another function called sip_send_mwi_to_softswitch()
<br>

<dd>&gt;.....in which I separate the comma separated mailboxes defined in
<br>

<dd>&gt;sip.conf for that peer. and send NOTIFY in a for loop for each of
<br>

<dd>&gt;the Mailboxes....by calling another new function <br>

<dd>&gt; transmit_notify_to_softswitch_with_mwi()<br>

<dd>&gt;<br>

<dd>&gt;In transmit_notify_to_softswitch_with_mwi() , I populate the
<br>

<dd>&gt;sip_pvt-&gt;username with the mailbox number (minus the mailbox
<br>

<dd>&gt;context, if any)...so that the mailbox number gets added to the
&quot;TO&quot; <br>

<dd>&gt;header in the NOTIFY going out to that Softswitch...for the 
<br>

<dd>&gt;Softswitch to pass on the NOTIFY to the appropriate
Endpoint....<br>

<dd>&gt;<br>

<dd>&gt;The DIFF is below, comments appreciated.......<br>

<dd>&gt;<br>

<dd>&gt;<br>

<dd>&gt;<br>

<dd>&gt;<br>

<dd>&gt;[root@jerrylinux channels]# diff chan_sip.c.wrking1
chan_sip.c.orig<br>

<dd>&gt;489,490d488<br>

<dd>&gt;&lt; int *lastmsgsent_switch; /* maintaining last message <br>

<dd>&gt;sent for EPS on a Third Party Softswitch */<br>

<dd>&gt;&lt;<br>

<dd>&gt;1207c1205<br>

<dd>&gt;&lt;<br>

<dd>&gt;---<br>

<dd>&gt;&gt;<br>

<dd>&gt;1209d1206<br>

<dd>&gt;&lt;<br>

<dd>&gt;1212d1208<br>

<dd>&gt;&lt;<br>

<dd>&gt;3930,3932d3925<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;4217,4271d4209<br>

<dd>&gt;&lt; /*--- transmit_notify_to_softswitch_with_mwi: Notify
Softswitch user of<br>

<dd>&gt;&lt; messages waiting in voicemail ---*/<br>

<dd>&gt;&lt; /* Notification works for Softswitch peers with mailbox=
definitions<br>

<dd>&gt;&lt; * in sip.conf<br>

<dd>&gt;&lt; * We use the SIP Event package message-summary<br>

<dd>&gt;&lt; * MIME type defaults to
&quot;application/simple-message-summary&quot;;<br>

<dd>&gt;&lt; */<br>

<dd>&gt;&lt; static int transmit_notify_to_softswitch_with_mwi(struct
sip_pvt <br>

<dd>&gt;*p, char *mbox, int newmsgs, int oldmsgs)<br>

<dd>&gt;&lt; {<br>

<dd>&gt;&lt; struct sip_request req;<br>

<dd>&gt;&lt; char tmp[256];<br>

<dd>&gt;&lt; char tmp2[256];<br>

<dd>&gt;&lt; char *tmp_mbox;<br>

<dd>&gt;&lt; char clen[20];<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; /* I will put the Mailbox Number - the part before the
@<br>

<dd>&gt;&lt; * in p-&gt;username, and then call initreqprep as
initreqprep<br>

<dd>&gt;&lt; * looks for a p-&gt;username and puts it in TO Header<br>

<dd>&gt;&lt; */<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; tmp_mbox = (char*) calloc(strlen(mbox), sizeof(char));<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; strncpy(tmp_mbox, mbox, strlen(mbox));<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; tmp_mbox = strsep(&amp;tmp_mbox, &quot;@&quot;);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; strncpy(p-&gt;username, tmp_mbox, strlen(tmp_mbox));<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; initreqprep(&amp;req, p, &quot;NOTIFY&quot;, NULL);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; add_header(&amp;req, &quot;Event&quot;,
&quot;message-summary&quot;);<br>

<dd>&gt;&lt; add_header(&amp;req, &quot;Content-Type&quot;,
default_notifymime);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; snprintf(tmp, sizeof(tmp), &quot;Messages-Waiting:
%s\r\n&quot;, <br>

<dd>&gt;ne wmsgs ? &quot;yes&quot; : &quot;no&quot;);<br>

<dd>&gt;&lt; snprintf(tmp2, sizeof(tmp2), &quot;Voice-Message: %d/%d\r
\n&quot;, <br>

<dd>&gt;newmsgs, oldmsgs);<br>

<dd>&gt;&lt; snprintf(clen, sizeof(clen), &quot;%d&quot;,
(int)(strlen(tmp) + <br>

<dd>&gt;strlen(tmp2)));<br>

<dd>&gt;&lt; add_header(&amp;req, &quot;Content-Length&quot;, 
clen);<br>

<dd>&gt;&lt; add_line(&amp;req, tmp);<br>

<dd>&gt;&lt; add_line(&amp;req, tmp2);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; if (!p-&gt;initreq.headers) {<br>

<dd>&gt;&lt; /* Use this as the basis */<br>

<dd>&gt;&lt; copy_request(&amp;p-&gt;initreq, &amp;req);<br>

<dd>&gt;&lt; parse(&amp;p-&gt;initreq);<br>

<dd>&gt;&lt; if (sip_debug_test_pvt(p))<br>

<dd>&gt;&lt; ast_verbose(&quot;%d headers, %d lines\n&quot;, <br>

<dd>&gt;p-&gt;initreq.headers, p-&gt;initreq.lines);<br>

<dd>&gt;&lt; determine_firstline_parts(&amp;p-&gt;initreq);<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; return send_request(p, &amp;req, 1, p-&gt;ocseq);<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;8628,8734d8565<br>

<dd>&gt;&lt; //Ujju - sip_send_mwi_to_softswitch : Sending MWI to another
Softswitch.<br>

<dd>&gt;&lt; static int sip_send_mwi_to_softswitch(struct sip_peer
*peer)<br>

<dd>&gt;&lt; {<br>

<dd>&gt;&lt; /* Checking for all the m alboxes configured for a
softswitch<br>

<dd>&gt;&lt; and sending NOTIFY w/MWI for all */<br>

<dd>&gt;&lt; struct sip_pvt *p;<br>

<dd>&gt;&lt; char name[256] = &quot;&quot;;<br>

<dd>&gt;&lt; int newmsgs, oldmsgs;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; if(peer-&gt;mailbox==NULL){<br>

<dd>&gt;&lt; ast_log(LOG_WARNING, &quot;No Mailboxes defined in sip.conf
and <br>

<dd>&gt;voicemail.conf for this softswitch&quot;);<br>

<dd>&gt;&lt; return 0;<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; int i;<br>

<dd>&gt;&lt; int mbox_count=0;<br>

<dd>&gt;&lt; char *mbox[500]; /*Pointer to individual malboxes*/<br>

<dd>&gt;&lt; char *tmp=NULL; /*Temp Pointer to individual
mailboxes*/<br>

<dd>&gt;&lt; char *mailboxes;/* storing full comma separated mailbox
<br>

<dd>&gt;string here */<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; mailboxes=(char
*)calloc(strlen(peer-&gt;mailbox),sizeof(char));<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; strcpy(mailboxes,peer-&gt;mailbox);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; tmp=strchr(mailboxes,',');<br>

<dd>&gt;&lt; //**mbox=(char **)malloc(sizeof(char *)*256);<br>

<dd>&gt;&lt; //This copies first Mailbox in mbox[0]<br>

<dd>&gt;&lt; mbox[mbox_count]=mailboxes;<br>

<dd>&gt;&lt; mbox[mbox_count]=strsep(&amp;mbox[mbox_count],
&quot;,&quot;);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; //This copies rest of the mailboxes in mbox[1, 2,
3......]<br>

<dd>&gt;&lt; while(tmp!=NULL)<br>

<dd>&gt;&lt; {<br>

<dd>&gt;&lt; mbox_count++;<br>

<dd>&gt;&lt; tmp+=1;<br>

<dd>&gt;&lt; mbox[mbox_count]=(char*) calloc(strlen(tmp),
sizeof(char));<br>

<dd>&gt;&lt; strncpy(mbox[mbox_count],tmp, strlen(tmp));<br>

<dd>&gt;&lt; mbox[mbox_count]=strsep(&amp;mbox[mbox_count],
&quot;,&quot;);<br>

<dd>&gt;&lt; tmp=strchr(tmp,',');<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; /* Allocating memory for PTR to last msg for each mailbox
<br>

<dd>&gt;for EPs on Softswitch */<br>

<dd>&gt;&lt; if (peer-&gt;lastmsgsent_switch == NULL) {<br>

<dd>&gt;&lt; peer-&gt;lastmsgsent_switch = (int *) <br>

<dd>&gt;calloc(mbox_count,sizeof(int));<br>

<dd>&gt;&lt; for (i=0;i&lt;=mbox_count;i++)<br>

<dd>&gt;&lt; peer-&gt;lastmsgsent_switch[i]=-1;<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; //Now looping through all the Mailboxes to send individual
Notify's<br>

<dd>&gt;&lt; for(i=0;i&lt;=mbox_count;i++) {<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; ast_app_messagecount(mbox[i], &amp;newmsgs,
&amp;oldmsgs);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; time(&amp;peer-&gt;lastmsgcheck);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; /* Retur n now if it's the same thing we told them <br>

<dd>&gt;last time */<br>

<dd>&gt;&lt; if (((newmsgs &lt;&lt; 8) | (oldmsgs)) == <br>

<dd>&gt;peer-&gt;lastmsgsent_switch[i]) {<br>

<dd>&gt;&lt; if (i==mbox_count)<br>

<dd>&gt;&lt; return 0;<br>

<dd>&gt;&lt; else<br>

<dd>&gt;&lt; continue;<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; p = sip_alloc(NULL, NULL, 0);<br>

<dd>&gt;&lt; if (!p) {<br>

<dd>&gt;&lt; ast_log(LOG_WARNING, &quot;Unable to build sip <br>

<dd>&gt;pvt data for MWI\n&quot;);<br>

<dd>&gt;&lt; return -1;<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt; strncpy(name, peer-&gt;name, sizeof(name) - 1);<br>

<dd>&gt;&lt; peer-&gt;lastmsgsent_switch[i] = ((newmsgs &lt;&lt; 8) |
(oldmsgs));<br>

<dd>&gt;&lt; if (create_addr(p, name)) {<br>

<dd>&gt;&amp;lt<br>

<dd>; /* Maybe they're not registered, etc. */<br>

<dd>&gt;&lt; sip_destroy(p);<br>

<dd>&gt;&lt; return 0;<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt; /* Recalculate our side, and recalculate Call ID */<br>

<dd>&gt;&lt; if
(ast_sip_ouraddrfor(&amp;p-&gt;sa.sin_addr,&amp;p-&gt;ourip))<br>

<dd>&gt;&lt; memcpy(&amp;p-&gt;ourip, &amp;__ourip,
sizeof(p-&gt;ourip));<br>

<dd>&gt;&lt; build_via(p, p-&gt;via, sizeof(p-&gt;via));<br>

<dd>&gt;&lt; build_callid(p-&gt;callid, sizeof(p-&gt;callid),
p-&gt;ourip, <br>

<dd>&gt;p-&gt;fromdomain);<br>

<dd>&gt;&lt; /* Here I call another Function to Build Proper to header
*/<br>

<dd>&gt;&lt; /* Sen d MWI */<br>

<dd>&gt;&lt; ast_set_flag(p, SIP_OUTGOING);<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; //Ujju Set the p-&gt;peername pointer to char to NULL <br>

<dd>&gt;if its length is 0<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; if (!strlen(p-&gt;peername)){<br>

<dd>&gt;&lt; strncpy(p-&gt;peername, peer-&gt;name,
sizeof(p-&gt;peername));<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; transmit_notify_to_softswitch_with_mwi(p, mbox[i], <br>

<dd>&gt;newmsgs, oldmsgs);<br>

<dd>&gt;&amp;l<br>

<dd>t; ; sip_scheddestroy(p, 15000);<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; return 0;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt;<br>

<dd>&gt;8743,8750c8574<br>

<dd>&gt;&lt; /* Ujju Here we call function to separate all the mailboxes
<br>

<dd>&gt;if tohost ne NULL and<br>

<dd>&gt;&lt; then call the below func - sip_send_mwi_to_softswitch -
<br>

<dd>&gt;for each of those mailboxes */<br>

<dd>&gt;&lt;<br>

<dd>&gt;&lt; if (strlen(peer-&gt;tohost) != 0){<br>

<dd>&gt;&lt; sip_send_mwi_to_softswitch(peer);<br>

<dd>&gt;&lt; return 0;<br>

<dd>&gt;&lt; }<br>

<dd>&gt;&lt;<br>

<dd>&gt;---<br>

<dd>&gt;&gt; /* Check for messages */<br>

<dd>&gt;<br>

<dd>&gt;<br>

<dd>&gt;<br>

<dd>&gt;Do you Yahoo!?<br>

<dd>&gt;Yahoo! Small Business - <br>

<dd>&gt;Try <br>

<dd>&gt;our new resources site!<br>

<dd>&gt;<br>

<dd>&gt;_______________________________________________<br>

<dd>&gt;Asterisk-Dev mailing list<br>

<dd>&gt;Asterisk-Dev@lists.digium.com<br>

<dd>&gt;<a href="http://lists.digium.com/mailman/listinfo/asterisk-dev" eudora="autourl">http://lists.digium.com/mailman/listinfo/asterisk-dev</a><br>

<dd>&gt;To UNSUBSCRIBE or update options visit:<br>

<dd>&gt;
<a href="http://lists.digium.com/mailman/listinfo/asterisk-dev" eudora="autourl">http://lists.digium.com/mailman/listinfo/asterisk-dev</a><br><br>

</dl><br><br>
<br>
Do you Yahoo!?<br>
Yahoo! Mail - 250MB free storage.
<a href="http://us.rd.yahoo.com/evt=29915/*http://info.mail.yahoo.com/mail_250">Do
more. Manage less.</a> <br>
_______________________________________________<br>
Asterisk-Dev mailing list<br>
Asterisk-Dev@lists.digium.com<br>
<a href="http://lists.digium.com/mailman/listinfo/asterisk-dev" eudora="autourl">http://lists.digium.com/mailman/listinfo/asterisk-dev</a><br>
To UNSUBSCRIBE or update options visit:<br>
&nbsp;&nbsp;
<a href="http://lists.digium.com/mailman/listinfo/asterisk-dev" eudora="autourl">http://lists.digium.com/mailman/listinfo/asterisk-dev</a>
</blockquote></body>
</html>