HEX
Server: LiteSpeed
System: Linux cpir1.prohostdns.com 4.18.0-553.123.2.lve.el8.x86_64 #1 SMP Thu May 7 23:17:13 UTC 2026 x86_64
User: pelakir (2976)
PHP: 8.2.31
Disabled: exec, shell_exec, system, passthru, proc_open, proc_close, proc_terminate, proc_get_status, popen, pclose, pcntl_exec
Upload Files
File: /home/pelakir/public_html/wp-content/plugins/digits/includes/plugins/bp.php
<?php

if (!defined('ABSPATH')) {
    exit;
}

add_action('bp_signup_pre_validate', 'dig_bp_signup_pre_validate', 20);
function dig_bp_signup_pre_validate()
{
    if (!dig_bp_show_phone_signup()) {
        return;
    }

    global $bp;

    $countrycode = sanitize_text_field($_POST['digt_countrycode']);
    $mobile = sanitize_mobile_field_dig($_POST['mobile_email']);
    $otp = sanitize_text_field($_POST['digit_ac_otp']);
    $csrf = sanitize_text_field($_POST['csrf']);

    $validateMob = dig_validateMobileNumber($countrycode, $mobile, $otp, $csrf, 2, $_POST['code'], true);

    if ($validateMob['success'] === false) {
        $bp->signup->errors['signup_mobile'] = $validateMob['msg'];
    }


}

function dig_bp_add_user_meta($user_id, $user_login, $user_password, $user_email, $usermeta)
{
    if (!dig_bp_show_phone_signup()) {
        return;
    }
    if (!is_wp_error($user_id)) {
        $countrycode = sanitize_text_field($_POST['digt_countrycode']);
        $mobile = sanitize_text_field($_POST['mobile_email']);
        update_user_meta($user_id, 'digt_countrycode', $countrycode);
        update_user_meta($user_id, 'digits_phone_no', $mobile);
        update_user_meta($user_id, 'digits_phone', $countrycode . $mobile);
    }
}

add_action('bp_core_signup_user', 'dig_bp_add_user_meta', 10, 5);

function dig_bp_validation_error()
{
    if (!dig_bp_show_phone_signup()) {
        return;
    }
    global $bp;

    if (!isset($bp->signup->errors['signup_mobile'])) {
        return;
    }
    echo '<div class="error">' . $bp->signup->errors['signup_mobile'] . '</div>';
}

add_action('bp_account_details_fields', 'dig_bp_show_mobile_number');

function dig_bp_show_mobile_number()
{
    if (!dig_bp_show_phone_signup()) {
        return;
    }

    ?>
    <div>
        <label for="username"><?php _e('Mobile Number', 'digits'); ?><?php _e('(required)', 'buddypress'); ?></label>
        <input type="text" name="username" id="username" value="" mob="1" />
    </div>
    <?php dig_bp_validation_error(); ?>


    <?php
}


add_action('bp_account_details_fields', 'dig_otp_bp_reg', 1000);
function dig_otp_bp_reg()
{
    if (!dig_bp_show_phone_signup()) {
        return;
    }

    // Prevent caching of forms with nonces
    if (!defined('DONOTCACHEPAGE')) {
        define('DONOTCACHEPAGE', true);
    }

    ?>

    <input type="hidden" name="dig_nounce" class="dig_nounce" value="<?php echo wp_create_nonce('dig_form') ?>">
    <div id="dig_bp_reg_otp">
        <label for="digit_ac_otp"><?php _e("OTP", "digits"); ?> <span class="required">*</span></label>
        <input type="text" class="input-text" name="digit_ac_otp" id="digit_ac_otp" />
    </div>
    <?php


    //echo "<div class=\"dig_bp_enb\" style='display:none;'>";

}


function dig_createUser($name, $mobileormail, $csrf, $code)
{

}

//add_action('bp_account_details_fields','dig_bp_reg_end',1);
function dig_bp_reg_end()
{
    //echo "</div>";
}

add_action('bp_before_registration_submit_buttons', 'dig_bp_sub_reg', 1);
function dig_bp_sub_reg()
{
    if (!dig_bp_show_phone_signup()) {
        return;
    }
    ?>


    <input type="hidden" name="code" id="dig_bp_reg_code">
    <input type="hidden" name="csrf" id="dig_bp_reg_csrf">

    <?php
}


add_action('bp_after_registration_submit_buttons', 'dig_bp_reg_end', 1);


add_action('bp_core_general_settings_before_submit', 'dig_bp_addCurrentmobHidden');
function dig_bp_addCurrentmobHidden()
{
    // Prevent caching of forms with nonces
    if (!defined('DONOTCACHEPAGE')) {
        define('DONOTCACHEPAGE', true);
    }

    ?>

    <label><?php _e("Mobile Number", "digits"); ?></label>
    <input type="text" name="bp_edit_user_mobile" id="username" mob="1" f-mob="1"
        countryCode="<?php echo esc_attr(get_the_author_meta('digt_countrycode', get_current_user_id())); ?>"
        value="<?php echo esc_attr(get_the_author_meta('digits_phone_no', get_current_user_id())); ?>" />


    <input type="hidden" name="dig_nounce" class="dig_nounce" value="<?php echo wp_create_nonce('dig_form') ?>">
    <input type="hidden" name="code" id="dig_bp_ea_code" />
    <input type="hidden" name="csrf" id="dig_bp_ea_csrf" />
    <?php if (is_super_admin()): ?>
        <input type="hidden" id="dig_superadmin">
    <?php endif; ?>
    <input type="hidden" name="current_mob" id="dig_bp_current_mob"
        value="<?php echo esc_attr(get_the_author_meta('digits_phone_no', get_current_user_id())); ?>" />

    <div id="bp_otp_dig_ea" style="display: none;"><label for="digit_ac_otp"><?php _e("OTP", "digits"); ?> <span
                class="required">*</span></label>
        <input type="text" class="input-text" name="digit_ac_otp" id="digit_ac_otp" />
    </div>
    <?php
}

add_action('bp_core_general_settings_after_submit', 'add_dig_otp_bp');
function add_dig_otp_bp()
{


    echo "<div  class=\"dig_resendotp dig_bp_ac_ea_resend\" id=\"dig_man_resend_otp_btn\" style='text-align: inherit;' dis='1'>" . __('Resend OTP', 'digits') . " <span>(00:<span>" . dig_getOtpTime() . "</span>)</span></div>";

}


add_action('bp_actions', 'dig_bp_settings_action_general');
function dig_bp_settings_action_general()
{

    if (isset($_POST['mobile_email']) && isset($_POST['dig_nounce']) && is_user_logged_in()) {
        $phone = sanitize_mobile_field_dig($_POST['mobile_email']);
        $countrycode = sanitize_text_field($_POST['digt_countrycode']);


        if (empty($phone) || !is_numeric($phone)) {
            return;
        }

        $otp = sanitize_text_field($_POST['digit_ac_otp']);

        if (!is_super_admin()) {
            if (empty($otp)) {
                return;
            }
            if (verifyOTP($countrycode, $phone, $otp, true)) {

                $mob = $countrycode . $phone;
            } else {

                return;
            }

        }

        if (!empty($mob)) {
            $user = getUserFromPhone($mob);
            if ($phone != 0 && $user == null) {
                update_user_meta(get_current_user_id(), 'digt_countrycode', $countrycode);
                update_user_meta(get_current_user_id(), 'digits_phone_no', $phone);
                update_user_meta(get_current_user_id(), 'digits_phone', $countrycode . $phone);
            }
        }
    }
}

function dig_bp_show_phone_signup()
{
    $dig_reg_details = digit_get_reg_fields();
    $reg_mobilenumber = $dig_reg_details['dig_reg_mobilenumber'];
    return $reg_mobilenumber > 0;
}