1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-02-24 15:27:43 +01:00
openstamanager/app/Http/Controllers/AuthController.php
Maicol Battistini 2fd591d583
fix(auth): 🐛 Ricordami non funzionante
Invece di vederlo come booleano, trattalo come una stringa
2021-12-30 17:11:44 +01:00

77 lines
2.2 KiB
PHP

<?php
namespace App\Http\Controllers;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Illuminate\Validation\ValidationException;
use JetBrains\PhpStorm\ArrayShape;
class AuthController extends Controller
{
/**
* Handle an authentication attempt.
*/
public function login(Request $request): JsonResponse|Response
{
try {
$request->validate($this->rules($request));
} catch (ValidationException $e) {
return response()->json(['errors' => $e->errors()], 422);
}
$credentials = $request->only(['username', 'password']);
if (filter_var($request->get('username'), FILTER_VALIDATE_EMAIL)) {
$credentials['email'] = $credentials['username'];
unset($credentials['username']);
}
if (auth()->attempt($credentials, $request->get('remember') === 'on')) {
$request->session()->regenerate();
if ($request->hasSession()) {
$request->session()->put('auth.password_confirmed_at', time());
}
return response()->noContent();
}
return response()->json([
'errors' => ['invalid_credentials' => __('Le credenziali non sono valide.')],
], Response::HTTP_BAD_REQUEST);
}
/**
* Log the user out of the application.
*
* @noinspection RepetitiveMethodCallsInspection
*/
public function logout(Request $request): Response
{
auth()->logout();
$request->session()->invalidate();
$request->session()->regenerateToken();
return response()->noContent();
}
#[ArrayShape(['username' => 'string', 'password' => 'string', 'remember' => 'string'])]
private function rules(Request $request): array
{
$additional_validation = '';
$db_field = 'username';
if (filter_var($request->input('username'), FILTER_VALIDATE_EMAIL)) {
$additional_validation = '|email';
$db_field = 'email';
}
return [
'username' => "required|string|exists:users,$db_field|$additional_validation",
'password' => 'required|string',
'remember' => 'string|in:on',
];
}
}