mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-07 00:48:55 +01:00
f0b4b44d1e
The latest version of sodium_compat includes support for AEGIS and preliminary support for PHP 8.4. Additionally, the PHP 8.2+ `SensitiveParameter` attribute is now applied where appropriate to functions in the public API. This attribute is used to mark parameters that are sensitive and should be redacted from stack traces. References: * [https://github.com/paragonie/sodium_compat/releases/tag/v1.21.0 sodium_compat 1.21.0 release notes] * [https://github.com/paragonie/sodium_compat/releases/tag/v1.21.1 sodium_compat 1.21.1 release notes] * [https://github.com/paragonie/sodium_compat/compare/v1.20.0...v1.21.1 Full list of changes in sodium_compat 1.21.1] Follow-up to [49741], [51002], [51591], [52988], [54150], [54310], [55699]. Props jrf, dd32, paragoninitiativeenterprises. Fixes #61686. Built from https://develop.svn.wordpress.org/trunk@58752 git-svn-id: http://core.svn.wordpress.org/trunk@58154 1a063a9b-81f0-0310-95a4-ce76da25c4cd
277 lines
7.8 KiB
PHP
277 lines
7.8 KiB
PHP
<?php
|
|
|
|
if (!defined('SODIUM_CRYPTO_CORE_RISTRETTO255_BYTES')) {
|
|
define(
|
|
'SODIUM_CRYPTO_CORE_RISTRETTO255_BYTES',
|
|
ParagonIE_Sodium_Compat::CRYPTO_CORE_RISTRETTO255_BYTES
|
|
);
|
|
define('SODIUM_COMPAT_POLYFILLED_RISTRETTO255', true);
|
|
}
|
|
if (!defined('SODIUM_CRYPTO_CORE_RISTRETTO255_HASHBYTES')) {
|
|
define(
|
|
'SODIUM_CRYPTO_CORE_RISTRETTO255_HASHBYTES',
|
|
ParagonIE_Sodium_Compat::CRYPTO_CORE_RISTRETTO255_HASHBYTES
|
|
);
|
|
}
|
|
if (!defined('SODIUM_CRYPTO_CORE_RISTRETTO255_SCALARBYTES')) {
|
|
define(
|
|
'SODIUM_CRYPTO_CORE_RISTRETTO255_SCALARBYTES',
|
|
ParagonIE_Sodium_Compat::CRYPTO_CORE_RISTRETTO255_SCALARBYTES
|
|
);
|
|
}
|
|
if (!defined('SODIUM_CRYPTO_CORE_RISTRETTO255_NONREDUCEDSCALARBYTES')) {
|
|
define(
|
|
'SODIUM_CRYPTO_CORE_RISTRETTO255_NONREDUCEDSCALARBYTES',
|
|
ParagonIE_Sodium_Compat::CRYPTO_CORE_RISTRETTO255_NONREDUCEDSCALARBYTES
|
|
);
|
|
}
|
|
if (!defined('SODIUM_CRYPTO_SCALARMULT_RISTRETTO255_SCALARBYTES')) {
|
|
define(
|
|
'SODIUM_CRYPTO_SCALARMULT_RISTRETTO255_SCALARBYTES',
|
|
ParagonIE_Sodium_Compat::CRYPTO_SCALARMULT_RISTRETTO255_SCALARBYTES
|
|
);
|
|
}
|
|
if (!defined('SODIUM_CRYPTO_SCALARMULT_RISTRETTO255_BYTES')) {
|
|
define(
|
|
'SODIUM_CRYPTO_SCALARMULT_RISTRETTO255_BYTES',
|
|
ParagonIE_Sodium_Compat::CRYPTO_SCALARMULT_RISTRETTO255_BYTES
|
|
);
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_core_ristretto255_add')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_add()
|
|
*
|
|
* @param string $p
|
|
* @param string $q
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_add(
|
|
#[\SensitiveParameter]
|
|
$p,
|
|
#[\SensitiveParameter]
|
|
$q
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_add($p, $q, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_from_hash')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_from_hash()
|
|
*
|
|
* @param string $s
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_from_hash(
|
|
#[\SensitiveParameter]
|
|
$s
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_from_hash($s, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_is_valid_point')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_is_valid_point()
|
|
*
|
|
* @param string $s
|
|
* @return bool
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_is_valid_point(
|
|
#[\SensitiveParameter]
|
|
$s
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_is_valid_point($s, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_random')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_random()
|
|
*
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_random()
|
|
{
|
|
return ParagonIE_Sodium_Compat::ristretto255_random(true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_add')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_add()
|
|
*
|
|
* @param string $x
|
|
* @param string $y
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_add(
|
|
#[\SensitiveParameter]
|
|
$x,
|
|
#[\SensitiveParameter]
|
|
$y
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_add($x, $y, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_complement')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_complement()
|
|
*
|
|
* @param string $s
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_complement(
|
|
#[\SensitiveParameter]
|
|
$s
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_complement($s, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_invert')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_invert()
|
|
*
|
|
* @param string $p
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_invert(
|
|
#[\SensitiveParameter]
|
|
$p
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_invert($p, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_mul')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_mul()
|
|
*
|
|
* @param string $x
|
|
* @param string $y
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_mul(
|
|
#[\SensitiveParameter]
|
|
$x,
|
|
#[\SensitiveParameter]
|
|
$y
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_mul($x, $y, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_negate')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_negate()
|
|
*
|
|
* @param string $s
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_negate(
|
|
#[\SensitiveParameter]
|
|
$s
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_negate($s, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_random')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_random()
|
|
*
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_random()
|
|
{
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_random(true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_reduce')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_reduce()
|
|
*
|
|
* @param string $s
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_reduce(
|
|
#[\SensitiveParameter]
|
|
$s
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_reduce($s, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_sub')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_sub()
|
|
*
|
|
* @param string $x
|
|
* @param string $y
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_scalar_sub(
|
|
#[\SensitiveParameter]
|
|
$x,
|
|
#[\SensitiveParameter]
|
|
$y
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_sub($x, $y, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_core_ristretto255_sub')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_sub()
|
|
*
|
|
* @param string $p
|
|
* @param string $q
|
|
* @return string
|
|
* @throws SodiumException
|
|
*/
|
|
function sodium_crypto_core_ristretto255_sub(
|
|
#[\SensitiveParameter]
|
|
$p,
|
|
#[\SensitiveParameter]
|
|
$q
|
|
) {
|
|
return ParagonIE_Sodium_Compat::ristretto255_sub($p, $q, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_scalarmult_ristretto255')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::crypto_scalarmult_ristretto255()
|
|
* @param string $n
|
|
* @param string $p
|
|
* @return string
|
|
* @throws SodiumException
|
|
* @throws TypeError
|
|
*/
|
|
function sodium_crypto_scalarmult_ristretto255(
|
|
#[\SensitiveParameter]
|
|
$n,
|
|
#[\SensitiveParameter]
|
|
$p
|
|
) {
|
|
return ParagonIE_Sodium_Compat::scalarmult_ristretto255($n, $p, true);
|
|
}
|
|
}
|
|
if (!is_callable('sodium_crypto_scalarmult_ristretto255_base')) {
|
|
/**
|
|
* @see ParagonIE_Sodium_Compat::crypto_scalarmult_ristretto255_base()
|
|
* @param string $n
|
|
* @return string
|
|
* @throws SodiumException
|
|
* @throws TypeError
|
|
*/
|
|
function sodium_crypto_scalarmult_ristretto255_base(
|
|
#[\SensitiveParameter]
|
|
$n
|
|
) {
|
|
return ParagonIE_Sodium_Compat::scalarmult_ristretto255_base($n, true);
|
|
}
|
|
} |