libpcp  0.2.1
mac.h
1 /*
2  This file is part of Pretty Curved Privacy (pcp1).
3 
4  Copyright (C) 2013 T.Linden.
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  You can contact me by mail: <tlinden AT cpan DOT org>.
20 */
21 
22 
23 #ifndef _HAVE_PCP_MAC
24 #define _HAVE_PCP_MAC
25 
30 #include <strings.h>
31 #include <stdlib.h>
32 #include <errno.h>
33 #include <sodium.h>
34 #include "pad.h"
35 #include "mem.h"
36 
37 
38 /* how many times do we hash the passphrase */
39 #define HCYCLES 128000
40 
58 size_t pcp_sodium_mac(unsigned char **cipher,
59  unsigned char *cleartext,
60  size_t clearsize,
61  unsigned char *nonce,
62  unsigned char *key);
63 
82 int pcp_sodium_verify_mac(unsigned char **cleartext,
83  unsigned char* message,
84  size_t messagesize,
85  unsigned char *nonce,
86  unsigned char *key);
87 
88 
89 
90 
91 #endif /* _HAVE_PCP_MAC */
92