[Freeswitch-svn] [commit] r10568 - freeswitch/trunk/src/mod/endpoints/mod_sofia
FreeSWITCH SVN
anthm at freeswitch.org
Wed Dec 3 07:44:32 PST 2008
Author: anthm
Date: Wed Dec 3 10:44:31 2008
New Revision: 10568
Log:
MODENDP-156
Modified:
freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c
Modified: freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c
==============================================================================
--- freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c (original)
+++ freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c Wed Dec 3 10:44:31 2008
@@ -1409,6 +1409,36 @@
return 0;
}
+static int show_reg_callback_xml(void *pArg, int argc, char **argv, char **columnNames)
+{
+ struct cb_helper *cb = (struct cb_helper *) pArg;
+ char exp_buf[128] = "";
+ switch_time_exp_t tm;
+ const int buflen = 2048;
+ char xmlbuf[buflen];
+
+ if (argv[6]) {
+ switch_time_t etime = atoi(argv[6]);
+ switch_size_t retsize;
+
+ switch_time_exp_lt(&tm, switch_time_from_sec(etime));
+ switch_strftime_nocheck(exp_buf, &retsize, sizeof(exp_buf), "%Y-%m-%d %T", &tm);
+ }
+
+ cb->stream->write_function(cb->stream,
+ "<Registration>\n"
+ "<Call-ID>%s</Call-ID>\n"
+ "<User>%s@%s</User>\n"
+ "<Contact>%s</Contact>\n"
+ "<Agent>%s</Agent>\n"
+ "<Status>%s(%s) EXP(%s)</Status>\n"
+ "<Host>%s</Host>\n"
+ "</Registration>\n",
+ switch_str_nil(argv[0]), switch_str_nil(argv[1]), switch_str_nil(argv[2]), switch_amp_encode(switch_str_nil(argv[3]),xmlbuf,buflen),
+ switch_str_nil(argv[7]), switch_str_nil(argv[4]), switch_str_nil(argv[5]), exp_buf, switch_str_nil(argv[11]));
+ return 0;
+}
+
static const char *status_names[] = { "DOWN", "UP", NULL };
static switch_status_t cmd_status(char **argv, int argc, switch_stream_handle_t *stream)
@@ -1594,6 +1624,194 @@
return SWITCH_STATUS_SUCCESS;
}
+static switch_status_t cmd_xml_status(char **argv, int argc, switch_stream_handle_t *stream)
+{
+ sofia_profile_t *profile = NULL;
+ sofia_gateway_t *gp;
+ switch_hash_index_t *hi;
+ void *val;
+ const void *vvar;
+ const int buflen = 2096;
+ char xmlbuf[buflen];
+ int c = 0;
+ int ac = 0;
+ const char *header = "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>";
+
+ if (argc > 0) {
+ if (argc == 1) {
+ stream->write_function(stream, "Invalid Syntax!\n");
+ return SWITCH_STATUS_SUCCESS;
+ }
+ if (!strcasecmp(argv[0], "gateway")) {
+ if ((gp = sofia_reg_find_gateway(argv[1]))) {
+ switch_assert(gp->state < REG_STATE_LAST);
+ stream->write_function(stream, "%s\n", header);
+ stream->write_function(stream, "<Gateway>\n");
+ stream->write_function(stream, "<Name>%s</Name>\n", switch_str_nil(gp->name));
+ stream->write_function(stream, "<Scheme>%s</Scheme>\n", switch_str_nil(gp->register_scheme));
+ stream->write_function(stream, "<Realm>%s</Realm>\n", switch_str_nil(gp->register_realm));
+ stream->write_function(stream, "<Username>%s</Username>\n", switch_str_nil(gp->register_username));
+ stream->write_function(stream, "<Password>%s</Password>\n", switch_strlen_zero(gp->register_password) ? "no" : "yes");
+ stream->write_function(stream, "<From>%s</From>\n", switch_amp_encode(switch_str_nil(gp->register_from),xmlbuf,buflen));
+ stream->write_function(stream, "<Contact>%s</Contact>\n", switch_amp_encode(switch_str_nil(gp->register_contact),xmlbuf,buflen));
+ stream->write_function(stream, "<To>%s</To>\n", switch_str_nil(gp->register_to));
+ stream->write_function(stream, "<Proxy>%s</Proxy>\n", switch_str_nil(gp->register_proxy));
+ stream->write_function(stream, "<Context>%s</Context>\n", switch_str_nil(gp->register_context));
+ stream->write_function(stream, "<Expires>%s</Expires>\n", switch_str_nil(gp->expires_str));
+ stream->write_function(stream, "<Freq>%d</Freq>\n", gp->freq);
+ stream->write_function(stream, "<Ping>%d</Ping>\n", gp->ping);
+ stream->write_function(stream, "<PingFreq>%d</PingFreq>\n", gp->ping_freq);
+ stream->write_function(stream, "<State>%s</State>\n", sofia_state_names[gp->state]);
+ stream->write_function(stream, "<Status>%s%s</Status>\n", status_names[gp->status], gp->pinging ? " (ping)" : "");
+ stream->write_function(stream, "</Gateway>\n");
+ sofia_reg_release_gateway(gp);
+ } else {
+ stream->write_function(stream, "Invalid Gateway!\n");
+ }
+ } else if (!strcasecmp(argv[0], "profile")) {
+ struct cb_helper cb;
+ char *sql = NULL;
+
+ if ((argv[1]) && (profile = sofia_glue_find_profile(argv[1]))) {
+ if (!argv[2] || strcasecmp(argv[2], "reg")) {
+ stream->write_function(stream, "%s\n", header);
+ stream->write_function(stream, "<Profile>\n");
+ stream->write_function(stream, "<ProfileInfo>\n");
+ stream->write_function(stream, "<Name>%s</Name>\n", switch_str_nil(argv[1]));
+ stream->write_function(stream, "<DomainName>%s</DomainName>\n", profile->domain_name ? profile->domain_name : "N/A");
+ if (strcasecmp(argv[1], profile->name)) {
+ stream->write_function(stream, "<AliasOf>%s</AliasOf>\n", switch_str_nil(profile->name));
+ }
+ stream->write_function(stream, "<DBName>%s</DBName>\n", switch_str_nil(profile->dbname));
+ stream->write_function(stream, "<PresHosts>%s</PresHosts>\n", switch_str_nil(profile->presence_hosts));
+ stream->write_function(stream, "<Dialplan>%s</Dialplan>\n", switch_str_nil(profile->dialplan));
+ stream->write_function(stream, "<Context>%s</Context>\n", switch_str_nil(profile->context));
+ stream->write_function(stream, "<ChallengeRealm>%s</ChallengeRealm>\n",
+ switch_strlen_zero(profile->challenge_realm) ? "auto_to" : profile->challenge_realm);
+ stream->write_function(stream, "<RTP-IP>%s</RTP-IP>\n", switch_str_nil(profile->rtpip));
+ if (profile->extrtpip) {
+ stream->write_function(stream, "<Ext-RTP-IP>%s</Ext-RTP-IP>\n", profile->extrtpip);
+ }
+
+ stream->write_function(stream, "<SIP-IP>%s</SIP-IP>\n", switch_str_nil(profile->sipip));
+ if (profile->extsipip) {
+ stream->write_function(stream, "<Ext-SIP-IP>%s</Ext-SIP-IP>\n", profile->extsipip);
+ }
+ stream->write_function(stream, "<URL>%s</URL>\n", switch_str_nil(profile->url));
+ stream->write_function(stream, "<BIND-URL>%s</BIND-URL>\n", switch_str_nil(profile->bindurl));
+ if (sofia_test_pflag(profile, PFLAG_TLS)) {
+ stream->write_function(stream, "<TLS-URL>%s</TLS-URL>\n", switch_str_nil(profile->tls_url));
+ stream->write_function(stream, "<TLS-BIND-URL>%s</TLS-BIND-URL>\n", switch_str_nil(profile->tls_bindurl));
+ }
+ stream->write_function(stream, "<HOLD-MUSIC>%s</HOLD-MUSIC>\n", switch_strlen_zero(profile->hold_music) ? "N/A" : profile->hold_music);
+ stream->write_function(stream, "<CODECS>%s</CODECS>\n", switch_str_nil(profile->codec_string));
+ stream->write_function(stream, "<TEL-EVENT>%d</TEL-EVENT>\n", profile->te);
+ if (profile->dtmf_type == DTMF_2833) {
+ stream->write_function(stream, "<DTMF-MODE>rfc2833</DTMF-MODE>\n");
+ } else if (profile->dtmf_type == DTMF_INFO) {
+ stream->write_function(stream, "<DTMF-MODE>info</DTMF-MODE>\n");
+ } else {
+ stream->write_function(stream, "<DTMF-MODE>none</DTMF-MODE>\n");
+ }
+ stream->write_function(stream, "<CNG>%d</CNG>\n", profile->cng_pt);
+ stream->write_function(stream, "<SESSION-TO>%d</SESSION-TO>\n", profile->session_timeout);
+ stream->write_function(stream, "<MAX-DIALOG>%d</MAX-DIALOG>\n", profile->max_proceeding);
+ stream->write_function(stream, "<NOMEDIA>%s</NOMEDIA>\n", switch_test_flag(profile, TFLAG_INB_NOMEDIA) ? "true" : "false");
+ stream->write_function(stream, "<LATE-NEG>%s</LATE-NEG>\n", switch_test_flag(profile, TFLAG_LATE_NEGOTIATION) ? "true" : "false");
+ stream->write_function(stream, "<PROXY-MEDIA>%s</PROXY-MEDIA>\n", switch_test_flag(profile, TFLAG_PROXY_MEDIA) ? "true" : "false");
+ stream->write_function(stream, "<AGGRESSIVENAT>%s</AGGRESSIVENAT>\n", sofia_test_pflag(profile, PFLAG_AGGRESSIVE_NAT_DETECTION) ? "true" : "false");
+ stream->write_function(stream, "<STUN_ENABLED>%s</STUN_ENABLED>\n", sofia_test_pflag(profile, PFLAG_STUN_ENABLED) ? "true" : "false");
+ stream->write_function(stream, "<STUN_AUTO_DISABLE>%s</STUN_AUTO_DISABLE>\n", sofia_test_pflag(profile, PFLAG_STUN_AUTO_DISABLE) ? "true" : "false");
+ }
+ stream->write_function(stream, "</ProfileInfo>\n");
+ stream->write_function(stream, "<Registrations>\n");
+
+ cb.profile = profile;
+ cb.stream = stream;
+
+ if (argv[3]) {
+ if (argv[4]) {
+ if (!strcasecmp(argv[3], "pres")) {
+ sql = switch_mprintf("select call_id,sip_user,sip_host,contact,status,"
+ "rpid,expires,user_agent,server_user,server_host,profile_name,hostname"
+ " from sip_registrations where profile_name='%q' and presence_hosts like '%%%q%%'",
+ profile->name, argv[4]);
+ }
+ } else {
+ sql = switch_mprintf("select call_id,sip_user,sip_host,contact,status,"
+ "rpid,expires,user_agent,server_user,server_host,profile_name,hostname"
+ " from sip_registrations where profile_name='%q' and contact like '%%%q%%'",
+ profile->name, argv[3]);
+ }
+ }
+
+ if (!sql) {
+ sql = switch_mprintf("select call_id,sip_user,sip_host,contact,status,"
+ "rpid,expires,user_agent,server_user,server_host,profile_name,hostname"
+ " from sip_registrations where profile_name='%q'",
+ profile->name);
+ }
+
+ sofia_glue_execute_sql_callback(profile, SWITCH_FALSE, profile->ireg_mutex, sql, show_reg_callback_xml, &cb);
+ free(sql);
+
+ stream->write_function(stream, "</Registrations>\n");
+ stream->write_function(stream, "</Profile>\n");
+
+ sofia_glue_release_profile(profile);
+ } else {
+ stream->write_function(stream, "Invalid Profile!\n");
+ }
+ } else {
+ stream->write_function(stream, "Invalid Syntax!\n");
+ }
+
+ return SWITCH_STATUS_SUCCESS;
+ }
+
+ stream->write_function(stream, "%s\n", header);
+ stream->write_function(stream, "<Profiles>\n");
+ switch_mutex_lock(mod_sofia_globals.hash_mutex);
+ for (hi = switch_hash_first(NULL, mod_sofia_globals.profile_hash); hi; hi = switch_hash_next(hi)) {
+ switch_hash_this(hi, &vvar, NULL, &val);
+ profile = (sofia_profile_t *) val;
+ if (sofia_test_pflag(profile, PFLAG_RUNNING)) {
+
+ if (strcmp(vvar, profile->name)) {
+ ac++;
+ stream->write_function(stream, "<alias>\n<Name>%s</Name>\n<Type>%s</Type>\n<Data>%s</Data>\n<State>%s</State>\n</alias>\n", vvar, "alias", profile->name, "ALIASED");
+ } else {
+ stream->write_function(stream, "<profile>\n<Name>%s</Name>\n<Type>%s</Type>\n<Data>%s</Data>\n<State>%s (%u)</State>\n</profile>\n", profile->name, "profile", profile->url,
+ sofia_test_pflag(profile, PFLAG_RUNNING) ? "RUNNING" : "DOWN", profile->inuse);
+
+ if (sofia_test_pflag(profile, PFLAG_TLS)) {
+ stream->write_function(stream, "<profile>\n<Name>%s</Name>\n<Type>%s</Type>\n<Data>%s</Data>\n<State>%s (%u) (TLS)</State>\n</profile>\n", profile->name, "profile", profile->tls_url,
+ sofia_test_pflag(profile, PFLAG_RUNNING) ? "RUNNING" : "DOWN", profile->inuse);
+ }
+
+ c++;
+
+ for (gp = profile->gateways; gp; gp = gp->next) {
+ switch_assert(gp->state < REG_STATE_LAST);
+ stream->write_function(stream, "<gateway>\n<Name>%s</Name>\n<Type>%s</Type>\n<Data>%s</Data>\n<State>%s</State>\n</gateway>\n", gp->name, "gateway", gp->register_to, sofia_state_names[gp->state]);
+ if (gp->state == REG_STATE_FAILED || gp->state == REG_STATE_TRYING) {
+ time_t now = switch_timestamp(NULL);
+ if (gp->retry > now) {
+ stream->write_function(stream, " (retry: %ds)", gp->retry - now);
+ } else {
+ stream->write_function(stream, " (retry: NEVER)");
+ }
+ }
+ stream->write_function(stream, "\n");
+ }
+ }
+ }
+ }
+ switch_mutex_unlock(mod_sofia_globals.hash_mutex);
+ stream->write_function(stream, "</Profiles>\n");
+ return SWITCH_STATUS_SUCCESS;
+}
+
static switch_status_t cmd_profile(char **argv, int argc, switch_stream_handle_t *stream)
{
sofia_profile_t *profile = NULL;
@@ -1983,6 +2201,8 @@
func = cmd_profile;
} else if (!strcasecmp(argv[0], "status")) {
func = cmd_status;
+ } else if (!strcasecmp(argv[0], "xmlstatus")) {
+ func = cmd_xml_status;
} else if (!strcasecmp(argv[0], "loglevel")) {
if (argc > 1 && argv[1]) {
int level;
More information about the Freeswitch-svn
mailing list