Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

test_hmac.c

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  * test_hmac.c - calculates the HMAC-SHA1 hash value
00059  * 
00060  * This algorithm is used in the OTA Prov architecture for bootstrap
00061  * securtiy by means of a shared secret.
00062  * 
00063  * References:
00064  *   - WAP-184-PROVBOOT-20010314a.pdf (Provisioning Bootstrap), WAP Forum 
00065  *   - HMAC: Keyed-Hashing for Message Authentication”, Krawczyk, H., 
00066  *     Bellare, M., and Canetti, R., RFC 2104
00067  *
00068  * Stipe Tolj <stolj@wapme.de>
00069  */
00070 
00071 #include <string.h>
00072 #include <unistd.h>
00073 #include <signal.h>
00074 
00075 #include "gwlib/gwlib.h"
00076 
00077 #ifdef HAVE_LIBSSL
00078 #include <openssl/hmac.h>
00079 #endif
00080 
00081 #ifndef EVP_MAX_MD_SIZE
00082 #define EVP_MAX_MD_SIZE 1
00083 #endif
00084 
00085 int main(int argc, char **argv)
00086 {
00087     Octstr *data, *filename, *mac, *key;
00088     unsigned char macbuf[EVP_MAX_MD_SIZE], *p;
00089     int mac_len;
00090 #ifdef HAVE_LIBSSL
00091     HMAC_CTX ctx;
00092 #endif
00093 
00094     gwlib_init();
00095 
00096     get_and_set_debugs(argc, argv, NULL);
00097 
00098     key = octstr_create(argv[1]);    
00099     filename = octstr_create(argv[2]);
00100     data = octstr_read_file(octstr_get_cstr(filename));
00101 
00102     debug("",0,"Dumping file `%s':", octstr_get_cstr(filename));
00103     octstr_dump(data, 0);
00104 
00105 #ifdef HAVE_LIBSSL
00106     HMAC_Init(&ctx, octstr_get_cstr(key), octstr_len(key), EVP_sha1());
00107     p = HMAC(EVP_sha1(), octstr_get_cstr(key), octstr_len(key), 
00108          octstr_get_cstr(data), octstr_len(data), 
00109          macbuf, &mac_len);
00110     HMAC_cleanup(&ctx);
00111 #else
00112     macbuf[0] = 0;
00113     mac_len = 0;
00114     p = macbuf;
00115     warning(0, "No SSL support. Can't calculate HMAC value.");
00116 #endif
00117     
00118     mac = octstr_create_from_data(p, mac_len);
00119     octstr_binary_to_hex(mac, 0);
00120     
00121     debug("",0,"HMAC of file `%s' and key `%s' is:", 
00122           octstr_get_cstr(filename), octstr_get_cstr(key));
00123     octstr_dump(mac, 0);      
00124 
00125     octstr_destroy(data);
00126     octstr_destroy(mac);
00127     octstr_destroy(key);
00128     gwlib_shutdown();
00129     return 0;
00130 }
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.