Initial commit
This commit is contained in:
84
laravel/app/Http/Controllers/Api/V1/TaskController.php
Normal file
84
laravel/app/Http/Controllers/Api/V1/TaskController.php
Normal file
@@ -0,0 +1,84 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use App\Events\TaskCreated;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Http\Requests\StoreTaskRequest;
|
||||
use App\Http\Requests\UpdateTaskRequest;
|
||||
use App\Http\Resources\TaskResource;
|
||||
use App\Http\Resources\TaskResourceCollection;
|
||||
use App\Models\Task;
|
||||
use Auth;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
|
||||
final class TaskController extends Controller
|
||||
{
|
||||
public function __construct()
|
||||
{
|
||||
$this->authorizeResource(Task::class, 'task');
|
||||
}
|
||||
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*/
|
||||
public function index(): TaskResourceCollection
|
||||
{
|
||||
$tasks = request()->user()
|
||||
->tasks()
|
||||
->latest()
|
||||
->paginate(10);
|
||||
|
||||
return new TaskResourceCollection($tasks);
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*/
|
||||
public function store(StoreTaskRequest $request)
|
||||
{
|
||||
$task = Auth::user()->tasks()->create($request->validated());
|
||||
|
||||
event(new TaskCreated($task)); // вынести бы из контроллера
|
||||
|
||||
return new TaskResource($task)
|
||||
->response()
|
||||
->setStatusCode(Response::HTTP_CREATED)
|
||||
->header('Location', route('tasks.show', $task));
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*/
|
||||
public function show(Task $task): TaskResource
|
||||
{
|
||||
return new TaskResource($task);
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*/
|
||||
public function update(UpdateTaskRequest $request, Task $task): TaskResource
|
||||
{
|
||||
$task->update($request->validated());
|
||||
|
||||
if ($task->status->isCompleted()) {
|
||||
$task->notified_at = null;
|
||||
$task->save();
|
||||
}
|
||||
|
||||
return new TaskResource($task);
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*/
|
||||
public function destroy(Task $task)
|
||||
{
|
||||
$task->delete();
|
||||
|
||||
return response()->noContent();
|
||||
}
|
||||
}
|
||||
65
laravel/app/Http/Controllers/AuthController.php
Normal file
65
laravel/app/Http/Controllers/AuthController.php
Normal file
@@ -0,0 +1,65 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Contracts\AuthServiceContract;
|
||||
use App\Data\Auth\LoginData;
|
||||
use App\Http\Requests\LoginRequest;
|
||||
use Illuminate\Http\JsonResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Throwable;
|
||||
|
||||
final class AuthController extends Controller
|
||||
{
|
||||
public function __construct(
|
||||
private readonly AuthServiceContract $authService
|
||||
) {
|
||||
}
|
||||
|
||||
public function login(LoginRequest $request): JsonResponse
|
||||
{
|
||||
try {
|
||||
$credentials = LoginData::fromArray($request->validated());
|
||||
$result = $this->authService->attemptLogin($credentials);
|
||||
|
||||
if ($result->error) {
|
||||
return response()->json([
|
||||
'message' => $result->error->message(),
|
||||
], $result->error->httpStatusCode());
|
||||
}
|
||||
|
||||
return response()->json([
|
||||
'token' => $result->token,
|
||||
]);
|
||||
} catch (Throwable $e) {
|
||||
Log::error('AuthController.login: '.$e->getMessage(), [
|
||||
'ip' => $request->ip()
|
||||
]);
|
||||
return response()->json([
|
||||
'message' => 'Unavailable'
|
||||
], Response::HTTP_SERVICE_UNAVAILABLE);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public function logout(Request $request): JsonResponse
|
||||
{
|
||||
try {
|
||||
$request->user()->tokens()->delete();
|
||||
return response()->json([
|
||||
'message' => 'Logged out'
|
||||
], Response::HTTP_OK);
|
||||
} catch (Throwable $e) {
|
||||
Log::error('AuthController.logout: '.$e->getMessage(), [
|
||||
'ip' => $request->ip()
|
||||
]);
|
||||
return response()->json([
|
||||
'message' => 'Unavailable'
|
||||
], Response::HTTP_SERVICE_UNAVAILABLE);
|
||||
}
|
||||
}
|
||||
}
|
||||
11
laravel/app/Http/Controllers/Controller.php
Normal file
11
laravel/app/Http/Controllers/Controller.php
Normal file
@@ -0,0 +1,11 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
|
||||
use Illuminate\Routing\Controller as BaseController;
|
||||
|
||||
abstract class Controller extends BaseController
|
||||
{
|
||||
use AuthorizesRequests;
|
||||
}
|
||||
Reference in New Issue
Block a user