File tree 2 files changed +34
-8
lines changed
2 files changed +34
-8
lines changed Original file line number Diff line number Diff line change @@ -3629,14 +3629,11 @@ PHP_FUNCTION(openssl_pkey_new)
3629
3629
OPENSSL_PKEY_SET_BN (Z_ARRVAL_P (data ), dh , g );
3630
3630
OPENSSL_PKEY_SET_BN (Z_ARRVAL_P (data ), dh , priv_key );
3631
3631
OPENSSL_PKEY_SET_BN (Z_ARRVAL_P (data ), dh , pub_key );
3632
- if (dh -> p && dh -> g ) {
3633
- if (!dh -> pub_key ) {
3634
- DH_generate_key (dh );
3635
- }
3636
- if (EVP_PKEY_assign_DH (pkey , dh )) {
3637
- ZVAL_COPY_VALUE (return_value , zend_list_insert (pkey , le_key ));
3638
- return ;
3639
- }
3632
+ if (dh -> p && dh -> g &&
3633
+ (dh -> pub_key || DH_generate_key (dh )) &&
3634
+ EVP_PKEY_assign_DH (pkey , dh )) {
3635
+ ZVAL_COPY_VALUE (return_value , zend_list_insert (pkey , le_key ));
3636
+ return ;
3640
3637
}
3641
3638
DH_free (dh );
3642
3639
}
Original file line number Diff line number Diff line change
1
+ --TEST--
2
+ Bug #55259 (openssl extension does not get the DH parameters from DH key resource)
3
+ --SKIPIF--
4
+ <?php if (!extension_loaded ("openssl " )) die ("skip " ); ?>
5
+ --FILE--
6
+ <?php
7
+
8
+ $ phex = 'dcf93a0b883972ec0e19989ac5a2ce310e1d37717e8d9571bb7623731866e61e ' .
9
+ 'f75a2e27898b057f9891c2e27a639c3f29b60814581cd3b2ca3986d268370557 ' .
10
+ '7d45c2e7e52dc81c7a171876e5cea74b1448bfdfaf18828efd2519f14e45e382 ' .
11
+ '6634af1949e5b535cc829a483b8a76223e5d490a257f05bdff16f2fb22c583ab ' ;
12
+ $ dh_details = array ( 'p ' => $ phex , 'g ' => '2 ' );
13
+ $ dh = openssl_pkey_new (array ( 'dh ' => array ( 'p ' => $ phex , 'g ' => '2 ' )));
14
+ var_dump ($ dh );
15
+ $ dh = openssl_pkey_new (array ( 'dh ' => array ( 'p ' => hex2bin ($ phex ), 'g ' => '2 ' )));
16
+ $ details = openssl_pkey_get_details ($ dh );
17
+ var_dump (bin2hex ($ details ['dh ' ]['p ' ]));
18
+ var_dump ($ details ['dh ' ]['g ' ]);
19
+ var_dump (strlen ($ details ['dh ' ]['pub_key ' ]));
20
+ var_dump (strlen ($ details ['dh ' ]['priv_key ' ]));
21
+ echo "Done " ;
22
+ ?>
23
+ --EXPECT--
24
+ bool(false)
25
+ string(256) "dcf93a0b883972ec0e19989ac5a2ce310e1d37717e8d9571bb7623731866e61ef75a2e27898b057f9891c2e27a639c3f29b60814581cd3b2ca3986d2683705577d45c2e7e52dc81c7a171876e5cea74b1448bfdfaf18828efd2519f14e45e3826634af1949e5b535cc829a483b8a76223e5d490a257f05bdff16f2fb22c583ab"
26
+ string(1) "2"
27
+ int(128)
28
+ int(128)
29
+ Done
You can’t perform that action at this time.
0 commit comments