8209d4d60bc54fdc2f205e838477631f30ced1b2
[metze/wireshark/wip.git] / epan / crypt / eax.h
1 /* eax.h
2  * Encryption and decryption routines implementing the EAX' encryption mode
3  * Copyright 2010, Edward J. Beroset, edward.j.beroset@us.elster.com
4  *
5  * $Id$
6  *
7  * Wireshark - Network traffic analyzer
8  * By Gerald Combs <gerald@wireshark.org>
9  * Copyright 1998 Gerald Combs
10  *
11  * This program is free software; you can redistribute it and/or
12  * modify it under the terms of the GNU General Public License
13  * as published by the Free Software Foundation; either version 2
14  * of the License, or (at your option) any later version.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program; if not, write to the Free Software
23  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24  */
25 #ifdef HAVE_CONFIG_H
26 #include "config.h"
27 #endif
28
29 #include <glib.h>
30 typedef struct tagMAC_T
31 {
32     guint8 Mac[4];
33 } MAC_T;
34
35 #define EAX_MODE_CLEARTEXT_AUTH     1
36 #define EAX_MODE_CIPHERTEXT_AUTH    2
37
38 #define EAX_SIZEOF_KEY              16
39
40 /*!
41  Decrypts cleartext data using EAX' mode (see ANSI Standard C12.22-2008).
42
43  @param[in]     pN      pointer to cleartext (canonified form)
44  @param[in]     pK      pointer to secret key
45  @param[in,out] pC      pointer to ciphertext
46  @param[in]     SizeN   byte length of cleartext (pN) buffer
47  @param[in]     SizeK   byte length of secret key (pK) 
48  @param[in]     SizeC   byte length of ciphertext (pC) buffer
49  @param[in]     pMac    four-byte Message Authentication Code
50  @param[in]     Mode    EAX_MODE_CLEARTEXT_AUTH or EAX_MODE_CIPHERTEXT_AUTH
51  @return                TRUE if message has been authenticated; FALSE if not 
52                         authenticated, invalid Mode or error
53  */
54 gboolean Eax_Decrypt(guint8 *pN, guint8 *pK, guint8 *pC, 
55                  guint32 SizeN, guint32 SizeK, guint32 SizeC, MAC_T *pMac, 
56                  guint8 Mode);
57