Your IP : 216.73.216.93


Current Path : /home/users/unlimited/www/facebook.codeskitter.site/xhr/
Upload File :
Current File : /home/users/unlimited/www/facebook.codeskitter.site/xhr/login.php

<?php
if ($f == 'login') {
    $sessionUserId = null;
    if (!empty($_SESSION['user_id'])) {
        $sessionUserId = $_SESSION['user_id'];
        $_SESSION['user_id'] = '';
        unset($_SESSION['user_id']);
    }
    if (!empty($_COOKIE['user_id'])) {
        $sessionUserId =$_COOKIE['user_id'];
        $_COOKIE['user_id'] = '';
        unset($_COOKIE['user_id']);
        setcookie('user_id', '', -1);
        setcookie('user_id', '', -1, '/');
    }
    $data_ = array();
    $phone = 0;
    if (isset($_POST['username']) && isset($_POST['password'])) {
        if ($wo['config']['prevent_system'] == 1) {
            if (!WoCanLogin()) {
                $errors[] = $error_icon . $wo['lang']['login_attempts'];
                header("Content-type: application/json");
                echo json_encode(array(
                    'errors' => $errors
                ));
                exit();
            }
        }
        $username = Wo_Secure($_POST['username']);
        $password = $_POST['password'];

        $result   = Wo_Login($username, $password);
        if ($result === false) {
            $errors[] = $error_icon . $wo['lang']['incorrect_username_or_password_label'];
            if ($wo['config']['prevent_system'] == 1) {
                WoAddBadLoginLog();
            }
        } else if (Wo_UserInactive($_POST['username']) === true) {
            $errors[] = $error_icon . $wo['lang']['account_disbaled_contanct_admin_label'];
        } else if (Wo_VerfiyIP($_POST['username']) === false) {
            $_SESSION['code_id'] = Wo_UserIdForLogin($username);
            $two_factor_hash = bin2hex(random_bytes(18));
            $db->where('user_id',$_SESSION['code_id'])->update(T_USERS,array('two_factor_hash' => $two_factor_hash));
            cache($_SESSION['code_id'], 'users', 'delete');
            $user_data = Wo_UserData($_SESSION['code_id']);
            setcookie("two_factor_method", $user_data['two_factor_method'], time() + (60 * 60), "/");
            setcookie("two_factor_username", $user_data['username'], time() + (60 * 60), "/");
            $_SESSION['two_factor_hash'] = $two_factor_hash;
            setcookie("two_factor_hash", $two_factor_hash, time() + (60 * 60));
            $_SESSION['code_id'] = Wo_UserIdForLogin($username);
            $data_               = array(
                'status' => 600,
                'location' => Wo_SeoLink('index.php?link1=unusual-login')
            );
            $phone               = 1;
        } else if (Wo_TwoFactor($_POST['username']) === false) {
            $_SESSION['code_id'] = Wo_UserIdForLogin($username);
            $two_factor_hash = bin2hex(random_bytes(18));
            $db->where('user_id',$_SESSION['code_id'])->update(T_USERS,array('two_factor_hash' => $two_factor_hash));
            cache($_SESSION['code_id'], 'users', 'delete');
            $user_data = Wo_UserData($_SESSION['code_id']);
            setcookie("two_factor_method", $user_data['two_factor_method'], time() + (60 * 60), "/");
            setcookie("two_factor_username", $user_data['username'], time() + (60 * 60), "/");
            $_SESSION['two_factor_hash'] = $two_factor_hash;
            setcookie("two_factor_hash", $two_factor_hash, time() + (60 * 60));
            $data_               = array(
                'status' => 600,
                'location' => $wo['config']['site_url'] . '/unusual-login?type=two-factor'
            );
            $phone               = 1;
        } else if (Wo_UserActive($_POST['username']) === false) {
            $_SESSION['code_id'] = Wo_UserIdForLogin($username);
            $data_               = array(
                'status' => 600,
                'location' => Wo_SeoLink('index.php?link1=user-activation')
            );
            $phone               = 1;
        }
        if (empty($errors) && $phone == 0) {
            if ($wo['loggedin'] == true && $username !== $wo['user']['name']) {
                $user_id             = Wo_UserIdForLogin($username);
                $add = true;
                if (!empty($wo['switched_accounts'])) {
                    foreach ($wo['switched_accounts'] as $key => $value) {
                        if ($value['user_id'] == $wo['user']['user_id']) {
                            $add = false;
                        }
                        if ($user_id == $value['user_id']) {
                            unset($wo['switched_accounts'][$key]);
                        }
                    }
                }
                if ($add == true) {
                    $session_user = '';
                    if ($sessionUserId) {
                        $session_user = $sessionUserId;
                    }
                    if ($sessionUserId) {
                        $session_user = $sessionUserId;
                    }
                    $info = array('email' => $wo['user']['email'],
                        'name'  => $wo['user']['name'],
                        'avatar' => $wo['user']['avatar'],
                        'session' => $session_user,
                        'user_id' => $wo['user']['user_id']);
                    $wo['switched_accounts'][] = $info;
                    setcookie("switched_accounts", json_encode($wo['switched_accounts']), time() + (10 * 365 * 24 * 60 * 60));
                }
                session_unset();
                $_SESSION['user_id'] = '';
                session_destroy();
                $_SESSION = array();
                unset($_SESSION);
                if(isset($_COOKIE['user_id'])) {
                $_COOKIE['user_id'] = '';
                unset($_COOKIE['user_id']);
                setcookie('user_id', '', -1);
                setcookie('user_id', '', -1,'/');
                }
            }
            $userid              = Wo_UserIdForLogin($username);
            $ip                  = Wo_Secure(get_ip_address());
            $update              = mysqli_query($sqlConnect, "UPDATE " . T_USERS . " SET `ip_address` = '{$ip}' WHERE `user_id` = '{$userid}'");
            cache($userid, 'users', 'delete');
            $session             = Wo_CreateLoginSession(Wo_UserIdForLogin($username));
            $_SESSION['user_id'] = $session;
            Wo_DeleteBadLogins();
            if ($wo['config']['remember_device'] == 1 && !empty($_POST['remember_device']) && $_POST['remember_device'] == 'on') {
                setcookie("user_id", $session, time() + (10 * 365 * 24 * 60 * 60));
            }
            setcookie('ad-con', htmlentities(json_encode(array(
                'date' => date('Y-m-d'),
                'ads' => array()
            ))), time() + (10 * 365 * 24 * 60 * 60));
            $data = array(
                'status' => 200
            );
            if (!empty($_POST['last_url'])) {
                $data['location'] = $_POST['last_url'];
            } else {
                $data['location'] = $wo['config']['site_url'] . "/?cache=" . time();
            }
            $user_data = Wo_UserData($userid);
            if ($wo['config']['membership_system'] == 1 && $user_data['is_pro'] == 0) {
                $data['location'] = Wo_SeoLink('index.php?link1=go-pro');
            }
        }
    }
    header("Content-type: application/json");
    if (!empty($errors)) {
        echo json_encode(array(
            'errors' => $errors
        ));
    } else if (!empty($data_)) {
        echo json_encode($data_);
    } else {

        echo json_encode($data);
    }
    exit();
}