1 /* General MD5 support.
2 Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
3 Free Software Foundation, Inc.
5 This file is part of GNU Wget.
7 GNU Wget is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 GNU Wget is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with Wget. If not, see <http://www.gnu.org/licenses/>.
20 Additional permission under GNU GPL version 3 section 7
22 If you modify this program, or any covered work, by linking or
23 combining it with the OpenSSL project's OpenSSL library (or a
24 modified version of that library), containing parts covered by the
25 terms of the OpenSSL or SSLeay licenses, the Free Software Foundation
26 grants you additional permission to convey the resulting work.
27 Corresponding Source for a non-source form of such a combination
28 shall include the source code for the parts of OpenSSL used as well
29 as that of the covered work. */
35 #ifdef HAVE_BUILTIN_MD5
37 typedef struct md5_ctx gen_md5_context_imp;
40 #ifdef HAVE_SOLARIS_MD5
42 typedef MD5_CTX gen_md5_context_imp;
45 #ifdef HAVE_OPENSSL_MD5
46 # include <openssl/md5.h>
47 typedef MD5_CTX gen_md5_context_imp;
50 struct gen_md5_context {
51 gen_md5_context_imp imp;
54 /* Originally I planned for these to be macros, but that's very hard
55 because some of these MD5 implementations use the same names for
56 their types. For example, it is impossible to include <md5.h> and
57 <openssl/ssl.h> on Solaris, because the latter includes its own MD5
58 implementation, which clashes with <md5.h>. */
61 gen_md5_context_size (void)
63 return sizeof (struct gen_md5_context);
67 gen_md5_init (gen_md5_context *ctx)
69 gen_md5_context_imp *ctx_imp = &ctx->imp;
71 #ifdef HAVE_BUILTIN_MD5
72 md5_init_ctx (ctx_imp);
75 #ifdef HAVE_SOLARIS_MD5
79 #ifdef HAVE_OPENSSL_MD5
85 gen_md5_update (unsigned const char *buffer, int len, gen_md5_context *ctx)
87 gen_md5_context_imp *ctx_imp = &ctx->imp;
89 #ifdef HAVE_BUILTIN_MD5
90 md5_process_bytes (buffer, len, ctx_imp);
93 #ifdef HAVE_SOLARIS_MD5
94 MD5Update (ctx_imp, (unsigned char *)buffer, len);
97 #ifdef HAVE_OPENSSL_MD5
98 MD5_Update (ctx_imp, buffer, len);
103 gen_md5_finish (gen_md5_context *ctx, unsigned char *result)
105 gen_md5_context_imp *ctx_imp = &ctx->imp;
107 #ifdef HAVE_BUILTIN_MD5
108 md5_finish_ctx (ctx_imp, result);
111 #ifdef HAVE_SOLARIS_MD5
112 MD5Final (result, ctx_imp);
115 #ifdef HAVE_OPENSSL_MD5
116 MD5_Final (result, ctx_imp);
121 /* A debugging function for checking whether an MD5 library works. */
126 debug_test_md5 (char *buf)
128 unsigned char raw[16];
133 ALLOCA_MD5_CONTEXT (ctx);
136 gen_md5_update ((unsigned char *)buf, strlen (buf), ctx);
137 gen_md5_finish (ctx, raw);
144 *p2++ = XNUM_TO_digit (*p1 >> 4);
145 *p2++ = XNUM_TO_digit (*p1 & 0xf);