Use shared copy of hmac5 implementation.
[samba.git] / lib / crypto / crypto.h
1 /* 
2    Unix SMB/CIFS implementation.
3
4    Copyright (C) Andrew Tridgell 2004
5    
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 3 of the License, or
9    (at your option) any later version.
10    
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15    
16    You should have received a copy of the GNU General Public License
17    along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include "../lib/crypto/crc32.h"
21 #include "../lib/crypto/md4.h"
22 #include "../lib/crypto/md5.h"
23 #include "../lib/crypto/hmacmd5.h"
24 #include "../lib/crypto/sha256.h"
25 #include "../lib/crypto/hmacsha256.h"
26
27 struct arcfour_state {
28         uint8_t sbox[256];
29         uint8_t index_i;
30         uint8_t index_j;
31 };
32
33 void arcfour_init(struct arcfour_state *state, const DATA_BLOB *key);
34 void arcfour_crypt_sbox(struct arcfour_state *state, uint8_t *data, int len);
35 void arcfour_crypt_blob(uint8_t *data, int len, const DATA_BLOB *key);
36 void arcfour_crypt(uint8_t *data, const uint8_t keystr[16], int len);
37