mime change

This commit is contained in:
alma 2025-04-24 16:17:16 +02:00
parent eb02fd016b
commit ee78a646b9
6 changed files with 33 additions and 30 deletions

View File

@ -1,15 +1,10 @@
import { NextResponse } from 'next/server'; import { NextResponse } from 'next/server';
import { simpleParser } from 'mailparser'; import { simpleParser } from 'mailparser';
import DOMPurify from 'dompurify'; import DOMPurify from 'isomorphic-dompurify';
import { JSDOM } from 'jsdom';
// Create a window object for DOMPurify
const window = new JSDOM('').window;
const purify = DOMPurify(window);
function cleanHtml(html: string): string { function cleanHtml(html: string): string {
try { try {
return purify.sanitize(html, { 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_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_ATTR: ['href', 'src', 'alt', 'title', 'class', 'style'],
ALLOWED_URI_REGEXP: /^(?:(?:(?:f|ht)tps?|mailto|tel):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i ALLOWED_URI_REGEXP: /^(?:(?:(?:f|ht)tps?|mailto|tel):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i
@ -20,6 +15,14 @@ function cleanHtml(html: string): string {
} }
} }
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 POST(request: Request) { export async function POST(request: Request) {
try { try {
const { emailContent } = await request.json(); const { emailContent } = await request.json();
@ -35,10 +38,10 @@ export async function POST(request: Request) {
return NextResponse.json({ return NextResponse.json({
subject: parsed.subject || null, subject: parsed.subject || null,
from: parsed.from?.text || null, from: getAddressText(parsed.from),
to: parsed.to?.text || null, to: getAddressText(parsed.to),
cc: parsed.cc?.text || null, cc: getAddressText(parsed.cc),
bcc: parsed.bcc?.text || null, bcc: getAddressText(parsed.bcc),
date: parsed.date || null, date: parsed.date || null,
html: parsed.html ? cleanHtml(parsed.html) : null, html: parsed.html ? cleanHtml(parsed.html) : null,
text: parsed.text || null, text: parsed.text || null,

8
node_modules/.package-lock.json generated vendored
View File

@ -3812,13 +3812,13 @@
"dev": true "dev": true
}, },
"node_modules/isomorphic-dompurify": { "node_modules/isomorphic-dompurify": {
"version": "2.23.0", "version": "2.24.0",
"resolved": "https://registry.npmjs.org/isomorphic-dompurify/-/isomorphic-dompurify-2.23.0.tgz", "resolved": "https://registry.npmjs.org/isomorphic-dompurify/-/isomorphic-dompurify-2.24.0.tgz",
"integrity": "sha512-f9w5fPJwlu+VK1uowFy4eWYgd7uxl0nQJbtorGp1OAs6JeY1qPkBQKNee1RXrnr68GqZ86PwQ6LF/5rW1TrOZQ==", "integrity": "sha512-SgKoDBCQveodymGMBPpzs9MOTCk4Luq0bTfwoPrUKa7q0FnCLZMtqR25Rnq228zJfMTsX1ZItiJbDtjb2lyv4A==",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"dompurify": "^3.2.5", "dompurify": "^3.2.5",
"jsdom": "^26.0.0" "jsdom": "^26.1.0"
}, },
"engines": { "engines": {
"node": ">=18" "node": ">=18"

View File

@ -1,6 +1,6 @@
{ {
"name": "isomorphic-dompurify", "name": "isomorphic-dompurify",
"version": "2.23.0", "version": "2.24.0",
"description": "Makes it possible to use DOMPurify on server and client in the same way.", "description": "Makes it possible to use DOMPurify on server and client in the same way.",
"keywords": [ "keywords": [
"security", "security",
@ -31,11 +31,11 @@
"types": "index.d.ts", "types": "index.d.ts",
"dependencies": { "dependencies": {
"dompurify": "^3.2.5", "dompurify": "^3.2.5",
"jsdom": "^26.0.0" "jsdom": "^26.1.0"
}, },
"devDependencies": { "devDependencies": {
"terser": "^5.39.0", "terser": "^5.39.0",
"vitest": "^3.1.1" "vitest": "^3.1.2"
}, },
"engines": { "engines": {
"node": ">=18" "node": ">=18"

10
package-lock.json generated
View File

@ -59,7 +59,7 @@
"imap": "^0.8.19", "imap": "^0.8.19",
"imapflow": "^1.0.184", "imapflow": "^1.0.184",
"input-otp": "1.4.1", "input-otp": "1.4.1",
"isomorphic-dompurify": "^2.23.0", "isomorphic-dompurify": "^2.24.0",
"jwt-decode": "^4.0.0", "jwt-decode": "^4.0.0",
"libmime": "^5.3.6", "libmime": "^5.3.6",
"lucide-react": "^0.454.0", "lucide-react": "^0.454.0",
@ -4440,13 +4440,13 @@
"dev": true "dev": true
}, },
"node_modules/isomorphic-dompurify": { "node_modules/isomorphic-dompurify": {
"version": "2.23.0", "version": "2.24.0",
"resolved": "https://registry.npmjs.org/isomorphic-dompurify/-/isomorphic-dompurify-2.23.0.tgz", "resolved": "https://registry.npmjs.org/isomorphic-dompurify/-/isomorphic-dompurify-2.24.0.tgz",
"integrity": "sha512-f9w5fPJwlu+VK1uowFy4eWYgd7uxl0nQJbtorGp1OAs6JeY1qPkBQKNee1RXrnr68GqZ86PwQ6LF/5rW1TrOZQ==", "integrity": "sha512-SgKoDBCQveodymGMBPpzs9MOTCk4Luq0bTfwoPrUKa7q0FnCLZMtqR25Rnq228zJfMTsX1ZItiJbDtjb2lyv4A==",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"dompurify": "^3.2.5", "dompurify": "^3.2.5",
"jsdom": "^26.0.0" "jsdom": "^26.1.0"
}, },
"engines": { "engines": {
"node": ">=18" "node": ">=18"

View File

@ -60,7 +60,7 @@
"imap": "^0.8.19", "imap": "^0.8.19",
"imapflow": "^1.0.184", "imapflow": "^1.0.184",
"input-otp": "1.4.1", "input-otp": "1.4.1",
"isomorphic-dompurify": "^2.23.0", "isomorphic-dompurify": "^2.24.0",
"jwt-decode": "^4.0.0", "jwt-decode": "^4.0.0",
"libmime": "^5.3.6", "libmime": "^5.3.6",
"lucide-react": "^0.454.0", "lucide-react": "^0.454.0",

View File

@ -1961,13 +1961,13 @@ isexe@^2.0.0:
resolved "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz" resolved "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz"
integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==
isomorphic-dompurify@^2.23.0: isomorphic-dompurify@^2.24.0:
version "2.23.0" version "2.24.0"
resolved "https://registry.npmjs.org/isomorphic-dompurify/-/isomorphic-dompurify-2.23.0.tgz" resolved "https://registry.npmjs.org/isomorphic-dompurify/-/isomorphic-dompurify-2.24.0.tgz"
integrity sha512-f9w5fPJwlu+VK1uowFy4eWYgd7uxl0nQJbtorGp1OAs6JeY1qPkBQKNee1RXrnr68GqZ86PwQ6LF/5rW1TrOZQ== integrity sha512-SgKoDBCQveodymGMBPpzs9MOTCk4Luq0bTfwoPrUKa7q0FnCLZMtqR25Rnq228zJfMTsX1ZItiJbDtjb2lyv4A==
dependencies: dependencies:
dompurify "^3.2.5" dompurify "^3.2.5"
jsdom "^26.0.0" jsdom "^26.1.0"
jackspeak@^3.1.2: jackspeak@^3.1.2:
version "3.4.3" version "3.4.3"
@ -1998,7 +1998,7 @@ jsbn@1.1.0:
resolved "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz" resolved "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz"
integrity sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A== integrity sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A==
jsdom@^26.0.0: jsdom@^26.1.0:
version "26.1.0" version "26.1.0"
resolved "https://registry.npmjs.org/jsdom/-/jsdom-26.1.0.tgz" resolved "https://registry.npmjs.org/jsdom/-/jsdom-26.1.0.tgz"
integrity sha512-Cvc9WUhxSMEo4McES3P7oK3QaXldCfNWp7pl2NNeiIFlCoLr3kfq9kb1fxftiwk1FLV7CvpvDfonxtzUDeSOPg== integrity sha512-Cvc9WUhxSMEo4McES3P7oK3QaXldCfNWp7pl2NNeiIFlCoLr3kfq9kb1fxftiwk1FLV7CvpvDfonxtzUDeSOPg==