mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-03-13 01:30:11 +01:00
81 lines
2.5 KiB
PHP
81 lines
2.5 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(['message' => $e->getMessage(), 'errors' => $e->errors()], Response::HTTP_UNPROCESSABLE_ENTITY);
|
|
// }
|
|
//
|
|
// $credentials = $request->only(['username', 'password']);
|
|
//
|
|
// // TODO: Rivedere con Laravel 10
|
|
// 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([
|
|
// 'message' => __('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();
|
|
}
|
|
|
|
// /**
|
|
// * @return array{username: string, password: string, remember: string}
|
|
// */
|
|
// #[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',
|
|
// ];
|
|
// }
|
|
}
|