actually take the caller id name and/or number from the rpid. Still incomplete, but should do a better job

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@5694 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Michael Jerris 2007-09-11 14:51:13 +00:00
parent 3fa9239dc0
commit 9ce2aba87a
1 changed files with 22 additions and 4 deletions

View File

@ -34,6 +34,8 @@
* *
*/ */
#include "mod_sofia.h" #include "mod_sofia.h"
#include "sofia-sip/msg_parser.h"
extern su_log_t tport_log[]; extern su_log_t tport_log[];
static void sofia_handle_sip_i_state(switch_core_session_t *session, int status, static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
@ -1686,13 +1688,29 @@ const char *_url_set_chanvars(switch_core_session_t *session, url_t *url, const
void process_rpid(sip_unknown_t *un, private_object_t *tech_pvt) void process_rpid(sip_unknown_t *un, private_object_t *tech_pvt)
{ {
int argc, x, screen = 1; int argc, x, screen = 1;
char *mydata, *argv[10] = { 0 }; char *mydata, *user, *argv[10] = { 0 };
char *display = NULL;
size_t n = 0;
if (!switch_strlen_zero(un->un_value)) { if (!switch_strlen_zero(un->un_value)) {
if ((mydata = strdup(un->un_value))) { if ((mydata = strdup(un->un_value))) {
argc = switch_separate_string(mydata, ';', argv, (sizeof(argv) / sizeof(argv[0]))); argc = switch_separate_string(mydata, ';', argv, (sizeof(argv) / sizeof(argv[0])));
// Do We really need this at this time /* FIXME: This is completely insufficient parsing code, and should use the parsers from sofia-sip */
// clid_uri = argv[0]; if (*argv[0] == '"') {
if (msg_quoted_d(&argv[0], &display) != -1)
tech_pvt->caller_profile->caller_id_name = switch_core_session_strdup(tech_pvt->session, display);
}
if (*argv[0] == '<') {
char *start, *end;
argv[0]++;
n = strcspn(argv[0], ":");
argv[0] += (n + 1);
n = strcspn(argv[0], "@");
end = argv[0] + n;
if (*end) *end++ = '\0';
tech_pvt->caller_profile->caller_id_number = switch_core_session_strdup(tech_pvt->session, argv[0]);
}
for (x = 1; x < argc && argv[x]; x++) { for (x = 1; x < argc && argv[x]; x++) {
// we dont need to do anything with party yet we should only be seeing party=calling here anyway // we dont need to do anything with party yet we should only be seeing party=calling here anyway
@ -1701,7 +1719,7 @@ void process_rpid(sip_unknown_t *un, private_object_t *tech_pvt)
// party = argv[x]; // party = argv[x];
// } else // } else
if (!strncasecmp(argv[x], "privacy=", 8)) { if (!strncasecmp(argv[x], "privacy=", 8)) {
char *arg = argv[x] + 9; char *arg = argv[x] + 8;
if (!strcasecmp(arg, "yes")) { if (!strcasecmp(arg, "yes")) {
switch_set_flag(tech_pvt->caller_profile, SWITCH_CPF_HIDE_NAME | SWITCH_CPF_HIDE_NUMBER); switch_set_flag(tech_pvt->caller_profile, SWITCH_CPF_HIDE_NAME | SWITCH_CPF_HIDE_NUMBER);