/* The oSIP library implements the Session Initiation Protocol (SIP -rfc3261-) Copyright (C) 2001,2002,2003 Aymeric MOIZARD jack@atosc.org This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include #include #include #include #include /* fills the call_id of message. */ /* INPUT : const char *hvalue | value of header. */ /* OUTPUT: osip_message_t *sip | structure to save results. */ /* returns -1 on error. */ int osip_message_set_call_id (osip_message_t * sip, const char *hvalue) { int i; if (hvalue == NULL || hvalue[0] == '\0') return 0; if (sip->call_id != NULL) return -1; i = osip_call_id_init (&(sip->call_id)); if (i != 0) return -1; sip->message_property = 2; i = osip_call_id_parse (sip->call_id, hvalue); if (i != 0) { osip_call_id_free (sip->call_id); sip->call_id = NULL; return -1; } return 0; } /* returns the call_id. */ /* INPUT : osip_message_t *sip | sip message. */ osip_call_id_t * osip_message_get_call_id (const osip_message_t * sip) { return sip->call_id; } int osip_call_id_init (osip_call_id_t ** callid) { *callid = (osip_call_id_t *) osip_malloc (sizeof (osip_call_id_t)); if (*callid == NULL) return -1; (*callid)->number = NULL; (*callid)->host = NULL; return 0; } /* deallocates a osip_call_id_t structure. */ /* INPUT : osip_call_id_t *| callid. */ void osip_call_id_free (osip_call_id_t * callid) { if (callid == NULL) return; osip_free (callid->number); osip_free (callid->host); callid->number = NULL; callid->host = NULL; osip_free (callid); } /* fills the call_id structure. */ /* INPUT : char *hvalue | value of header. */ /* OUTPUT: osip_call_id_t *callid | structure to save results. */ /* returns -1 on error. */ int osip_call_id_parse (osip_call_id_t * callid, const char *hvalue) { const char *host; const char *end; callid->number = NULL; callid->host = NULL; host = strchr (hvalue, '@'); /* SEARCH FOR '@' */ end = hvalue + strlen (hvalue); if (host == NULL) host = end; else { if (end - host + 1 < 2) return -1; callid->host = (char *) osip_malloc (end - host); if (callid->host == NULL) return -1; osip_strncpy (callid->host, host + 1, end - host - 1); osip_clrspace (callid->host); } if (host - hvalue + 1 < 2) return -1; callid->number = (char *) osip_malloc (host - hvalue + 1); if (callid->number == NULL) return -1; osip_strncpy (callid->number, hvalue, host - hvalue); osip_clrspace (callid->number); return 0; /* ok */ } /* returns the call_id as a string. */ /* INPUT : osip_call_id_t *call_id | call_id. */ /* returns null on error. */ int osip_call_id_to_str (const osip_call_id_t * callid, char **dest) { *dest = NULL; if ((callid == NULL) || (callid->number == NULL)) return -1; if (callid->host == NULL) { *dest = (char *) osip_malloc (strlen (callid->number) + 1); if (*dest == NULL) return -1; sprintf (*dest, "%s", callid->number); } else { *dest = (char *) osip_malloc (strlen (callid->number) + strlen (callid->host) + 2); if (*dest == NULL) return -1; sprintf (*dest, "%s@%s", callid->number, callid->host); } return 0; } char * osip_call_id_get_number (osip_call_id_t * callid) { if (callid == NULL) return NULL; return callid->number; } char * osip_call_id_get_host (osip_call_id_t * callid) { if (callid == NULL) return NULL; return callid->host; } void osip_call_id_set_number (osip_call_id_t * callid, char *number) { callid->number = number; } void osip_call_id_set_host (osip_call_id_t * callid, char *host) { callid->host = host; } int osip_call_id_clone (const osip_call_id_t * callid, osip_call_id_t ** dest) { int i; osip_call_id_t *ci; *dest = NULL; if (callid == NULL) return -1; if (callid->number == NULL) return -1; i = osip_call_id_init (&ci); if (i == -1) /* allocation failed */ return -1; ci->number = osip_strdup (callid->number); if (callid->host != NULL) ci->host = osip_strdup (callid->host); *dest = ci; return 0; } int osip_call_id_match (osip_call_id_t * callid1, osip_call_id_t * callid2) { if (callid1 == NULL || callid2 == NULL) return -1; if (callid1->number == NULL || callid2->number == NULL) return -1; if (0 != strcmp (callid1->number, callid2->number)) return -1; if ((callid1->host == NULL) && (callid2->host == NULL)) return 0; if ((callid1->host == NULL) && (callid2->host != NULL)) return -1; if ((callid1->host != NULL) && (callid2->host == NULL)) return -1; if (0 != strcmp (callid1->host, callid2->host)) return -1; return 0; }