Further cleanups.
[metze/wireshark/wip.git] / wsutil / 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  * Wireshark - Network traffic analyzer
6  * By Gerald Combs <gerald@wireshark.org>
7  * Copyright 1998 Gerald Combs
8  *
9  * This program is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License
11  * as published by the Free Software Foundation; either version 2
12  * of the License, or (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22  */
23
24 #ifndef _EAX_H
25 #define _EAX_H
26
27 #include <glib.h>
28 #include "ws_symbol_export.h"
29
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 WS_DLL_PUBLIC
55 gboolean Eax_Decrypt(guint8 *pN, guint8 *pK, guint8 *pC,
56                  guint32 SizeN, guint32 SizeK, guint32 SizeC, MAC_T *pMac,
57                  guint8 Mode);
58
59 #endif