Electroneum
Toggle main menu visibility
Loading...
Searching...
No Matches
hmac-md5.h
Go to the documentation of this file.
1
/*
2
* libEtPan! -- a mail stuff library
3
*
4
* Copyright (C) 2001, 2005 - DINH Viet Hoa
5
* All rights reserved.
6
*
7
* Redistribution and use in source and binary forms, with or without
8
* modification, are permitted provided that the following conditions
9
* are met:
10
* 1. Redistributions of source code must retain the above copyright
11
* notice, this list of conditions and the following disclaimer.
12
* 2. Redistributions in binary form must reproduce the above copyright
13
* notice, this list of conditions and the following disclaimer in the
14
* documentation and/or other materials provided with the distribution.
15
* 3. Neither the name of the libEtPan! project nor the names of its
16
* contributors may be used to endorse or promote products derived
17
* from this software without specific prior written permission.
18
*
19
* THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
20
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
23
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29
* SUCH DAMAGE.
30
*/
31
32
/* hmac-md5.h -- HMAC_MD5 functions
33
*/
34
35
/*
36
* $Id: hmac-md5.h,v 1.1.1.1 2005/03/18 20:17:28 zautrix Exp $
37
*/
38
39
#ifndef HMAC_MD5_H
40
#define HMAC_MD5_H 1
41
42
namespace
md5
43
{
44
45
46
47
#define HMAC_MD5_SIZE 16
48
49
/* intermediate MD5 context */
50
typedef
struct
HMAC_MD5_CTX_s
{
51
MD5_CTX
ictx
,
octx
;
52
}
HMAC_MD5_CTX
;
53
54
/* intermediate HMAC state
55
* values stored in network byte order (Big Endian)
56
*/
57
typedef
struct
HMAC_MD5_STATE_s
{
58
UINT4
istate
[4];
59
UINT4
ostate
[4];
60
}
HMAC_MD5_STATE
;
61
62
/* One step hmac computation
63
*
64
* digest may be same as text or key
65
*/
66
void
hmac_md5
(
const
unsigned
char
*text,
int
text_len,
67
const
unsigned
char
*
key
,
int
key_len,
68
unsigned
char
digest[
HMAC_MD5_SIZE
]);
69
70
/* create context from key
71
*/
72
void
hmac_md5_init
(
HMAC_MD5_CTX
*hmac,
73
const
unsigned
char
*
key
,
int
key_len);
74
75
/* precalculate intermediate state from key
76
*/
77
void
hmac_md5_precalc
(
HMAC_MD5_STATE
*hmac,
78
const
unsigned
char
*
key
,
int
key_len);
79
80
/* initialize context from intermediate state
81
*/
82
void
hmac_md5_import
(
HMAC_MD5_CTX
*hmac,
HMAC_MD5_STATE
*
state
);
83
84
#define hmac_md5_update(hmac, text, text_len) MD5Update(&(hmac)->ictx, (text), (text_len))
85
86
/* finish hmac from intermediate result. Intermediate result is zeroed.
87
*/
88
void
hmac_md5_final
(
unsigned
char
digest[
HMAC_MD5_SIZE
],
89
HMAC_MD5_CTX
*hmac);
90
91
}
92
93
#endif
/* HMAC_MD5_H */
HMAC_MD5_SIZE
#define HMAC_MD5_SIZE
Definition
hmac-md5.h:47
key
const char * key
Definition
hmac_keccak.cpp:39
md5
Definition
hmac-md5.h:43
md5::HMAC_MD5_CTX
struct md5::HMAC_MD5_CTX_s HMAC_MD5_CTX
md5::hmac_md5
void hmac_md5(const unsigned char *text, int text_len, const unsigned char *key, int key_len, unsigned char digest[HMAC_MD5_SIZE])
md5::hmac_md5_precalc
void hmac_md5_precalc(HMAC_MD5_STATE *hmac, const unsigned char *key, int key_len)
md5::hmac_md5_final
void hmac_md5_final(unsigned char digest[HMAC_MD5_SIZE], HMAC_MD5_CTX *hmac)
md5::hmac_md5_init
void hmac_md5_init(HMAC_MD5_CTX *hmac, const unsigned char *key, int key_len)
md5::UINT4
unsigned int UINT4
Definition
md5global.h:63
md5::HMAC_MD5_STATE
struct md5::HMAC_MD5_STATE_s HMAC_MD5_STATE
md5::hmac_md5_import
void hmac_md5_import(HMAC_MD5_CTX *hmac, HMAC_MD5_STATE *state)
md5::HMAC_MD5_CTX_s
Definition
hmac-md5.h:50
md5::HMAC_MD5_CTX_s::ictx
MD5_CTX ictx
Definition
hmac-md5.h:51
md5::HMAC_MD5_CTX_s::octx
MD5_CTX octx
Definition
hmac-md5.h:51
md5::HMAC_MD5_STATE_s
Definition
hmac-md5.h:57
md5::HMAC_MD5_STATE_s::ostate
UINT4 ostate[4]
Definition
hmac-md5.h:59
md5::HMAC_MD5_STATE_s::istate
UINT4 istate[4]
Definition
hmac-md5.h:58
md5::MD5_CTX
Definition
md5_l.h:68
state
Definition
blake256.h:37
contrib
epee
include
hmac-md5.h
Generated on
for Electroneum by
1.17.0