courrier multi account restore compose

This commit is contained in:
alma 2025-04-28 20:49:42 +02:00
parent 6a7d69ecf8
commit 3d72af9300
2 changed files with 24 additions and 39 deletions

View File

@ -1,6 +1,6 @@
import { NextResponse } from 'next/server';
import { getServerSession } from 'next-auth';
import { authOptions } from '@/app/api/auth/[...nextauth]/route';
import { authOptions } from '@/lib/auth';
import { markEmailReadStatus } from '@/lib/services/email-service';
// Global cache reference (will be moved to a proper cache solution in the future)
@ -33,59 +33,37 @@ export async function POST(
{ params }: { params: { id: string } }
) {
try {
// Get session
const session = await getServerSession(authOptions);
if (!session?.user?.id) {
return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
}
// No need to await Promise.resolve(), params is already an object
const { id: emailId } = params;
if (!emailId) {
return NextResponse.json({ error: 'Email ID is required' }, { status: 400 });
}
try {
// Use the email service to mark the email as read
// First try with INBOX folder
let success = await markEmailReadStatus(session.user.id, emailId, true, 'INBOX');
// If not found in INBOX, try to find it in other common folders
if (!success) {
const commonFolders = ['Sent', 'Drafts', 'Trash', 'Spam', 'Junk'];
for (const folder of commonFolders) {
success = await markEmailReadStatus(session.user.id, emailId, true, folder);
if (success) {
// If found in a different folder, invalidate that folder's cache
invalidateCache(session.user.id, folder);
break;
}
}
} else {
// Email found in INBOX, invalidate INBOX cache
invalidateCache(session.user.id, 'INBOX');
}
if (!success) {
return NextResponse.json(
{ error: 'Email not found in any folder' },
{ status: 404 }
);
}
const { folder = 'INBOX', accountId } = await request.json();
return NextResponse.json({ success: true });
} catch (error) {
console.error('Error marking email as read:', error);
const success = await markEmailReadStatus(
session.user.id,
emailId,
true,
folder
);
if (!success) {
return NextResponse.json(
{ error: 'Failed to mark email as read' },
{ status: 500 }
);
}
return NextResponse.json({ success: true });
} catch (error) {
console.error('Error marking email as read:', error);
return NextResponse.json(
{ error: 'Failed to mark email as read' },
{ error: 'Internal server error' },
{ status: 500 }
);
}

View File

@ -41,10 +41,17 @@ setInterval(() => {
Object.entries(connectionPool).forEach(([key, { client, lastUsed }]) => {
if (now - lastUsed > CONNECTION_TIMEOUT) {
console.log(`Closing idle IMAP connection for ${key}`);
client.logout().catch(err => {
console.error(`Error closing connection for ${key}:`, err);
});
delete connectionPool[key];
try {
if (client.usable) {
client.logout().catch(err => {
console.error(`Error closing connection for ${key}:`, err);
});
}
} catch (error) {
console.error(`Error checking connection status for ${key}:`, error);
} finally {
delete connectionPool[key];
}
}
});
}, 60 * 1000); // Check every minute