add fsctl loglevel [<level>] fsctl command

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@5790 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2007-10-03 23:43:01 +00:00
parent e44ad9588c
commit 1667112b3b
8 changed files with 39 additions and 8 deletions

View File

@ -156,6 +156,7 @@ struct switch_runtime {
switch_mutex_t *throttle_mutex; switch_mutex_t *throttle_mutex;
uint32_t sps_total; uint32_t sps_total;
int32_t sps; int32_t sps;
uint32_t hard_log_level;
}; };
extern struct switch_runtime runtime; extern struct switch_runtime runtime;

View File

@ -1443,7 +1443,7 @@ SWITCH_DECLARE(switch_time_t) switch_core_uptime(void);
\param val the command arguement (if needed) \param val the command arguement (if needed)
\return 0 on success nonzero on error \return 0 on success nonzero on error
*/ */
SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, uint32_t * val); SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, int32_t * val);
/*! /*!
\brief Get the output console \brief Get the output console

View File

@ -1007,7 +1007,8 @@ typedef enum {
SCSC_PAUSE_INBOUND, SCSC_PAUSE_INBOUND,
SCSC_HUPALL, SCSC_HUPALL,
SCSC_SHUTDOWN, SCSC_SHUTDOWN,
SCSC_CHECK_RUNNING SCSC_CHECK_RUNNING,
SCSC_LOGLEVEL
} switch_session_ctl_t; } switch_session_ctl_t;
typedef struct apr_pool_t switch_memory_pool_t; typedef struct apr_pool_t switch_memory_pool_t;

View File

@ -94,7 +94,7 @@ SWITCH_STANDARD_API(ctl_function)
{ {
int argc; int argc;
char *mydata, *argv[5]; char *mydata, *argv[5];
uint32_t arg = 0; int32_t arg = 0;
if (switch_strlen_zero(cmd)) { if (switch_strlen_zero(cmd)) {
stream->write_function(stream, "USAGE: %s\n", CTL_SYNTAX); stream->write_function(stream, "USAGE: %s\n", CTL_SYNTAX);
@ -116,6 +116,18 @@ SWITCH_STANDARD_API(ctl_function)
} else if (!strcasecmp(argv[0], "shutdown")) { } else if (!strcasecmp(argv[0], "shutdown")) {
arg = 0; arg = 0;
switch_core_session_ctl(SCSC_SHUTDOWN, &arg); switch_core_session_ctl(SCSC_SHUTDOWN, &arg);
} else if (!strcasecmp(argv[0], "loglevel")) {
if (argc > 1) {
if (*argv[1] > 47 && *argv[1] < 58) {
arg = atoi(argv[1]);
} else {
arg = switch_log_str2level(argv[1]);
}
} else {
arg = -1;
}
switch_core_session_ctl(SCSC_LOGLEVEL, &arg);
stream->write_function(stream, "log level %s [%d]\n", switch_log_level2str(arg), arg);
} else { } else {
stream->write_function(stream, "INVALID COMMAND\nUSAGE: fsctl [hupall|pause|resume|shutdown]\n"); stream->write_function(stream, "INVALID COMMAND\nUSAGE: fsctl [hupall|pause|resume|shutdown]\n");
goto end; goto end;

View File

@ -68,7 +68,7 @@ static HANDLE shutdown_event;
*/ */
static void handle_SIGHUP(int sig) static void handle_SIGHUP(int sig)
{ {
uint32_t arg = 0; int32_t arg = 0;
if (sig); if (sig);
/* send shutdown signal to the freeswitch core */ /* send shutdown signal to the freeswitch core */
switch_core_session_ctl(SCSC_SHUTDOWN, &arg); switch_core_session_ctl(SCSC_SHUTDOWN, &arg);

View File

@ -204,7 +204,7 @@ static void *SWITCH_THREAD_FUNC console_thread(switch_thread_t *thread, void *ob
switch_memory_pool_t *pool = (switch_memory_pool_t *) obj; switch_memory_pool_t *pool = (switch_memory_pool_t *) obj;
while (running) { while (running) {
uint32_t arg; int32_t arg;
switch_core_session_ctl(SCSC_CHECK_RUNNING, &arg); switch_core_session_ctl(SCSC_CHECK_RUNNING, &arg);
if (!arg) { if (!arg) {
@ -270,7 +270,7 @@ SWITCH_DECLARE(void) switch_console_loop(void)
switch_thread_create(&thread, thd_attr, console_thread, pool, pool); switch_thread_create(&thread, thd_attr, console_thread, pool, pool);
while (running) { while (running) {
uint32_t arg = 0; int32_t arg = 0;
switch_core_session_ctl(SCSC_CHECK_RUNNING, &arg); switch_core_session_ctl(SCSC_CHECK_RUNNING, &arg);
if (!arg) { if (!arg) {
break; break;

View File

@ -623,7 +623,7 @@ SWITCH_DECLARE(switch_time_t) switch_core_uptime(void)
return switch_time_now() - runtime.initiated; return switch_time_now() - runtime.initiated;
} }
SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, uint32_t * val) SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, int32_t * val)
{ {
if (switch_test_flag((&runtime), SCF_SHUTTING_DOWN)) { if (switch_test_flag((&runtime), SCF_SHUTTING_DOWN)) {
return -1; return -1;
@ -646,6 +646,18 @@ SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, uint32
case SCSC_CHECK_RUNNING: case SCSC_CHECK_RUNNING:
*val = runtime.running; *val = runtime.running;
break; break;
case SCSC_LOGLEVEL:
if (*val > -1) {
printf("WTF %d\n", *val);
runtime.hard_log_level = *val;
}
if (runtime.hard_log_level > SWITCH_LOG_CONSOLE) {
printf("WTF %d\n", *val);
runtime.hard_log_level = SWITCH_LOG_CONSOLE;
}
*val = runtime.hard_log_level;
break;
} }
return 0; return 0;

View File

@ -30,7 +30,8 @@
* *
*/ */
#include <switch.h> #include <switch.h>
#include "private/switch_core_pvt.h"
struct switch_runtime runtime;
static const char *LEVELS[] = { static const char *LEVELS[] = {
"EMERG", "EMERG",
@ -166,6 +167,10 @@ SWITCH_DECLARE(void) switch_log_printf(switch_text_channel_t channel, const char
uint32_t len; uint32_t len;
const char *extra_fmt = "%s [%s] %s:%d %s()%c%s"; const char *extra_fmt = "%s [%s] %s:%d %s()%c%s";
if (level < runtime.hard_log_level) {
return;
}
va_start(ap, fmt); va_start(ap, fmt);
handle = switch_core_data_channel(channel); handle = switch_core_data_channel(channel);