diff options
author | mogorman <mogorman@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-01-10 16:08:28 +0000 |
---|---|---|
committer | mogorman <mogorman@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-01-10 16:08:28 +0000 |
commit | dea4f0a665931da2f7f1b106b7ba450c9f1db4b6 (patch) | |
tree | e2e07c410262f39024999b82aa7a4318cfb6600c /funcs/func_md5.c | |
parent | 901b0ed354fb86d200044d7e95692f7df938ac8d (diff) |
6186 amd 6187 with minor revisions. added arg
parsing from macro.
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@7945 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'funcs/func_md5.c')
-rw-r--r-- | funcs/func_md5.c | 25 |
1 files changed, 16 insertions, 9 deletions
diff --git a/funcs/func_md5.c b/funcs/func_md5.c index c7217c815..552e876ed 100644 --- a/funcs/func_md5.c +++ b/funcs/func_md5.c @@ -55,27 +55,34 @@ static char *builtin_function_md5(struct ast_channel *chan, char *cmd, char *dat static char *builtin_function_checkmd5(struct ast_channel *chan, char *cmd, char *data, char *buf, size_t len) { - int argc; - char *argv[2]; - char *args; char newmd5[33]; + char *parse; + AST_DECLARE_APP_ARGS(args, + AST_APP_ARG(digest); + AST_APP_ARG(data); + ); if (ast_strlen_zero(data)) { ast_log(LOG_WARNING, "Syntax: CHECK_MD5(<digest>,<data>) - missing argument!\n"); return NULL; } - args = ast_strdupa(data); - argc = ast_app_separate_args(args, '|', argv, sizeof(argv) / sizeof(argv[0])); - - if (argc < 2) { + parse = ast_strdupa(data); + if (!parse) { + ast_log(LOG_ERROR, "Out of memory!\n"); + return NULL; + } + + AST_STANDARD_APP_ARGS(args, parse); + + if (args.argc < 2) { ast_log(LOG_WARNING, "Syntax: CHECK_MD5(<digest>,<data>) - missing argument!\n"); return NULL; } - ast_md5_hash(newmd5, argv[1]); + ast_md5_hash(newmd5, args.data); - if (!strcasecmp(newmd5, argv[0])) /* they match */ + if (!strcasecmp(newmd5, args.digest) ) /* they match */ ast_copy_string(buf, "1", len); else ast_copy_string(buf, "0", len); |