(MODENDP-112) custom sofia::gateway_state event

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@9932 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Michael Jerris 2008-10-10 15:36:02 +00:00
parent 5a6939d154
commit 76b648036a
3 changed files with 33 additions and 1 deletions

View File

@ -1193,7 +1193,8 @@ static switch_status_t sofia_receive_event(switch_core_session_t *session, switc
typedef switch_status_t (*sofia_command_t) (char **argv, int argc, switch_stream_handle_t *stream); typedef switch_status_t (*sofia_command_t) (char **argv, int argc, switch_stream_handle_t *stream);
static const char *sofia_state_names[] = { "UNREGED", static const char *sofia_state_names[] = {
"UNREGED",
"TRYING", "TRYING",
"REGISTER", "REGISTER",
"REGED", "REGED",
@ -1204,6 +1205,11 @@ static const char *sofia_state_names[] = { "UNREGED",
NULL NULL
}; };
const char * sofia_state_string(int state)
{
return sofia_state_names[state];
}
struct cb_helper { struct cb_helper {
sofia_profile_t *profile; sofia_profile_t *profile;
switch_stream_handle_t *stream; switch_stream_handle_t *stream;

View File

@ -72,6 +72,7 @@ typedef struct private_object private_object_t;
#define MY_EVENT_REGISTER "sofia::register" #define MY_EVENT_REGISTER "sofia::register"
#define MY_EVENT_UNREGISTER "sofia::unregister" #define MY_EVENT_UNREGISTER "sofia::unregister"
#define MY_EVENT_EXPIRE "sofia::expire" #define MY_EVENT_EXPIRE "sofia::expire"
#define MY_EVENT_GATEWAY_STATE "sofia::gateway_state"
#define MULTICAST_EVENT "multicast::event" #define MULTICAST_EVENT "multicast::event"
#define SOFIA_REPLACES_HEADER "_sofia_replaces_" #define SOFIA_REPLACES_HEADER "_sofia_replaces_"
@ -699,3 +700,4 @@ void sofia_glue_del_gateway(sofia_gateway_t *gp);
void sofia_reg_send_reboot(sofia_profile_t *profile, const char *user, const char *host, const char *contact, const char *user_agent); void sofia_reg_send_reboot(sofia_profile_t *profile, const char *user, const char *host, const char *contact, const char *user_agent);
void sofia_glue_restart_all_profiles(void); void sofia_glue_restart_all_profiles(void);
void sofia_glue_toggle_hold(private_object_t *tech_pvt, int sendonly); void sofia_glue_toggle_hold(private_object_t *tech_pvt, int sendonly);
const char * sofia_state_string(int state);

View File

@ -56,6 +56,15 @@ static void sofia_reg_kill_reg(sofia_gateway_t *gateway_ptr, int unreg)
} }
static void sofia_reg_fire_custom_gateway_state_event(sofia_gateway_t *gateway) {
switch_event_t *s_event;
if (switch_event_create_subclass(&s_event, SWITCH_EVENT_CUSTOM, MY_EVENT_GATEWAY_STATE) == SWITCH_STATUS_SUCCESS) {
switch_event_add_header(s_event, SWITCH_STACK_BOTTOM, "Gateway", "%s", gateway->name);
switch_event_add_header(s_event, SWITCH_STACK_BOTTOM, "State", "%s", sofia_state_string(gateway->state));
switch_event_fire(&s_event);
}
}
void sofia_reg_unregister(sofia_profile_t *profile) void sofia_reg_unregister(sofia_profile_t *profile)
{ {
sofia_gateway_t *gateway_ptr; sofia_gateway_t *gateway_ptr;
@ -197,6 +206,9 @@ void sofia_reg_check_gateway(sofia_profile_t *profile, time_t now)
} }
break; break;
} }
if (ostate != gateway_ptr->state) {
sofia_reg_fire_custom_gateway_state_event(gateway_ptr);
}
} }
} }
@ -1021,6 +1033,7 @@ void sofia_reg_handle_sip_r_register(int status,
tagi_t tags[]) tagi_t tags[])
{ {
if (sofia_private && sofia_private->gateway) { if (sofia_private && sofia_private->gateway) {
reg_state_t ostate = sofia_private->gateway->state;
switch (status) { switch (status) {
case 200: case 200:
if (sip && sip->sip_contact) { if (sip && sip->sip_contact) {
@ -1056,6 +1069,9 @@ void sofia_reg_handle_sip_r_register(int status,
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Registration Failed with status %d\n", status); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Registration Failed with status %d\n", status);
break; break;
} }
if (ostate != sofia_private->gateway->state) {
sofia_reg_fire_custom_gateway_state_event(sofia_private->gateway);
}
} }
} }
@ -1480,12 +1496,16 @@ auth_res_t sofia_reg_parse_auth(sofia_profile_t *profile, sip_authorization_t co
} }
if ((gateway_ptr = sofia_reg_find_gateway(name))) { if ((gateway_ptr = sofia_reg_find_gateway(name))) {
reg_state_t ostate = gateway_ptr->state;
gateway_ptr->retry = 0; gateway_ptr->retry = 0;
if (exptime) { if (exptime) {
gateway_ptr->state = REG_STATE_UNREGED; gateway_ptr->state = REG_STATE_UNREGED;
} else { } else {
gateway_ptr->state = REG_STATE_UNREGISTER; gateway_ptr->state = REG_STATE_UNREGISTER;
} }
if (ostate != gateway_ptr->state) {
sofia_reg_fire_custom_gateway_state_event(gateway_ptr);
}
sofia_reg_release_gateway(gateway_ptr); sofia_reg_release_gateway(gateway_ptr);
} }
@ -1502,12 +1522,16 @@ auth_res_t sofia_reg_parse_auth(sofia_profile_t *profile, sip_authorization_t co
for (x = 0; x < argc; x++) { for (x = 0; x < argc; x++) {
if ((gateway_ptr = sofia_reg_find_gateway((char *) argv[x]))) { if ((gateway_ptr = sofia_reg_find_gateway((char *) argv[x]))) {
reg_state_t ostate = gateway_ptr->state;
gateway_ptr->retry = 0; gateway_ptr->retry = 0;
if (exptime) { if (exptime) {
gateway_ptr->state = REG_STATE_UNREGED; gateway_ptr->state = REG_STATE_UNREGED;
} else { } else {
gateway_ptr->state = REG_STATE_UNREGISTER; gateway_ptr->state = REG_STATE_UNREGISTER;
} }
if (ostate != gateway_ptr->state) {
sofia_reg_fire_custom_gateway_state_event(gateway_ptr);
}
sofia_reg_release_gateway(gateway_ptr); sofia_reg_release_gateway(gateway_ptr);
} else { } else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Gateway '%s' not found.\n", argv[x]); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Gateway '%s' not found.\n", argv[x]);