From bdf209d6fe6ffb91fc232321135f53fe9da3fa01 Mon Sep 17 00:00:00 2001 From: "madjid.asa" Date: Thu, 23 Nov 2023 11:30:55 +0100 Subject: [PATCH 1/3] update saved data items for inbound parsing --- lemarche/api/emails/serializers.py | 3 +++ lemarche/api/emails/views.py | 20 ++++++++++++++++++-- lemarche/static/js/filter_data_message.js | 23 +++++++++++++++-------- 3 files changed, 36 insertions(+), 10 deletions(-) diff --git a/lemarche/api/emails/serializers.py b/lemarche/api/emails/serializers.py index 00e8b3923..037ed5a03 100644 --- a/lemarche/api/emails/serializers.py +++ b/lemarche/api/emails/serializers.py @@ -27,5 +27,8 @@ class EmailItemSerializer(serializers.Serializer): Headers = serializers.DictField() +ATTRIBUTES_TO_SAVE_FOR_INBOUND = ["From", "To", "CC", "ReplyTo", "SentAtDate", "Attachments"] + + class EmailsSerializer(serializers.Serializer): items = serializers.ListField(child=EmailItemSerializer()) diff --git a/lemarche/api/emails/views.py b/lemarche/api/emails/views.py index 2b6cbba84..7d67a1514 100644 --- a/lemarche/api/emails/views.py +++ b/lemarche/api/emails/views.py @@ -4,7 +4,7 @@ from rest_framework.response import Response from rest_framework.views import APIView -from lemarche.api.emails.serializers import EmailsSerializer +from lemarche.api.emails.serializers import ATTRIBUTES_TO_SAVE_FOR_INBOUND, EmailsSerializer from lemarche.conversations.models import Conversation from lemarche.conversations.utils import get_info_from_email_prefix from lemarche.www.conversations.tasks import send_email_from_conversation @@ -13,6 +13,21 @@ logger = logging.getLogger(__name__) +def clean_saved_data_of_inbound(data_inbound: dict): + """We clean saved data to respect the law of RGPD + + Args: + data_inbound (dict): all data that we receive from inbound api + + Returns: + dict with only neccessary key to save + """ + clean_saved_data = {} + for key in ATTRIBUTES_TO_SAVE_FOR_INBOUND: + clean_saved_data[key] = data_inbound.get(key) + return clean_saved_data + + class InboundParsingEmailView(APIView): def post(self, request): serializer = EmailsSerializer(data=request.data) @@ -23,7 +38,8 @@ def post(self, request): version, conv_uuid, user_kind = get_info_from_email_prefix(inbound_email_prefix) conv: Conversation = Conversation.objects.get_conv_from_uuid(conv_uuid=conv_uuid, version=version) # save the input data - conv.data.append(serializer.data) + data_inbound_clean = clean_saved_data_of_inbound(data_inbound=serializer.data.get("items")[0]) + conv.data.append(data_inbound_clean) conv.save() # find user_kind if version >= 1: diff --git a/lemarche/static/js/filter_data_message.js b/lemarche/static/js/filter_data_message.js index 4ecd6d60a..e39134b03 100644 --- a/lemarche/static/js/filter_data_message.js +++ b/lemarche/static/js/filter_data_message.js @@ -1,8 +1,8 @@ function filterData(data, filterText) { return data.filter(item => { - const from = `${item.items[0].From.Name} || ${item.items[0].From.Address}`; - const to = item.items[0].To[0].Address; - const RawHtmlBody = item.items[0].RawHtmlBody; + const from = `${item.From.Name} || ${item.From.Address}`; + const to = item.To[0].Address; + const RawHtmlBody = item.RawHtmlBody; // filter fields return from.includes(filterText) || to.includes(filterText) || RawHtmlBody.includes(filterText); }); @@ -11,14 +11,14 @@ function filterData(data, filterText) { // Fonction pour générer les lignes du tableau HTML function generateTableRows(filteredData) { const rows = filteredData.map(item => { - const sendAt = new Date(item.items[0].SentAtDate).strftime('%d/%m/%Y %Hh%M'); - const from = `${item.items[0].From.Name} - ${item.items[0].From.Address}`; - const RawHtmlBody = item.items[0].RawHtmlBody ? item.items[0].RawHtmlBody : item.items[0].RawTextBody; + const sendAt = new Date(item.SentAtDate).strftime('%d/%m/%Y %Hh%M'); + const from = `${item.From.Name} - ${item.From.Address}`; + const attachementsCount = item.Attachments ? item.Attachments.length : 0; return ` ${sendAt} ${from} - ${RawHtmlBody} + ${attachementsCount} `; }); @@ -35,7 +35,14 @@ function init() { // const filteredData = filterData(rawData, filterText); // generate rows - const tableRows = generateTableRows(rawData); + const headTable = ` + + Date d'envoi + Expéditeur + Nombre de PJ + + `; + const tableRows = headTable + generateTableRows(rawData); // insert rows dataTableBody.innerHTML = tableRows; From 5eecd6d17ee27908dfeae813fb009f1b3c59bcf6 Mon Sep 17 00:00:00 2001 From: "madjid.asa" Date: Tue, 28 Nov 2023 11:06:27 +0100 Subject: [PATCH 2/3] add disclaimers for attachments --- lemarche/www/conversations/tasks.py | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/lemarche/www/conversations/tasks.py b/lemarche/www/conversations/tasks.py index 0688cc74b..9ef747ace 100644 --- a/lemarche/www/conversations/tasks.py +++ b/lemarche/www/conversations/tasks.py @@ -3,6 +3,12 @@ from lemarche.utils.emails import send_mail_async, whitelist_recipient_list +DISCLAIMER_ATTACHMENTS = ( + "\nVeuillez noter que cette conversation email ne prend pas en charge les pièces jointes.\n" + "Pour envoyer un document, un devis ou autre, demandez les coordonnées direct de votre interlocuteur" +) + + def send_first_email_from_conversation(conv: Conversation): siae: Siae = conv.siae from_email = f"{conv.sender_first_name} {conv.sender_last_name} <{conv.sender_email_buyer_encoded}>" @@ -16,7 +22,7 @@ def send_first_email_from_conversation(conv: Conversation): f"{sender_company_name}" f"Ce client vous a contacté via le Marché de l'inclusion. " "Pour échanger avec lui, répondez simplement à cet e-mail.\n" - ) + ) + DISCLAIMER_ATTACHMENTS send_mail_async( email_subject=conv.title, @@ -34,7 +40,7 @@ def send_email_from_conversation( from_email = f"{conv.sender_first_name} {conv.sender_last_name} <{conv.sender_email_buyer_encoded}>" send_mail_async( email_subject=email_subject, - email_body=email_body, + email_body=email_body + DISCLAIMER_ATTACHMENTS, recipient_list=whitelist_recipient_list([conv.sender_email_siae]), from_email=from_email, email_body_html=email_body_html, @@ -45,7 +51,7 @@ def send_email_from_conversation( from_email = f"{siae.contact_full_name} <{conv.sender_email_siae_encoded}>" send_mail_async( email_subject=email_subject, - email_body=email_body, + email_body=email_body + DISCLAIMER_ATTACHMENTS, recipient_list=whitelist_recipient_list([conv.sender_email_buyer]), from_email=from_email, email_body_html=email_body_html, From c20e04da1856e6a5af7e739c8d98dc4977fc986d Mon Sep 17 00:00:00 2001 From: "madjid.asa" Date: Tue, 28 Nov 2023 14:36:26 +0100 Subject: [PATCH 3/3] move ATTRIBUTES_TO_SAVE_FOR_INBOUND to constants --- lemarche/api/emails/serializers.py | 3 --- lemarche/api/emails/views.py | 3 ++- lemarche/conversations/constants.py | 1 + 3 files changed, 3 insertions(+), 4 deletions(-) create mode 100644 lemarche/conversations/constants.py diff --git a/lemarche/api/emails/serializers.py b/lemarche/api/emails/serializers.py index 037ed5a03..00e8b3923 100644 --- a/lemarche/api/emails/serializers.py +++ b/lemarche/api/emails/serializers.py @@ -27,8 +27,5 @@ class EmailItemSerializer(serializers.Serializer): Headers = serializers.DictField() -ATTRIBUTES_TO_SAVE_FOR_INBOUND = ["From", "To", "CC", "ReplyTo", "SentAtDate", "Attachments"] - - class EmailsSerializer(serializers.Serializer): items = serializers.ListField(child=EmailItemSerializer()) diff --git a/lemarche/api/emails/views.py b/lemarche/api/emails/views.py index 7d67a1514..e451ddb91 100644 --- a/lemarche/api/emails/views.py +++ b/lemarche/api/emails/views.py @@ -4,7 +4,8 @@ from rest_framework.response import Response from rest_framework.views import APIView -from lemarche.api.emails.serializers import ATTRIBUTES_TO_SAVE_FOR_INBOUND, EmailsSerializer +from lemarche.api.emails.serializers import EmailsSerializer +from lemarche.conversations.constants import ATTRIBUTES_TO_SAVE_FOR_INBOUND from lemarche.conversations.models import Conversation from lemarche.conversations.utils import get_info_from_email_prefix from lemarche.www.conversations.tasks import send_email_from_conversation diff --git a/lemarche/conversations/constants.py b/lemarche/conversations/constants.py new file mode 100644 index 000000000..e56280a17 --- /dev/null +++ b/lemarche/conversations/constants.py @@ -0,0 +1 @@ +ATTRIBUTES_TO_SAVE_FOR_INBOUND = ["From", "To", "CC", "ReplyTo", "SentAtDate", "Attachments"]