Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Tcl) Outlook Send Email with AttachmentsThis example sends a plain-text email with attachments. Other examples exist for:
This example applies to: Exchange Online | Office 365 | Hotmail.com | Live.com | MSN.com | Outlook.com | Passport.com
load ./chilkat.dll # Important: This example requires Chilkat v9.5.0.68 or greater. # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. set http [new_CkHttp] # Use your previously obtained access token here: # See the following examples for getting an access token: # Get Microsoft Graph OAuth2 Access Token (Azure AD v2.0 Endpoint). # Get Microsoft Graph OAuth2 Access Token (Azure AD Endpoint). # Refresh Access Token (Azure AD v2.0 Endpoint). # Refresh Access Token (Azure AD Endpoint). CkHttp_put_AuthToken $http "MICROSOFT_GRAPH_ACCESS_TOKEN" # To send mail, we'll POST to the following endpoint: # # POST /users/{id | userPrincipalName}/sendMail # # (The special keyword "me" may be used in place of a principal name.) # # Load the files to be attached. set attach1 [new_CkBinData] CkBinData_LoadFile $attach1 "qa_data/pdf/fishing.pdf" set attach2 [new_CkBinData] CkBinData_LoadFile $attach2 "qa_data/msword/sample.docx" # The body of the POST request contains JSON that specifies the email subject, body, # recipients, etc. This example will build the following JSON plain-text email: # # { # "message": { # "subject": "Sample Email with Attachments", # "body": { # "contentType": "Text", # "content": "This is the plain-text body..." # }, # "toRecipients": [ # { # "emailAddress": { # "name": "Chilkat Software", # "address": "admin@chilkat.io" # } # }, # { # "emailAddress": { # "address": "chilkat.support@gmail.com" # } # } # ], # "ccRecipients": [ # { # "emailAddress": { # "name": "Chilkat Blog", # "address": "admin@cknotes.com" # } # } # ], # "attachments": [ # { # "@odata.type": "#microsoft.graph.fileAttachment", # "name": "fishing.pdf", # "contentType": "application/pdf", # "size": <theActualSize>, # "isInline": false, # "contentBytes": "base64_data_here" # }, # { # "@odata.type": "#microsoft.graph.fileAttachment", # "name": "sample.docx", # "contentType": "application/vnd.openxmlformats-officedocument.wordprocessingml.document", # "size": <theActualSize>, # "isInline": false, # "contentBytes": "base64_data_here" # } # ] # }, # "saveToSentItems": true # } # # Build the above JSON. set json [new_CkJsonObject] CkJsonObject_UpdateString $json "message.subject" "Sample Email with Attachments" CkJsonObject_UpdateString $json "message.body.contentType" "Text" CkJsonObject_UpdateString $json "message.body.content" "This is the plain-text body..." CkJsonObject_UpdateString $json "message.toRecipients[0].emailAddress.name" "Chilkat Software" CkJsonObject_UpdateString $json "message.toRecipients[0].emailAddress.address" "admin@chilkat.io" CkJsonObject_UpdateString $json "message.toRecipients[1].emailAddress.address" "chilkat.support@gmail.com" CkJsonObject_UpdateString $json "message.ccRecipients[0].emailAddress.name" "Chilkat Blog" CkJsonObject_UpdateString $json "message.ccRecipients[0].emailAddress.address" "admin@cknotes.com" CkJsonObject_UpdateString $json "message.attachments[0].\"@odata.type\"" "#microsoft.graph.fileAttachment" CkJsonObject_UpdateString $json "message.attachments[0].name" "fishing.pdf" CkJsonObject_UpdateString $json "message.attachments[0].contentType" "application/pdf" CkJsonObject_UpdateInt $json "message.attachments[0].size" [CkBinData_get_NumBytes $attach1] CkJsonObject_UpdateBool $json "message.attachments[0].isInline" 0 CkJsonObject_UpdateBd $json "message.attachments[0].contentBytes" "base64" $attach1 CkJsonObject_UpdateString $json "message.attachments[1].\"@odata.type\"" "#microsoft.graph.fileAttachment" CkJsonObject_UpdateString $json "message.attachments[1].name" "sample.docx" CkJsonObject_UpdateString $json "message.attachments[1].contentType" "application/vnd.openxmlformats-officedocument.wordprocessingml.document" CkJsonObject_UpdateInt $json "message.attachments[1].size" [CkBinData_get_NumBytes $attach2] CkJsonObject_UpdateBool $json "message.attachments[1].isInline" 0 CkJsonObject_UpdateBd $json "message.attachments[1].contentBytes" "base64" $attach2 CkJsonObject_UpdateBool $json "saveToSentItems" 1 # ------------------------------------------------------------- # Important: This example requires Chilkat v9.5.0.68 or greater. # ------------------------------------------------------------- # Send the HTTP POST (i.e. send the HTML email) # resp is a CkHttpResponse set resp [CkHttp_PostJson3 $http "https://graph.microsoft.com/v1.0/me/sendMail" "application/json" $json] if {[CkHttp_get_LastMethodSuccess $http] != 1} then { puts [CkHttp_lastErrorText $http] delete_CkHttp $http delete_CkBinData $attach1 delete_CkBinData $attach2 delete_CkJsonObject $json exit } # The send succeeded if the response status code = 202. # In the success case, there is no response body. (We just get the response code to know that it succeeded.) if {[CkHttpResponse_get_StatusCode $resp] != 202} then { CkJsonObject_Load $json [CkHttpResponse_bodyStr $resp] CkJsonObject_put_EmitCompact $json 0 puts [CkJsonObject_emit $json] puts "Failed, response status code = [CkHttpResponse_get_StatusCode $resp]" } else { puts "Outlook Mail with Attachments Sent." } delete_CkHttpResponse $resp delete_CkHttp $http delete_CkBinData $attach1 delete_CkBinData $attach2 delete_CkJsonObject $json |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.