маленькие изменения
parent
c4a30b8e27
commit
eef076234b
File diff suppressed because one or more lines are too long
|
|
@ -203,7 +203,182 @@ class PostResource extends JsonResource
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
### 3.3 Form Requests
|
### 3.3 API Controllers
|
||||||
|
|
||||||
|
**Laravel Spectrum** автоматически анализирует контроллеры для генерации документации.
|
||||||
|
|
||||||
|
#### AuthController
|
||||||
|
|
||||||
|
```php
|
||||||
|
// app/Http/Controllers/Api/AuthController.php
|
||||||
|
|
||||||
|
namespace App\Http\Controllers\Api;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Http\Requests\LoginRequest;
|
||||||
|
use App\Http\Requests\RegisterRequest;
|
||||||
|
use App\Http\Resources\UserResource;
|
||||||
|
use App\Models\User;
|
||||||
|
use Illuminate\Http\JsonResponse;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Support\Facades\Hash;
|
||||||
|
|
||||||
|
class AuthController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Register a new user.
|
||||||
|
*/
|
||||||
|
public function register(RegisterRequest $request): JsonResponse
|
||||||
|
{
|
||||||
|
$user = User::create([
|
||||||
|
'name' => $request->name,
|
||||||
|
'email' => $request->email,
|
||||||
|
'password' => Hash::make($request->password),
|
||||||
|
]);
|
||||||
|
|
||||||
|
$token = $user->createToken('auth-token')->plainTextToken;
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'User registered successfully',
|
||||||
|
'user' => new UserResource($user),
|
||||||
|
'token' => $token,
|
||||||
|
], 201);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Login user.
|
||||||
|
*/
|
||||||
|
public function login(LoginRequest $request): JsonResponse
|
||||||
|
{
|
||||||
|
$user = User::where('email', $request->email)->first();
|
||||||
|
|
||||||
|
if (!$user || !Hash::check($request->password, $user->password)) {
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'Invalid credentials',
|
||||||
|
], 401);
|
||||||
|
}
|
||||||
|
|
||||||
|
$token = $user->createToken('auth-token')->plainTextToken;
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'Login successful',
|
||||||
|
'user' => new UserResource($user),
|
||||||
|
'token' => $token,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Logout user.
|
||||||
|
*/
|
||||||
|
public function logout(Request $request): JsonResponse
|
||||||
|
{
|
||||||
|
$request->user()->currentAccessToken()->delete();
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'Logged out successfully',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get authenticated user.
|
||||||
|
*/
|
||||||
|
public function user(Request $request): JsonResponse
|
||||||
|
{
|
||||||
|
return response()->json([
|
||||||
|
'user' => new UserResource($request->user()),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### PostController
|
||||||
|
|
||||||
|
```php
|
||||||
|
// app/Http/Controllers/Api/PostController.php
|
||||||
|
|
||||||
|
namespace App\Http\Controllers\Api;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Http\Requests\StorePostRequest;
|
||||||
|
use App\Http\Requests\UpdatePostRequest;
|
||||||
|
use App\Http\Resources\PostCollection;
|
||||||
|
use App\Http\Resources\PostResource;
|
||||||
|
use App\Models\Post;
|
||||||
|
use Illuminate\Http\JsonResponse;
|
||||||
|
|
||||||
|
class PostController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Display a listing of posts.
|
||||||
|
*/
|
||||||
|
public function index(): PostCollection
|
||||||
|
{
|
||||||
|
$posts = Post::with('user')->latest()->paginate(15);
|
||||||
|
return new PostCollection($posts);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Store a newly created post.
|
||||||
|
*/
|
||||||
|
public function store(StorePostRequest $request): JsonResponse
|
||||||
|
{
|
||||||
|
$post = Post::create([
|
||||||
|
'title' => $request->title,
|
||||||
|
'content' => $request->content,
|
||||||
|
'user_id' => $request->user()->id,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$post->load('user');
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'Post created successfully',
|
||||||
|
'post' => new PostResource($post),
|
||||||
|
], 201);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Display the specified post.
|
||||||
|
*/
|
||||||
|
public function show(Post $post): JsonResponse
|
||||||
|
{
|
||||||
|
$post->load('user');
|
||||||
|
return response()->json([
|
||||||
|
'post' => new PostResource($post),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update the specified post.
|
||||||
|
*/
|
||||||
|
public function update(UpdatePostRequest $request, Post $post): JsonResponse
|
||||||
|
{
|
||||||
|
$this->authorize('update', $post);
|
||||||
|
|
||||||
|
$post->update($request->validated());
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'Post updated successfully',
|
||||||
|
'post' => new PostResource($post),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the specified post.
|
||||||
|
*/
|
||||||
|
public function destroy(Post $post): JsonResponse
|
||||||
|
{
|
||||||
|
$this->authorize('delete', $post);
|
||||||
|
|
||||||
|
$post->delete();
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'Post deleted successfully',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### 3.4 Form Requests
|
||||||
|
|
||||||
**Laravel Spectrum** автоматически определяет правила валидации из Form Requests.
|
**Laravel Spectrum** автоматически определяет правила валидации из Form Requests.
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue