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_ */
bn.h for openssl
Definition: dh.h:41