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) 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
load ./chilkat.dll # This example assumes the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. set http [new_CkHttp] # 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: set req [new_CkHttpRequest] # 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" CkHttpRequest_put_Path $req "/v1.0/me/onenote/sections/0-3A33FCEB9B74CC15!20350/pages" # We'll be sending a POST. CkHttpRequest_put_HttpVerb $req "POST" # The Content-Type is multipart/form-data # Chilkat will automatically generate a boundary string. CkHttpRequest_put_ContentType $req "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. # ------------------------------ set sbHtml [new_CkStringBuilder] set bCrlf 1 CkStringBuilder_AppendLine $sbHtml "<!DOCTYPE html>" $bCrlf CkStringBuilder_AppendLine $sbHtml "<html>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <head>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <title>A page with <i>rendered</i> images and an <b>attached</b> file</title>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <meta name=\"created\" content=\"TIMESTAMP_CURRENT\" />" $bCrlf CkStringBuilder_AppendLine $sbHtml " </head>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <body>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <p>Here's an image from an online source:</p>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <img src=\"https://www.chilkatsoft.com/images/starfish.jpg\" alt=\"an image on the page\" width=\"500\" />" $bCrlf CkStringBuilder_AppendLine $sbHtml " <p>Here's an image uploaded as binary data:</p>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <img src=\"name:imageBlock1\" alt=\"an image on the page\" width=\"300\" />" $bCrlf CkStringBuilder_AppendLine $sbHtml " <p>Here's a file attachment:</p>" $bCrlf CkStringBuilder_AppendLine $sbHtml " <object data-attachment=\"FileName.pdf\" data=\"name:fileBlock1\" type=\"application/pdf\" />" $bCrlf CkStringBuilder_AppendLine $sbHtml " </body>" $bCrlf CkStringBuilder_AppendLine $sbHtml "</html>" $bCrlf set dtNow [new_CkDateTime] CkDateTime_SetFromCurrentSystemTime $dtNow set numReplaced [CkStringBuilder_Replace $sbHtml "TIMESTAMP_CURRENT" [CkDateTime_getAsTimestamp $dtNow 1]] CkHttpRequest_AddStringForUpload2 $req "Presentation" "" [CkStringBuilder_getAsString $sbHtml] "utf-8" "text/html" # ------------------------------ # Add the JPG image. # ------------------------------ set success [CkHttpRequest_AddFileForUpload2 $req "imageBlock1" "qa_data/jpg/penguins2.jpg" "image/jpeg"] if {$success == 0} then { puts [CkHttpRequest_lastErrorText $req] delete_CkHttp $http delete_CkHttpRequest $req delete_CkStringBuilder $sbHtml delete_CkDateTime $dtNow exit } # ------------------------------ # Add the PDF attachment. # ------------------------------ set bdPdf [new_CkBinData] set success [CkBinData_LoadFile $bdPdf "qa_data/pdf/helloWorld.pdf"] if {$success == 0} then { puts "Failed to load PDF file." delete_CkHttp $http delete_CkHttpRequest $req delete_CkStringBuilder $sbHtml delete_CkDateTime $dtNow delete_CkBinData $bdPdf exit } set success [CkHttpRequest_AddBdForUpload $req "fileBlock1" "FileName.pdf" $bdPdf "application/pdf"] if {$success == 0} then { puts [CkHttpRequest_lastErrorText $req] delete_CkHttp $http delete_CkHttpRequest $req delete_CkStringBuilder $sbHtml delete_CkDateTime $dtNow delete_CkBinData $bdPdf exit } # Adds the "Authorization: Bearer ACCESS_TOKEN" header. CkHttp_put_AuthToken $http "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). # resp is a CkHttpResponse set resp [CkHttp_SynchronousRequest $http "graph.microsoft.com" 443 1 $req] if {[CkHttp_get_LastMethodSuccess $http] == 0} then { puts [CkHttp_lastErrorText $http] delete_CkHttp $http delete_CkHttpRequest $req delete_CkStringBuilder $sbHtml delete_CkDateTime $dtNow delete_CkBinData $bdPdf exit } set sbResponseBody [new_CkStringBuilder] CkHttpResponse_GetBodySb $resp $sbResponseBody set jResp [new_CkJsonObject] CkJsonObject_LoadSb $jResp $sbResponseBody CkJsonObject_put_EmitCompact $jResp 0 puts "Response status code: [CkHttpResponse_get_StatusCode $resp]" puts "Response Body:" puts [CkJsonObject_emit $jResp] set respStatusCode [CkHttpResponse_get_StatusCode $resp] puts "Response Status Code = $respStatusCode" if {$respStatusCode >= 400} then { puts "Response Header:" puts [CkHttpResponse_header $resp] puts "Failed." delete_CkHttpResponse $resp delete_CkHttp $http delete_CkHttpRequest $req delete_CkStringBuilder $sbHtml delete_CkDateTime $dtNow delete_CkBinData $bdPdf delete_CkStringBuilder $sbResponseBody delete_CkJsonObject $jResp exit } delete_CkHttpResponse $resp # 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 set odata_context [CkJsonObject_stringOf $jResp "\"@odata.context\""] set id [CkJsonObject_stringOf $jResp "id"] set self [CkJsonObject_stringOf $jResp "self"] set createdDateTime [CkJsonObject_stringOf $jResp "createdDateTime"] set title [CkJsonObject_stringOf $jResp "title"] set createdByAppId [CkJsonObject_stringOf $jResp "createdByAppId"] set contentUrl [CkJsonObject_stringOf $jResp "contentUrl"] set lastModifiedDateTime [CkJsonObject_stringOf $jResp "lastModifiedDateTime"] set linksOneNoteClientUrlHref [CkJsonObject_stringOf $jResp "links.oneNoteClientUrl.href"] set linksOneNoteWebUrlHref [CkJsonObject_stringOf $jResp "links.oneNoteWebUrl.href"] delete_CkHttp $http delete_CkHttpRequest $req delete_CkStringBuilder $sbHtml delete_CkDateTime $dtNow delete_CkBinData $bdPdf delete_CkStringBuilder $sbResponseBody delete_CkJsonObject $jResp |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.