diff --git a/app/Http/Controllers/LoginController.php b/app/Http/Controllers/Auth/LoginController.php similarity index 96% rename from app/Http/Controllers/LoginController.php rename to app/Http/Controllers/Auth/LoginController.php index 07594b5..bf6d285 100644 --- a/app/Http/Controllers/LoginController.php +++ b/app/Http/Controllers/Auth/LoginController.php @@ -1,9 +1,10 @@ ['required', 'string', 'min:5', 'max:16', 'unique:account.account'], + 'email' => ['required', 'string', 'email', 'max:255', 'unique:account.account'], + 'password' => ['required', 'string', 'min:5', 'max:16'], + 'tac' => ['required'], + ]); + } + + /** + * Create a new user instance after a valid registration. + * + * @param array $data + * @return Account + */ + protected function create(array $data): Account + { + $account = new Account(); + $account->login = $data['login']; + $account->email = $data['email']; + $account->password = (new MySQLHasher)->make($data['password']); + $account->status = AccountStatusEnum::NOT_AVAILABLE; + $account->saveOrFail(); + + return $account; + } + + /** + * Show the application registration form. + * + * @return View + */ + public function showRegistrationForm(): View + { + return view('user/registration/register'); + } + + /** + * Handle a registration request for the application. + * + * @param Request $request + * @return RedirectResponse + * @throws ValidationException + */ + public function register(Request $request) + { + $this->validator($request->all())->validate(); + + event(new Registered($user = $this->create($request->all()))); + + Auth::guard()->login($user); + + return redirect('user/verification/notice'); + } +} diff --git a/app/Http/Controllers/Auth/VerificationController.php b/app/Http/Controllers/Auth/VerificationController.php new file mode 100644 index 0000000..a763c04 --- /dev/null +++ b/app/Http/Controllers/Auth/VerificationController.php @@ -0,0 +1,69 @@ +middleware('auth'); + $this->middleware('signed')->only('verify'); + $this->middleware('throttle:6,1')->only('verify', 'resend'); + } + + /** + * Show the email verification notice. + * + * @param Request $request + * @return RedirectResponse|View + */ + public function show(Request $request): View|RedirectResponse + { + return $request->user()->hasVerifiedEmail() + ? redirect($this->redirectPath()) + : view('user/registration/verification-notice'); + } + + /** + * The user has been verified. + * + * @param Request $request + * @return View + */ + protected function verified(Request $request): View + { + return view('user/registration/registration-success'); + } +} diff --git a/app/Models/Account.php b/app/Models/Account.php index 5a6ab7e..389ebe2 100644 --- a/app/Models/Account.php +++ b/app/Models/Account.php @@ -49,7 +49,6 @@ class Account extends User implements MustVerifyEmail */ protected $fillable = [ 'login', - 'password', 'email', ]; @@ -71,7 +70,6 @@ class Account extends User implements MustVerifyEmail */ protected $casts = [ 'email_verified_at' => 'datetime', - 'password' => 'hashed', 'status' => AccountStatusEnum::class ]; diff --git a/resources/views/layouts/app.blade.php b/resources/views/layouts/app.blade.php index 95ac4e1..35fe30f 100644 --- a/resources/views/layouts/app.blade.php +++ b/resources/views/layouts/app.blade.php @@ -226,7 +226,7 @@ function () { - @if (Auth::user()->status == \App\Models\Enums\AccountStatusEnum::OK) + @if (Auth::user()->hasVerifiedEmail())
diff --git a/resources/views/main/community/code-of-conduct.blade.php b/resources/views/main/community/code-of-conduct.blade.php index 1981cc1..0d3f759 100644 --- a/resources/views/main/community/code-of-conduct.blade.php +++ b/resources/views/main/community/code-of-conduct.blade.php @@ -10,7 +10,7 @@

Scopul acestui Ghid al Comunitatii este sa creeze un mediu placut ce va face sederea in aceasta comunitate plina de distractie, unica si sigura, incurajand utilizatorii sa se comporte intr-o maniera care promoveaza integritatea, decenta si respectul.

- Acest Ghid al Comunitatii va ajuta sa intelegeti ce inseamna sa faceti parte din comunitatea Metin2. Tineti minte ca prin folosirea platformelor Metin2 sunteti de acord cu Ghidul Comunitatii Metin2 si a termenilor & conditiilor.

+ Acest Ghid al Comunitatii va ajuta sa intelegeti ce inseamna sa faceti parte din comunitatea Metin2. Tineti minte ca prin folosirea platformelor Metin2 sunteti de acord cu Ghidul Comunitatii Metin2 si a termenilor & conditiilor.

Cateva lucruri de tinut minte atunci cand folositi platforma Metin2

diff --git a/resources/views/user/registration/registration-failed.blade.php b/resources/views/user/misc/registration-failed.blade.php similarity index 100% rename from resources/views/user/registration/registration-failed.blade.php rename to resources/views/user/misc/registration-failed.blade.php diff --git a/resources/views/user/registration/resendack.blade.php b/resources/views/user/misc/resendack.blade.php similarity index 100% rename from resources/views/user/registration/resendack.blade.php rename to resources/views/user/misc/resendack.blade.php diff --git a/resources/views/user/registration/register.blade.php b/resources/views/user/registration/register.blade.php index 5518a85..8102fa0 100644 --- a/resources/views/user/registration/register.blade.php +++ b/resources/views/user/registration/register.blade.php @@ -7,28 +7,19 @@

Înregistrarea

-
-
-
1
-

Înregistrare

-
-
-
2
-

Activează și descarcă

-
-
-
3
-

Instalează și joacă-te

-
-
+ + +

sau la autentificareCreează un cont

+ @csrf +
- +
@@ -81,7 +72,20 @@ Am citit Termenii și Condițiile și Declarația privind protecția datelor. *
+

* este necesar

diff --git a/resources/views/user/registration/registration-success.blade.php b/resources/views/user/registration/registration-success.blade.php new file mode 100644 index 0000000..6a9a5ae --- /dev/null +++ b/resources/views/user/registration/registration-success.blade.php @@ -0,0 +1,42 @@ +@extends('layouts.app') + +@section('content') + +
+
+
+
+

Contul tău

+ + + +
+
+
+
+

Ai fost înregistrat cu succes!

+
+ +
+

+ Contul tău este acum activat. Continuă prin a descărca jocul de mai jos. + Distracție plăcută! +

+
+ +

Descarcă jocul

+
+ + Descarcă
jocul acum +
+
+
+
+
+
+
+
+
+
 
+
+@endsection diff --git a/resources/views/user/registration/verification-notice.blade.php b/resources/views/user/registration/verification-notice.blade.php new file mode 100644 index 0000000..2361d10 --- /dev/null +++ b/resources/views/user/registration/verification-notice.blade.php @@ -0,0 +1,59 @@ +@extends('layouts.app') + +@section('content') + +
+
+
+
+

Contul tău

+ + + +
+
+
+
+

Activează-ți contul!

+
+
+

+ 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. +

+ +

Nu ai primit un e-mail?

+
+ + @if (session('resent')) +

Un nou e-mail de verificare a fost trimis!

+ @endif + +

+ Te rugăm să aștepți câteva minute pentru a primi e-mail-ul de activare. + Totodată, nu uita să verifici folderele Spam / Junk. În cazul în care + încă nu primești mesajul, poți solicita retrimiterea acestuia. + +

+ + + Retrimite mailul de activare + +

+
+

Descarcă jocul

+
+ + Descarcă
jocul acum +
+
+
+
+
+
+
+
+
+
 
+
+@endsection diff --git a/resources/views/user/registration/activation-pending.blade.php b/resources/views/user/registration/verification-verify.blade.php similarity index 100% rename from resources/views/user/registration/activation-pending.blade.php rename to resources/views/user/registration/verification-verify.blade.php diff --git a/routes/web.php b/routes/web.php index bba57d8..5bf3165 100644 --- a/routes/web.php +++ b/routes/web.php @@ -1,6 +1,8 @@ group(function() { # 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')); + Route::get('/register', [RegisterController::class, 'showRegistrationForm'])->middleware('guest'); + Route::post('/register', [RegisterController::class, 'register'])->middleware('guest'); + Route::get('/verification/notice', [VerificationController::class, 'show'])->name('verification.notice'); + Route::get('/verification/verify/{id}/{hash}', [VerificationController::class, 'verify'])->name('verification.verify'); + Route::get('/verification/resend', [VerificationController::class, 'resend'])->name('verification.resend'); # Authentication Route::middleware('guest')->group(function() { Route::get('/login', fn () => view('user/login'))->name('login'); Route::post('/login', [LoginController::class, 'login']); - // will autocomplete the username - Route::get('/login/{username}', fn ($username) => view('user/login')); }); Route::get('/logout', [LoginController::class, 'logout']); Route::get('/passwordlostrequest', fn () => view('user/passwordlostrequest')); Route::get('/passwordlost/{username}/{hash}', fn ($username, $hash) => view('user/passwordlost-expired')); + # User administration Route::middleware(['auth', 'verified'])->group(function() { Route::get('/administration', fn () => view('user/administration'));