Skip to content

Latest commit

 

History

History
220 lines (151 loc) · 6.96 KB

sendgrid.md

File metadata and controls

220 lines (151 loc) · 6.96 KB

The sendgrid Package

FYI: KNOWN ISSUES WITH SENDGRID

The sendgrid package provides some useful emailing capabilities via the SendGrid Email Delivery Service. 📬 ✉️

Reference:

Installation

Installing the package, as necessary:

pip install sendgrid

# optionally install a specific version:
#pip install sendgrid==6.6.0

NOTE: we'll want to make sure the installed version is greater than 6.0.5, because earlier versions of this package worked differently, and the code examples in this document only apply to the newer versions.

Setup

First, sign up for a SendGrid account, and click the verification link sent to your email address.

Then follow the instructions to complete your "Single Sender Verification", clicking the link in another confirmation email to verify your single sender address. You should also be able to access via the settings menu:

NOTE: some students have reported that yahoo-issued, university-issued, and work-issued email addresses may be less likely to work. So if you run into issues with these kinds of addresses, perhaps try a Gmail address.

Moving forward we will reference this single sender address as the SENDGRID_SENDER_ADDRESS.

Finally, create a SendGrid API Key with "full access" permissions (i.e. the SENDGRID_API_KEY).

Usage

Authorization

We'll need to handle secret credentials differently, depending on the development environment.

Credentials in Colab

If working in a Colab notebook, we'll use notebook secrets to specify the secret credentials (i.e. the API key, and the sender email address):

from google.colab import userdata

SENDGRID_API_KEY = userdata.get("SENDGRID_API_KEY")
SENDGRID_SENDER_ADDRESS = userdata.get("SENDGRID_SENDER_ADDRESS")

Credentials in Local Development Project

Otherwise, if working locally, we'll use Environment Variables to specify the secret credentials, ideally in conjunction with a ".env" file approach:

import os
from dotenv import load_dotenv

load_dotenv()

SENDGRID_API_KEY = os.getenv("SENDGRID_API_KEY", default="OOPS, please set env var called 'SENDGRID_API_KEY'")
SENDGRID_SENDER_ADDRESS = os.getenv("SENDGRID_SENDER_ADDRESS", default="OOPS, please set env var called 'SENDGRID_SENDER_ADDRESS'")

Sending Emails

After you have configured your credentials, use the code below to send yourself an email:

from sendgrid import SendGridAPIClient
from sendgrid.helpers.mail import Mail

client = SendGridAPIClient(SENDGRID_API_KEY)
print("CLIENT:", type(client)) #> <class 'sendgrid.sendgrid.SendGridAPIClient>

subject = "Your Receipt from the Green Grocery Store"

html_content = "Hello World"
print("HTML:", html_content)

message = Mail(
    from_email=SENDGRID_SENDER_ADDRESS, # needs to be the verified sender address
    to_emails=SENDGRID_SENDER_ADDRESS, # can specify any recipient address, but self-sending here for demo purposes
    subject=subject,
    html_content=html_content
)

try:
    response = client.send(message)

    print("RESPONSE:", type(response)) #> <class 'python_http_client.client.Response'>
    print(response.status_code) #> 202 indicates SUCCESS
    print(response.body)
    print(response.headers)

except Exception as err:
    print(type(err))
    print(err)

NOTE: if you see a status code of 202, it means the message was sent successfully

Check your inbox:

NOTE: this message might take a minute to send, and it might be in your spam folder to start (in which case click "this email looks safe")

Customizing HTML Content

For the mail object's html_content parameter, we can use a simple string like the example above, or we can start to use some HTML content:

html_content = "Hello <strong>World</strong>"
print(html_content)
html_content = f"""
<h3>Hello this is your receipt</h3>
<p>Date: ____________</p>
<ol>
    <li>You ordered: Product 1</li>
    <li>You ordered: Product 2</li>
    <li>You ordered: Product 3</li>
</ol>
"""
print(html_content)

NOTE: for students unfamiliar with HTML syntax, first see these notes about Basic HTML and HTML Lists.

Attachments

References:

Send email with file attachment(s):

import base64
from sendgrid import SendGridAPIClient
from sendgrid.helpers.mail import Mail, Attachment, FileContent, FileName, FileType, Disposition, ContentId

#
# PREPARE MESSAGE
#

subject="Unemployment"
html="<p>This is your Unemployment Report! See attached files.</p>"

client = SendGridAPIClient(SENDGRID_API_KEY)
message = Mail(
    from_email=SENDGRID_SENDER_ADDRESS,
    to_emails=SENDGRID_SENDER_ADDRESS,
    subject=subject,
    html_content=html
)

# encoding CSV files:
encoded_csv = base64.b64encode(df.to_csv(index=False).encode()).decode()

# attaching the file:
message.attachment = Attachment(
    file_content = FileContent(encoded_csv),
    file_type = FileType('text/csv'),
    file_name = FileName('unemployment_report.csv'),
    disposition = Disposition('attachment'),
    content_id = ContentId('Attachment 1')
)

# encoding binary files, like PDFs or images:
img_filepath = "my_image.png" # path / name of existing file
with open(img_filepath, 'rb') as f:
    data = f.read()
    f.close()
encoded_img = base64.b64encode(data).decode()

# attach the file:
message.attachment = Attachment(
    file_content = FileContent(encoded_img),
    file_type = FileType('image/png'),
    file_name = FileName('unemployment_chart.png'),
    disposition = Disposition('attachment'),
    content_id = ContentId('Attachment 2')
)

#
# SEND MESSAGE
#

response = client.send(message)
print(response.status_code)

NOTE: common file attachment types include:

  • 'text/csv'
  • 'image/png'
  • 'image/jpeg'
  • 'application/pdf'