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
(AutoIt) OneNote - Create PageCreates a new OneNote page with a rendered image and an attached PDF. For more information, see https://docs.microsoft.com/en-us/graph/api/section-post-pages?view=graph-rest-1.0
; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. $oHttp = ObjCreate("Chilkat.Http") Local $bSuccess ; To create a OneNote page, we want to send an HTTP request like the following: ; POST https://graph.microsoft.com/v1.0/me/onenote/sections/{section_id}/pages ; Content-length: 312 ; Content-type: multipart/form-data; boundary=MyPartBoundary198374 ; ; --MyPartBoundary198374 ; Content-Disposition:form-data; name="Presentation" ; Content-Type:text/html ; ; <!DOCTYPE html> ; <html> ; <head> ; <title>A page with <i>rendered</i> images and an <b>attached</b> file</title> ; <meta name="created" content="2015-07-22T09:00:00-08:00" /> ; </head> ; <body> ; <p>Here's an image from an online source:</p> ; <img src="https://..." alt="an image on the page" width="500" /> ; <p>Here's an image uploaded as binary data:</p> ; <img src="name:imageBlock1" alt="an image on the page" width="300" /> ; <p>Here's a file attachment:</p> ; <object data-attachment="FileName.pdf" data="name:fileBlock1" type="application/pdf" /> ; </body> ; </html> ; ; --MyPartBoundary198374 ; Content-Disposition:form-data; name="imageBlock1" ; Content-Type:image/jpeg ; ; ... binary image data ... ; ; --MyPartBoundary198374 ; Content-Disposition:form-data; name="fileBlock1" ; Content-Type:application/pdf ; ; ... binary file data ... ; ; --MyPartBoundary198374-- ; Build the request in a Chilkat HTTP request object: $oReq = ObjCreate("Chilkat.HttpRequest") ; Our URL is https://graph.microsoft.com/v1.0/me/onenote/sections/{section_id}/pages ; The path part of the URL is "/v1.0/me/onenote/sections/{section_id}/pages" ; In this example, our section ID is "0-3A33FCEB9B74CC15!20350" $oReq.Path = "/v1.0/me/onenote/sections/0-3A33FCEB9B74CC15!20350/pages" ; We'll be sending a POST. $oReq.HttpVerb = "POST" ; The Content-Type is multipart/form-data ; Chilkat will automatically generate a boundary string. $oReq.ContentType = "multipart/form-data" ; When Chilkat HTTP was written many years ago, multipart requests were primarily for uploads. ; Thus the names of methods that add a multipart section end with "ForUpload". ; The multipart request we wish to build has 3 sections: text/html, image/jpeg, and application/pdf. ; ------------------------------ ; Add the text/html part. ; ------------------------------ $oSbHtml = ObjCreate("Chilkat.StringBuilder") Local $bCrlf = True $oSbHtml.AppendLine("<!DOCTYPE html>",$bCrlf) $oSbHtml.AppendLine("<html>",$bCrlf) $oSbHtml.AppendLine(" <head>",$bCrlf) $oSbHtml.AppendLine(" <title>A page with <i>rendered</i> images and an <b>attached</b> file</title>",$bCrlf) $oSbHtml.AppendLine(" <meta name=""created"" content=""TIMESTAMP_CURRENT"" />",$bCrlf) $oSbHtml.AppendLine(" </head>",$bCrlf) $oSbHtml.AppendLine(" <body>",$bCrlf) $oSbHtml.AppendLine(" <p>Here's an image from an online source:</p>",$bCrlf) $oSbHtml.AppendLine(" <img src=""https://www.chilkatsoft.com/images/starfish.jpg"" alt=""an image on the page"" width=""500"" />",$bCrlf) $oSbHtml.AppendLine(" <p>Here's an image uploaded as binary data:</p>",$bCrlf) $oSbHtml.AppendLine(" <img src=""name:imageBlock1"" alt=""an image on the page"" width=""300"" />",$bCrlf) $oSbHtml.AppendLine(" <p>Here's a file attachment:</p>",$bCrlf) $oSbHtml.AppendLine(" <object data-attachment=""FileName.pdf"" data=""name:fileBlock1"" type=""application/pdf"" />",$bCrlf) $oSbHtml.AppendLine(" </body>",$bCrlf) $oSbHtml.AppendLine("</html>",$bCrlf) $oDtNow = ObjCreate("Chilkat.CkDateTime") $oDtNow.SetFromCurrentSystemTime() Local $iNumReplaced = $oSbHtml.Replace("TIMESTAMP_CURRENT",$oDtNow.GetAsTimestamp(True)) $oReq.AddStringForUpload2("Presentation","",$oSbHtml.GetAsString(),"utf-8","text/html") ; ------------------------------ ; Add the JPG image. ; ------------------------------ $bSuccess = $oReq.AddFileForUpload2("imageBlock1","qa_data/jpg/penguins2.jpg","image/jpeg") If ($bSuccess = False) Then ConsoleWrite($oReq.LastErrorText & @CRLF) Exit EndIf ; ------------------------------ ; Add the PDF attachment. ; ------------------------------ $oBdPdf = ObjCreate("Chilkat.BinData") $bSuccess = $oBdPdf.LoadFile("qa_data/pdf/helloWorld.pdf") If ($bSuccess = False) Then ConsoleWrite("Failed to load PDF file." & @CRLF) Exit EndIf $bSuccess = $oReq.AddBdForUpload("fileBlock1","FileName.pdf",$oBdPdf,"application/pdf") If ($bSuccess = False) Then ConsoleWrite($oReq.LastErrorText & @CRLF) Exit EndIf ; Adds the "Authorization: Bearer ACCESS_TOKEN" header. $oHttp.AuthToken = "ACCESS_TOKEN" ; POST to https://graph.microsoft.com/v1.0/me/onenote/sections/{section_id}/pages ; The path part of the URL is already specified in the req object. ; We only need to specify the domain and the fact that we're doing "https" (SSL/TLS). Local $oResp = $oHttp.SynchronousRequest("graph.microsoft.com",443,True,$oReq) If ($oHttp.LastMethodSuccess = False) Then ConsoleWrite($oHttp.LastErrorText & @CRLF) Exit EndIf $oSbResponseBody = ObjCreate("Chilkat.StringBuilder") $oResp.GetBodySb($oSbResponseBody) $oJResp = ObjCreate("Chilkat.JsonObject") $oJResp.LoadSb($oSbResponseBody) $oJResp.EmitCompact = False ConsoleWrite("Response status code: " & $oResp.StatusCode & @CRLF) ConsoleWrite("Response Body:" & @CRLF) ConsoleWrite($oJResp.Emit() & @CRLF) Local $iRespStatusCode = $oResp.StatusCode ConsoleWrite("Response Status Code = " & $iRespStatusCode & @CRLF) If ($iRespStatusCode >= 400) Then ConsoleWrite("Response Header:" & @CRLF) ConsoleWrite($oResp.Header & @CRLF) ConsoleWrite("Failed." & @CRLF) Exit EndIf ; Sample JSON response: ; (Sample code for parsing the JSON response is shown below) ; { ; "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('admin%40chilkat.io')/onenote/sections('0-3A33FCEB9B74CC15%2120350')/pages/$entity", ; "id": "0-18ac61117a664f7e946bcceaeebd6f57!36-3A33FCEB9B74CC15!20350", ; "self": "https://graph.microsoft.com/v1.0/users/admin@chilkat.io/onenote/pages/0-18ac61117a664f7e946bcceaeebd6f57!36-3A33FCEB9B74CC15!20350", ; "createdDateTime": "2020-10-22T19:02:12Z", ; "title": "A page with rendered images and an attached file", ; "createdByAppId": "WLID-00000000441C9990", ; "contentUrl": "https://graph.microsoft.com/v1.0/users/admin@chilkat.io/onenote/pages/0-18ac61117a664f7e946bcceaeebd6f57!36-3A33FCEB9B74CC15!20350/content", ; "lastModifiedDateTime": "2020-10-23T00:02:13.3254289Z", ; "links": { ; "oneNoteClientUrl": { ; "href": "onenote:https://d.docs.live.net/3a33fceb9b74cc15/Documents/Testing%20Notebook/Ddd.one#A%20page%20with%20rendered%20images%20and%20an%20attached%20file§ion-id=9d78c221-486e-45f8-8355-1810e475f6c0&page-id=36cd1982-1ef1-4b11-b5a1-30b3dbc43d05&end" ; }, ; "oneNoteWebUrl": { ; "href": "https://onedrive.live.com/redir.aspx?cid=3a33fceb9b74cc15&page=edit&resid=3A33FCEB9B74CC15!20344&parId=3A33FCEB9B74CC15!187&wd=target%28Ddd.one%7C9d78c221-486e-45f8-8355-1810e475f6c0%2FA%20page%20with%20rendered%20images%20and%20an%20attached%20file%7C36cd1982-1ef1-4b11-b5a1-30b3dbc43d05%2F%29" ; } ; } ; } ; Sample code for parsing the JSON response... ; Use the following online tool to generate parsing code from sample JSON: ; Generate Parsing Code from JSON Local $sOdata_context = $oJResp.StringOf("""@odata.context""") Local $sId = $oJResp.StringOf("id") Local $self = $oJResp.StringOf("self") Local $sCreatedDateTime = $oJResp.StringOf("createdDateTime") Local $sTitle = $oJResp.StringOf("title") Local $sCreatedByAppId = $oJResp.StringOf("createdByAppId") Local $sContentUrl = $oJResp.StringOf("contentUrl") Local $sLastModifiedDateTime = $oJResp.StringOf("lastModifiedDateTime") Local $sLinksOneNoteClientUrlHref = $oJResp.StringOf("links.oneNoteClientUrl.href") Local $sLinksOneNoteWebUrlHref = $oJResp.StringOf("links.oneNoteWebUrl.href") |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.