app_verbose.c
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 #include "asterisk.h"
00032
00033 ASTERISK_FILE_VERSION(__FILE__, "$Revision: 328209 $")
00034
00035 #include "asterisk/module.h"
00036 #include "asterisk/app.h"
00037 #include "asterisk/channel.h"
00038
00039 static char *app_verbose = "Verbose";
00040 static char *app_log = "Log";
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079 static int verbose_exec(struct ast_channel *chan, const char *data)
00080 {
00081 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, "%30d", &vsize) != 1) {
00100 vsize = 0;
00101 ast_log(LOG_WARNING, "'%s' is not a verboser number\n", args.level);
00102 }
00103 if (option_verbose >= vsize) {
00104 switch (vsize) {
00105 case 0:
00106 ast_verbose("%s\n", args.msg);
00107 break;
00108 case 1:
00109 ast_verbose(VERBOSE_PREFIX_1 "%s\n", args.msg);
00110 break;
00111 case 2:
00112 ast_verbose(VERBOSE_PREFIX_2 "%s\n", args.msg);
00113 break;
00114 case 3:
00115 ast_verbose(VERBOSE_PREFIX_3 "%s\n", args.msg);
00116 break;
00117 default:
00118 ast_verbose(VERBOSE_PREFIX_4 "%s\n", args.msg);
00119 }
00120 }
00121
00122 return 0;
00123 }
00124
00125 static int log_exec(struct ast_channel *chan, const char *data)
00126 {
00127 char *parse;
00128 int lnum = -1;
00129 char extension[AST_MAX_EXTENSION + 5], context[AST_MAX_EXTENSION + 2];
00130 AST_DECLARE_APP_ARGS(args,
00131 AST_APP_ARG(level);
00132 AST_APP_ARG(msg);
00133 );
00134
00135 if (ast_strlen_zero(data))
00136 return 0;
00137
00138 parse = ast_strdupa(data);
00139 AST_STANDARD_APP_ARGS(args, parse);
00140
00141 if (!strcasecmp(args.level, "ERROR")) {
00142 lnum = __LOG_ERROR;
00143 } else if (!strcasecmp(args.level, "WARNING")) {
00144 lnum = __LOG_WARNING;
00145 } else if (!strcasecmp(args.level, "NOTICE")) {
00146 lnum = __LOG_NOTICE;
00147 } else if (!strcasecmp(args.level, "DEBUG")) {
00148 lnum = __LOG_DEBUG;
00149 } else if (!strcasecmp(args.level, "VERBOSE")) {
00150 lnum = __LOG_VERBOSE;
00151 } else if (!strcasecmp(args.level, "DTMF")) {
00152 lnum = __LOG_DTMF;
00153 } else {
00154 ast_log(LOG_ERROR, "Unknown log level: '%s'\n", args.level);
00155 }
00156
00157 if (lnum > -1) {
00158 snprintf(context, sizeof(context), "@ %s", chan->context);
00159 snprintf(extension, sizeof(extension), "Ext. %s", chan->exten);
00160
00161 ast_log(lnum, extension, chan->priority, context, "%s\n", args.msg);
00162 }
00163
00164 return 0;
00165 }
00166
00167 static int unload_module(void)
00168 {
00169 int res;
00170
00171 res = ast_unregister_application(app_verbose);
00172 res |= ast_unregister_application(app_log);
00173
00174 return res;
00175 }
00176
00177 static int load_module(void)
00178 {
00179 int res;
00180
00181 res = ast_register_application_xml(app_log, log_exec);
00182 res |= ast_register_application_xml(app_verbose, verbose_exec);
00183
00184 return res;
00185 }
00186
00187 AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Send verbose output");