2021-05-25 15:55:58 +02:00
|
|
|
<?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
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_add(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$p,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$q
|
|
|
|
) {
|
2021-05-25 15:55:58 +02:00
|
|
|
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()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $s
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_from_hash(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$s
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_from_hash($s, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_core_ristretto255_is_valid_point')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_is_valid_point()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $s
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return bool
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_is_valid_point(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$s
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_is_valid_point($s, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
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()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $x
|
|
|
|
* @param string $y
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_scalar_add(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$x,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$y
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_add($x, $y, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_complement')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_complement()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $s
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_scalar_complement(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$s
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_complement($s, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_invert')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_invert()
|
|
|
|
*
|
|
|
|
* @param string $p
|
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_scalar_invert(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$p
|
|
|
|
) {
|
2021-05-25 15:55:58 +02:00
|
|
|
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()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $x
|
|
|
|
* @param string $y
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_scalar_mul(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$x,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$y
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_mul($x, $y, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_negate')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_negate()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $s
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_scalar_negate(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$s
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_negate($s, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
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()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $s
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_scalar_reduce(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$s
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_reduce($s, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_core_ristretto255_scalar_sub')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_scalar_sub()
|
|
|
|
*
|
2022-09-26 16:00:10 +02:00
|
|
|
* @param string $x
|
|
|
|
* @param string $y
|
2021-05-25 15:55:58 +02:00
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_scalar_sub(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$x,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$y
|
|
|
|
) {
|
2022-09-26 16:00:10 +02:00
|
|
|
return ParagonIE_Sodium_Compat::ristretto255_scalar_sub($x, $y, true);
|
2021-05-25 15:55:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!is_callable('sodium_crypto_core_ristretto255_sub')) {
|
|
|
|
/**
|
|
|
|
* @see ParagonIE_Sodium_Compat::ristretto255_sub()
|
|
|
|
*
|
|
|
|
* @param string $p
|
|
|
|
* @param string $q
|
|
|
|
* @return string
|
|
|
|
* @throws SodiumException
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_core_ristretto255_sub(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$p,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$q
|
|
|
|
) {
|
2021-05-25 15:55:58 +02:00
|
|
|
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
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_scalarmult_ristretto255(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$n,
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$p
|
|
|
|
) {
|
2021-05-25 15:55:58 +02:00
|
|
|
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
|
|
|
|
*/
|
2024-07-18 15:00:16 +02:00
|
|
|
function sodium_crypto_scalarmult_ristretto255_base(
|
|
|
|
#[\SensitiveParameter]
|
|
|
|
$n
|
|
|
|
) {
|
2021-05-25 15:55:58 +02:00
|
|
|
return ParagonIE_Sodium_Compat::scalarmult_ristretto255_base($n, true);
|
|
|
|
}
|
|
|
|
}
|