Lianja
Lianja
Outlook -- Create Reply Email, Update, and Send
See more Outlook Examples
Creates a reply email in the Drafts folder, updates the reply with information, and then sends the reply.Chilkat Lianja Downloads
llSuccess = .F.
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
loHttp = createobject("CkHttp")
// Use your previously obtained access token here:
loHttp.AuthToken = "MICROSOFT_GRAPH_ACCESS_TOKEN"
// This example will search /Inbox for a message that will be replied to.
// First we need to get the folder ID for /Inbox.
// Then we'll search for messages based on some criteria, and reply to the 1st matching message.
// To reply, we'll create the reply message in the Drafts folder, update it with content, and the send.
// Get the folder ID for /Inbox from the folder map created by this example
loHtFolderMap = createobject("CkHashtable")
loSbMap = createobject("CkStringBuilder")
loSbMap.LoadFile("qa_data/outlook/folderMap.xml","utf-8")
loHtFolderMap.AddFromXmlSb(loSbMap)
// Get the ID for the "/Inbox" folder:
lcFolderId = loHtFolderMap.LookupStr("/Inbox")
if (loHtFolderMap.LastMethodSuccess <> .T.) then
? "Folder ID not found"
release loHttp
release loHtFolderMap
release loSbMap
return
endif
llSuccess = .T.
loJson = createobject("CkJsonObject")
loJson.EmitCompact = .F.
// Search for unread emails in this folder from support@chilkatsoft.com
loHttp.SetUrlVar("folder_id",lcFolderId)
loHttp.SetUrlVar("select","id,subject")
loHttp.SetUrlVar("filter","(isRead eq false) and (from/emailAddress/address eq 'support@chilkatsoft.com')")
loSbResponse = createobject("CkStringBuilder")
llSuccess = loHttp.QuickGetSb("https://graph.microsoft.com/v1.0/me/mailFolders/{$folder_id}/messages?$filter={$filter}&$select={$select}",loSbResponse)
if (llSuccess = .F.) then
? loHttp.LastErrorText
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
return
endif
loJson.LoadSb(loSbResponse)
// Show the results..
? loJson.Emit()
if (loJson.SizeOfArray("value") = 0) then
? "Empty result set."
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
return
endif
// Sample results:
// {
// "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('me')/mailFolders('AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEMAAAA')/messages(id,subject)",
// "value": [
// {
// "@odata.etag": "W/\"CQAAABYAAADn68XtMop0TpsYJGpfKXY9AADOpwfq\"",
// "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgBGAAADsVyfxjDU406Ic4X7ill8xAcA5_vF7TKKdE6bGCRqXyl2PQAAAgEMAAAA5_vF7TKKdE6bGCRqXyl2PQAAAM6Jj1wAAAA=",
// "subject": "This email contains a PDF attachment"
// },
// {
// "@odata.etag": "W/\"CQAAABYAAADn68XtMop0TpsYJGpfKXY9AADOpwfs\"",
// "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgBGAAADsVyfxjDU406Ic4X7ill8xAcA5_vF7TKKdE6bGCRqXyl2PQAAAgEMAAAA5_vF7TKKdE6bGCRqXyl2PQAAAM6Jj14AAAA=",
// "subject": "This email has the word Amazon in the subject.."
// }
// ]
// }
// We'll create a reply for the 1st message in the result set.
// We'll need the message existing id.
lcExistingMsgId = loJson.StringOf("value[0].id")
// To create a reply, send a request such as the following:
// POST https://graph.microsoft.com/v1.0/me/messages/{id}/createReply
// Content-type: application/json
// Content-length: 248
//
// {
// "comment": "comment-value"
// }
loJsonRequestBody = createobject("CkJsonObject")
loJsonRequestBody.UpdateString("comment","This is a comment")
loHttp.SetUrlVar("message_id",lcExistingMsgId)
// Create the reply in the Drafts folder:
loResp = createobject("CkHttpResponse")
llSuccess = loHttp.HttpJson("POST","https://graph.microsoft.com/v1.0/me/messages/{$message_id}/createReply",loJsonRequestBody,"application/json",loResp)
if (llSuccess = .F.) then
? loHttp.LastErrorText
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
release loJsonRequestBody
release loResp
return
endif
// A 201 response indicates success.
if (loResp.StatusCode = 201) then
? "Created reply draft."
llSuccess = .T.
else
? "Response status code = " + str(loResp.StatusCode)
? "Failed to create reply draft."
llSuccess = .F.
endif
// Show the response in both cases..
loJsonResponse = createobject("CkJsonObject")
loJsonResponse.EmitCompact = .F.
loJsonResponse.Load(loResp.BodyStr)
? loJsonResponse.Emit()
if (llSuccess = .F.) then
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
release loJsonRequestBody
release loResp
release loJsonResponse
return
endif
// ----------------------------------------------
// Get the message id of the newly created reply.
lcReplyMsgId = loJsonResponse.StringOf("id")
// Update the message with new text in the body..
// Send an HTTP PATCH request that looks something like this:
// Only send the message parts that are changing.
// PATCH https://graph.microsoft.com/v1.0/me/messages/{reply_message_id}
// Content-type: application/json
// Content-length: 248
//
// {
// "subject": "subject-value",
// "body": {
// "contentType": "html",
// "content": "updated HTML goes here"
// },
// "inferenceClassification": "other"
// }
loJsonPatch = createobject("CkJsonObject")
loJsonPatch.UpdateString("body.contentType","html")
// The reply email that Outlook created will contain the original message under a horizontal rule.
// The body.content should contain this substring: "<body bgcolor=\"#FFFFFF\">\r\n<hr "
// We're going to insert our reply after the body tag, and before the hr tag.
loSbHtml = createobject("CkStringBuilder")
loJsonResponse.StringOfSb("body.content",loSbHtml)
// Insert the response HTML in the reply HTML body.
lnNumReplaced = loSbHtml.ReplaceBetween('<body bgcolor="#FFFFFF">',"<hr ",Chr(13) + Chr(10),"<p>This is my response.</p>")
if (lnNumReplaced <> 1) then
? "Something is amiss!"
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
release loJsonRequestBody
release loResp
release loJsonResponse
release loJsonPatch
release loSbHtml
return
endif
loJsonPatch.UpdateString("body.content",loSbHtml.GetAsString())
// Add additional CC, BCC, or TO recipients like this:
lnNumToRecipients = loJsonResponse.SizeOfArray("toRecipients")
i = 0
// Copy existing TO recipients.
do while i < lnNumToRecipients
loJsonPatch.I = i
loJsonResponse.I = i
loJsonPatch.UpdateString("toRecipients[i].emailAddress.name",loJsonResponse.StringOf("toRecipients[i].emailAddress.name"))
loJsonPatch.UpdateString("toRecipients[i].emailAddress.address",loJsonResponse.StringOf("toRecipients[i].emailAddress.address"))
i = i + 1
enddo
// Add an additional TO recipient.
loJsonPatch.I = lnNumToRecipients
loJsonPatch.UpdateString("toRecipients[i].emailAddress.name","Chilkat")
loJsonPatch.UpdateString("toRecipients[i].emailAddress.address","admin@chilkat.io")
lnNumCcRecipients = loJsonResponse.SizeOfArray("ccRecipients")
i = 0
// Copy existing CC recipients.
do while i < lnNumCcRecipients
loJsonPatch.I = i
loJsonResponse.I = i
loJsonPatch.UpdateString("ccRecipients[i].emailAddress.name",loJsonResponse.StringOf("ccRecipients[i].emailAddress.name"))
loJsonPatch.UpdateString("ccRecipients[i].emailAddress.address",loJsonResponse.StringOf("ccRecipients[i].emailAddress.address"))
i = i + 1
enddo
// Add an additional CC recipient.
loJsonPatch.I = lnNumCcRecipients
loJsonPatch.UpdateString("ccRecipients[i].emailAddress.name","Chilkat GMail")
loJsonPatch.UpdateString("ccRecipients[i].emailAddress.address","chilkat.support@gmail.com")
loJsonPatch.EmitCompact = .F.
? loJsonPatch.Emit()
loHttp.SetUrlVar("message_id",lcReplyMsgId)
llSuccess = loHttp.HttpJson("PATCH","https://graph.microsoft.com/v1.0/me/messages/{$message_id}",loJsonPatch,"application/json",loResp)
if (llSuccess = .F.) then
? loHttp.LastErrorText
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
release loJsonRequestBody
release loResp
release loJsonResponse
release loJsonPatch
release loSbHtml
return
endif
// A 200 response indicates success.
if (loResp.StatusCode = 200) then
? "Patched the reply draft."
llSuccess = .T.
else
? "Response status code = " + str(loResp.StatusCode)
? "Failed to patch the reply draft."
llSuccess = .F.
endif
// Show the response in both cases..
loJsonResponse.Load(loResp.BodyStr)
? loJsonResponse.Emit()
if (llSuccess = .F.) then
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
release loJsonRequestBody
release loResp
release loJsonResponse
release loJsonPatch
release loSbHtml
return
endif
// ---------------------------------------------------------------------
// OK, let's send the reply email...
// To send, POST with an empty request body:
// POST https://graph.microsoft.com/v1.0/me/messages/{id}/send
llSuccess = loHttp.HttpStr("POST","https://graph.microsoft.com/v1.0/me/messages/{$message_id}/send","","","",loResp)
if (llSuccess = .F.) then
? loHttp.LastErrorText
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
release loJsonRequestBody
release loResp
release loJsonResponse
release loJsonPatch
release loSbHtml
return
endif
// A 202 response indicates success.
if (loResp.StatusCode = 202) then
? "Sent the email reply."
// If the status code was 202, there is no response body.
else
? "Response status code = " + str(loResp.StatusCode)
? "Failed to send the email reply."
loJsonResponse.Load(loResp.BodyStr)
? loJsonResponse.Emit()
endif
? "Finished."
// -----------------------------------------------------------------------
// A sample successful JSON response for the createReply looks like this:
// {
// "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#message",
// "@odata.type": "#microsoft.graph.message",
// "@odata.etag": "W/\"CQAAABYAAADn68XtMop0TpsYJGpfKXY9AADQAwR4\"",
// "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgBGAAADsVyfxjDU406Ic4X7ill8xAcA5_vF7TKKdE6bGCRqXyl2PQAAAgEPAAAA5_vF7TKKdE6bGCRqXyl2PQAAAM-lQbAAAAA=",
// "createdDateTime": "2017-06-01T14:31:56Z",
// "lastModifiedDateTime": "2017-06-01T14:31:56Z",
// "changeKey": "CQAAABYAAADn68XtMop0TpsYJGpfKXY9AADQAwR4",
// "categories": [
// ],
// "receivedDateTime": "2017-06-01T14:31:56Z",
// "sentDateTime": "2017-06-01T14:31:56Z",
// "hasAttachments": false,
// "internetMessageId": "<SN1PR20MB0461AF40FC899A8462536F04E6F60@SN1PR20MB0461.namprd20.prod.outlook.com>",
// "subject": "RE: This email contains a PDF attachment",
// "bodyPreview": "________________________________\r\nFrom: Chilkat Software <support@chilkatsoft.com>\r\nSent: Tuesday, May 30, 2017 10:58:56 PM\r\nTo: chilkatsoft@outlook.com\r\nSubject: This email contains a PDF attachment\r\n\r\nThis email contains a PDF attachment\r\n--\r\nBest Regar",
// "importance": "normal",
// "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEPAAAA",
// "conversationId": "AQQkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAQAMMaWY-CWmVOqNKt-NiVhkU=",
// "isDeliveryReceiptRequested": false,
// "isReadReceiptRequested": false,
// "isRead": true,
// "isDraft": true,
// "webLink": "https://outlook.live.com/owa/?ItemID=AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgBGAAADsVyfxjDU406Ic4X7ill8xAcA5%2BvF7TKKdE6bGCRqXyl2PQAAAgEPAAAA5%2BvF7TKKdE6bGCRqXyl2PQAAAM%2FlQbAAAAA%3D&exvsurl=1&viewmodel=ReadMessageItem",
// "inferenceClassification": "focused",
// "body": {
// "contentType": "html",
// "content": "<html>\r\n<head>\r\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\r\n<meta content=\"text/html; charset=us-ascii\">\r\n<meta content=\"text/html; charset=utf-8\">\r\n</head>\r\n<body bgcolor=\"#FFFFFF\">\r\n<hr tabindex=\"-1\" style=\"display:inline-block; width:98%\"> ... </html>\r\n"
// },
// "sender": {
// "emailAddress": {
// "name": "Matt Smith",
// "address": "chilkatsoft@outlook.com"
// }
// },
// "from": {
// "emailAddress": {
// "name": "Matt Smith",
// "address": "chilkatsoft@outlook.com"
// }
// },
// "toRecipients": [
// {
// "emailAddress": {
// "name": "Chilkat Software",
// "address": "support@chilkatsoft.com"
// }
// }
// ],
// "ccRecipients": [
// ],
// "bccRecipients": [
// ],
// "replyTo": [
// ]
// }
//
// -----------------------------------------------------------------------
// A sample successful PATCH JSON response looks like this:
// {
// "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('admin%40chilkat.io')/messages/$entity",
// "@odata.etag": "W/\"CQAAABYAAADn68XtMop0TpsYJGpfKXY9AADQAwSA\"",
// "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgBGAAADsVyfxjDU406Ic4X7ill8xAcA5_vF7TKKdE6bGCRqXyl2PQAAAgEPAAAA5_vF7TKKdE6bGCRqXyl2PQAAAM-lQbMAAAA=",
// "createdDateTime": "2017-06-01T15:18:14Z",
// "lastModifiedDateTime": "2017-06-01T15:18:17Z",
// "changeKey": "CQAAABYAAADn68XtMop0TpsYJGpfKXY9AADQAwSA",
// "categories": [
// ],
// "receivedDateTime": "2017-06-01T15:18:15Z",
// "sentDateTime": "2017-06-01T15:18:15Z",
// "hasAttachments": false,
// "internetMessageId": "<SN1PR20MB046138C4A26051200764FE38E6F60@SN1PR20MB0461.namprd20.prod.outlook.com>",
// "subject": "RE: This email has the word Amazon in the subject..",
// "bodyPreview": "This is my response.\r\n\r\n________________________________\r\nFrom: Chilkat Software <support@chilkatsoft.com>\r\nSent: Tuesday, May 30, 2017 11:40:01 PM\r\nTo: Chilkat Software\r\nSubject: This email has the word Amazon in the subject..\r\n\r\nThis email has the word ",
// "importance": "normal",
// "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEPAAAA",
// "conversationId": "AQQkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAQAE64PfPP1n1IhU4YasnNN0Q=",
// "isDeliveryReceiptRequested": false,
// "isReadReceiptRequested": false,
// "isRead": true,
// "isDraft": true,
// "webLink": "https://outlook.live.com/owa/?ItemID=AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgBGAAADsVyfxjDU406Ic4X7ill8xAcA5%2BvF7TKKdE6bGCRqXyl2PQAAAgEPAAAA5%2BvF7TKKdE6bGCRqXyl2PQAAAM%2FlQbMAAAA%3D&exvsurl=1&viewmodel=ReadMessageItem",
// "inferenceClassification": "focused",
// "body": {
// "contentType": "html",
// "content": "<html>\r\n<head>\r\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\r\n<meta content=\"text/html; charset=us-ascii\">\r\n<meta content=\"text/html; charset=us-ascii\">\r\n<meta content=\"text/html; charset=utf-8\">\r\n</head>\r\n<body bgcolor=\"#FFFFFF\">\r\n<p>This is my response.</p>\r\n<hr tabindex=\"-1\" style=\"display:inline-block; width:98%\">\r\n<div id=\"divRplyFwdMsg\" dir=\"ltr\"><font face=\"Calibri, sans-serif\" color=\"#000000\" style=\"font-size:11pt\"><b>From:</b> Chilkat Software <support@chilkatsoft.com><br>\r\n<b>Sent:</b> Tuesday, May 30, 2017 11:40:01 PM<br>\r\n<b>To:</b> Chilkat Software<br>\r\n<b>Subject:</b> This email has the word Amazon in the subject..</font>\r\n<div> </div>\r\n</div>\r\n<div><font face=\"Calibri\">This email has the word Amazon in the subject..</font><br>\r\n<div class=\"moz-signature\">-- <br>\r\nBest Regards,<br>\r\nMatt Smith<br>\r\nChilkat Software, Inc.<br>\r\n<p><a href=\"https://twitter.com/chilkatsoft\">Follow Chilkat on Twitter</a> </p>\r\n</div>\r\n</div>\r\n</body>\r\n</html>\r\n"
// },
// "sender": {
// "emailAddress": {
// "name": "Matt Smith",
// "address": "chilkatsoft@outlook.com"
// }
// },
// "from": {
// "emailAddress": {
// "name": "Matt Smith",
// "address": "chilkatsoft@outlook.com"
// }
// },
// "toRecipients": [
// {
// "emailAddress": {
// "name": "Chilkat Software",
// "address": "support@chilkatsoft.com"
// }
// }
// ],
// "ccRecipients": [
// ],
// "bccRecipients": [
// ],
// "replyTo": [
// ]
// }
release loHttp
release loHtFolderMap
release loSbMap
release loJson
release loSbResponse
release loJsonRequestBody
release loResp
release loJsonResponse
release loJsonPatch
release loSbHtml