[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: SocialiteController.php
<?php namespace App\Http\Controllers\Auth; use App\Http\Controllers\Controller; use App\Models\Role; use Illuminate\Http\Request; use Laravel\Socialite\Facades\Socialite; use Illuminate\Support\Facades\Auth; use Exception; use App\User; class SocialiteController extends Controller { public function __construct() { $settings = getFeaturesSettings(); \Config::set('services.google.client_id', !empty($settings['google_client_id']) ? $settings['google_client_id'] : ''); \Config::set('services.google.client_secret', !empty($settings['google_client_secret']) ? $settings['google_client_secret'] : ''); \Config::set('services.google.redirect', url("/google/callback")); \Config::set('services.facebook.client_id', !empty($settings['facebook_client_id']) ? $settings['facebook_client_id'] : ''); \Config::set('services.facebook.client_secret', !empty($settings['facebook_client_secret']) ? $settings['facebook_client_secret'] : ''); \Config::set('services.facebook.redirect', url("/facebook/callback")); } /** * Create a new controller instance. * */ public function redirectToGoogle() { return Socialite::driver('google')->redirect(); } /** * Create a new controller instance. * * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector */ public function handleGoogleCallback(Request $request) { try { $account = Socialite::driver('google')->user(); $user = User::query()->where(function ($query) use ($account) { $query->where('google_id', $account->id) ->orWhere('email', $account->email); })->first(); if (empty($user)) { $user = User::create([ 'full_name' => $account->name, 'email' => $account->email, 'google_id' => $account->id, 'role_id' => Role::getUserRoleId(), 'role_name' => Role::$user, 'status' => User::$active, 'verified' => false, 'created_at' => time(), 'password' => null ]); } else { $checkLoginDeviceLimit = $this->checkLoginDeviceLimit($user); if ($checkLoginDeviceLimit != "ok") { Auth::logout(); $request->session()->flush(); $request->session()->regenerate(); return $this->sendMaximumActiveSessionResponse(); } } $user->update([ 'google_id' => $account->id, ]); Auth::loginUsingId($user->id); $loginController = (new LoginController()); return $loginController->afterLogged($request, true); } catch (Exception $e) { $toastData = [ 'title' => trans('public.request_failed'), 'msg' => trans('auth.fail_login_by_google'), 'status' => 'error' ]; return back()->with(['toast' => $toastData]); } } /** * Create a redirect method to facebook api. * */ public function redirectToFacebook() { return Socialite::driver('facebook')->redirect(); } /** * Return a callback method from facebook api. * * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector */ public function handleFacebookCallback(Request $request) { try { $account = Socialite::driver('facebook')->user(); $user = User::query()->where('facebook_id', $account->id)->first(); if (empty($user)) { $user = User::create([ 'full_name' => $account->name, 'email' => $account->email, 'facebook_id' => $account->id, 'role_id' => Role::getUserRoleId(), 'role_name' => Role::$user, 'status' => User::$active, 'verified' => false, 'created_at' => time(), 'password' => null ]); } else { $checkLoginDeviceLimit = $this->checkLoginDeviceLimit($user); if ($checkLoginDeviceLimit != "ok") { Auth::logout(); $request->session()->flush(); $request->session()->regenerate(); return $this->sendMaximumActiveSessionResponse(); } } Auth::loginUsingId($user->id); $loginController = (new LoginController()); return $loginController->afterLogged($request, true); } catch (Exception $e) { $toastData = [ 'title' => trans('public.request_failed'), 'msg' => trans('auth.fail_login_by_facebook'), 'status' => 'error' ]; return back()->with(['toast' => $toastData]); } } private function checkLoginDeviceLimit($user) { $securitySettings = getGeneralSecuritySettings(); if (!empty($securitySettings) and !empty($securitySettings['login_device_limit'])) { $limitCount = !empty($securitySettings['number_of_allowed_devices']) ? $securitySettings['number_of_allowed_devices'] : 1; $count = $user->logged_count; if ($count >= $limitCount) { return "no"; } } return 'ok'; } protected function sendMaximumActiveSessionResponse() { $toastData = [ 'title' => trans('update.login_failed'), 'msg' => trans('update.device_limit_reached_please_try_again'), 'status' => 'error' ]; return redirect('/login')->with(['login_failed_active_session' => $toastData]); } }
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: premium320.web-hosting.com
Server IP: 66.29.153.54
PHP Version: 8.2.29
Server Software: LiteSpeed
System: Linux premium320.web-hosting.com 4.18.0-553.50.1.lve.el8.x86_64 #1 SMP Thu Apr 17 19:10:24 UTC 2025 x86_64
HDD Total: 97.87 GB
HDD Free: 76.85 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
No
git:
Yes
User Info
Username: aoneqssk
User ID (UID): 1285
Group ID (GID): 1290
Script Owner UID: 1285
Current Dir Owner: 1285