#include "sal_eXosip2.h"
+typedef enum {
+ PIDF = 0,
+ RFCxxxx = 1,
+ MSOLDPRES = 2
+} presence_type_t;
+
+/*
+ * REVISIT: this static variable forces every dialog to use the same presence description type depending
+ * on what is received on a single dialog...
+ */
+static presence_type_t presence_style = PIDF;
SalOp * sal_find_out_subscribe(Sal *sal, int sid){
const MSList *elem;
return 0;
}
-static void add_presence_body(osip_message_t *notify, SalPresenceStatus online_status)
-{
- char buf[1000];
-#ifdef SUPPORT_MSN
- int atom_id = 1000;
-#endif
- char *contact_info;
+static void mk_presence_body (const SalPresenceStatus online_status, const char *contact_info,
+ char *buf, size_t buflen, presence_type_t ptype) {
+ switch (ptype) {
+ case RFCxxxx: {
+ /* definition from http://msdn.microsoft.com/en-us/library/cc246202%28PROT.10%29.aspx */
+ int atom_id = 1000;
+
+ if (online_status==SalPresenceOnline)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+<presence>\n\
+<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
+<atom id=\"%i\">\n\
+<address uri=\"%s\" priority=\"0.800000\">\n\
+<status status=\"open\" />\n\
+<msnsubstatus substatus=\"online\" />\n\
+</address>\n\
+</atom>\n\
+</presence>", contact_info, atom_id, contact_info);
- osip_from_t *from=NULL;
- from=osip_message_get_from(notify);
- osip_uri_to_str(from->url,&contact_info);
+ }
+ else if (online_status == SalPresenceBusy ||
+ online_status == SalPresenceDonotdisturb)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+<presence>\n\
+<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
+<atom id=\"%i\">\n\
+<address uri=\"%s\" priority=\"0.800000\">\n\
+<status status=\"inuse\" />\n\
+<msnsubstatus substatus=\"busy\" />\n\
+</address>\n\
+</atom>\n</presence>", contact_info, atom_id, contact_info);
-#ifdef SUPPORT_MSN
+ }
+ else if (online_status==SalPresenceBerightback)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+<presence>\n\
+<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
+<atom id=\"%i\">\n\
+<address uri=\"%s\" priority=\"0.800000\">\n\
+<status status=\"open\" />\n\
+<msnsubstatus substatus=\"berightback\" />\n\
+</address>\n\
+</atom>\n\
+</presence>", contact_info, atom_id, contact_info);
- if (online_status==SalPresenceOnline)
- {
- sprintf(buf, "<?xml version=\"1.0\"?>\n\
-<!DOCTYPE presence\n\
-PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+ }
+ else if (online_status == SalPresenceAway ||
+ online_status == SalPresenceMoved)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
<presence>\n\
<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
<atom id=\"%i\">\n\
-<address uri=\"%s;user=ip\" priority=\"0.800000\">\n\
+<address uri=\"%s\" priority=\"0.800000\">\n\
<status status=\"open\" />\n\
-<msnsubstatus substatus=\"online\" />\n\
+<msnsubstatus substatus=\"away\" />\n\
</address>\n\
</atom>\n\
</presence>", contact_info, atom_id, contact_info);
- }
- else if (online_status==SalPresenceBusy)
- {
- sprintf(buf, "<?xml version=\"1.0\"?>\n\
-<!DOCTYPE presence\n\
-PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+ }
+ else if (online_status==SalPresenceOnthephone)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
<presence>\n\
<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
<atom id=\"%i\">\n\
-<address uri=\"%s;user=ip\" priority=\"0.800000\">\n\
+<address uri=\"%s\" priority=\"0.800000\">\n\
<status status=\"inuse\" />\n\
-<msnsubstatus substatus=\"busy\" />\n\
+<msnsubstatus substatus=\"onthephone\" />\n\
</address>\n\
</atom>\n\
</presence>", contact_info, atom_id, contact_info);
- }
- else if (online_status==SalPresenceBerightback)
- {
- sprintf(buf, "<?xml version=\"1.0\"?>\n\
-<!DOCTYPE presence\n\
-PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+ }
+ else if (online_status==SalPresenceOuttolunch)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+<presence>\n\
+<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
+<atom id=\"%i\">\n\
+<address uri=\"%s\" priority=\"0.800000\">\n\
+<status status=\"open\" />\n\
+<msnsubstatus substatus=\"outtolunch\" />\n\
+</address>\n\
+</atom>\n\
+</presence>", contact_info, atom_id, contact_info);
+
+ }
+ else
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+<presence>\n\
+<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
+<atom id=\"%i\">\n\
+<address uri=\"%s\" priority=\"0.800000\">\n\
+<status status=\"closed\" />\n\
+<msnsubstatus substatus=\"away\" />\n\
+</address>\n\
+</atom>\n\
+</presence>", contact_info, atom_id, contact_info);
+ }
+ break;
+ }
+ case MSOLDPRES: {
+ /* Couldn't find schema http://schemas.microsoft.com/2002/09/sip/presence
+ * so messages format has been taken from Communigate that can send notify
+ * requests with this schema
+ */
+ int atom_id = 1000;
+
+ if (online_status==SalPresenceOnline)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence SYSTEM \"http://schemas.microsoft.com/2002/09/sip/presence\">\n\
+<presence>\n\
+<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
+<atom id=\"%i\">\n\
+<address uri=\"%s\">\n\
+<status status=\"open\" />\n\
+<msnsubstatus substatus=\"online\" />\n\
+</address>\n\
+</atom>\n\
+</presence>", contact_info, atom_id, contact_info);
+
+ }
+ else if (online_status == SalPresenceBusy ||
+ online_status == SalPresenceDonotdisturb)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence SYSTEM \"http://schemas.microsoft.com/2002/09/sip/presence\">\n\
+<presence>\n\
+<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
+<atom id=\"%i\">\n\
+<address uri=\"%s\">\n\
+<status status=\"inuse\" />\n\
+<msnsubstatus substatus=\"busy\" />\n\
+</address>\n\
+</atom>\n</presence>", contact_info, atom_id, contact_info);
+
+ }
+ else if (online_status==SalPresenceBerightback)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence SYSTEM \"http://schemas.microsoft.com/2002/09/sip/presence\">\n\
<presence>\n\
<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
<atom id=\"%i\">\n\
-<address uri=\"%s;user=ip\" priority=\"0.800000\">\n\
+<address uri=\"%s\">\n\
<status status=\"inactive\" />\n\
<msnsubstatus substatus=\"berightback\" />\n\
</address>\n\
</atom>\n\
</presence>", contact_info, atom_id, contact_info);
- }
- else if (online_status==SalPresenceAway)
- {
- sprintf(buf, "<?xml version=\"1.0\"?>\n\
-<!DOCTYPE presence\n\
-PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+ }
+ else if (online_status == SalPresenceAway ||
+ online_status == SalPresenceMoved)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence SYSTEM \"http://schemas.microsoft.com/2002/09/sip/presence\">\n\
<presence>\n\
<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
<atom id=\"%i\">\n\
-<address uri=\"%s;user=ip\" priority=\"0.800000\">\n\
+<address uri=\"%s\">\n\
<status status=\"inactive\" />\n\
-<msnsubstatus substatus=\"away\" />\n\
+<msnsubstatus substatus=\"idle\" />\n\
</address>\n\
</atom>\n\
</presence>", contact_info, atom_id, contact_info);
- }
- else if (online_status==SalPresenceOnthephone)
- {
- sprintf(buf, "<?xml version=\"1.0\"?>\n\
-<!DOCTYPE presence\n\
-PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+ }
+ else if (online_status==SalPresenceOnthephone)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence SYSTEM \"http://schemas.microsoft.com/2002/09/sip/presence\">\n\
<presence>\n\
<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
<atom id=\"%i\">\n\
-<address uri=\"%s;user=ip\" priority=\"0.800000\">\n\
+<address uri=\"%s\">\n\
<status status=\"inuse\" />\n\
<msnsubstatus substatus=\"onthephone\" />\n\
</address>\n\
</atom>\n\
</presence>", contact_info, atom_id, contact_info);
- }
- else if (online_status==SalPresenceOuttolunch)
- {
- sprintf(buf, "<?xml version=\"1.0\"?>\n\
-<!DOCTYPE presence\n\
-PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+ }
+ else if (online_status==SalPresenceOuttolunch)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence SYSTEM \"http://schemas.microsoft.com/2002/09/sip/presence\">\n\
<presence>\n\
<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
<atom id=\"%i\">\n\
-<address uri=\"%s;user=ip\" priority=\"0.800000\">\n\
+<address uri=\"%s\">\n\
<status status=\"inactive\" />\n\
<msnsubstatus substatus=\"outtolunch\" />\n\
</address>\n\
</atom>\n\
</presence>", contact_info, atom_id, contact_info);
- }
- else
- {
- sprintf(buf, "<?xml version=\"1.0\"?>\n\
-<!DOCTYPE presence\n\
-PUBLIC \"-//IETF//DTD RFCxxxx XPIDF 1.0//EN\" \"xpidf.dtd\">\n\
+ }
+ else
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\"?>\n\
+<!DOCTYPE presence SYSTEM \"http://schemas.microsoft.com/2002/09/sip/presence\">\n\
<presence>\n\
<presentity uri=\"%s;method=SUBSCRIBE\" />\n\
<atom id=\"%i\">\n\
-<address uri=\"%s;user=ip\" priority=\"0.800000\">\n\
-<status status=\"inactive\" />\n\
-<msnsubstatus substatus=\"away\" />\n\
+<address uri=\"%s\">\n\
+<status status=\"closed\" />\n\
+<msnsubstatus substatus=\"offline\" />\n\
</address>\n\
</atom>\n\
</presence>", contact_info, atom_id, contact_info);
- }
-
- osip_message_set_body(notify, buf, strlen(buf));
- osip_message_set_content_type(notify, "application/xpidf+xml");
-#else
+ }
+ break;
+ }
+ default: { /* use pidf+xml as default format, rfc4479, rfc4480, rfc3863 */
- if (online_status==SalPresenceOnline)
- {
- sprintf(buf, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
-<presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- entity=\"%s\">\n\
+ if (online_status==SalPresenceOnline)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
+<presence xmlns=\"urn:ietf:params:xml:ns:pidf\" \
+xmlns:dm=\"urn:ietf:params:xml:ns:pidf:data-model\" \
+xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" \
+entity=\"%s\">\n\
<tuple id=\"sg89ae\">\n\
-<status>\n\
-<basic>open</basic>\n\
-</status>\n\
+<status><basic>open</basic></status>\n\
<contact priority=\"0.8\">%s</contact>\n\
-<note>online</note>\n\
</tuple>\n\
</presence>",
- contact_info, contact_info);
- }
- else if (online_status==SalPresenceBusy)
- {
- sprintf(buf, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
-<presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
+contact_info, contact_info);
+ }
+ else if (online_status == SalPresenceBusy ||
+ online_status == SalPresenceDonotdisturb)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
+<presence xmlns=\"urn:ietf:params:xml:ns:pidf\" \
+xmlns:dm=\"urn:ietf:params:xml:ns:pidf:data-model\" \
+xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" \
+entity=\"%s\">\n\
<tuple id=\"sg89ae\">\n\
-<status>\n\
-<basic>open</basic>\n\
-<es:activities>\n\
- <es:activity>busy</es:activity>\n\
-</es:activities>\n\
-</status>\n\
+<status><basic>open</basic></status>\n\
<contact priority=\"0.8\">%s</contact>\n\
-<note>busy</note>\n\
</tuple>\n\
+<dm:person id=\"sg89aep\">\n\
+<rpid:activities><rpid:busy/></rpid:activities>\n\
+</dm:person>\n\
</presence>",
- contact_info, contact_info);
- }
- else if (online_status==SalPresenceBerightback)
- {
- sprintf(buf, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
-<presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
+contact_info, contact_info);
+ }
+ else if (online_status==SalPresenceBerightback)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
+<presence xmlns=\"urn:ietf:params:xml:ns:pidf\" \
+xmlns:dm=\"urn:ietf:params:xml:ns:pidf:data-model\" \
+xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" \
+entity=\"%s\">\n\
<tuple id=\"sg89ae\">\n\
-<status>\n\
-<basic>open</basic>\n\
-<es:activities>\n\
- <es:activity>in-transit</es:activity>\n\
-</es:activities>\n\
-</status>\n\
+<status><basic>open</basic></status>\n\
<contact priority=\"0.8\">%s</contact>\n\
-<note>be right back</note>\n\
</tuple>\n\
+<dm:person id=\"sg89aep\">\n\
+<rpid:activities><rpid:in-transit/></rpid:activities>\n\
+</dm:person>\n\
</presence>",
- contact_info, contact_info);
- }
- else if (online_status==SalPresenceAway)
- {
- sprintf(buf, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
-<presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
+contact_info, contact_info);
+ }
+ else if (online_status == SalPresenceAway ||
+ online_status == SalPresenceMoved)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
+<presence xmlns=\"urn:ietf:params:xml:ns:pidf\" \
+xmlns:dm=\"urn:ietf:params:xml:ns:pidf:data-model\" \
+xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" \
+entity=\"%s\">\n\
<tuple id=\"sg89ae\">\n\
-<status>\n\
-<basic>open</basic>\n\
-<es:activities>\n\
- <es:activity>away</es:activity>\n\
-</es:activities>\n\
-</status>\n\
+<status><basic>open</basic></status>\n\
<contact priority=\"0.8\">%s</contact>\n\
-<note>away</note>\n\
</tuple>\n\
+<dm:person id=\"sg89aep\">\n\
+<rpid:activities><rpid:away/></rpid:activities>\n\
+</dm:person>\n\
</presence>",
- contact_info, contact_info);
- }
- else if (online_status==SalPresenceOnthephone)
- {
- sprintf(buf, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
-<presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
+contact_info, contact_info);
+ }
+ else if (online_status==SalPresenceOnthephone)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
+<presence xmlns=\"urn:ietf:params:xml:ns:pidf\" \
+xmlns:dm=\"urn:ietf:params:xml:ns:pidf:data-model\" \
+xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" \
+entity=\"%s\">\n\
<tuple id=\"sg89ae\">\n\
-<status>\n\
-<basic>open</basic>\n\
-<es:activities>\n\
- <es:activity>on-the-phone</es:activity>\n\
-</es:activities>\n\
-</status>\n\
+<status><basic>open</basic></status>\n\
<contact priority=\"0.8\">%s</contact>\n\
-<note>on the phone</note>\n\
</tuple>\n\
+<dm:person id=\"sg89aep\">\n\
+<rpid:activities><rpid:on-the-phone/></rpid:activities>\n\
+</dm:person>\n\
</presence>",
- contact_info, contact_info);
- }
- else if (online_status==SalPresenceOuttolunch)
- {
- sprintf(buf, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
-<presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
-<tuple id=\"sg89ae\">\n\
-<status>\n\
-<basic>open</basic>\n\
-<es:activities>\n\
- <es:activity>meal</es:activity>\n\
-</es:activities>\n\
-</status>\n\
+contact_info, contact_info);
+ }
+ else if (online_status==SalPresenceOuttolunch)
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
+<presence xmlns=\"urn:ietf:params:xml:ns:pidf\" \
+xmlns:dm=\"urn:ietf:params:xml:ns:pidf:data-model\" \
+xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" \
+entity=\"%s\">\n\
+<tuple id=\"7777\">\n\
+<status><basic>open</basic></status>\n\
<contact priority=\"0.8\">%s</contact>\n\
-<note>out to lunch</note>\n\
</tuple>\n\
+<dm:person id=\"78787878\">\n\
+<rpid:activities><rpid:meal/></rpid:activities>\n\
+<rpid:note>Out to lunch</rpid:note> \n\
+</dm:person>\n\
</presence>",
- contact_info, contact_info);
- }
- else
- {
- /* */
- sprintf(buf, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
-<presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
-xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
-entity=\"%s\">\n%s",
- contact_info,
-"<tuple id=\"sg89ae\">\n\
-<status>\n\
-<basic>closed</basic>\n\
-<es:activities>\n\
- <es:activity>permanent-absence</es:activity>\n\
-</es:activities>\n\
-</status>\n\
+contact_info, contact_info);
+ }
+ else
+ {
+ snprintf(buf, buflen, "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
+<presence xmlns=\"urn:ietf:params:xml:ns:pidf\" \
+xmlns:dm=\"urn:ietf:params:xml:ns:pidf:data-model\" \
+xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" \
+entity=\"%s\">\n\
+<tuple id=\"sg89ae\">\n\
+<status><basic>closed</basic></status>\n\
+<contact priority=\"0.8\">%s</contact>\n\
</tuple>\n\
-\n</presence>\n");
+</presence>\n", contact_info, contact_info);
+ }
+ break;
}
- osip_message_set_body(notify, buf, strlen(buf));
- osip_message_set_content_type(notify, "application/pidf+xml");
+ } // switch
+
+}
+
+static void add_presence_body(osip_message_t *notify, SalPresenceStatus online_status)
+{
+ char buf[1000];
+ char *contact_info;
+
+ osip_from_t *from=NULL;
+ from=osip_message_get_from(notify);
+ osip_uri_to_str(from->url,&contact_info);
+
+ mk_presence_body (online_status, contact_info, buf, sizeof (buf), presence_style);
+
+ osip_message_set_body(notify, buf, strlen(buf));
+ osip_message_set_content_type(notify,
+ presence_style ? "application/xpidf+xml" : "application/pidf+xml");
-#endif
osip_free(contact_info);
}
int i;
char buf[1024];
- if (presence_mode==SalPresenceOnline)
- {
- snprintf(buf, sizeof(buf), "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
- <presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- entity=\"%s\">\n\
- <tuple id=\"sg89ae\">\n\
- <status>\n\
- <basic>open</basic>\n\
- </status>\n\
- <contact priority=\"0.8\">%s</contact>\n\
- <note>online</note>\n\
- </tuple>\n\
- </presence>",
- from, from);
- }
- else if (presence_mode==SalPresenceBusy
- ||presence_mode==SalPresenceDonotdisturb)
- {
- snprintf(buf, sizeof(buf), "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
- <presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
- <tuple id=\"sg89ae\">\n\
- <status>\n\
- <basic>open</basic>\n\
- <es:activities>\n\
- <es:activity>busy</es:activity>\n\
- </es:activities>\n\
- </status>\n\
- <contact priority=\"0.8\">%s</contact>\n\
- <note>busy</note>\n\
- </tuple>\n\
- </presence>",
- from, from);
- }
- else if (presence_mode==SalPresenceBerightback)
- {
- snprintf(buf, sizeof(buf), "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
- <presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
- <tuple id=\"sg89ae\">\n\
- <status>\n\
- <basic>open</basic>\n\
- <es:activities>\n\
- <es:activity>in-transit</es:activity>\n\
- </es:activities>\n\
- </status>\n\
- <contact priority=\"0.8\">%s</contact>\n\
- <note>be right back</note>\n\
- </tuple>\n\
- </presence>",
- from,from);
- }
- else if (presence_mode==SalPresenceAway
- ||presence_mode==SalPresenceMoved)
- {
- snprintf(buf, sizeof(buf), "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
- <presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
- <tuple id=\"sg89ae\">\n\
- <status>\n\
- <basic>open</basic>\n\
- <es:activities>\n\
- <es:activity>away</es:activity>\n\
- </es:activities>\n\
- </status>\n\
- <contact priority=\"0.8\">%s</contact>\n\
- <note>away</note>\n\
- </tuple>\n\
- </presence>",
- from, from);
- }
- else if (presence_mode==SalPresenceOnthephone)
- {
- snprintf(buf, sizeof(buf), "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
- <presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
- <tuple id=\"sg89ae\">\n\
- <status>\n\
- <basic>open</basic>\n\
- <es:activities>\n\
- <es:activity>on-the-phone</es:activity>\n\
- </es:activities>\n\
- </status>\n\
- <contact priority=\"0.8\">%s</contact>\n\
- <note>on the phone</note>\n\
- </tuple>\n\
- </presence>",
- from, from);
- }
- else if (presence_mode==SalPresenceOuttolunch)
- {
- snprintf(buf, sizeof(buf), "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
- <presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n\
- <tuple id=\"sg89ae\">\n\
- <status>\n\
- <basic>open</basic>\n\
- <es:activities>\n\
- <es:activity>meal</es:activity>\n\
- </es:activities>\n\
- </status>\n\
- <contact priority=\"0.8\">%s</contact>\n\
- <note>out to lunch</note>\n\
- </tuple>\n\
- </presence>",
- from, from);
- }
- else{
- /* offline */
- snprintf(buf, sizeof(buf), "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n\
- <presence xmlns=\"urn:ietf:params:xml:ns:pidf\"\n\
- xmlns:es=\"urn:ietf:params:xml:ns:pidf:status:rpid-status\"\n\
- entity=\"%s\">\n%s",
- from,
- "<tuple id=\"sg89ae\">\n\
- <status>\n\
- <basic>closed</basic>\n\
- <es:activities>\n\
- <es:activity>permanent-absence</e:activity>\n\
- </es:activities>\n\
- </status>\n\
- </tuple>\n\
- \n</presence>\n");
- }
+ mk_presence_body (presence_mode, from, buf, sizeof (buf), presence_style);
- i = eXosip_build_publish(&pub,from, to, NULL, "presence", "1800", "application/pidf+xml", buf);
+ i = eXosip_build_publish(&pub,from, to, NULL, "presence", "300",
+ presence_style ? "application/xpidf+xml" : "application/pidf+xml", buf);
if (i<0){
ms_warning("Failed to build publish request.");
return -1;
}else if (strstr(body->body,"berightback")!=NULL
|| strstr(body->body,"in-transit")!=NULL ){
estatus=SalPresenceBerightback;
- }else if (strstr(body->body,"away")!=NULL){
+ }else if (strstr(body->body,"away")!=NULL
+ || strstr(body->body,"idle")){
estatus=SalPresenceAway;
}else if (strstr(body->body,"onthephone")!=NULL
|| strstr(body->body,"on-the-phone")!=NULL){
ms_message("And outgoing subscription terminated by remote.");
}
sal->callbacks.notify_presence(op,op->sid!=-1 ? SalSubscribeActive : SalSubscribeTerminated, estatus,NULL);
+
+ /* try to detect presence message style used by server,
+ * and switch our presence messages to servers style */
+ if (strstr (body->body, "//IETF//DTD RFCxxxx XPIDF 1.0//EN") != NULL) {
+ presence_style = RFCxxxx;
+ } else if (strstr(body->body,"http://schemas.microsoft.com/2002/09/sip/presence")!=NULL) {
+ presence_style = MSOLDPRES;
+ }
+
osip_free(tmp);
}