diff --git a/src/mod/applications/mod_commands/mod_commands.c b/src/mod/applications/mod_commands/mod_commands.c
index 5b346228ab..ae965ecf43 100644
--- a/src/mod/applications/mod_commands/mod_commands.c
+++ b/src/mod/applications/mod_commands/mod_commands.c
@@ -570,6 +570,7 @@ SWITCH_STANDARD_API(status_function)
switch_core_time_duration_t duration = { 0 };
char *http = NULL;
int sps = 0, last_sps = 0;
+ const char *var;
if (session) {
return SWITCH_STATUS_FALSE;
@@ -581,6 +582,14 @@ SWITCH_STANDARD_API(status_function)
http = switch_event_get_header(stream->param_event, "http-host");
}
+ if ((var = switch_event_get_header(stream->param_event, "content-type"))) {
+ if (!strcasecmp(var, "text/plain")) {
+ http = NULL;
+ }
+ } else {
+ stream->write_function(stream, "%s", "Content-Type: text/html\n\n");
+ }
+
if (http || (cmd && strstr(cmd, "html"))) {
html = 1;
stream->write_function(stream, "
FreeSWITCH Status
\n");
@@ -2008,7 +2017,17 @@ SWITCH_STANDARD_API(show_function)
}
if (stream->param_event) {
+ const char *var;
holder.http = switch_event_get_header(stream->param_event, "http-host");
+
+ if ((var = switch_event_get_header(stream->param_event, "content-type"))) {
+ if (!strcasecmp(var, "text/plain")) {
+ holder.http = NULL;
+ }
+ } else {
+ stream->write_function(stream, "%s", "Content-Type: text/html\n\n");
+ }
+
}
holder.print_title = 1;
diff --git a/src/mod/xml_int/mod_xml_rpc/mod_xml_rpc.c b/src/mod/xml_int/mod_xml_rpc/mod_xml_rpc.c
index 3f90b6011f..91491b5f3f 100644
--- a/src/mod/xml_int/mod_xml_rpc/mod_xml_rpc.c
+++ b/src/mod/xml_int/mod_xml_rpc/mod_xml_rpc.c
@@ -158,6 +158,7 @@ static abyss_bool http_directory_auth(TSession * r, char *domain_name)
const char *box;
int at = 0;
switch_event_t *params = NULL;
+ char *dp;
p = RequestHeaderValue(r, "authorization");
@@ -166,17 +167,20 @@ static abyss_bool http_directory_auth(TSession * r, char *domain_name)
x = GetToken(&p);
if (x) {
if (!strcasecmp(x, "basic")) {
-
-
NextToken((const char **const) &p);
switch_b64_decode(p, user, sizeof(user));
if ((pass = strchr(user, ':'))) {
*pass++ = '\0';
}
-
+
+ if ((dp = strchr(user, '@'))) {
+ *dp++ = '\0';
+ domain_name = dp;
+ }
+
if (!domain_name) {
- if ((domain_name = strchr(user, '@'))) {
- *domain_name++ = '\0';
+ if (dp) {
+ domain_name = dp;
at++;
} else {
domain_name = (char *) r->requestInfo.host;
@@ -209,7 +213,7 @@ static abyss_bool http_directory_auth(TSession * r, char *domain_name)
switch_event_destroy(¶ms);
box = switch_xml_attr_soft(x_user, "mailbox");
-
+
for (x_param = switch_xml_child(x_domain, "param"); x_param; x_param = x_param->next) {
const char *var = switch_xml_attr_soft(x_param, "name");
const char *val = switch_xml_attr_soft(x_param, "value");
@@ -224,6 +228,7 @@ static abyss_bool http_directory_auth(TSession * r, char *domain_name)
}
if (!(x_params = switch_xml_child(x_user, "params"))) {
+ r->requestInfo.user = strdup(user);
goto authed;
}
@@ -306,15 +311,17 @@ static abyss_bool http_directory_auth(TSession * r, char *domain_name)
goto fail;
authed:
+
+ if (r->requestInfo.user && domain_name) {
+ ResponseAddField(r, "freeswitch-user", r->requestInfo.user);
+ ResponseAddField(r, "freeswitch-domain", domain_name);
- ResponseAddField(r, "freeswitch-user", r->requestInfo.user);
- ResponseAddField(r, "freeswitch-domain", domain_name);
+ if (x_domain_root) {
+ switch_xml_free(x_domain_root);
+ }
- if (x_domain_root) {
- switch_xml_free(x_domain_root);
+ return TRUE;
}
-
- return TRUE;
}
}
}
@@ -437,7 +444,7 @@ abyss_bool handler_hook(TSession * r)
char *fs_user = NULL, *fs_domain = NULL;
char *path_info = NULL;
abyss_bool ret = TRUE;
- int html = 0;
+ int html = 0, text = 0;
stream.data = r;
stream.write_function = http_stream_write;
@@ -452,6 +459,9 @@ abyss_bool handler_hook(TSession * r)
} else if ((command = strstr(r->requestInfo.uri, "/webapi/"))) {
command += 8;
html++;
+ } else if ((command = strstr(r->requestInfo.uri, "/txtapi/"))) {
+ command += 8;
+ text++;
} else {
return FALSE;
}
@@ -509,7 +519,11 @@ abyss_bool handler_hook(TSession * r)
if (switch_event_create(&stream.param_event, SWITCH_EVENT_API) == SWITCH_STATUS_SUCCESS) {
const char *const content_length = RequestHeaderValue(r, "content-length");
-
+
+ if (html)
+ switch_event_add_header(stream.param_event, SWITCH_STACK_BOTTOM, "Content-type", "%s", "text/html");
+ else if (text)
+ switch_event_add_header(stream.param_event, SWITCH_STACK_BOTTOM, "Content-type", "%s", "text/plain");
if (fs_user)
switch_event_add_header(stream.param_event, SWITCH_STACK_BOTTOM, "FreeSWITCH-User", "%s", fs_user);
if (fs_domain)
@@ -633,6 +647,8 @@ abyss_bool handler_hook(TSession * r)
if (html) {
ResponseAddField(r, "Content-Type", "text/html");
+ } else if (text) {
+ ResponseAddField(r, "Content-Type", "text/plain");
}
for (i = 0; i < r->response_headers.size; i++) {
@@ -646,7 +662,7 @@ abyss_bool handler_hook(TSession * r)
switch_snprintf(buf, sizeof(buf), "Connection: close\r\n");
ConnWrite(r->conn, buf, (uint32_t) strlen(buf));
- if (html) {
+ if (html || text) {
ConnWrite(r->conn, "\r\n", 2);
}