Files
ars-backend/app/Http/Controllers/ChatSessionController.php
ROOG c6d6534b63 main: 用户管理和会话功能初始实现
- 添加用户管理功能的测试,包括创建、更新、停用、激活用户及用户登录 JWT 测试
- 提供用户管理相关的请求验证类与控制器
- 引入 CORS 配置信息,支持跨域请求
- 添加数据库播种器以便创建根用户
- 配置 API 默认使用 JWT 认证
- 添加聊天会话和消息的模型、迁移文件及关联功能
2025-12-14 17:49:08 +08:00

52 lines
1.6 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Exceptions\ChatSessionStatusException;
use App\Http\Requests\AppendMessageRequest;
use App\Http\Requests\CreateSessionRequest;
use App\Http\Resources\MessageResource;
use App\Models\Message;
use App\Services\ChatService;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
class ChatSessionController extends Controller
{
public function __construct(private readonly ChatService $service)
{
}
public function store(CreateSessionRequest $request): JsonResponse
{
$session = $this->service->createSession($request->input('session_name'));
return response()->json($session, 201);
}
public function append(string $sessionId, AppendMessageRequest $request): JsonResponse
{
try {
$message = $this->service->appendMessage([
'session_id' => $sessionId,
...$request->validated(),
]);
} catch (ChatSessionStatusException $e) {
return response()->json(['message' => $e->getMessage()], 403);
}
return (new MessageResource($message))->response()->setStatusCode(201);
}
public function listMessages(Request $request, string $sessionId): JsonResponse
{
$afterSeq = (int) $request->query('after_seq', 0);
$limit = (int) $request->query('limit', 50);
$limit = $limit > 0 && $limit <= 200 ? $limit : 50;
$messages = $this->service->listMessagesBySeq($sessionId, $afterSeq, $limit);
return MessageResource::collection($messages)->response();
}
}