HEX
Server: LiteSpeed
System: Linux d8 4.18.0-553.30.1.lve.el8.x86_64 #1 SMP Tue Dec 3 01:21:19 UTC 2024 x86_64
User: wbwebdes (3015)
PHP: 8.1.31
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/wbwebdes/domains/support.wb-webdesign.com/public_html/verify_registration.php
<?php
/**
 *
 * This file is part of HESK - PHP Help Desk Software.
 *
 * (c) Copyright Klemen Stirn. All rights reserved.
 * https://www.hesk.com
 *
 * For the full copyright and license agreement information visit
 * https://www.hesk.com/eula.php
 *
 */

define('IN_SCRIPT',1);
define('HESK_PATH','./');
define('HESK_NO_ROBOTS',1);

/* Get all the required files and functions */
require(HESK_PATH . 'hesk_settings.inc.php');
define('TEMPLATE_PATH', HESK_PATH . "theme/{$hesk_settings['site_theme']}/");
require(HESK_PATH . 'inc/common.inc.php');
require(HESK_PATH . 'inc/customer_accounts.inc.php');

// Are customer accounts enabled?
if (!$hesk_settings['customer_accounts']) {
    header('Location: index.php');
    exit();
}

// Are we in maintenance mode?
hesk_check_maintenance();

hesk_load_database_functions();
hesk_session_start('CUSTOMER');

hesk_dbConnect();

// If we don't have both an email *and* a verification token, don't attempt to do anything
if (!isset($_GET['email']) || !isset($_GET['verificationToken'])) {
    header('Location: index.php');
    exit();
}
$email = $_GET['email'];
$verificationToken = $_GET['verificationToken'];

$verification_result = hesk_verify_customer_account($email, $verificationToken);
$verification_type = 'NEW';

if (!$verification_result && $hesk_settings['customer_accounts_allow_email_changes']) {
    // Maybe they're changing their email?
    $verification_result = hesk_verify_email_change_request($email, $verificationToken);
    $verification_type = 'EMAIL UPDATE';
}

if (!$verification_result) {
    hesk_process_messages($hesklang['customer_registration_verify_failure'], 'NOREDIRECT');
    $hesk_settings['render_template'](TEMPLATE_PATH . 'customer/account/verify-registration.php', [
        'messages' => hesk_get_messages()
    ]);
    return;
}

hesk_merge_customer_accounts($email);


if ($hesk_settings['customer_accounts_admin_approvals'] && $verification_type === 'NEW') {
    hesk_mark_account_needing_approval($email);

    // Notify staff members?
    // Don't send an email every time, only when we reach a treshold number of pending approvals
    $notify_treshold = array(
        1, 5, 10, 50, 100, 500, 1000
    );
    $res = hesk_dbQuery("SELECT COUNT(*) FROM `".hesk_dbEscape($hesk_settings['db_pfix'])."customers` WHERE `verified` = 2");
    $num = hesk_dbResult($res);
    if (in_array($num, $notify_treshold)) {
        require(HESK_PATH . 'inc/email_functions.inc.php');
        hesk_notifyStaffOfPendingApprovals($num);
    }

    hesk_process_messages($hesklang['customer_registration_verify_approval_needed'],
        'NOREDIRECT',
        'NOTICE');
    $hesk_settings['render_template'](TEMPLATE_PATH . 'customer/account/verify-registration.php', [
        'messages' => hesk_get_messages()
    ]);
} else {
    $_SESSION['login_email'] = $email;
    $message = $verification_type === 'NEW' ?
        $hesklang['customer_registration_verify_success'] :
        $hesklang['customer_change_email_verify_success'];
    hesk_process_messages($message, 'login.php', 'SUCCESS');
}