Sample code for 30+ languages & platforms
Tcl

SendGrid -- Send Email with Attachment

See more SendGrid Examples

Sends an email with an attachment.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.

set http [new_CkHttp]

# Implements the following CURL command:

# curl --request POST \
#   --url https://api.sendgrid.com/v3/mail/send \
#   --header 'authorization: Bearer YOUR_API_KEY' \
#   --header 'Content-Type: application/json' \
#   --data '{"personalizations": [{"to": [{"email": "recipient@example.com"}]}],"from": {"email": "sender@example.com"},"subject":"Hello, World!","content": [{"type": "text/html","value": "Hey,<br>Please find attachment."}], "attachments": [{"content": "BASE64_ENCODED_CONTENT", "type": "text/plain", "filename": "attachment.txt"}]}'

# Use the following online tool to generate HTTP code from a CURL command
# Convert a cURL Command to HTTP Source Code

# Use this online tool to generate code from sample JSON:
# Generate Code to Create JSON

# The following JSON is sent in the request body.

# {
#   "personalizations": [
#     {
#       "to": [
#         {
#           "email": "recipient@example.com"
#         }
#       ]
#     }
#   ],
#   "from": {
#     "email": "sender@example.com"
#   },
#   "subject": "Hello, World!",
#   "content": [
#     {
#       "type": "text/html",
#       "value": "Hey,<br>Please find attachment."
#     }
#   ],
#   "attachments": [
#     {
#       "content": "BASE64_ENCODED_CONTENT",
#       "type": "text/plain",
#       "filename": "attachment.txt"
#     }
#   ]
# }

set json [new_CkJsonObject]

CkJsonObject_UpdateString $json "personalizations[0].to[0].email" "recipient@example.com"
CkJsonObject_UpdateString $json "from.email" "sender@example.com"
CkJsonObject_UpdateString $json "subject" "Hello, World!"
CkJsonObject_UpdateString $json "content[0].type" "text/html"
CkJsonObject_UpdateString $json "content[0].value" "Hey,<br>Please find attachment."

# Load a file to be attached.
set bd [new_CkBinData]

set success [CkBinData_LoadFile $bd "qa_data/pdf/hello.pdf"]

CkJsonObject_UpdateString $json "attachments[0].content" [CkBinData_getEncoded $bd "base64"]
CkJsonObject_UpdateString $json "attachments[0].type" "application/pdf"
CkJsonObject_UpdateString $json "attachments[0].filename" "hello.pdf"

# Adds the "Authorization: Bearer YOUR_API_KEY" header.
CkHttp_put_AuthToken $http "YOUR_API_KEY"

set resp [new_CkHttpResponse]

set success [CkHttp_HttpJson $http "POST" "https://api.sendgrid.com/v3/mail/send" $json "application/json" $resp]
if {$success == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkHttp $http
    delete_CkJsonObject $json
    delete_CkBinData $bd
    delete_CkHttpResponse $resp
    exit
}

set respStatusCode [CkHttpResponse_get_StatusCode $resp]
puts "Response Status Code = $respStatusCode"
if {$respStatusCode != 202} then {
    puts "Response Header:"
    puts [CkHttpResponse_header $resp]
    puts "Response Body:"
    puts [CkHttpResponse_bodyStr $resp]
    puts "Failed."
    delete_CkHttp $http
    delete_CkJsonObject $json
    delete_CkBinData $bd
    delete_CkHttpResponse $resp
    exit
}

puts "Success."

delete_CkHttp $http
delete_CkJsonObject $json
delete_CkBinData $bd
delete_CkHttpResponse $resp