Files
UNIT3D-Community-Edition/app/Http/Controllers/Auth/LoginController.php
2020-04-14 20:38:48 -04:00

132 lines
4.1 KiB
PHP

<?php
/**
* NOTICE OF LICENSE.
*
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D Community Edition
*
* @author HDVinnie <hdinnovations@protonmail.com>
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
*/
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Models\Group;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Http\Request;
class LoginController extends Controller
{
use AuthenticatesUsers;
// Upon Successful Login
protected $redirectTo = '/';
// Max Attempts Until Lockout
public $maxAttempts = 3;
// Minutes Lockout
public $decayMinutes = 60;
/**
* LoginController Constructor.
*/
public function __construct()
{
$this->middleware('guest', ['except' => 'logout']);
}
public function username()
{
return 'username';
}
/**
* Validate The User Login Request.
*
* @param \Illuminate\Http\Request $request
*
* @throws \Illuminate\Validation\ValidationException
*/
protected function validateLogin(Request $request)
{
if (config('captcha.enabled') == true) {
$this->validate($request, [
$this->username() => 'required|string',
'password' => 'required|string',
'captcha' => 'hiddencaptcha',
]);
} else {
$this->validate($request, [
$this->username() => 'required|string',
'password' => 'required|string',
]);
}
}
protected function authenticated(Request $request, $user)
{
$banned_group = cache()->rememberForever('banned_group', fn() => Group::where('slug', '=', 'banned')->pluck('id'));
$validating_group = cache()->rememberForever('validating_group', fn() => Group::where('slug', '=', 'validating')->pluck('id'));
$disabled_group = cache()->rememberForever('disabled_group', fn() => Group::where('slug', '=', 'disabled')->pluck('id'));
$member_group = cache()->rememberForever('member_group', fn() => Group::where('slug', '=', 'user')->pluck('id'));
if ($user->active == 0 || $user->group_id == $validating_group[0]) {
$this->guard()->logout();
$request->session()->invalidate();
return redirect()->route('login')
->withErrors(trans('auth.not-activated'));
}
if ($user->group_id == $banned_group[0]) {
$this->guard()->logout();
$request->session()->invalidate();
return redirect()->route('login')
->withErrors(trans('auth.banned'));
}
if ($user->group_id == $disabled_group[0]) {
$user->group_id = $member_group[0];
$user->can_upload = 1;
$user->can_download = 1;
$user->can_comment = 1;
$user->can_invite = 1;
$user->can_request = 1;
$user->can_chat = 1;
$user->disabled_at = null;
$user->save();
return redirect()->route('home.index')
->withSuccess(trans('auth.welcome-restore'));
}
if (auth()->viaRemember() && $user->group_id == $disabled_group[0]) {
$user->group_id = $member_group[0];
$user->can_upload = 1;
$user->can_download = 1;
$user->can_comment = 1;
$user->can_invite = 1;
$user->can_request = 1;
$user->can_chat = 1;
$user->disabled_at = null;
$user->save();
return redirect()->route('home.index')
->withSuccess(trans('auth.welcome-restore'));
}
if ($user->read_rules == 0) {
return redirect()->to(config('other.rules_url'))
->withWarning(trans('auth.require-rules'));
}
return redirect()->route('home.index')
->withSuccess(trans('auth.welcome'));
}
}