| Server IP : 103.191.208.88 / Your IP : 216.73.216.44 Web Server : Microsoft-IIS/10.0 System : Windows NT COSMIC 10.0 build 20348 (Windows Server 2022) AMD64 User : IWPD_1831(willswel_) ( 0) PHP Version : 8.2.31 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : D:/Inetpub/vhosts/willswell.com/httpdocs/wp-content/plugins/fluentform/app/Helpers/ |
Upload File : |
<?php
namespace FluentForm\App\Helpers;
class Protector
{
/**
* Get the salt for the encryption and decryption.
*/
public static function getSalt()
{
$salt = get_option('_fluentform_security_salt');
if (!$salt) {
$salt = wp_generate_password();
update_option('_fluentform_security_salt', $salt, 'no');
}
return $salt;
}
/**
* Encryp a text using a predefined salt.
*
* @param string $text
*
* @return string $text
*/
public static function encrypt($text)
{
$key = static::getSalt();
$cipher = 'AES-128-CBC';
$ivlen = openssl_cipher_iv_length($cipher);
$iv = openssl_random_pseudo_bytes($ivlen);
$ciphertext_raw = openssl_encrypt($text, $cipher, $key, $options = OPENSSL_RAW_DATA, $iv);
$hmac = hash_hmac('sha256', $iv . $ciphertext_raw, $key, $as_binary = true);
return base64_encode($iv . $hmac . $ciphertext_raw);
}
/**
* Decrypt a text using a predefined salt.
*
* @param string $text
*
* @return string $text
*/
public static function decrypt($text)
{
$key = static::getSalt();
$c = base64_decode($text, true);
$cipher = 'AES-128-CBC';
$ivlen = openssl_cipher_iv_length($cipher);
$sha2len = 32;
if ($c === false || strlen($c) < $ivlen + $sha2len) {
return null;
}
$iv = substr($c, 0, $ivlen);
$hmac = substr($c, $ivlen, $sha2len);
$ciphertext_raw = substr($c, $ivlen + $sha2len);
// Verify with current HMAC (IV + ciphertext)
$calcmac = hash_hmac('sha256', $iv . $ciphertext_raw, $key, $as_binary = true);
if (!hash_equals($hmac, $calcmac)) {
// Fallback: verify with legacy HMAC (ciphertext only) for tokens generated before v6.2.0 IV authentication fix.
if (!apply_filters('fluentform/allow_legacy_token_decrypt', false)) {
return null;
}
$legacymac = hash_hmac('sha256', $ciphertext_raw, $key, $as_binary = true);
if (!hash_equals($hmac, $legacymac)) {
return null;
}
}
$original_plaintext = openssl_decrypt($ciphertext_raw, $cipher, $key, $options = OPENSSL_RAW_DATA, $iv);
return $original_plaintext !== false ? $original_plaintext : null;
}
}