| 
<?phpdeclare(strict_types=1);
 namespace ParagonIE\Paserk\Tests\Operations;
 
 use ParagonIE\HiddenString\HiddenString;
 use ParagonIE\Paserk\Operations\PBKW;
 use ParagonIE\Paserk\PaserkException;
 use ParagonIE\Paseto\Keys\AsymmetricSecretKey;
 use ParagonIE\Paseto\Keys\SymmetricKey;
 use ParagonIE\Paseto\Protocol\{
 Version3,
 Version4
 };
 use ParagonIE\Paseto\ProtocolInterface;
 use PHPUnit\Framework\TestCase;
 
 /**
 * Class PBKWTest
 * @package ParagonIE\Paserk\Tests\Operations
 *
 * @covers PBKW
 */
 class PBKWTest extends TestCase
 {
 /** @var ProtocolInterface[] */
 protected array $versions = [];
 
 public function setUp(): void
 {
 $this->versions = [
 new Version3(),
 new Version4(),
 ];
 }
 
 /**
 * @throws PaserkException
 */
 public function testWrap()
 {
 $password = new HiddenString('correct horse battery staple');
 $testConfig = [
 'iterations' => 1000,
 'memlimit' => SODIUM_CRYPTO_PWHASH_MEMLIMIT_INTERACTIVE,
 'opslimit' => SODIUM_CRYPTO_PWHASH_OPSLIMIT_INTERACTIVE,
 'parallelism' => 1,
 ];
 
 foreach ($this->versions as $v) {
 $pbkw = PBKW::forVersion($v);
 
 $localKey = SymmetricKey::generate($v);
 $secretKey = AsymmetricSecretKey::generate($v);
 
 $lw = $pbkw->localPwWrap($localKey, $password, $testConfig);
 $lu = $pbkw->localPwUnwrap($lw, $password);
 $this->assertSame($lu->encode(), $localKey->encode());
 
 $sw = $pbkw->secretPwWrap($secretKey, $password, $testConfig);
 $su = $pbkw->secretPwUnwrap($sw, $password);
 $this->assertSame($su->encode(), $secretKey->encode());
 }
 }
 }
 
 |