mirror of
https://github.com/simple-login/app.git
synced 2024-11-16 17:08:30 +01:00
Merge pull request #212 from SibrenVasse/multipart_fix
Fix reverse alias replacement multipart message
This commit is contained in:
commit
28287ff93e
1 changed files with 38 additions and 14 deletions
|
@ -30,9 +30,13 @@ It should contain the following info:
|
||||||
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
import arrow
|
||||||
import email
|
import email
|
||||||
|
import spf
|
||||||
import time
|
import time
|
||||||
import uuid
|
import uuid
|
||||||
|
from aiosmtpd.controller import Controller
|
||||||
|
from aiosmtpd.smtp import Envelope
|
||||||
from email import encoders
|
from email import encoders
|
||||||
from email.message import Message
|
from email.message import Message
|
||||||
from email.mime.application import MIMEApplication
|
from email.mime.application import MIMEApplication
|
||||||
|
@ -42,11 +46,6 @@ from io import BytesIO
|
||||||
from smtplib import SMTP
|
from smtplib import SMTP
|
||||||
from typing import List, Tuple
|
from typing import List, Tuple
|
||||||
|
|
||||||
import arrow
|
|
||||||
import spf
|
|
||||||
from aiosmtpd.controller import Controller
|
|
||||||
from aiosmtpd.smtp import Envelope
|
|
||||||
|
|
||||||
from app import pgp_utils, s3
|
from app import pgp_utils, s3
|
||||||
from app.alias_utils import try_auto_create
|
from app.alias_utils import try_auto_create
|
||||||
from app.config import (
|
from app.config import (
|
||||||
|
@ -95,7 +94,6 @@ from app.utils import random_string
|
||||||
from init_app import load_pgp_public_keys
|
from init_app import load_pgp_public_keys
|
||||||
from server import create_app
|
from server import create_app
|
||||||
|
|
||||||
|
|
||||||
_IP_HEADER = "X-SimpleLogin-Client-IP"
|
_IP_HEADER = "X-SimpleLogin-Client-IP"
|
||||||
_MAILBOX_ID_HEADER = "X-SimpleLogin-Mailbox-ID"
|
_MAILBOX_ID_HEADER = "X-SimpleLogin-Mailbox-ID"
|
||||||
|
|
||||||
|
@ -264,6 +262,30 @@ def replace_header_when_reply(msg: Message, alias: Alias, header: str):
|
||||||
add_or_replace_header(msg, header, new_header)
|
add_or_replace_header(msg, header, new_header)
|
||||||
|
|
||||||
|
|
||||||
|
def replace_str_in_msg(msg: Message, fr: str, to: str):
|
||||||
|
if msg.get_content_maintype() != "text":
|
||||||
|
return msg
|
||||||
|
new_body = msg.get_payload(decode=True).replace(fr.encode(), to.encode())
|
||||||
|
|
||||||
|
# If utf-8 decoding fails, do not touch message part
|
||||||
|
try:
|
||||||
|
new_body = new_body.decode("utf-8")
|
||||||
|
except:
|
||||||
|
return msg
|
||||||
|
|
||||||
|
cte = (
|
||||||
|
msg["Content-Transfer-Encoding"].lower()
|
||||||
|
if msg["Content-Transfer-Encoding"]
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
subtype = msg.get_content_subtype()
|
||||||
|
delete_header(msg, "Content-Transfer-Encoding")
|
||||||
|
delete_header(msg, "Content-Type")
|
||||||
|
|
||||||
|
email.contentmanager.set_text_content(msg, new_body, subtype=subtype, cte=cte)
|
||||||
|
return msg
|
||||||
|
|
||||||
|
|
||||||
def generate_reply_email():
|
def generate_reply_email():
|
||||||
# generate a reply_email, make sure it is unique
|
# generate a reply_email, make sure it is unique
|
||||||
# not use while loop to avoid infinite loop
|
# not use while loop to avoid infinite loop
|
||||||
|
@ -556,15 +578,17 @@ def handle_reply(envelope, smtp: SMTP, msg: Message, rcpt_to: str) -> (bool, str
|
||||||
envelope.rcpt_options,
|
envelope.rcpt_options,
|
||||||
)
|
)
|
||||||
|
|
||||||
# replace the "ra+string@simplelogin.co" by the alias in the email body
|
# replace "ra+string@simplelogin.co" by the contact email in the email body
|
||||||
# as this is usually included in when replying
|
# as this is usually included when replying
|
||||||
if user.replace_reverse_alias:
|
if user.replace_reverse_alias:
|
||||||
payload = (
|
if msg.is_multipart():
|
||||||
msg.get_payload()
|
for part in msg.walk():
|
||||||
.encode()
|
if part.get_content_maintype() != "text":
|
||||||
.replace(reply_email.encode(), contact.website_email.encode())
|
continue
|
||||||
)
|
part = replace_str_in_msg(part, reply_email, contact.website_email)
|
||||||
msg.set_payload(payload)
|
|
||||||
|
else:
|
||||||
|
msg = replace_str_in_msg(msg, reply_email, contact.website_email)
|
||||||
|
|
||||||
if alias_domain in ALIAS_DOMAINS:
|
if alias_domain in ALIAS_DOMAINS:
|
||||||
add_dkim_signature(msg, alias_domain)
|
add_dkim_signature(msg, alias_domain)
|
||||||
|
|
Loading…
Reference in a new issue