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);
}
}

View File

@@ -46,7 +46,7 @@ return [
|
*/
'expiration' => null,
'expiration' => 10,
/*
|--------------------------------------------------------------------------

View File

@@ -1,5 +1,6 @@
<?php
use App\Http\Controllers\Api\AuthController;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Route;
@@ -17,3 +18,9 @@ use Illuminate\Support\Facades\Route;
Route::middleware('auth:sanctum')->get('/user', function (Request $request) {
return $request->user();
});
Route::post('login', [AuthController::class, 'login']);
Route::post('logout',[AuthController::class,'logout']);
Route::apiResource('words', \App\Http\Controllers\Api\WordsController::class);

View File

@@ -26,36 +26,17 @@ Route::get('/', function () {
return redirect('words');
});
Route::prefix('test')->group(function () {
Route::get('/{name?}', function (?string $name = null) {
return $name ?? 'niente';
})->whereAlpha('name');
Route::get('/{number}', function (int $number = null) {
return $number;
})->whereNumber('number');
});
Route::get('/pippo', function (Request $request) {
return response()->json([
'name' => 'Abigail',
'state' => 'CA',
]);
});
Route::get('/dashboard', function () {
return view('dashboard');
})->middleware(['auth', 'verified'])->name('dashboard');
Route::middleware('auth')->group(function () {
Route::get('/profile', [ProfileController::class, 'edit'])->name('profile.edit');
Route::patch('/profile', [ProfileController::class, 'update'])->name('profile.update');
Route::delete('/profile', [ProfileController::class, 'destroy'])->name('profile.destroy');
});
//Route::get('/dashboard', function () {
// return view('dashboard');
//})->middleware(['auth', 'verified'])->name('dashboard');
//
//Route::middleware('auth')->group(function () {
// Route::get('/profile', [ProfileController::class, 'edit'])->name('profile.edit');
// Route::patch('/profile', [ProfileController::class, 'update'])->name('profile.update');
// Route::delete('/profile', [ProfileController::class, 'destroy'])->name('profile.destroy');
//});
Route::prefix('words')->group(function () {
Route::get('/', [WordsController::class, 'index'])->name('words.index');