1. Go to this page and download the library: Download paragonie/hpke library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
paragonie / hpke example snippets
use ParagonIE\HPKE\Factory;
// Either approach will work fine.
$ciphersuite = Factory::init('DHKEM(X25519, HKDF-SHA256), HKDF-SHA256, AES-128-GCM');
$otherCS = Factory::dhkem_p256sha256_hkdf_sha256_chacha20poly1305();
use ParagonIE\HPKE\HPKE;
use ParagonIE\HPKE\KEM\DHKEM\{DecapsKey, EncapsKey};
use Mdanter\Ecc\Serializer\{
PublicKey\PemPublicKeySerializer,
PrivateKey\PemPrivateKeySerializer
};
/** @var HPKE $hpke */
/**
* @var EncapsKey $public
* @var DecapsKey $secret
*/
[$secret, $public] = $hpke->kem->generateKeys();
// You can now use Easy-ECC or PHP-ECC to manage these keys:
$decapsulationKeyToSaveToDisk = (new PemPrivateKeySerializer())
->serialize($secret->toPrivateKey());
$encapsKeySharePublicly = (new PemPublicKeySerializer())
->serialize($public->toPublicKey());
use ParagonIE\HPKE\HPKE;
use ParagonIE\HPKE\KEM\DHKEM\{DecapsKey, EncapsKey};
/**
* @var HPKE $hpke
* @var EncapsKey $public
* @var DecapsKey $secret
*/
const INFO = 'my custom protocol name';
// On one side
[$enc, $sender] = $hpke->setupBaseSender($public, INFO);
// On te other
$receiver = $hpke->setupBaseReceiver($secret, $enc, INFO);
// And now you can encrypt/decrypt:
$encrypted1 = $sender->seal('test message', 'first message AAD');
$decrypted1 = $receiver->open($encrypted1, 'first message AAD');
// The sequence is advanced automatically by our API