My Project
Loading...
Searching...
No Matches
wolfssl
openssl
dh.h
1
/* dh.h
2
*
3
* Copyright (C) 2006-2020 wolfSSL Inc.
4
*
5
* This file is part of wolfSSL.
6
*
7
* wolfSSL is free software; you can redistribute it and/or modify
8
* it under the terms of the GNU General Public License as published by
9
* the Free Software Foundation; either version 2 of the License, or
10
* (at your option) any later version.
11
*
12
* wolfSSL is distributed in the hope that it will be useful,
13
* but WITHOUT ANY WARRANTY; without even the implied warranty of
14
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
* GNU General Public License for more details.
16
*
17
* You should have received a copy of the GNU General Public License
18
* along with this program; if not, write to the Free Software
19
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
20
*/
21
22
/* dh.h for openSSL */
23
24
25
#ifndef WOLFSSL_DH_H_
26
#define WOLFSSL_DH_H_
27
28
#include <
wolfssl/openssl/bn.h
>
29
30
#ifdef __cplusplus
31
extern
"C"
{
32
#endif
33
34
#ifndef WOLFSSL_DH_TYPE_DEFINED
/* guard on redeclaration */
35
typedef
struct
WOLFSSL_DH
WOLFSSL_DH
;
36
#define WOLFSSL_DH_TYPE_DEFINED
37
#endif
38
39
typedef
WOLFSSL_DH
DH
;
40
41
struct
WOLFSSL_DH
{
42
WOLFSSL_BIGNUM* p;
43
WOLFSSL_BIGNUM* g;
44
WOLFSSL_BIGNUM* q;
45
WOLFSSL_BIGNUM* pub_key;
/* openssh deference g^x */
46
WOLFSSL_BIGNUM* priv_key;
/* openssh deference x */
47
void
* internal;
/* our DH */
48
char
inSet;
/* internal set from external ? */
49
char
exSet;
/* external set from internal ? */
50
/*added for lighttpd openssl compatibility, go back and add a getter in
51
* lighttpd src code.
52
*/
53
int
length;
54
};
55
56
WOLFSSL_API
WOLFSSL_DH
*wolfSSL_d2i_DHparams(
WOLFSSL_DH
**dh,
57
const
unsigned
char
**pp,
long
length);
58
WOLFSSL_API
int
wolfSSL_i2d_DHparams(
const
WOLFSSL_DH
*dh,
unsigned
char
**out);
59
WOLFSSL_API
WOLFSSL_DH
* wolfSSL_DH_new(
void
);
60
WOLFSSL_API
void
wolfSSL_DH_free(
WOLFSSL_DH
*);
61
62
WOLFSSL_API
int
wolfSSL_DH_check(
const
WOLFSSL_DH
*dh,
int
*codes);
63
WOLFSSL_API
int
wolfSSL_DH_size(
WOLFSSL_DH
*);
64
WOLFSSL_API
int
wolfSSL_DH_generate_key(
WOLFSSL_DH
*);
65
WOLFSSL_API
int
wolfSSL_DH_compute_key(
unsigned
char
* key, WOLFSSL_BIGNUM* pub,
66
WOLFSSL_DH
*);
67
WOLFSSL_API
int
wolfSSL_DH_LoadDer(
WOLFSSL_DH
*,
const
unsigned
char
*,
int
sz);
68
WOLFSSL_API
int
wolfSSL_DH_set0_pqg(
WOLFSSL_DH
*, WOLFSSL_BIGNUM*,
69
WOLFSSL_BIGNUM*, WOLFSSL_BIGNUM*);
70
71
#define DH_new wolfSSL_DH_new
72
#define DH_free wolfSSL_DH_free
73
74
#define d2i_DHparams wolfSSL_d2i_DHparams
75
#define i2d_DHparams wolfSSL_i2d_DHparams
76
#define DH_check wolfSSL_DH_check
77
78
#define DH_size wolfSSL_DH_size
79
#define DH_generate_key wolfSSL_DH_generate_key
80
#define DH_compute_key wolfSSL_DH_compute_key
81
#if defined(OPENSSL_VERSION_NUMBER) && OPENSSL_VERSION_NUMBER >= 0x10100000L
82
#define DH_set0_pqg wolfSSL_DH_set0_pqg
83
#endif
84
#define DH_bits(x) (BN_num_bits(x->p))
85
86
#define DH_GENERATOR_2 2
87
#define DH_CHECK_P_NOT_PRIME 0x01
88
#define DH_CHECK_P_NOT_SAFE_PRIME 0x02
89
#define DH_NOT_SUITABLE_GENERATOR 0x08
90
91
/* Temporary values for wolfSSL_DH_Check*/
92
#define DH_CHECK_INVALID_Q_VALUE 0x10
93
#define DH_CHECK_Q_NOT_PRIME 0x11
94
/* end temp */
95
96
/* for pre 1.1.0 */
97
#define get_rfc2409_prime_768 wolfSSL_DH_768_prime
98
#define get_rfc2409_prime_1024 wolfSSL_DH_1024_prime
99
#define get_rfc3526_prime_1536 wolfSSL_DH_1536_prime
100
#define get_rfc3526_prime_2048 wolfSSL_DH_2048_prime
101
#define get_rfc3526_prime_3072 wolfSSL_DH_3072_prime
102
#define get_rfc3526_prime_4096 wolfSSL_DH_4096_prime
103
#define get_rfc3526_prime_6144 wolfSSL_DH_6144_prime
104
#define get_rfc3526_prime_8192 wolfSSL_DH_8192_prime
105
106
#ifdef __cplusplus
107
}
/* extern "C" */
108
#endif
109
110
#if defined(OPENSSL_ALL) || defined(HAVE_STUNNEL)
111
#define DH_generate_parameters wolfSSL_DH_generate_parameters
112
#define DH_generate_parameters_ex wolfSSL_DH_generate_parameters_ex
113
#endif
/* OPENSSL_ALL || HAVE_STUNNEL */
114
115
#endif
/* WOLFSSL_DH_H_ */
WOLFSSL_DH
Definition
dh.h:41
bn.h
bn.h for openssl