sendgrid-python icon indicating copy to clipboard operation
sendgrid-python copied to clipboard

Setting Personalization Removes Existing template_data

Open jr-bespoke opened this issue 3 years ago • 4 comments

Issue Summary

I am trying to determine why using add_personalization removes the existing dynamic_template_data I already set on my mail object. If this is desired behavior, I would have expected some kind of note about it in the docs, or preferably a warning in the code.

I tried looking in the knowledge base, on github issues, and on stack overflow. I could not find anything to suggest why this might be happening. I found the workaround by simply resetting dynamic_template_data. I could, of course, simply add the personalization first and then add the dynamic_template_data, but this seemed like a silent gotcha that should be brought to the sendgrid team's awareness.

Steps to Reproduce

  1. Attach dynamic template data to mail object
  2. Have cc recipients, so add personalization to mail object
  3. Dynamic template data is now empty

Code Snippet

def our_simplified_send_func(to_, template_id, template_data, cc_recipients = []):
    mail = Mail(from_email=self._from, to_emails=_to) # self._from is a class var
    mail.dynamic_template_data = template_data
    mail.template_id = template_id

    if len(cc_recipients) > 0:
        sendgrid_personalization = Personalization()

        for cc in cc_recipients:
            sendgrid_personalization.add_cc( To(cc, cc) )

        for to_recipient in to_:
            sendgrid_personalization.add_to( To(to_recipient, to_recipient) )
            mail.add_personalization(sendgrid_personalization)

        # Why do I need to re-add dynamic_template_data after adding a personalization?
        mail.dynamic_template_data = template_data

Exception/Log

It's not an explicit exception or error log so much as running `add_personalization` removes the existing dynamic_template_data.

Technical details:

  • sendgrid-python version: 6.4.8
  • python version: 3.8.12

jr-bespoke avatar Jan 24 '22 23:01 jr-bespoke

Hi @jr-bespoke! I tried reproducing the issue using your code snippet, and saw that the dynamic template data still exists. When you create your new personalization (with two recipients & ccs) and add it to the object on line 14, the original top-level data (with the single recipient, template data & id) becomes another personalization (or separate email) under the hood.

Read here to gain a clearer idea of how personalizations work & how you can meet your desired use case. Let me know if you have any other questions!

beebzz avatar Feb 01 '22 22:02 beebzz

I had the same issue that when adding personalization the dynamic template did not have any of the data. Had to do the same as ts.

phithor avatar Feb 16 '22 21:02 phithor

I think there's a disconnect between the code snippet provided and what the intended goal is. The issue is that dynamic template data is a part of a personalization which also includes recipients. This allows for using the same dynamic template and generating multiple personalized emails to different recipients with different dynamic template data in a single API call. This also means that a personalization generally should not be added multiple times to a single Mail instance.

Recommend building the personalization(s) to match the goal and then adding it/them to the Mail instance. Or just adding the CCs to the mail object. E.g.,

def our_simplified_send_func(to_, template_id, template_data, cc_recipients = []):
    mail = Mail(from_email=self._from, to_emails=_to) # self._from is a class var
    mail.dynamic_template_data = template_data
    mail.template_id = template_id

    for cc in cc_recipients:
        mail.add_cc(Cc(cc, cc))

childish-sambino avatar Mar 11 '22 20:03 childish-sambino

Closing due to lack of activity.

rakatyal avatar Apr 12 '22 15:04 rakatyal