2021-05-25 09:55:58 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
if (!is_callable('sodium_crypto_stream_xchacha20')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::crypto_stream_xchacha20()
|
|
|
|
* @param int $len
|
|
|
|
* @param string $nonce
|
|
|
|
* @param string $key
|
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
* @throws TypeError
|
|
|
|
*/
|
2024-07-18 09:00:16 -04:00
|
|
|
function sodium_crypto_stream_xchacha20(
|
|
|
|
$len,
|
|
|
|
$nonce,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$key
|
|
|
|
) {
|
2021-05-25 09:55:58 -04:00
|
|
|
return ParagonIE_Sodium_Compat::crypto_stream_xchacha20($len, $nonce, $key, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_stream_xchacha20_keygen')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::crypto_stream_xchacha20_keygen()
|
|
|
|
* @return string
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
function sodium_crypto_stream_xchacha20_keygen()
|
|
|
|
{
|
|
|
|
return ParagonIE_Sodium_Compat::crypto_stream_xchacha20_keygen();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_stream_xchacha20_xor')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::crypto_stream_xchacha20_xor()
|
|
|
|
* @param string $message
|
|
|
|
* @param string $nonce
|
|
|
|
* @param string $key
|
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
* @throws TypeError
|
|
|
|
*/
|
2024-07-18 09:00:16 -04:00
|
|
|
function sodium_crypto_stream_xchacha20_xor(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$message,
|
|
|
|
$nonce,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$key
|
|
|
|
) {
|
2021-05-25 09:55:58 -04:00
|
|
|
return ParagonIE_Sodium_Compat::crypto_stream_xchacha20_xor($message, $nonce, $key, true);
|
|
|
|
}
|
|
|
|
}
|
2022-09-13 20:13:14 -04:00
|
|
|
if (!is_callable('sodium_crypto_stream_xchacha20_xor_ic')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::crypto_stream_xchacha20_xor_ic()
|
|
|
|
* @param string $message
|
|
|
|
* @param string $nonce
|
|
|
|
* @param int $counter
|
|
|
|
* @param string $key
|
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
* @throws TypeError
|
|
|
|
*/
|
2024-07-18 09:00:16 -04:00
|
|
|
function sodium_crypto_stream_xchacha20_xor_ic(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$message,
|
|
|
|
$nonce,
|
|
|
|
$counter,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$key
|
|
|
|
) {
|
2022-09-13 20:13:14 -04:00
|
|
|
return ParagonIE_Sodium_Compat::crypto_stream_xchacha20_xor_ic($message, $nonce, $counter, $key, true);
|
|
|
|
}
|
|
|
|
}
|