mime change
This commit is contained in:
parent
bb0a77e40f
commit
1b9633f70b
@ -1,27 +1,5 @@
|
||||
import { NextResponse } from 'next/server';
|
||||
import { simpleParser } from 'mailparser';
|
||||
import DOMPurify from 'isomorphic-dompurify';
|
||||
|
||||
function cleanHtml(html: string): string {
|
||||
try {
|
||||
return DOMPurify.sanitize(html, {
|
||||
ALLOWED_TAGS: ['p', 'br', 'div', 'span', 'a', 'img', 'strong', 'em', 'u', 'ul', 'ol', 'li', 'blockquote', 'pre', 'code', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6'],
|
||||
ALLOWED_ATTR: ['href', 'src', 'alt', 'title', 'class', 'style'],
|
||||
ALLOWED_URI_REGEXP: /^(?:(?:(?:f|ht)tps?|mailto|tel):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i
|
||||
});
|
||||
} catch (error) {
|
||||
console.error('Error cleaning HTML:', error);
|
||||
return html;
|
||||
}
|
||||
}
|
||||
|
||||
function getAddressText(address: any): string | null {
|
||||
if (!address) return null;
|
||||
if (Array.isArray(address)) {
|
||||
return address.map(addr => addr.value?.[0]?.address || '').filter(Boolean).join(', ');
|
||||
}
|
||||
return address.value?.[0]?.address || null;
|
||||
}
|
||||
import { parseEmail } from '@/lib/server/email-parser';
|
||||
|
||||
export async function POST(request: Request) {
|
||||
try {
|
||||
@ -34,20 +12,8 @@ export async function POST(request: Request) {
|
||||
);
|
||||
}
|
||||
|
||||
const parsed = await simpleParser(emailContent);
|
||||
|
||||
return NextResponse.json({
|
||||
subject: parsed.subject || null,
|
||||
from: getAddressText(parsed.from),
|
||||
to: getAddressText(parsed.to),
|
||||
cc: getAddressText(parsed.cc),
|
||||
bcc: getAddressText(parsed.bcc),
|
||||
date: parsed.date || null,
|
||||
html: parsed.html ? cleanHtml(parsed.html) : null,
|
||||
text: parsed.text || null,
|
||||
attachments: parsed.attachments || [],
|
||||
headers: Object.fromEntries(parsed.headers)
|
||||
});
|
||||
const parsed = await parseEmail(emailContent);
|
||||
return NextResponse.json(parsed);
|
||||
} catch (error) {
|
||||
console.error('Error parsing email:', error);
|
||||
return NextResponse.json(
|
||||
|
||||
45
lib/server/email-parser.ts
Normal file
45
lib/server/email-parser.ts
Normal file
@ -0,0 +1,45 @@
|
||||
import { simpleParser } from 'mailparser';
|
||||
import DOMPurify from 'isomorphic-dompurify';
|
||||
|
||||
function cleanHtml(html: string): string {
|
||||
try {
|
||||
return DOMPurify.sanitize(html, {
|
||||
ALLOWED_TAGS: ['p', 'br', 'div', 'span', 'a', 'img', 'strong', 'em', 'u', 'ul', 'ol', 'li', 'blockquote', 'pre', 'code', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6'],
|
||||
ALLOWED_ATTR: ['href', 'src', 'alt', 'title', 'class', 'style'],
|
||||
ALLOWED_URI_REGEXP: /^(?:(?:(?:f|ht)tps?|mailto|tel):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i
|
||||
});
|
||||
} catch (error) {
|
||||
console.error('Error cleaning HTML:', error);
|
||||
return html;
|
||||
}
|
||||
}
|
||||
|
||||
function getAddressText(address: any): string | null {
|
||||
if (!address) return null;
|
||||
if (Array.isArray(address)) {
|
||||
return address.map(addr => addr.value?.[0]?.address || '').filter(Boolean).join(', ');
|
||||
}
|
||||
return address.value?.[0]?.address || null;
|
||||
}
|
||||
|
||||
export async function parseEmail(emailContent: string) {
|
||||
try {
|
||||
const parsed = await simpleParser(emailContent);
|
||||
|
||||
return {
|
||||
subject: parsed.subject || null,
|
||||
from: getAddressText(parsed.from),
|
||||
to: getAddressText(parsed.to),
|
||||
cc: getAddressText(parsed.cc),
|
||||
bcc: getAddressText(parsed.bcc),
|
||||
date: parsed.date || null,
|
||||
html: parsed.html ? cleanHtml(parsed.html) : null,
|
||||
text: parsed.text || null,
|
||||
attachments: parsed.attachments || [],
|
||||
headers: Object.fromEntries(parsed.headers)
|
||||
};
|
||||
} catch (error) {
|
||||
console.error('Error parsing email:', error);
|
||||
throw error;
|
||||
}
|
||||
}
|
||||
20
next.config.js
Normal file
20
next.config.js
Normal file
@ -0,0 +1,20 @@
|
||||
/** @type {import('next').NextConfig} */
|
||||
const nextConfig = {
|
||||
webpack: (config, { isServer }) => {
|
||||
if (!isServer) {
|
||||
config.resolve.fallback = {
|
||||
...config.resolve.fallback,
|
||||
net: false,
|
||||
tls: false,
|
||||
fs: false,
|
||||
dns: false,
|
||||
child_process: false,
|
||||
http2: false,
|
||||
module: false,
|
||||
};
|
||||
}
|
||||
return config;
|
||||
},
|
||||
};
|
||||
|
||||
module.exports = nextConfig;
|
||||
Loading…
Reference in New Issue
Block a user