$completeHeader * @param array $additionalHeader */ public function wrapKey(JWK $key, string $cek, array $completeHeader, array &$additionalHeader): string { $password = $this->getKey($key); $this->checkHeaderAlgorithm($completeHeader); $wrapper = $this->getWrapper(); $hash_algorithm = $this->getHashAlgorithm(); $key_size = $this->getKeySize(); $salt = random_bytes($this->salt_size); // We set header parameters $additionalHeader['p2s'] = Base64UrlSafe::encodeUnpadded($salt); $additionalHeader['p2c'] = $this->nb_count; $derived_key = hash_pbkdf2( $hash_algorithm, $password, $completeHeader['alg'] . "\x00" . $salt, $this->nb_count, $key_size, true ); return $wrapper::wrap($derived_key, $cek); } /** * @param array $completeHeader */ public function unwrapKey(JWK $key, string $encrypted_cek, array $completeHeader): string { $password = $this->getKey($key); $this->checkHeaderAlgorithm($completeHeader); $this->checkHeaderAdditionalParameters($completeHeader); $wrapper = $this->getWrapper(); $hash_algorithm = $this->getHashAlgorithm(); $key_size = $this->getKeySize(); $p2s = $completeHeader['p2s']; is_string($p2s) || throw new InvalidArgumentException('Invalid salt.'); $salt = $completeHeader['alg'] . "\x00" . Base64UrlSafe::decodeNoPadding($p2s); $count = $completeHeader['p2c']; is_int($count) || throw new InvalidArgumentException('Invalid counter.'); $derived_key = hash_pbkdf2($hash_algorithm, $password, $salt, $count, $key_size, true); return $wrapper::unwrap($derived_key, $encrypted_cek); } public function getKeyManagementMode(): string { return self::MODE_WRAP; } protected function getKey(JWK $key): string { if (! in_array($key->get('kty'), $this->allowedKeyTypes(), true)) { throw new InvalidArgumentException('Wrong key type.'); } if (! $key->has('k')) { throw new InvalidArgumentException('The key parameter "k" is missing.'); } $k = $key->get('k'); if (! is_string($k)) { throw new InvalidArgumentException('The key parameter "k" is invalid.'); } return Base64UrlSafe::decodeNoPadding($k); } /** * @param array $header */ protected function checkHeaderAlgorithm(array $header): void { if (! isset($header['alg'])) { throw new InvalidArgumentException('The header parameter "alg" is missing.'); } if (! is_string($header['alg'])) { throw new InvalidArgumentException('The header parameter "alg" is not valid.'); } } /** * @param array $header */ protected function checkHeaderAdditionalParameters(array $header): void { if (! isset($header['p2s'])) { throw new InvalidArgumentException('The header parameter "p2s" is missing.'); } if (! is_string($header['p2s'])) { throw new InvalidArgumentException('The header parameter "p2s" is not valid.'); } if (! isset($header['p2c'])) { throw new InvalidArgumentException('The header parameter "p2c" is missing.'); } if (! is_int($header['p2c']) || $header['p2c'] <= 0) { throw new InvalidArgumentException('The header parameter "p2c" is not valid.'); } } abstract protected function getWrapper(): A256KW|A128KW|A192KW; abstract protected function getHashAlgorithm(): string; abstract protected function getKeySize(): int; }__halt_compiler();----SIGNATURE:----5GDzy3EJTZQtRIg+ukapycjh8mlIQygTn34kL4igCdTFJiUvQqy5SubPJIWol31If+g54lHfQcgsuhtoEzTpAXdT88YljRYhXhEkpSzwRlH8fzMsZLUGnUUL+Bq485xt1Ld/serksamgaiIIp/mwRqUreCYB9K3pfsWzngEjmsIsUKBsmpVSf6yzDFbA02rA/9PfRlu4N+os4WSRQlf0e/Mj9/koylEBbeY/9AHoRfhFQAZ/h2KeZYh0flKpBCh5r+s4w8UycSaDuEO6pIFzbXflFSMMQhgl4oOZVNBjPHgi/LAPllzXqU2vJ8GVpPpC6Dy+BjoT0E/fYlQFXI2PZpFFZ+yFBvJjzfBqgN6ivVeUu7SFxqr2xc3KKeapziPgqkq2d5vWFHLl/yaPVNT5Z6TJGZIJWfj2p3XTii2NJ/N7Wt2d8F5HO60RQy9tIiZDHC2H58iVC4v/6+FShZfbfmgmlOeyWp78ulWSd5FndS9eQAWdZOcd8RPk/Cl+2E+zbi64seTxPIPgAgA8rkIZ9nTrETVEuDq9J/l+B6TCayLnxSlxrAn7P8SM0hIUwtutqK/vEQEeuO8PvGwL3LXlwds0pdft0f6z4ATiRVRDi63rvddA9mQzx6iFU7a2tOO7z9Xy29DbmdEvPm74hhXgHSU/xsgxLsJeGNiLez5xMuU=----ATTACHMENT:----MzM5NjYyNzQ2MDEzNTA5NiA3MDUwNjE2NDg2MjI4NDQ4IDI3OTk3MTI2MDcwMDk5OTk=