send notifies for refer for 4579

This commit is contained in:
Anthony Minessale 2012-07-31 15:26:03 -05:00
parent e40e8696fc
commit a7b10081c8
3 changed files with 163 additions and 9 deletions

View File

@ -1325,6 +1325,49 @@ static void send_rfc_event(conference_obj_t *conference)
} }
static void send_conference_notify(conference_obj_t *conference, const char *status, switch_bool_t final)
{
switch_event_t *event;
char *name = NULL, *domain = NULL, *dup_domain = NULL;
if (!switch_test_flag(conference, CFLAG_RFC4579)) {
return;
}
if (!(name = conference->name)) {
name = "conference";
}
if (!(domain = conference->domain)) {
dup_domain = switch_core_get_variable_dup("domain");
if (!(domain = dup_domain)) {
domain = "cluecon.com";
}
}
if (switch_event_create(&event, SWITCH_EVENT_CONFERENCE_DATA) == SWITCH_STATUS_SUCCESS) {
event->flags |= EF_UNIQ_HEADERS;
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "conference-name", name);
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "conference-domain", domain);
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "conference-event", "refer");
if (final) {
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "final", "true");
}
switch_event_add_body(event, "%s", status);
switch_event_fire(&event);
}
switch_safe_free(dup_domain);
}
/* Gain exclusive access and add the member to the list */ /* Gain exclusive access and add the member to the list */
static switch_status_t conference_add_member(conference_obj_t *conference, conference_member_t *member) static switch_status_t conference_add_member(conference_obj_t *conference, conference_member_t *member)
{ {
@ -6459,6 +6502,11 @@ static switch_status_t conference_outcall(conference_obj_t *conference,
int rdlock = 0; int rdlock = 0;
switch_bool_t have_flags = SWITCH_FALSE; switch_bool_t have_flags = SWITCH_FALSE;
const char *outcall_flags; const char *outcall_flags;
int track = 0;
if (var_event && switch_true(switch_event_get_header(var_event, "conference_track_status"))) {
track++;
}
*cause = SWITCH_CAUSE_NORMAL_CLEARING; *cause = SWITCH_CAUSE_NORMAL_CLEARING;
@ -6500,6 +6548,12 @@ static switch_status_t conference_outcall(conference_obj_t *conference,
switch_mutex_lock(conference->mutex); switch_mutex_lock(conference->mutex);
conference->originating++; conference->originating++;
switch_mutex_unlock(conference->mutex); switch_mutex_unlock(conference->mutex);
if (track) {
send_conference_notify(conference, "SIP/2.0 100 Trying\r\n", SWITCH_FALSE);
}
status = switch_ivr_originate(session, &peer_session, cause, bridgeto, timeout, NULL, cid_name, cid_num, NULL, var_event, SOF_NO_LIMITS, cancel_cause); status = switch_ivr_originate(session, &peer_session, cause, bridgeto, timeout, NULL, cid_name, cid_num, NULL, var_event, SOF_NO_LIMITS, cancel_cause);
switch_mutex_lock(conference->mutex); switch_mutex_lock(conference->mutex);
conference->originating--; conference->originating--;
@ -6511,9 +6565,18 @@ static switch_status_t conference_outcall(conference_obj_t *conference,
if (caller_channel) { if (caller_channel) {
switch_channel_hangup(caller_channel, *cause); switch_channel_hangup(caller_channel, *cause);
} }
if (track) {
send_conference_notify(conference, "SIP/2.0 481 Failure\r\n", SWITCH_TRUE);
}
goto done; goto done;
} }
if (track) {
send_conference_notify(conference, "SIP/2.0 200 OK\r\n", SWITCH_TRUE);
}
rdlock = 1; rdlock = 1;
peer_channel = switch_core_session_get_channel(peer_session); peer_channel = switch_core_session_get_channel(peer_session);
@ -8462,6 +8525,8 @@ static void call_setup_event_handler(switch_event_t *event)
switch_event_add_header_string(var_event, SWITCH_STACK_BOTTOM, "conference_invite_uri", dial_uri); switch_event_add_header_string(var_event, SWITCH_STACK_BOTTOM, "conference_invite_uri", dial_uri);
switch_event_add_header_string(var_event, SWITCH_STACK_BOTTOM, "conference_track_status", "true");
if (!strncasecmp(ostr, "url+", 4)) { if (!strncasecmp(ostr, "url+", 4)) {
ostr += 4; ostr += 4;
} else if (!switch_true(full_url) && conference->outcall_templ) { } else if (!switch_true(full_url) && conference->outcall_templ) {

View File

@ -1289,10 +1289,72 @@ static void our_sofia_event_callback(nua_event_t event,
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "var_origination_caller_id_number", ref_by_user); switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "var_origination_caller_id_number", ref_by_user);
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "var_origination_caller_id_name", ref_by_user); switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "var_origination_caller_id_name", ref_by_user);
DUMP_EVENT(event);
switch_event_fire(&event); switch_event_fire(&event);
} }
if (sip) {
char *sql;
sofia_nat_parse_t np = { { 0 } };
char *contact_str;
char *proto = "sip", *orig_proto = "sip";
const char *call_id, *full_from, *full_to, *full_via, *from_user = NULL, *from_host = NULL, *to_user, *to_host, *full_agent;
char to_tag[13] = "";
char *event_str = "refer";
np.fs_path = 1;
contact_str = sofia_glue_gen_contact_str(profile, sip, nh, de, &np);
call_id = sip->sip_call_id->i_id;
full_from = sip_header_as_string(nh->nh_home, (void *) sip->sip_from);
full_to = sip_header_as_string(nh->nh_home, (void *) sip->sip_to);
full_via = sip_header_as_string(nh->nh_home, (void *) sip->sip_via);
full_agent = sip_header_as_string(nh->nh_home, (void *) sip->sip_user_agent);
switch_stun_random_string(to_tag, 12, NULL);
if (sip->sip_from) {
from_user = sip->sip_from->a_url->url_user;
from_host = sip->sip_from->a_url->url_host;
} else {
from_user = "n/a";
from_host = "n/a";
}
if (sip->sip_to) {
to_user = sip->sip_to->a_url->url_user;
to_host = sip->sip_to->a_url->url_host;
} else {
to_user = "n/a";
to_host = "n/a";
}
sql = switch_mprintf("insert into sip_subscriptions "
"(proto,sip_user,sip_host,sub_to_user,sub_to_host,presence_hosts,event,contact,call_id,full_from,"
"full_via,expires,user_agent,accept,profile_name,hostname,network_port,network_ip,version,orig_proto, full_to) "
"values ('%q','%q','%q','%q','%q','%q','%q','%q','%q','%q','%q',%ld,'%q','%q','%q','%q','%d','%q',-1,'%q','%q;tag=%q')",
proto, from_user, from_host, to_user, to_host, profile->presence_hosts ? profile->presence_hosts : "",
event_str, contact_str, call_id, full_from, full_via,
(long) switch_epoch_time_now(NULL) + 60,
full_agent, accept, profile->name, mod_sofia_globals.hostname,
np.network_port, np.network_ip, orig_proto, full_to, to_tag);
switch_assert(sql != NULL);
if (1 || mod_sofia_globals.debug_presence > 0 || mod_sofia_globals.debug_sla > 0) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "%s REFER SUBSCRIBE %s@%s %s@%s\n%s\n",
profile->name, from_user, from_host, to_user, to_host, sql);
}
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
sip_to_tag(nh->nh_home, sip->sip_to, to_tag);
}
nua_respond(nh, SIP_202_ACCEPTED, NUTAG_WITH_THIS_MSG(de->data->e_msg), TAG_END()); nua_respond(nh, SIP_202_ACCEPTED, NUTAG_WITH_THIS_MSG(de->data->e_msg), TAG_END());
switch_safe_free(method); switch_safe_free(method);
switch_safe_free(full_url); switch_safe_free(full_url);

View File

@ -900,8 +900,20 @@ static void send_conference_data(sofia_profile_t *profile, switch_event_t *event
const char *call_id = switch_event_get_header(event, "call_id"); const char *call_id = switch_event_get_header(event, "call_id");
const char *from_user = switch_event_get_header(event, "conference-name"); const char *from_user = switch_event_get_header(event, "conference-name");
const char *from_host = switch_event_get_header(event, "conference-domain"); const char *from_host = switch_event_get_header(event, "conference-domain");
const char *event_str = switch_event_get_header(event, "conference-event");
const char *notfound = switch_event_get_header(event, "notfound"); const char *notfound = switch_event_get_header(event, "notfound");
const char *body = switch_event_get_body(event); const char *body = switch_event_get_body(event);
const char *type = "application/conference-info+xml";
int final = switch_true(switch_event_get_header(event, "final");
if (!event_str) {
event_str = "conference";
}
if (!strcasecmp(event_str, "refer")) {
type = "message/sipfrag";
}
if (!(from_user && from_host)) { if (!(from_user && from_host)) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Event information not given\n"); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Event information not given\n");
@ -910,34 +922,49 @@ static void send_conference_data(sofia_profile_t *profile, switch_event_t *event
if (switch_true(notfound)) { if (switch_true(notfound)) {
sql = switch_mprintf("update sip_subscriptions set expires=%ld where " sql = switch_mprintf("update sip_subscriptions set expires=%ld where "
"hostname='%q' and profile_name='%q' and sub_to_user='%q' and sub_to_host='%q' and event='conference'", "hostname='%q' and profile_name='%q' and sub_to_user='%q' and sub_to_host='%q' and event='%q'",
(long)switch_epoch_time_now(NULL), (long)switch_epoch_time_now(NULL),
mod_sofia_globals.hostname, profile->name, mod_sofia_globals.hostname, profile->name,
from_user, from_host); from_user, from_host, event_str);
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE); sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
} }
if (switch_true(final)) {
sql = switch_mprintf("delete from sip_subscriptions where "
"hostname='%q' and profile_name='%q' and sub_to_user='%q' and sub_to_host='%q' and event='%q'",
mod_sofia_globals.hostname, profile->name,
from_user, from_host, event_str);
sofia_glue_execute_sql_now(profile, &sql, SWITCH_TRUE);
}
if (call_id) { if (call_id) {
sql = switch_mprintf("select full_to, full_from, contact %q ';_;isfocus', expires, call_id, event, network_ip, network_port, " sql = switch_mprintf("select full_to, full_from, contact %q ';_;isfocus', expires, call_id, event, network_ip, network_port, "
"'application/conference-info+xml' as ct,'%q' as pt " "'%q' as ct,'%q' as pt "
" from sip_subscriptions where " " from sip_subscriptions where "
"hostname='%q' and profile_name='%q' and sub_to_user='%q' and sub_to_host='%q' and event='conference'" "hostname='%q' and profile_name='%q' and sub_to_user='%q' and sub_to_host='%q' and event='%q'"
"and call_id = '%q' ", "and call_id = '%q' ",
switch_sql_concat(), switch_sql_concat(),
type,
switch_str_nil(body), switch_str_nil(body),
mod_sofia_globals.hostname, profile->name, mod_sofia_globals.hostname, profile->name,
from_user, from_host, call_id); from_user, from_host, event_str, call_id);
} else { } else {
sql = switch_mprintf("select full_to, full_from, contact %q ';_;isfocus', expires, call_id, event, network_ip, network_port, " sql = switch_mprintf("select full_to, full_from, contact %q ';_;isfocus', expires, call_id, event, network_ip, network_port, "
"'application/conference-info+xml' as ct,'%q' as pt " "'%q' as ct,'%q' as pt "
" from sip_subscriptions where " " from sip_subscriptions where "
"hostname='%q' and profile_name='%q' and sub_to_user='%q' and sub_to_host='%q' and event='conference'", "hostname='%q' and profile_name='%q' and sub_to_user='%q' and sub_to_host='%q' and event='%q'",
switch_sql_concat(), switch_sql_concat(),
type,
switch_str_nil(body), switch_str_nil(body),
mod_sofia_globals.hostname, profile->name, mod_sofia_globals.hostname, profile->name,
from_user, from_host); from_user, from_host, event_str);
} }
sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_send_sql, &cb); sofia_glue_execute_sql_callback(profile, profile->ireg_mutex, sql, sofia_presence_send_sql, &cb);