Fix chat history authentication and conversation saving

- Fix critical async/await bug in chat API token verification
- Add comprehensive authentication debugging logs
- Fix conversations API Zod schema validation for query parameters
- Remove problematic CircularProgress import causing build warnings
- Improve error handling and user feedback in chat component

The main issue was that verifyToken() was called without await, causing
the chat API to receive a Promise object instead of the user payload,
resulting in undefined userId and failed conversation persistence.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
andupetcu
2025-09-22 12:47:59 +03:00
parent 6295c15755
commit 24c0577f44
3 changed files with 34 additions and 8 deletions

View File

@@ -14,8 +14,8 @@ const createConversationSchema = z.object({
const getConversationsSchema = z.object({
language: z.enum(['ro', 'en']).optional(),
limit: z.string().transform(Number).pipe(z.number().min(1).max(50)).optional().default('20'),
offset: z.string().transform(Number).pipe(z.number().min(0)).optional().default('0'),
limit: z.string().optional().default('20').transform(Number).pipe(z.number().min(1).max(50)),
offset: z.string().optional().default('0').transform(Number).pipe(z.number().min(0)),
})
// GET /api/chat/conversations - List user's conversations
@@ -44,7 +44,11 @@ export async function GET(request: NextRequest) {
// Parse query parameters
const url = new URL(request.url)
const queryParams = Object.fromEntries(url.searchParams.entries())
const queryParams = {
language: url.searchParams.get('language') || undefined,
limit: url.searchParams.get('limit') || '20',
offset: url.searchParams.get('offset') || '0'
}
const { language, limit, offset } = getConversationsSchema.parse(queryParams)
// Build where clause

View File

@@ -29,15 +29,21 @@ export async function POST(request: NextRequest) {
// Try to get user from authentication (optional for backward compatibility)
let userId: string | null = null
const authHeader = request.headers.get('authorization')
console.log('Chat API - authHeader present:', !!authHeader)
if (authHeader?.startsWith('Bearer ')) {
try {
const token = authHeader.substring(7)
const payload = verifyToken(token)
console.log('Chat API - token extracted, length:', token.length)
const payload = await verifyToken(token)
console.log('Chat API - token payload:', payload)
userId = payload.userId
console.log('Chat API - userId extracted from token:', userId)
} catch (error) {
// Continue without authentication for backward compatibility
console.log('Chat without authentication')
console.log('Chat API - authentication failed:', error.message)
}
} else {
console.log('Chat API - no valid auth header')
}
// Handle conversation logic
@@ -97,6 +103,11 @@ export async function POST(request: NextRequest) {
const aiResponse = await generateBiblicalResponse(message, locale, conversationHistory)
// Save messages to database if user is authenticated
console.log('Chat API - conversation saving check:', {
userId: userId ? 'present' : 'null',
finalConversationId: finalConversationId ? 'present' : 'null',
willSave: !!(userId && finalConversationId)
})
if (userId && finalConversationId) {
await prisma.$transaction([
// Save user message