Verbose logging application. More...
#include "asterisk.h"#include "asterisk/module.h"#include "asterisk/app.h"#include "asterisk/channel.h"
Go to the source code of this file.
Functions | |
| static void | __reg_module (void) |
| static void | __unreg_module (void) |
| static int | load_module (void) |
| static int | log_exec (struct ast_channel *chan, const char *data) |
| static int | unload_module (void) |
| static int | verbose_exec (struct ast_channel *chan, const char *data) |
Variables | |
| static struct ast_module_info | __mod_info = { .name = AST_MODULE, .flags = AST_MODFLAG_LOAD_ORDER , .description = "Send verbose output" , .key = "This paragraph is copyright (c) 2006 by Digium, Inc. \In order for your module to load, it must return this \key via a function called \"key\". Any code which \includes this paragraph must be licensed under the GNU \General Public License version 2 or later (at your \option). In addition to Digium's general reservations \of rights, Digium expressly reserves the right to \allow other parties to license this paragraph under \different terms. Any use of Digium, Inc. trademarks or \logos (including \"Asterisk\" or \"Digium\") without \express written permission of Digium, Inc. is prohibited.\n" , .buildopt_sum = AST_BUILDOPT_SUM, .load = load_module, .unload = unload_module, .load_pri = AST_MODPRI_DEFAULT, } |
| static char * | app_log = "Log" |
| static char * | app_verbose = "Verbose" |
| static struct ast_module_info * | ast_module_info = &__mod_info |
Verbose logging application.
Definition in file app_verbose.c.
| static void __reg_module | ( | void | ) | [static] |
Definition at line 173 of file app_verbose.c.
| static void __unreg_module | ( | void | ) | [static] |
Definition at line 173 of file app_verbose.c.
| static int load_module | ( | void | ) | [static] |
Definition at line 163 of file app_verbose.c.
References ast_register_application_xml, log_exec(), and verbose_exec().
{
int res;
res = ast_register_application_xml(app_log, log_exec);
res |= ast_register_application_xml(app_verbose, verbose_exec);
return res;
}
| static int log_exec | ( | struct ast_channel * | chan, |
| const char * | data | ||
| ) | [static] |
Definition at line 111 of file app_verbose.c.
References __LOG_DEBUG, __LOG_DTMF, __LOG_ERROR, __LOG_NOTICE, __LOG_VERBOSE, __LOG_WARNING, args, AST_APP_ARG, ast_channel_context(), ast_channel_exten(), ast_channel_priority(), AST_DECLARE_APP_ARGS, ast_log(), AST_MAX_EXTENSION, AST_STANDARD_APP_ARGS, ast_strlen_zero(), context, LOG_ERROR, and parse().
Referenced by load_module().
{
char *parse;
int lnum = -1;
char extension[AST_MAX_EXTENSION + 5], context[AST_MAX_EXTENSION + 2];
AST_DECLARE_APP_ARGS(args,
AST_APP_ARG(level);
AST_APP_ARG(msg);
);
if (ast_strlen_zero(data))
return 0;
parse = ast_strdupa(data);
AST_STANDARD_APP_ARGS(args, parse);
if (!strcasecmp(args.level, "ERROR")) {
lnum = __LOG_ERROR;
} else if (!strcasecmp(args.level, "WARNING")) {
lnum = __LOG_WARNING;
} else if (!strcasecmp(args.level, "NOTICE")) {
lnum = __LOG_NOTICE;
} else if (!strcasecmp(args.level, "DEBUG")) {
lnum = __LOG_DEBUG;
} else if (!strcasecmp(args.level, "VERBOSE")) {
lnum = __LOG_VERBOSE;
} else if (!strcasecmp(args.level, "DTMF")) {
lnum = __LOG_DTMF;
} else {
ast_log(LOG_ERROR, "Unknown log level: '%s'\n", args.level);
}
if (lnum > -1) {
snprintf(context, sizeof(context), "@ %s", ast_channel_context(chan));
snprintf(extension, sizeof(extension), "Ext. %s", ast_channel_exten(chan));
ast_log(lnum, extension, ast_channel_priority(chan), context, "%s\n", args.msg);
}
return 0;
}
| static int unload_module | ( | void | ) | [static] |
Definition at line 153 of file app_verbose.c.
References ast_unregister_application().
{
int res;
res = ast_unregister_application(app_verbose);
res |= ast_unregister_application(app_log);
return res;
}
| static int verbose_exec | ( | struct ast_channel * | chan, |
| const char * | data | ||
| ) | [static] |
Definition at line 79 of file app_verbose.c.
References args, AST_APP_ARG, AST_DECLARE_APP_ARGS, ast_log(), AST_STANDARD_APP_ARGS, ast_strlen_zero(), ast_verb, LOG_WARNING, and parse().
Referenced by load_module().
{
int vsize;
char *parse;
AST_DECLARE_APP_ARGS(args,
AST_APP_ARG(level);
AST_APP_ARG(msg);
);
if (ast_strlen_zero(data)) {
return 0;
}
parse = ast_strdupa(data);
AST_STANDARD_APP_ARGS(args, parse);
if (args.argc == 1) {
args.msg = args.level;
args.level = "0";
}
if (sscanf(args.level, "%30u", &vsize) != 1) {
vsize = 0;
ast_log(LOG_WARNING, "'%s' is not a verboser number\n", args.level);
} else if (4 < vsize) {
vsize = 4;
}
ast_verb(vsize, "%s\n", args.msg);
return 0;
}
struct ast_module_info __mod_info = { .name = AST_MODULE, .flags = AST_MODFLAG_LOAD_ORDER , .description = "Send verbose output" , .key = "This paragraph is copyright (c) 2006 by Digium, Inc. \In order for your module to load, it must return this \key via a function called \"key\". Any code which \includes this paragraph must be licensed under the GNU \General Public License version 2 or later (at your \option). In addition to Digium's general reservations \of rights, Digium expressly reserves the right to \allow other parties to license this paragraph under \different terms. Any use of Digium, Inc. trademarks or \logos (including \"Asterisk\" or \"Digium\") without \express written permission of Digium, Inc. is prohibited.\n" , .buildopt_sum = AST_BUILDOPT_SUM, .load = load_module, .unload = unload_module, .load_pri = AST_MODPRI_DEFAULT, } [static] |
Definition at line 173 of file app_verbose.c.
char* app_log = "Log" [static] |
Definition at line 40 of file app_verbose.c.
char* app_verbose = "Verbose" [static] |
Definition at line 39 of file app_verbose.c.
struct ast_module_info* ast_module_info = &__mod_info [static] |
Definition at line 173 of file app_verbose.c.