b374k
m1n1 1.01
Apache/2.4.41 (Ubuntu)
Linux vmi616275.contaboserver.net 5.4.0-84-generic #94-Ubuntu SMP Thu Aug 26 20:27:37 UTC 2021 x86_64
uid=33(www-data) gid=33(www-data) groups=33(www-data)
server ip : 62.171.164.128 | your ip : 127.0.0.1
safemode OFF
 >  / home / dev2.destoffenstraat.com / vendor / magento / framework / Encryption / Adapter /
Filename/home/dev2.destoffenstraat.com/vendor/magento/framework/Encryption/Adapter/SodiumChachaIetf.php
Size1.68 kb
Permissionrw-r--r--
Ownerroot : root
Create time17-Aug-2025 10:26
Last modified07-Jan-2021 21:08
Last accessed22-Aug-2025 12:45
Actionsedit | rename | delete | download (gzip)
Viewtext | code | image
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/

declare(strict_types=1);

namespace Magento\Framework\Encryption\Adapter;

/**
* Sodium adapter for encrypting and decrypting strings
*/
class SodiumChachaIetf implements EncryptionAdapterInterface
{
/**
* @var string
*/
private $key;

/**
* Sodium constructor.
* @param string $key
*/
public function __construct(
string $key
) {
$this->key = $key;
}

/**
* Encrypt a string
*
* @param string $data
* @return string string
* @throws \SodiumException
*/
public function encrypt(string $data): string
{
$nonce = random_bytes(SODIUM_CRYPTO_AEAD_CHACHA20POLY1305_IETF_NPUBBYTES);
$cipherText = sodium_crypto_aead_chacha20poly1305_ietf_encrypt(
(string)$data,
$nonce,
$nonce,
$this->key
);

return $nonce . $cipherText;
}

/**
* Decrypt a string
*
* @param string $data
* @return string
*/
public function decrypt(string $data): string
{
$nonce = mb_substr($data, 0, SODIUM_CRYPTO_AEAD_CHACHA20POLY1305_IETF_NPUBBYTES, '8bit');
$payload = mb_substr($data, SODIUM_CRYPTO_AEAD_CHACHA20POLY1305_IETF_NPUBBYTES, null, '8bit');

try {
$plainText = sodium_crypto_aead_chacha20poly1305_ietf_decrypt(
$payload,
$nonce,
$nonce,
$this->key
);
} catch (\SodiumException $e) {
$plainText = '';
}

return $plainText !== false ? $plainText : '';
}
}