Initial api service;

Clean code;
This commit is contained in:
c.girardi
2024-02-21 17:58:41 +01:00
parent cd9c380b58
commit f56a6e820c
7 changed files with 139 additions and 30 deletions

View File

@@ -0,0 +1,56 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
class AuthController extends Controller
{
public function __construct()
{
$this->middleware('auth:sanctum', ['only' => 'logout']);
}
/**
* @param Request $request
* @return \Illuminate\Http\JsonResponse
*/
public function login(Request $request)
{
$loginUserData = $request->validate([
'email' => 'required|string|email',
'password' => 'required|min:8'
]);
$user = User::where('email', $loginUserData['email'])->first();
if (!$user || !Hash::check($loginUserData['password'], $user->password)) {
return response()->json([
'message' => 'Invalid Credentials'
], 401);
}
$token = $user->createToken(
$user->name . '-AuthToken',
['*'],
(new \DateTime())->add(new \DateInterval('PT30M'))
)->plainTextToken;
return response()->json([
'access_token' => $token,
]);
}
/**
* @return \Illuminate\Http\JsonResponse
*/
public function logout()
{
auth()->user()->tokens()->delete();
return response()->json([
"message" => "logged out"
]);
}
}

View File

@@ -0,0 +1,42 @@
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Models\Word;
use Illuminate\Http\Request;
class WordsController extends Controller
{
public function __construct()
{
$this->middleware('auth:sanctum');
}
/**
* Display a listing of the resource.
*/
public function index()
{
$words = Word::all();
return response()->json([
'status' => true,
'words' => $words
]);
}
/**
* Display the specified resource.
*/
public function show(Word $word)
{
return response()->json([
'status' => true,
'words' => $word
]);
}
}

View File

@@ -2,6 +2,7 @@
namespace App\Http;
use App\Http\Middleware\ReturnJsonResponseMiddleware;
use Illuminate\Foundation\Http\Kernel as HttpKernel;
class Kernel extends HttpKernel
@@ -39,7 +40,8 @@ class Kernel extends HttpKernel
],
'api' => [
// \Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class,
\Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class,
ReturnJsonResponseMiddleware::class,
\Illuminate\Routing\Middleware\ThrottleRequests::class . ':api',
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],

View File

@@ -0,0 +1,21 @@
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class ReturnJsonResponseMiddleware
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
$request->headers->set('Accept', 'application/json');
return $next($request);
}
}