Update of /usr/cvsroot/asterisk
In directory mongoose.digium.com:/tmp/cvs-serv11476

Modified Files:
        pbx.c utils.c 
Log Message:
add MD5 and CHECK_MD5 functions, deprecate MD5 and MD5Check apps (bug #4123)


Index: pbx.c
===================================================================
RCS file: /usr/cvsroot/asterisk/pbx.c,v
retrieving revision 1.235
retrieving revision 1.236
diff -u -d -r1.235 -r1.236
--- pbx.c       1 May 2005 23:09:28 -0000       1.235
+++ pbx.c       4 May 2005 04:05:34 -0000       1.236
@@ -1370,6 +1370,51 @@
        return ret;
 }
 
+static char *builtin_function_md5(struct ast_channel *chan, char *cmd, char 
*data, char *buf, size_t len) 
+{
+       char md5[33];
+
+       if (!data || ast_strlen_zero(data)) {
+               ast_log(LOG_WARNING, "Syntax: MD5(<data>) - missing 
argument!\n");
+               return NULL;
+       }
+
+       ast_md5_hash(md5, data);
+       ast_copy_string(buf, md5, len);
+       
+       return buf;
+}
+
+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];
+
+       if (!data || ast_strlen_zero(data)) {
+               ast_log(LOG_WARNING, "Syntax: CHECK_MD5(<digest>,<data>) - 
missing argument!\n");
+               return NULL;
+       }
+
+       args = ast_strdupa(data);       
+       argc = ast_separate_app_args(args, '|', argv, sizeof(argv) / 
sizeof(argv[0]));
+
+       if (argc < 2) {
+               ast_log(LOG_WARNING, "Syntax: CHECK_MD5(<digest>,<data>) - 
missing argument!\n");
+               return NULL;
+       }
+
+       ast_md5_hash(newmd5, argv[1]);
+
+       if (!strcasecmp(newmd5, argv[0]))       /* they match */
+               ast_copy_string(buf, "1", len);
+       else
+               ast_copy_string(buf, "0", len);
+       
+       return buf;
+}
+
 static void pbx_substitute_variables_helper_full(struct ast_channel *c, const 
char *cp1, char *cp2, int count, struct varshead *headp)
 {
        char *cp4;
@@ -3554,6 +3599,21 @@
        .write = builtin_function_cdr_write,
 };
 
+static struct ast_custom_function_obj md5_function = {
+       .name = "MD5",
+       .desc = "Computes an MD5 digest",
+       .syntax = "MD5(<data>)",
+       .read = builtin_function_md5,
+       .write = NULL,
+};
+
+static struct ast_custom_function_obj checkmd5_function = {
+       .name = "CHECK_MD5",
+       .desc = "Checks an MD5 digest. Returns 1 on a match, 0 otherwise",
+       .syntax = "CHECK_MD5(<digest>,<data>)",
+       .read = builtin_function_checkmd5,
+       .write = NULL,
+};
 
 /*
  * CLI entries for upper commands ...
@@ -6000,6 +6060,8 @@
        ast_custom_function_register(&env_function);
        ast_custom_function_register(&len_function);
        ast_custom_function_register(&cdr_function);
+       ast_custom_function_register(&md5_function);
+       ast_custom_function_register(&checkmd5_function);
 
        /* Register builtin applications */
        for (x=0; x<sizeof(builtins) / sizeof(struct pbx_builtin); x++) {

Index: utils.c
===================================================================
RCS file: /usr/cvsroot/asterisk/utils.c,v
retrieving revision 1.41
retrieving revision 1.42
diff -u -d -r1.41 -r1.42
--- utils.c     3 May 2005 23:51:20 -0000       1.41
+++ utils.c     4 May 2005 04:05:34 -0000       1.42
@@ -252,16 +252,17 @@
 /*--- ast_md5_hash: Produce 16 char MD5 hash of value. ---*/
 void ast_md5_hash(char *output, char *input)
 {
-               struct MD5Context md5;
-               unsigned char digest[16];
-               char *ptr;
-               int x;
-               MD5Init(&md5);
-               MD5Update(&md5, input, strlen(input));
-               MD5Final(digest, &md5);
-               ptr = output;
-               for (x=0;x<16;x++)
-                       ptr += sprintf(ptr, "%2.2x", digest[x]);
+       struct MD5Context md5;
+       unsigned char digest[16];
+       char *ptr;
+       int x;
+
+       MD5Init(&md5);
+       MD5Update(&md5, input, strlen(input));
+       MD5Final(digest, &md5);
+       ptr = output;
+       for (x=0; x<16; x++)
+               ptr += sprintf(ptr, "%2.2x", digest[x]);
 }
 
 int ast_base64decode(unsigned char *dst, char *src, int max)

_______________________________________________
Asterisk-Cvs mailing list
Asterisk-Cvs@lists.digium.com
http://lists.digium.com/mailman/listinfo/asterisk-cvs

Reply via email to