app_verbose.c File Reference

Verbose logging application. More...

#include "asterisk.h"
#include "asterisk/module.h"
#include "asterisk/app.h"
#include "asterisk/channel.h"

Include dependency graph for app_verbose.c:

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, .support_level = AST_MODULE_SUPPORT_CORE, }
static char * app_log = "Log"
static char * app_verbose = "Verbose"
static struct ast_module_infoast_module_info = &__mod_info


Detailed Description

Verbose logging application.

Author:
Tilghman Lesher <app_verbose_v001@the-tilghman.com>

Definition in file app_verbose.c.


Function Documentation

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().

00164 {
00165    int res;
00166 
00167    res = ast_register_application_xml(app_log, log_exec);
00168    res |= ast_register_application_xml(app_verbose, verbose_exec);
00169 
00170    return res;
00171 }

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_strdupa, ast_strlen_zero, context, LOG_ERROR, and parse().

Referenced by load_module().

00112 {
00113    char *parse;
00114    int lnum = -1;
00115    char extension[AST_MAX_EXTENSION + 5], context[AST_MAX_EXTENSION + 2];
00116    AST_DECLARE_APP_ARGS(args,
00117       AST_APP_ARG(level);
00118       AST_APP_ARG(msg);
00119    );
00120 
00121    if (ast_strlen_zero(data))
00122       return 0;
00123 
00124    parse = ast_strdupa(data);
00125    AST_STANDARD_APP_ARGS(args, parse);
00126 
00127    if (!strcasecmp(args.level, "ERROR")) {
00128       lnum = __LOG_ERROR;
00129    } else if (!strcasecmp(args.level, "WARNING")) {
00130       lnum = __LOG_WARNING;
00131    } else if (!strcasecmp(args.level, "NOTICE")) {
00132       lnum = __LOG_NOTICE;
00133    } else if (!strcasecmp(args.level, "DEBUG")) {
00134       lnum = __LOG_DEBUG;
00135    } else if (!strcasecmp(args.level, "VERBOSE")) {
00136       lnum = __LOG_VERBOSE;
00137    } else if (!strcasecmp(args.level, "DTMF")) {
00138       lnum = __LOG_DTMF;
00139    } else {
00140       ast_log(LOG_ERROR, "Unknown log level: '%s'\n", args.level);
00141    }
00142 
00143    if (lnum > -1) {
00144       snprintf(context, sizeof(context), "@ %s", ast_channel_context(chan));
00145       snprintf(extension, sizeof(extension), "Ext. %s", ast_channel_exten(chan));
00146 
00147       ast_log(lnum, extension, ast_channel_priority(chan), context, "%s\n", args.msg);
00148    }
00149 
00150    return 0;
00151 }

static int unload_module ( void   )  [static]

Definition at line 153 of file app_verbose.c.

References ast_unregister_application().

00154 {
00155    int res;
00156 
00157    res = ast_unregister_application(app_verbose);
00158    res |= ast_unregister_application(app_log);
00159 
00160    return res;
00161 }

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_strdupa, ast_strlen_zero, ast_verb, LOG_WARNING, and parse().

Referenced by load_module().

00080 {
00081    unsigned int vsize;
00082    char *parse;
00083    AST_DECLARE_APP_ARGS(args,
00084       AST_APP_ARG(level);
00085       AST_APP_ARG(msg);
00086    );
00087 
00088    if (ast_strlen_zero(data)) {
00089       return 0;
00090    }
00091 
00092    parse = ast_strdupa(data);
00093    AST_STANDARD_APP_ARGS(args, parse);
00094    if (args.argc == 1) {
00095       args.msg = args.level;
00096       args.level = "0";
00097    }
00098 
00099    if (sscanf(args.level, "%30u", &vsize) != 1) {
00100       vsize = 0;
00101       ast_log(LOG_WARNING, "'%s' is not a verboser number\n", args.level);
00102    } else if (4 < vsize) {
00103       vsize = 4;
00104    }
00105 
00106    ast_verb(vsize, "%s\n", args.msg);
00107 
00108    return 0;
00109 }


Variable Documentation

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, .support_level = AST_MODULE_SUPPORT_CORE, } [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.

Definition at line 173 of file app_verbose.c.


Generated on Thu Apr 16 06:28:47 2015 for Asterisk - The Open Source Telephony Project by  doxygen 1.5.6