more presence tweaks
This commit is contained in:
parent
0a9f6041dc
commit
7f075c0c28
|
@ -1287,7 +1287,7 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
const char *from_user = switch_str_nil(switch_event_get_header(helper->event, "variable_sip_from_user"));
|
const char *from_user = switch_str_nil(switch_event_get_header(helper->event, "variable_sip_from_user"));
|
||||||
char *clean_to_user = NULL;
|
char *clean_to_user = NULL;
|
||||||
char *clean_from_user = NULL;
|
char *clean_from_user = NULL;
|
||||||
const char *p_to_user = switch_str_nil(switch_event_get_header(helper->event, "to-user"));
|
int force_status = 0;
|
||||||
#if 0
|
#if 0
|
||||||
char *buf;
|
char *buf;
|
||||||
switch_event_serialize(helper->event, &buf, SWITCH_FALSE);
|
switch_event_serialize(helper->event, &buf, SWITCH_FALSE);
|
||||||
|
@ -1312,9 +1312,6 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!strcasecmp(event_status, "Registered")) {
|
|
||||||
answer_state = "resubscribe";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_dialog) {
|
if (is_dialog) {
|
||||||
stream.write_function(&stream,
|
stream.write_function(&stream,
|
||||||
|
@ -1325,12 +1322,11 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
!strcasecmp(answer_state, "resubscribe") ? "partial" : "full", clean_id);
|
!strcasecmp(answer_state, "resubscribe") ? "partial" : "full", clean_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcasecmp(answer_state, "resubscribe")) {
|
if (strcasecmp(event_status, "Registered")) {
|
||||||
|
if (!zstr(answer_state)) {
|
||||||
|
astate = answer_state;
|
||||||
|
}
|
||||||
|
|
||||||
if (!strcasecmp(state, "cs_hangup")) {
|
|
||||||
astate = "terminated";
|
|
||||||
} else if (zstr(astate)) {
|
|
||||||
astate = switch_str_nil(switch_event_get_header(helper->event, "answer-state"));
|
|
||||||
if (zstr(astate)) {
|
if (zstr(astate)) {
|
||||||
if (is_dialog) {
|
if (is_dialog) {
|
||||||
astate = dft_state;
|
astate = dft_state;
|
||||||
|
@ -1338,7 +1334,6 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
astate = "terminated";
|
astate = "terminated";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (!strcasecmp(event_status, "hold")) {
|
if (!strcasecmp(event_status, "hold")) {
|
||||||
astate = "early";
|
astate = "early";
|
||||||
|
@ -1348,6 +1343,10 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
astate = "confirmed";
|
astate = "confirmed";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!strcasecmp(astate, "hangup")) {
|
||||||
|
astate = "terminated";
|
||||||
|
}
|
||||||
|
|
||||||
if (is_dialog) {
|
if (is_dialog) {
|
||||||
if (!strcasecmp(astate, "ringing")) {
|
if (!strcasecmp(astate, "ringing")) {
|
||||||
if (!strcasecmp(direction, "recipient")) {
|
if (!strcasecmp(direction, "recipient")) {
|
||||||
|
@ -1361,7 +1360,7 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
stream.write_function(&stream, "<state>%s</state>\n", astate);
|
stream.write_function(&stream, "<state>%s</state>\n", astate);
|
||||||
} else {
|
} else {
|
||||||
if (!strcasecmp(astate, "ringing")) {
|
if (!strcasecmp(astate, "ringing")) {
|
||||||
astate = "confirmed";
|
astate = "early";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1425,25 +1424,40 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
switch_set_string(status_line, status);
|
switch_set_string(status_line, status);
|
||||||
|
|
||||||
if (in) {
|
if (in) {
|
||||||
|
const char *direction = switch_event_get_header(helper->event, "Caller-Direction");
|
||||||
|
const char *op, *what = "Ring";
|
||||||
|
|
||||||
|
if (direction && !strcasecmp(direction, "outbound")) {
|
||||||
|
op = switch_event_get_header(helper->event, "Other-Leg-Caller-ID-Number");
|
||||||
|
} else {
|
||||||
|
if (!(op = switch_event_get_header(helper->event, "Caller-Callee-ID-Number"))) {
|
||||||
|
op = switch_event_get_header(helper->event, "Caller-Destination-Number");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (direction) {
|
||||||
|
what = !strcasecmp(direction, "outbound") ? "Call" : "Ring";
|
||||||
|
}
|
||||||
|
|
||||||
if (!strcmp(astate, "early")) {
|
if (!strcmp(astate, "early")) {
|
||||||
switch_snprintf(status_line, sizeof(status_line), "Ring %s", switch_str_nil(from_id));
|
if (zstr(op)) {
|
||||||
|
switch_snprintf(status_line, sizeof(status_line), "%s %s", what, status);
|
||||||
|
} else {
|
||||||
|
switch_snprintf(status_line, sizeof(status_line), "%s %s", what, op);
|
||||||
|
}
|
||||||
|
|
||||||
rpid = "on-the-phone";
|
rpid = "on-the-phone";
|
||||||
|
force_status = 1;
|
||||||
|
|
||||||
} else if (!strcmp(astate, "confirmed")) {
|
} else if (!strcmp(astate, "confirmed")) {
|
||||||
char *dest = switch_event_get_header(helper->event, "Caller-Destination-Number");
|
if (zstr(op)) {
|
||||||
if (zstr(from_id) && !zstr(dest)) {
|
|
||||||
from_id = dest;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (zstr(from_id)) {
|
|
||||||
from_id = p_to_user;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (zstr(from_id)) {
|
|
||||||
switch_snprintf(status_line, sizeof(status_line), "On The Phone %s", status);
|
switch_snprintf(status_line, sizeof(status_line), "On The Phone %s", status);
|
||||||
} else {
|
} else {
|
||||||
switch_snprintf(status_line, sizeof(status_line), "Talk %s", switch_str_nil(from_id));
|
switch_snprintf(status_line, sizeof(status_line), "Talk %s", op);
|
||||||
}
|
}
|
||||||
|
|
||||||
rpid = "on-the-phone";
|
rpid = "on-the-phone";
|
||||||
|
force_status = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
open = "open";
|
open = "open";
|
||||||
|
@ -1457,7 +1471,7 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
|
|
||||||
prpid = translate_rpid(rpid);
|
prpid = translate_rpid(rpid);
|
||||||
|
|
||||||
if (!zstr(dialog_status)) {
|
if (!zstr(dialog_status) && !force_status) {
|
||||||
status = dialog_status;
|
status = dialog_status;
|
||||||
switch_set_string(status_line, status);
|
switch_set_string(status_line, status);
|
||||||
}
|
}
|
||||||
|
@ -1468,7 +1482,6 @@ static int sofia_presence_sub_callback(void *pArg, int argc, char **argv, char *
|
||||||
|
|
||||||
|
|
||||||
pl = gen_pidf(user_agent, clean_id, profile->url, open, rpid, prpid, status_line, &ct);
|
pl = gen_pidf(user_agent, clean_id, profile->url, open, rpid, prpid, status_line, &ct);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -1530,7 +1530,10 @@ SWITCH_DECLARE(switch_channel_state_t) switch_channel_perform_set_running_state(
|
||||||
channel->direction == SWITCH_CALL_DIRECTION_OUTBOUND ? "outbound" : "inbound");
|
channel->direction == SWITCH_CALL_DIRECTION_OUTBOUND ? "outbound" : "inbound");
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Presence-Call-Direction",
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Presence-Call-Direction",
|
||||||
channel->direction == SWITCH_CALL_DIRECTION_OUTBOUND ? "outbound" : "inbound");
|
channel->direction == SWITCH_CALL_DIRECTION_OUTBOUND ? "outbound" : "inbound");
|
||||||
if (switch_channel_test_flag(channel, CF_ANSWERED)) {
|
|
||||||
|
if (switch_channel_down(channel)) {
|
||||||
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "hangup");
|
||||||
|
} else if (switch_channel_test_flag(channel, CF_ANSWERED)) {
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "answered");
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "answered");
|
||||||
} else if (switch_channel_test_flag(channel, CF_EARLY_MEDIA)) {
|
} else if (switch_channel_test_flag(channel, CF_EARLY_MEDIA)) {
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "early");
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "early");
|
||||||
|
@ -1811,7 +1814,9 @@ SWITCH_DECLARE(void) switch_channel_event_set_basic_data(switch_channel_t *chann
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Channel-Call-UUID", v);
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Channel-Call-UUID", v);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (switch_channel_test_flag(channel, CF_ANSWERED)) {
|
if (switch_channel_down(channel)) {
|
||||||
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "hangup");
|
||||||
|
} else if (switch_channel_test_flag(channel, CF_ANSWERED)) {
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "answered");
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "answered");
|
||||||
} else if (switch_channel_test_flag(channel, CF_EARLY_MEDIA)) {
|
} else if (switch_channel_test_flag(channel, CF_EARLY_MEDIA)) {
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "early");
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "Answer-State", "early");
|
||||||
|
|
Loading…
Reference in New Issue