Added blocking, started e-mail validation, fixed locale strings
This commit is contained in:
parent
c26d8e4642
commit
7de2a637c4
@ -16,8 +16,8 @@ class LoginController extends Controller
|
|||||||
public function login(Request $request): RedirectResponse
|
public function login(Request $request): RedirectResponse
|
||||||
{
|
{
|
||||||
$validator = Validator::make($request->all(), [
|
$validator = Validator::make($request->all(), [
|
||||||
'login' => ['required'],
|
'login' => 'required|string',
|
||||||
'password' => ['required'],
|
'password' => 'required|string',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
if ($validator->fails())
|
if ($validator->fails())
|
||||||
@ -25,21 +25,38 @@ public function login(Request $request): RedirectResponse
|
|||||||
|
|
||||||
$credentials = $validator->validated();
|
$credentials = $validator->validated();
|
||||||
|
|
||||||
if (Auth::attempt($credentials)) {
|
// Validate the credentials
|
||||||
|
if (!Auth::once($credentials)) {
|
||||||
|
return redirect('user/login')->withErrors([
|
||||||
|
'login' => 'The provided credentials do not match our records.',
|
||||||
|
])->onlyInput('login');
|
||||||
|
}
|
||||||
|
|
||||||
|
// The user is now available
|
||||||
|
$user = Auth::user();
|
||||||
|
|
||||||
|
// Check if the user is banned
|
||||||
|
if ($user->status->isBlocked()) {
|
||||||
|
Auth::logout();
|
||||||
|
|
||||||
|
$request->session()->invalidate();
|
||||||
|
|
||||||
|
return redirect('user/login')->withErrors([
|
||||||
|
'login' => 'Your account is blocked.',
|
||||||
|
])->onlyInput('login');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Authenticate user
|
||||||
|
Auth::login($user);
|
||||||
$request->session()->regenerate();
|
$request->session()->regenerate();
|
||||||
|
|
||||||
$user = Auth::user();
|
// Save user's IP address
|
||||||
$user->ip = $request->ip();
|
$user->ip = $request->ip();
|
||||||
$user->saveOrFail();
|
$user->saveOrFail();
|
||||||
|
|
||||||
return redirect()->intended('user/administration');
|
return redirect()->intended('user/administration');
|
||||||
}
|
}
|
||||||
|
|
||||||
return redirect('user/login')->withErrors([
|
|
||||||
'login' => 'The provided credentials do not match our records.',
|
|
||||||
])->onlyInput('login');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Log the user out of the application.
|
* Log the user out of the application.
|
||||||
|
@ -21,7 +21,7 @@ public function handle(Request $request, Closure $next, string ...$guards): Resp
|
|||||||
|
|
||||||
foreach ($guards as $guard) {
|
foreach ($guards as $guard) {
|
||||||
if (Auth::guard($guard)->check()) {
|
if (Auth::guard($guard)->check()) {
|
||||||
return redirect(RouteServiceProvider::HOME);
|
return redirect('user/administration');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,13 +2,15 @@
|
|||||||
|
|
||||||
namespace App\Models;
|
namespace App\Models;
|
||||||
|
|
||||||
// use Illuminate\Contracts\Auth\MustVerifyEmail;
|
use App\Models\Enums\AccountStatusEnum;
|
||||||
|
use Illuminate\Auth\Notifications\VerifyEmail;
|
||||||
|
use Illuminate\Contracts\Auth\MustVerifyEmail;
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
use Illuminate\Foundation\Auth\User;
|
use Illuminate\Foundation\Auth\User;
|
||||||
use Illuminate\Notifications\Notifiable;
|
use Illuminate\Notifications\Notifiable;
|
||||||
use Laravel\Sanctum\HasApiTokens;
|
use Laravel\Sanctum\HasApiTokens;
|
||||||
|
|
||||||
class Account extends User
|
class Account extends User implements MustVerifyEmail
|
||||||
{
|
{
|
||||||
use HasApiTokens, HasFactory, Notifiable;
|
use HasApiTokens, HasFactory, Notifiable;
|
||||||
|
|
||||||
@ -26,9 +28,20 @@ class Account extends User
|
|||||||
*/
|
*/
|
||||||
protected $table = 'account';
|
protected $table = 'account';
|
||||||
|
|
||||||
const UPDATED_AT = null;
|
/**
|
||||||
|
* The name of the "created at" column.
|
||||||
|
*
|
||||||
|
* @var string|null
|
||||||
|
*/
|
||||||
const CREATED_AT = 'create_time';
|
const CREATED_AT = 'create_time';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The name of the "updated at" column.
|
||||||
|
*
|
||||||
|
* @var string|null
|
||||||
|
*/
|
||||||
|
const UPDATED_AT = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The attributes that are mass assignable.
|
* The attributes that are mass assignable.
|
||||||
*
|
*
|
||||||
@ -59,5 +72,48 @@ class Account extends User
|
|||||||
protected $casts = [
|
protected $casts = [
|
||||||
'email_verified_at' => 'datetime',
|
'email_verified_at' => 'datetime',
|
||||||
'password' => 'hashed',
|
'password' => 'hashed',
|
||||||
|
'status' => AccountStatusEnum::class
|
||||||
];
|
];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine if the user has verified their email address.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function hasVerifiedEmail(): bool
|
||||||
|
{
|
||||||
|
return $this->status != AccountStatusEnum::NOT_AVAILABLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mark the given user's email as verified.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function markEmailAsVerified(): bool
|
||||||
|
{
|
||||||
|
return $this->forceFill([
|
||||||
|
'status' => AccountStatusEnum::OK,
|
||||||
|
])->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send the email verification notification.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function sendEmailVerificationNotification(): void
|
||||||
|
{
|
||||||
|
$this->notify(new VerifyEmail);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the email address that should be used for verification.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getEmailForVerification(): string
|
||||||
|
{
|
||||||
|
return $this->email;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
22
app/Models/Enums/AccountStatusEnum.php
Normal file
22
app/Models/Enums/AccountStatusEnum.php
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models\Enums;
|
||||||
|
|
||||||
|
enum AccountStatusEnum: string
|
||||||
|
{
|
||||||
|
case OK = 'OK';
|
||||||
|
case REPAIR = 'REPAIR';
|
||||||
|
case BLOCK = 'BLOCK';
|
||||||
|
case NOT_AVAILABLE = 'NOTAVAIL';
|
||||||
|
case BILLING_EXPIRED = 'NOBILL';
|
||||||
|
case BLOCK_LOGIN = 'BLKLOGIN';
|
||||||
|
case WEB_BLOCK = 'WEBBLK';
|
||||||
|
|
||||||
|
public function isBlocked(): bool
|
||||||
|
{
|
||||||
|
return match($this) {
|
||||||
|
self::BLOCK, self::BILLING_EXPIRED, self::BLOCK_LOGIN, self::WEB_BLOCK => true,
|
||||||
|
default => false,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
18
resources/views/components/registration/progress.blade.php
Normal file
18
resources/views/components/registration/progress.blade.php
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<div id="progressTracker">
|
||||||
|
@php($progressTexts = [
|
||||||
|
1 => 'Înregistrare',
|
||||||
|
2 => 'Activează și descarcă',
|
||||||
|
3 => 'Instalează și joacă-te',
|
||||||
|
])
|
||||||
|
|
||||||
|
@for ($i = 1; $i <= 3; $i++)
|
||||||
|
<div id="progress{{ $i }}" @class([
|
||||||
|
'inactive' => $step < $i,
|
||||||
|
'active' => $step == $i,
|
||||||
|
'passed' => $step > $i,
|
||||||
|
])>
|
||||||
|
<div class="step">{{ $i }}</div>
|
||||||
|
<p class="progress-text">{{ $progressTexts[$i] }}</p>
|
||||||
|
</div>
|
||||||
|
@endfor
|
||||||
|
</div>
|
@ -206,6 +206,16 @@ function () {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="boxes-middle"></div>
|
||||||
|
|
||||||
|
<div class="modul-box modul-box-2">
|
||||||
|
<div class="modul-box-bg">
|
||||||
|
<div class="modul-box-bg-bottom">
|
||||||
|
<h3>Descărcare</h3>
|
||||||
|
<a href="{{ url('main/download') }}" class="btn download-btn"></a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
@else
|
@else
|
||||||
<div class="modul-box modul-box-2">
|
<div class="modul-box modul-box-2">
|
||||||
<div class="modul-box-bg">
|
<div class="modul-box-bg">
|
||||||
@ -216,7 +226,8 @@ function () {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="boxes-middle"> </div>
|
@if (Auth::user()->status == \App\Models\Enums\AccountStatusEnum::OK)
|
||||||
|
<div class="boxes-middle"></div>
|
||||||
<div class="modul-box modul-box-2">
|
<div class="modul-box modul-box-2">
|
||||||
<div class="modul-box-bg">
|
<div class="modul-box-bg">
|
||||||
<div class="modul-box-bg-bottom">
|
<div class="modul-box-bg-bottom">
|
||||||
@ -225,18 +236,7 @@ function () {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@endguest
|
@endif
|
||||||
|
|
||||||
@guest
|
|
||||||
<div class="boxes-middle"> </div>
|
|
||||||
<div class="modul-box modul-box-2">
|
|
||||||
<div class="modul-box-bg">
|
|
||||||
<div class="modul-box-bg-bottom">
|
|
||||||
<h3>Descărcare</h3>
|
|
||||||
<a href="{{ url('main/download') }}" class="btn download-btn"></a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
@endguest
|
@endguest
|
||||||
|
|
||||||
{{--
|
{{--
|
||||||
@ -251,7 +251,7 @@ function () {
|
|||||||
</div>
|
</div>
|
||||||
--}}
|
--}}
|
||||||
|
|
||||||
<div class="boxes-middle"> </div>
|
<div class="boxes-middle"></div>
|
||||||
<div class="modul-box modul-box-2">
|
<div class="modul-box modul-box-2">
|
||||||
<div class="modul-box-bg">
|
<div class="modul-box-bg">
|
||||||
<div class="modul-box-bg-bottom">
|
<div class="modul-box-bg-bottom">
|
||||||
@ -261,74 +261,8 @@ function () {
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<?php /* <div class="boxes-middle"> </div>
|
|
||||||
|
|
||||||
<div class="modul-box modul-box-2">
|
|
||||||
<div class="modul-box-bg">
|
|
||||||
<div class="modul-box-bg-bottom">
|
|
||||||
<h3>Jucatori</h3>
|
|
||||||
<form action="#">
|
|
||||||
<div class="form-score">
|
|
||||||
<ul id="highscore">
|
|
||||||
<?php
|
|
||||||
$result = mysqli_query($con, "SELECT * FROM `player`.`player` WHERE `name` NOT LIKE '[%]%' ORDER BY `level` DESC, `exp` DESC LIMIT 0, 10");
|
|
||||||
$rank = 1;
|
|
||||||
$i = 1;
|
|
||||||
while($row = mysqli_fetch_array($result)) {
|
|
||||||
if ($i == 0) {
|
|
||||||
$i = 1;
|
|
||||||
echo "<li class=\"light\">";
|
|
||||||
} else {
|
|
||||||
$i = 0;
|
|
||||||
echo "<li>";
|
|
||||||
}
|
|
||||||
|
|
||||||
echo '<strong>' . $rank . '</strong> - <a href="?s=highscore" class="first">' . $row['name'] .'</a></li>';
|
|
||||||
$rank++;
|
|
||||||
}
|
|
||||||
?>
|
|
||||||
</ul>
|
|
||||||
<a href="?s=highscore" class="btn">Tot Clasamentul</a>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="boxes-middle"></div>
|
|
||||||
<div class="modul-box modul-box-2">
|
|
||||||
<div class="modul-box-bg">
|
|
||||||
<div class="modul-box-bg-bottom">
|
|
||||||
<h3>Bresle</h3>
|
|
||||||
<form action="#">
|
|
||||||
<div class="form-score">
|
|
||||||
<ul id="guild">
|
|
||||||
<?php
|
|
||||||
$result = mysqli_query($con, "SELECT * FROM player.guild WHERE name NOT LIKE '[%]%' ORDER BY level desc, exp desc LIMIT 0, 10");
|
|
||||||
$rank = 1;
|
|
||||||
$i = 1;
|
|
||||||
while($row = mysqli_fetch_array($result)) {
|
|
||||||
if ($i == 0) {
|
|
||||||
$i = 1;
|
|
||||||
echo "<li class=\"light\">";
|
|
||||||
} else {
|
|
||||||
$i = 0;
|
|
||||||
echo "<li>";
|
|
||||||
}
|
|
||||||
|
|
||||||
echo '<strong>' . $rank . '</strong> - <a href="?s=guild" class="first">' . $row['name'] . '</a></li>';
|
|
||||||
|
|
||||||
$rank++;
|
|
||||||
}
|
|
||||||
?>
|
|
||||||
</ul>
|
|
||||||
<a href="?s=guild&search=search&empirechoice=-1&classchoice=-1&characterchoice=" class="btn">Tot Clasamentul</a>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="boxes-bottom"></div> */ ?>
|
|
||||||
<div class="boxes-middle"> </div>
|
<div class="boxes-middle"> </div>
|
||||||
|
|
||||||
<div class="modul-box modul-box-2">
|
<div class="modul-box modul-box-2">
|
||||||
<div class="modul-box-bg">
|
<div class="modul-box-bg">
|
||||||
<div class="modul-box-bg-bottom">
|
<div class="modul-box-bg-bottom">
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
<img src="{{ asset('img/tutorial/1_4.jpg') }}" width="480" height="360" alt="" />
|
<img src="{{ asset('img/tutorial/1_4.jpg') }}" width="480" height="360" alt="" />
|
||||||
<p class="pager">4/ 4</p>
|
<p class="pager">4/ 4</p>
|
||||||
<p class="txt">Exista 4 clase diferite in joc, fiecare cu caracteristici individuale.<br />
|
<p class="txt">Exista 4 clase diferite in joc, fiecare cu caracteristici individuale.<br />
|
||||||
Poti sa te folosesti de sageti pentru a alege clasa. Cand caracterul tau este afisat in fata, poti folosi linkul din cutie (cu verde marcat) pentru a schimba aspectul caracterului prin alegerea intre 1 si 2. Intr-un final caracterul tau are nevoie de un nume. Dupa ce ai ales numele apasa pe " Creaza " pentru a da viata caracterului. Acum poti apasa pe Start pentru a intra in joc.</p>
|
Poti sa te folosesti de sageti pentru a alege clasa. Cand caracterul tau este afisat in fata, poti folosi linkul din cutie (cu verde marcat) pentru a schimba aspectul caracterului prin alegerea intre 1 si 2. Intr-un final caracterul tau are nevoie de un nume. Dupa ce ai ales numele apasa pe " Creeaza " pentru a da viata caracterului. Acum poti apasa pe Start pentru a intra in joc.</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -40,7 +40,7 @@
|
|||||||
<div id="subscribe">
|
<div id="subscribe">
|
||||||
<h3>Încă nu ai cont?</h3>
|
<h3>Încă nu ai cont?</h3>
|
||||||
<p>Crearea unui jucător (cont) este rapidă, usoară și gratis.</p>
|
<p>Crearea unui jucător (cont) este rapidă, usoară și gratis.</p>
|
||||||
<a class="btn-big" href="{{ url('user/register') }}" title="Crează un cont">Crează un cont</a>
|
<a class="btn-big" href="{{ url('user/register') }}" title="Creează un cont">Creează un cont</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -0,0 +1,45 @@
|
|||||||
|
@extends('layouts.app')
|
||||||
|
|
||||||
|
@section('content')
|
||||||
|
<!-- center column -->
|
||||||
|
<div class="col-2" id="authenticated">
|
||||||
|
<div class="content content-last">
|
||||||
|
<div class="content-bg">
|
||||||
|
<div class="content-bg-bottom">
|
||||||
|
<h2>Contul tău</h2>
|
||||||
|
|
||||||
|
<x-registration.progress :step="2" />
|
||||||
|
|
||||||
|
<div class="pass-lost-inner-content">
|
||||||
|
<div class="input-data-box">
|
||||||
|
<div id="activateAccount" class="inner-form-border">
|
||||||
|
<div class="inner-form-box clearfix">
|
||||||
|
<h3>Activează-ți contul!</h3>
|
||||||
|
<div class="trenner"></div>
|
||||||
|
<div id="activateBox">
|
||||||
|
<p>
|
||||||
|
Pentru finalizarea înregistrării tale, trebuie să îți verificăm adresa
|
||||||
|
de e-mail. Accesează-ți căsuța de e-mail și urmează link-ul din mesaj pentru activare.
|
||||||
|
</p>
|
||||||
|
<p id="resendNormal">
|
||||||
|
<a href="{{ url('user/resendack') }}">
|
||||||
|
Nu ai primit un e-mail? Retrimite mailul de activare
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<h3>Descarcă jocul</h3>
|
||||||
|
<div class="trenner"></div>
|
||||||
|
<a href="{{ url('main/download') }}" id="bigDownload">
|
||||||
|
Descarcă<br/>jocul acum
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="box-foot"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="shadow"> </div>
|
||||||
|
</div>
|
||||||
|
@endsection
|
@ -23,7 +23,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="inner-form-border">
|
<div class="inner-form-border">
|
||||||
<div class="inner-form-box">
|
<div class="inner-form-box">
|
||||||
<h3><a id="toLogin" href="{{ url('user/login') }}" title="sau la autentificare">sau la autentificare</a>Crează un cont</h3>
|
<h3><a id="toLogin" href="{{ url('user/login') }}" title="sau la autentificare">sau la autentificare</a>Creează un cont</h3>
|
||||||
<div class="trenner"></div>
|
<div class="trenner"></div>
|
||||||
<form name="registerForm" id="registerForm" method="post" action="{{ url('user/register') }}">
|
<form name="registerForm" id="registerForm" method="post" action="{{ url('user/register') }}">
|
||||||
<div>
|
<div>
|
@ -49,18 +49,24 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
Route::prefix('user')->group(function() {
|
Route::prefix('user')->group(function() {
|
||||||
Route::get('/register', fn () => view('user/register'));
|
# Registration
|
||||||
|
Route::get('/register', fn () => view('user/registration/register'))->middleware('guest');
|
||||||
|
Route::get('/activate', fn () => view('user/registration/activation-pending'))->name('verification.notice');
|
||||||
|
Route::get('/resendack', fn () => view('user/registration/resendack'));
|
||||||
|
|
||||||
|
# Authentication
|
||||||
|
Route::middleware('guest')->group(function() {
|
||||||
Route::get('/login', fn () => view('user/login'))->name('login');
|
Route::get('/login', fn () => view('user/login'))->name('login');
|
||||||
Route::post('/login', [LoginController::class, 'login']);
|
Route::post('/login', [LoginController::class, 'login']);
|
||||||
// will autocomplete the username
|
// will autocomplete the username
|
||||||
Route::get('/login/{username}', fn ($username) => view('user/login'));
|
Route::get('/login/{username}', fn ($username) => view('user/login'));
|
||||||
|
});
|
||||||
Route::get('/logout', [LoginController::class, 'logout']);
|
Route::get('/logout', [LoginController::class, 'logout']);
|
||||||
|
|
||||||
Route::get('/passwordlostrequest', fn () => view('user/passwordlostrequest'));
|
Route::get('/passwordlostrequest', fn () => view('user/passwordlostrequest'));
|
||||||
Route::get('/passwordlost/{username}/{hash}', fn ($username, $hash) => view('user/passwordlost-expired'));
|
Route::get('/passwordlost/{username}/{hash}', fn ($username, $hash) => view('user/passwordlost-expired'));
|
||||||
Route::get('/resendack', fn () => view('user/resendack'));
|
|
||||||
|
|
||||||
Route::middleware('auth')->group(function() {
|
Route::middleware(['auth', 'verified'])->group(function() {
|
||||||
Route::get('/administration', fn () => view('user/administration'));
|
Route::get('/administration', fn () => view('user/administration'));
|
||||||
|
|
||||||
Route::get('/characters', fn () => view('user/characters'));
|
Route::get('/characters', fn () => view('user/characters'));
|
||||||
|
Loading…
Reference in New Issue
Block a user