You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
120 lines
2.7 KiB
PHP
120 lines
2.7 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\Post;
|
|
use App\Models\User;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Http\Response;
|
|
|
|
class PostController extends Controller
|
|
{
|
|
public function index(Request $request): Response
|
|
{
|
|
$request->validate(
|
|
[
|
|
'lastPost' => 'required|integer',
|
|
'firstPost' => 'required|integer',
|
|
'order' => 'required|string|in:new,old',
|
|
]
|
|
);
|
|
|
|
$lastPost = $request->lastPost;
|
|
$firstPost = $request->firstPost;
|
|
|
|
$postsQuery = Post::query()->with('user')->orderByDesc(column: 'sequence');
|
|
|
|
if ($request->order == 'new') {
|
|
$postsQuery->where(column: 'sequence', operator: '>', value: $firstPost);
|
|
}
|
|
|
|
if ($request->order == 'old' && $lastPost != 0) {
|
|
$postsQuery->where(column: 'sequence', operator: '<', value: $lastPost);
|
|
}
|
|
|
|
$posts = $postsQuery->take(10)->get();
|
|
|
|
return response(
|
|
[
|
|
'status' => 200,
|
|
'data' => $posts,
|
|
]
|
|
);
|
|
}
|
|
|
|
public function store(Request $request): Response
|
|
{
|
|
$request->validate(
|
|
[
|
|
'title' => 'required|string',
|
|
'description' => 'required|string',
|
|
]
|
|
);
|
|
|
|
$user = $request->user();
|
|
|
|
if (! ($user instanceof User)) {
|
|
return response(
|
|
[
|
|
'status' => 400,
|
|
'message' => 'Invalid user',
|
|
]
|
|
);
|
|
}
|
|
|
|
$user->posts()->create(
|
|
[
|
|
'title' => $request->title,
|
|
'description' => $request->description,
|
|
]
|
|
);
|
|
|
|
return response(
|
|
[
|
|
'status' => 200,
|
|
'message' => 'Create Post Success!',
|
|
]
|
|
);
|
|
}
|
|
|
|
public function show(string $id): Response
|
|
{
|
|
$post = Post::query()->find($id);
|
|
|
|
return response(
|
|
[
|
|
'status' => 200,
|
|
'data' => $post,
|
|
]
|
|
);
|
|
}
|
|
|
|
public function userPosts(User $user, Request $request): Response
|
|
{
|
|
$request->validate(
|
|
[
|
|
'lastUserPost' => 'required|integer',
|
|
]
|
|
);
|
|
|
|
$lastUserPost = 0;
|
|
|
|
if ($request->lastUserPost) {
|
|
$lastUserPost = $request->lastUserPost;
|
|
}
|
|
|
|
$userPosts = $user->posts()
|
|
->getQuery()
|
|
->where(column: 'sequence', operator: '>', value: $lastUserPost)
|
|
->take(10)
|
|
->get();
|
|
|
|
return response(
|
|
[
|
|
'status' => 200,
|
|
'data' => $userPosts,
|
|
]
|
|
);
|
|
}
|
|
}
|