Wire Sysio Wire Sysion 1.0.0
Loading...
Searching...
No Matches
dh.cpp
Go to the documentation of this file.
1#include <fc/crypto/dh.hpp>
2#include <openssl/dh.h>
3
4namespace fc {
5 SSL_TYPE(ssl_dh, DH, DH_free)
6
7 static bool validate( const ssl_dh& dh, bool& valid ) {
8 int check;
9 DH_check(dh,&check);
10 return valid = !(check /*& DH_CHECK_P_NOT_SAFE_PRIME*/);
11 }
12
14 {
15 ssl_dh dh;
16 DH_generate_parameters_ex(dh.obj, s, g, NULL);
17 ssl_bignum bn_p;
18 DH_get0_pqg(dh.obj, (const BIGNUM**)&bn_p.obj, NULL, NULL);
19 p.resize( BN_num_bytes( bn_p ) );
20 if( p.size() )
21 BN_bn2bin( bn_p, (unsigned char*)&p.front() );
22 this->g = g;
23 return fc::validate( dh, valid );
24 }
25
27 {
28 if( !p.size() )
29 return valid = false;
30 ssl_dh dh = DH_new();
31 const auto bn_p = BN_bin2bn( (unsigned char*)&p.front(), p.size(), NULL );
32 const auto bn_g = BN_bin2bn( (unsigned char*)&g, 1, NULL );
33 DH_set0_pqg(dh.obj, bn_p, NULL, bn_g);
34 return fc::validate( dh, valid );
35 }
36
38 {
39 if( !p.size() )
40 return valid = false;
41 ssl_dh dh = DH_new();
42 const auto bn_p = BN_bin2bn( (unsigned char*)&p.front(), p.size(), NULL );
43 const auto bn_g = BN_bin2bn( (unsigned char*)&g, 1, NULL );
44 DH_set0_pqg(dh.obj, bn_p, NULL, bn_g);
45
46 if( !fc::validate( dh, valid ) )
47 {
48 return false;
49 }
50 DH_generate_key(dh);
51
52 ssl_bignum bn_pub_key;
53 ssl_bignum bn_priv_key;
54 DH_get0_key(dh.obj, (const BIGNUM**)&bn_pub_key.obj, (const BIGNUM**)&bn_priv_key.obj);
55 pub_key.resize( BN_num_bytes( bn_pub_key ) );
56 priv_key.resize( BN_num_bytes( bn_priv_key ) );
57 if( pub_key.size() )
58 BN_bn2bin( bn_pub_key.obj, (unsigned char*)&pub_key.front() );
59 if( priv_key.size() )
60 BN_bn2bin( bn_priv_key.obj, (unsigned char*)&priv_key.front() );
61
62 return true;
63 }
65 ssl_dh dh = DH_new();
66 auto bn_p = BN_bin2bn( (unsigned char*)&p.front(), p.size(), NULL );
67 auto bn_pub_key = BN_bin2bn( (unsigned char*)&pub_key.front(), pub_key.size(), NULL );
68 auto bn_priv_key = BN_bin2bn( (unsigned char*)&priv_key.front(), priv_key.size(), NULL );
69 auto bn_g = BN_bin2bn( (unsigned char*)&g, 1, NULL );
70 DH_set0_pqg(dh.obj, bn_p, NULL, bn_g);
71 DH_set0_key(dh.obj, bn_pub_key, bn_priv_key);
72
73 int check;
74 DH_check(dh,&check);
75 if( !fc::validate( dh, valid ) )
76 {
77 return false;
78 }
79
80 ssl_bignum pk;
81 BN_bin2bn( (unsigned char*)buf, s, pk );
82 shared_key.resize( DH_size(dh) );
83 DH_compute_key( (unsigned char*)&shared_key.front(), pk, dh );
84
85 return true;
86 }
87 bool diffie_hellman::compute_shared_key( const std::vector<char>& pubk ) {
88 return compute_shared_key( &pubk.front(), pubk.size() );
89 }
90}
bignum_st BIGNUM
Definition bigint.hpp:7
namespace sysio::chain
Definition authority.cpp:3
bool validate(const Authority &auth)
#define SSL_TYPE(name, ssl_type, free_func)
Definition openssl.hpp:34
unsigned int uint32_t
Definition stdint.h:126
unsigned char uint8_t
Definition stdint.h:124
std::vector< char > priv_key
Definition dh.hpp:18
bool compute_shared_key(const char *buf, uint32_t s)
Definition dh.cpp:64
bool validate()
Definition dh.cpp:26
std::vector< char > p
Definition dh.hpp:16
uint8_t g
Definition dh.hpp:21
std::vector< char > shared_key
Definition dh.hpp:19
bool generate_params(int s, uint8_t g)
Definition dh.cpp:13
std::vector< char > pub_key
Definition dh.hpp:17
bool generate_pub_key()
Definition dh.cpp:37
ssl_type * obj
Definition openssl.hpp:31
char * s
uint8_t buf[2048]