-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathsecp256k1_ecdh_customhash_equivalent_sha256.phpt
47 lines (40 loc) · 1.34 KB
/
secp256k1_ecdh_customhash_equivalent_sha256.phpt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
--TEST--
secp256k1_ecdh - can write equivalent hash fxn to default
--SKIPIF--
<?php
if (!extension_loaded("secp256k1")) print "skip extension not loaded";
if (!function_exists("secp256k1_ecdh")) print "skip no ecdh support";
?>
--FILE--
<?php
$context = secp256k1_context_create(SECP256K1_CONTEXT_SIGN | SECP256K1_CONTEXT_VERIFY);
$priv1 = str_pad('', 32, "\x41");
$priv2 = str_pad('', 32, "\x40");
$expectedSecret = '238c14f420887f8e9bfa78bc9bdded1975f0bb6384e33b4ebbf7a8c776844aec';
/** @var resource $pub1 */
$pub1 = null;
$result = \secp256k1_ec_pubkey_create($context, $pub1, $priv1);
echo $result . PHP_EOL;
// Function we suppose is equivalent to upstreams default hash fxn
$hashFxn = function (&$output, $x, $y) {
$version = 0x02 | (unpack("C", $y[31])[1] & 0x01);
$ctx = hash_init('sha256', 0);
hash_update($ctx, pack("C", $version));
hash_update($ctx, $x);
$output = hash_final($ctx, true);
return 1;
};
$secret = '';
$result = \secp256k1_ecdh($context, $secret, $pub1, $priv2, $hashFxn, 32, NULL);
echo $result . PHP_EOL;
echo unpack("H*", $secret)[1].PHP_EOL;
$result = \secp256k1_ecdh($context, $secret, $pub1, $priv2);
echo $result . PHP_EOL;
echo unpack("H*", $secret)[1].PHP_EOL;
?>
--EXPECT--
1
1
238c14f420887f8e9bfa78bc9bdded1975f0bb6384e33b4ebbf7a8c776844aec
1
238c14f420887f8e9bfa78bc9bdded1975f0bb6384e33b4ebbf7a8c776844aec