forked from bitpay/bitpay-php-keyutils
-
Notifications
You must be signed in to change notification settings - Fork 0
/
examples.php
89 lines (72 loc) · 2.65 KB
/
examples.php
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?php
use BitPayKeyUtils\KeyHelper\PrivateKey;
use BitPayKeyUtils\Storage\EncryptedFilesystemStorage;
require __DIR__ . '/vendor/autoload.php';
/**
* Generate new private key for every new merchant.
* Make sure you provide an easy recognizable name for each private key/Merchant
* NOTE: In case you are providing the BitPay services to your clients,
* you MUST generate a different key per each of your clients
*
* WARNING: It is EXTREMELY IMPORTANT to place this key files in a very SECURE location
**/
$privateKey = new PrivateKey(__DIR__ . '/secure/SecurePathPlusYourClientName.key');
$storageEngine = new EncryptedFilesystemStorage('YourMasterPassword');
try {
// Use the EncryptedFilesystemStorage to load the Merchant's encrypted private key with the Master Password.
$privateKey = $storageEngine->load(__DIR__ . '/secure/SecurePathPlusYourClientName.key');
} catch (Exception $ex) {
// Check if the loaded keys is a valid key
if (!$privateKey->isValid()) {
$privateKey->generate();
}
// Encrypt and store it securely.
// This Master password could be one for all keys or a different one for each merchant
$storageEngine->persist($privateKey);
}
/**
* Generate the public key from the private key every time (no need to store the public key).
**/
try {
$publicKey = $privateKey->getPublicKey();
} catch (Exception $ex) {
echo $ex->getMessage();
}
/**
* Derive the SIN from the public key.
**/
$sin = $publicKey->getSin()->__toString();
/**
* Use the SIN to request a pairing code and token.
* The pairing code has to be approved in the BitPay Dashboard
* THIS is just a cUrl example, which explains how to use the key pair for signing requests
**/
$resourceUrl = 'https://test.bitpay.com/tokens';
$facade = 'merchant';
$postData = json_encode([
'id' => $sin,
'facade' => $facade
]);
$curlCli = curl_init($resourceUrl);
curl_setopt($curlCli, CURLOPT_HTTPHEADER, [
'x-accept-version: 2.0.0',
'Content-Type: application/json',
'x-identity' => $publicKey->__toString(),
'x-signature' => $privateKey->sign($resourceUrl . $postData),
]);
curl_setopt($curlCli, CURLOPT_CUSTOMREQUEST, 'POST');
curl_setopt($curlCli, CURLOPT_POSTFIELDS, stripslashes($postData));
curl_setopt($curlCli, CURLOPT_RETURNTRANSFER, true);
$result = curl_exec($curlCli);
$resultData = json_decode($result, TRUE);
curl_close($curlCli);
if (array_key_exists('error', $resultData)) {
echo $resultData['error'];
exit;
}
/**
* Example of a pairing Code returned from the BitPay API
* which needs to be APPROVED on the BitPay Dashboard before being able to use it.
**/
echo $resultData['data'][0]['pairingCode'];
/** End of request **/