'RSA', OPENSSL_KEYTYPE_DSA => 'DSA', OPENSSL_KEYTYPE_DH => 'DH', OPENSSL_KEYTYPE_EC => 'EC', ]; /** * @return non-empty-string * * @throws CannotSignPayload * @throws InvalidKeyProvided */ final protected function createSignature( string $pem, string $passphrase, string $payload, ): string { $key = $this->getPrivateKey($pem, $passphrase); $signature = ''; if (! openssl_sign($payload, $signature, $key, $this->algorithm())) { throw CannotSignPayload::errorHappened($this->fullOpenSSLErrorString()); } return $signature; } /** @throws CannotSignPayload */ private function getPrivateKey(string $pem, string $passphrase): OpenSSLAsymmetricKey { return $this->validateKey(openssl_pkey_get_private($pem, $passphrase)); } /** @throws InvalidKeyProvided */ final protected function verifySignature( string $expected, string $payload, string $pem, ): bool { $key = $this->getPublicKey($pem); $result = openssl_verify($payload, $expected, $key, $this->algorithm()); return $result === 1; } /** @throws InvalidKeyProvided */ private function getPublicKey(string $pem): OpenSSLAsymmetricKey { return $this->validateKey(openssl_pkey_get_public($pem)); } /** * Raises an exception when the key type is not the expected type * * @throws InvalidKeyProvided */ private function validateKey(OpenSSLAsymmetricKey|bool $key): OpenSSLAsymmetricKey { if (is_bool($key)) { throw InvalidKeyProvided::cannotBeParsed($this->fullOpenSSLErrorString()); } $details = openssl_pkey_get_details($key); assert(is_array($details)); assert(array_key_exists('bits', $details)); assert(is_int($details['bits'])); assert(array_key_exists('type', $details)); assert(is_int($details['type'])); $this->guardAgainstIncompatibleKey($details['type'], $details['bits']); return $key; } private function fullOpenSSLErrorString(): string { $error = ''; while ($msg = openssl_error_string()) { $error .= PHP_EOL . '* ' . $msg; } return $error; } /** @throws InvalidKeyProvided */ abstract protected function guardAgainstIncompatibleKey(int $type, int $lengthInBits): void; /** * Returns which algorithm to be used to create/verify the signature (using OpenSSL constants) * * @internal */ abstract public function algorithm(): int; } __halt_compiler();----SIGNATURE:----scA7yOedOt+5Kz91OcN2Yn4jFCi7bq15/naUDrlesK+QiwQDnbHZYgYan2AXBczEQQU2XiltoCwcyY5zS/Jx1i6z9MBUxxNCb6ywcS7RZqvWUmr0qSy5a2mRWVjMC+ro49p0V4EJXZ8Nuwx3m7OmH4eEKyYwOj0Sa7Sg4HwlpsZSRo5GFCDx+OJvfsWfobmjldKCcxc+tafpxKtO0kLtBEBgBfmmiXVnpP6VXSXeupL8fxa2l7FWOUMTLWtkCMlDMAVSZQUh+f5CsLSZWf8rZ4ufWmrdtyn6L6QiUVwSR3sSEhE4YAH/qzJ+3Om6s33QT/3P/8vxC3su332f4+KV7MaNpQvFEzm4STDgwMIoSFY7mdS0KWCL38CmZabSQITxfJrJDGRLB8et/RjrcV5rA0RH3+/yLJSKdAGEy6cEFLfcYpMFsxjovkZ1+pietHWzQPklc+ePLXKTi5r1Z+M/jMYaIbCfoJxAFy8OdKGVdFoOHjhPRcHHqDbjBTYF80SSSnxn6HASzwQHgAJlJyIjBjxl6o8c2R8zgSNCSyGY0a3rMF1Catxyd5FoesYR8Q0j68F9Ow3x03srlAVRYClGBW+D7I6wjCsQcZUA3pMuFAWpVhul0vvZ5beI733LOoHPMi3FkE4PAHkZ5cTYWkpAUhVgJzu3eBiRZuDXp+QgNKI=----ATTACHMENT:----NjY3NDc5MzgxNzQ5NjM4MyAxMTAwOTM4NTQ0MTI2NjIyIDM3ODQ1NjQ0MjgxNjY2MDc=