namespace MO_CAW\PRO\Functionality;
use MO_CAW\PRO\Utils;
use MO_CAW\Common\DB_Utils;
use MO_CAW\PRO\Constants;
use MO_CAW\Common\Functionality\MO_User as Common_MO_User;
class MO_User extends Common_MO_User
{
public static function does_user_has_license()
{
$ql = base64_encode("mo_caw_user_details");
$Wi = DB_Utils::get_option($ql, array());
$Fq = Utils::miniorange_encoder("mo_caw_customer_license_verified");
$zR = $Wi[$Fq] ?? false;
if (!$zR) {
goto Ur;
}
$zR = Utils::miniorange_decoder($zR);
Ur:
return "License verified" === $zR ? true : false;
}
public static function verify_and_store_license($A_)
{
$mn = self::check_customer_ln();
$tD = json_decode($mn, true);
if (!(json_last_error() === JSON_ERROR_NONE)) {
goto I7;
}
$mn = $tD;
I7:
if (is_array($mn) && isset($mn["status"]) && Constants::SUCCESS_STATUS === $mn["status"]) {
goto Aq;
}
return "You haven't upgraded to this plan yet.";
goto AF;
Aq:
$p9 = self::XfskodsfhHJ($A_);
$tD = json_decode($p9, true);
if (!(json_last_error() === JSON_ERROR_NONE)) {
goto Yc;
}
$p9 = $tD;
Yc:
if (is_array($p9) && isset($p9["status"]) && Constants::SUCCESS_STATUS === $p9["status"]) {
goto G_;
}
if (is_array($p9) && isset($p9["status"]) && strcasecmp($p9["status"], "FAILED") === 0) {
goto Mf;
}
return "An error occurred while processing your request. Please Try again.";
goto FM;
G_:
$ql = base64_encode("mo_caw_user_details");
$Wi = DB_Utils::get_option($ql, array());
$Fq = array("mo_caw_customer_license_verified", "mo_caw_customer_license_expiry");
$LD = array("License verified", $mn["licenseExpiry"]);
$gs = count($Fq);
$Nm = 0;
Ph:
if (!($Nm < $gs)) {
goto RM;
}
$Wi[Utils::miniorange_encoder($Fq[$Nm])] = Utils::miniorange_encoder($LD[$Nm]);
bg:
$Nm++;
goto Ph;
RM:
DB_Utils::update_option($ql, $Wi);
$tb = DB_Utils::get_option("mo_caw_user_display_details", array());
$tb["license_expiry"] = $mn["licenseExpiry"];
DB_Utils::update_option("mo_caw_user_display_details", $tb);
self::set_license_expiry();
return "License verification successful";
goto FM;
Mf:
if (strcasecmp($p9["message"], "Code has Expired") === 0) {
goto b1;
}
return "You have entered an invalid license key. Please enter a valid license key.";
goto AK;
b1:
return "Invalid license key. Please use an unused key or please contact apisupport@xecurify.com to purchase more.";
AK:
FM:
AF:
}
private static function check_customer_ln()
{
$K6 = Constants::HOST_NAME . Constants::CUSTOMER_LICENSE_API;
$ql = base64_encode("mo_caw_user_details");
$Wi = DB_Utils::get_option($ql, array());
$a8 = isset($Wi[Utils::miniorange_encoder("mo_caw_customer_id")]) ? Utils::miniorange_decoder($Wi[Utils::miniorange_encoder("mo_caw_customer_id")]) : '';
$jE = isset($Wi[Utils::miniorange_encoder("mo_caw_customer_api_key")]) ? Utils::miniorange_decoder($Wi[Utils::miniorange_encoder("mo_caw_customer_api_key")]) : '';
$P9 = self::get_timestamp();
$WB = $a8 . $P9 . $jE;
$Hn = hash("sha2", $WB);
$tc = '';
$tc = array("customerId" => $a8, "applicationName" => Constants::PLAN_NAME . "_plan");
$rU = wp_json_encode($tc);
$Ug = array("Content-Type" => Constants::JSON_HEADER_NAME);
$Ug["Customer-Key"] = $a8;
$Ug["Timestamp"] = $P9;
$Ug["Authorization"] = $Hn;
$PG = array("method" => \strtoupper(Constants::HTTP_POST), "body" => $rU, "timeout" => "20", "redirection" => "5", "httpversion" => "1.0", "blocking" => true, "headers" => $Ug);
$nm = wp_remote_post($K6, $PG);
if (!is_wp_error($nm)) {
goto OO;
}
$XG = $nm->get_error_message();
echo "Something went wrong: {$XG}";
exit;
OO:
return wp_remote_retrieve_body($nm);
}
private static function XfskodsfhHJ($Ha)
{
$K6 = Constants::HOST_NAME . Constants::BACKUP_CODE_VERIFY_API;
$ql = base64_encode("mo_caw_user_details");
$Wi = DB_Utils::get_option($ql, array());
$a8 = isset($Wi[Utils::miniorange_encoder("mo_caw_customer_id")]) ? Utils::miniorange_decoder($Wi[Utils::miniorange_encoder("mo_caw_customer_id")]) : '';
$jE = isset($Wi[Utils::miniorange_encoder("mo_caw_customer_api_key")]) ? Utils::miniorange_decoder($Wi[Utils::miniorange_encoder("mo_caw_customer_api_key")]) : '';
$P9 = self::get_timestamp();
$WB = $a8 . $P9 . $jE;
$Hn = hash("sha2", $WB);
$tc = '';
$tc = array("code" => $Ha, "customerKey" => $a8, "additionalFields" => array("field1" => site_url()));
$rU = wp_json_encode($tc);
$Ug = array("Content-Type" => Constants::JSON_HEADER_NAME);
$Ug["Customer-Key"] = $a8;
$Ug["Timestamp"] = $P9;
$Ug["Authorization"] = $Hn;
$PG = array("method" => \strtoupper(Constants::HTTP_POST), "body" => $rU, "timeout" => "20", "redirection" => "5", "httpversion" => "1.0", "blocking" => true, "headers" => $Ug);
$nm = wp_remote_post($K6, $PG);
if (!is_wp_error($nm)) {
goto g8;
}
$XG = $nm->get_error_message();
echo "Something went wrong: {$XG}";
exit;
g8:
return wp_remote_retrieve_body($nm);
}
public static function set_license_expiry()
{
$vE = self::check_customer_ln();
$vE = json_decode($vE, true);
if (!(isset($vE["licenseExpiry"]) && strtotime($vE["licenseExpiry"]))) {
goto jw;
}
$ql = base64_encode("mo_caw_user_details");
$Wi = DB_Utils::get_option($ql, array());
$nn = $vE["licenseExpiry"];
$yZ = false;
$SV = gmdate("Y-m-d H:i:s");
$yZ = $nn >= $SV ? "enabled" : Constants::DISABLED;
$Wi[Utils::miniorange_encoder("mo_caw_license_expiry_status")] = Utils::miniorange_encoder($yZ);
$Wi[Utils::miniorange_encoder("mo_caw_customer_license_expiry")] = Utils::miniorange_encoder($nn);
$Wi = DB_Utils::update_option($ql, $Wi);
$tb = DB_Utils::get_option("mo_caw_user_display_details", array());
$tb["license_expiry"] = $nn;
DB_Utils::update_option("mo_caw_user_display_details", $tb);
jw:
}
private static function get_timestamp()
{
$K6 = Constants::HOST_NAME . Constants::GET_TIMESTAMP_API;
return Utils::send_request_to_miniorange(array(), false, '', array(), false, $K6);
}
}
© 2023 Quttera Ltd. All rights reserved.