Visual FoxPro
Visual FoxPro
OneNote - Create Section
See more OneNote Examples
Creates a new notebook section in Microsoft OneNoteChilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJson
LOCAL loResp
LOCAL loSbResponseBody
LOCAL loJResp
LOCAL lnRespStatusCode
LOCAL lcOdata_context
LOCAL lcId
LOCAL lcSelf
LOCAL lcCreatedDateTime
LOCAL lcDisplayName
LOCAL lcLastModifiedDateTime
LOCAL lnIsDefault
LOCAL lcPagesUrl
LOCAL lcCreatedByUserId
LOCAL lcCreatedByUserDisplayName
LOCAL lcLastModifiedByUserId
LOCAL lcLastModifiedByUserDisplayName
lnSuccess = 0
* This example assumes the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
loHttp = CreateObject('Chilkat.Http')
* Implements the following CURL command:
* curl -X POST https://graph.microsoft.com/v1.0/me/onenote/notebooks/{notebook_id}/sections \
* -H 'authorization: Bearer ACCESS_TOKEN'
* -H "Content-type: application/json" \
* -d '{
* "displayName": "Section name"
* }'
* 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.
* {
* "displayName": "Ddd"
* }
* Create a new section named "Ddd"
loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("displayName","Ddd")
loHttp.SetRequestHeader("Content-type","application/json")
* Adds the "Authorization: Bearer ACCESS_TOKEN" header.
loHttp.AuthToken = "ACCESS_TOKEN"
loHttp.SetUrlVar("notebook_id","0-3A33FCEB9B74CC15!20344")
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpJson("POST","https://graph.microsoft.com/v1.0/me/onenote/notebooks/{$notebook_id}/sections",loJson,"application/json",loResp)
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loJson
RELEASE loResp
CANCEL
ENDIF
loSbResponseBody = CreateObject('Chilkat.StringBuilder')
loResp.GetBodySb(loSbResponseBody)
loJResp = CreateObject('Chilkat.JsonObject')
loJResp.LoadSb(loSbResponseBody)
loJResp.EmitCompact = 0
? "Response Body:"
? loJResp.Emit()
lnRespStatusCode = loResp.StatusCode
? "Response Status Code = " + STR(lnRespStatusCode)
IF (lnRespStatusCode >= 400) THEN
? "Response Header:"
? loResp.Header
? "Failed."
RELEASE loHttp
RELEASE loJson
RELEASE loResp
RELEASE loSbResponseBody
RELEASE loJResp
CANCEL
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/notebooks('0-3A33FCEB9B74CC15%2120344')/sections/$entity",
* "id": "0-3A33FCEB9B74CC15!20350",
* "self": "https://graph.microsoft.com/v1.0/users/admin@chilkat.io/onenote/sections/0-3A33FCEB9B74CC15!20350",
* "createdDateTime": "2020-10-22T23:22:30.673Z",
* "displayName": "Ddd",
* "lastModifiedDateTime": "2020-10-22T23:22:30.803Z",
* "isDefault": false,
* "pagesUrl": "https://graph.microsoft.com/v1.0/users/admin@chilkat.io/onenote/sections/0-3A33FCEB9B74CC15!20350/pages",
* "createdBy": {
* "user": {
* "id": "3A33FCEB9B74CC15",
* "displayName": "Matt Smith"
* }
* },
* "lastModifiedBy": {
* "user": {
* "id": "3A33FCEB9B74CC15",
* "displayName": "Matt Smith"
* }
* }
* }
* Sample code for parsing the JSON response...
* Use the following online tool to generate parsing code from sample JSON:
* Generate Parsing Code from JSON
lcOdata_context = loJResp.StringOf('"@odata.context"')
lcId = loJResp.StringOf("id")
lcSelf = loJResp.StringOf("self")
lcCreatedDateTime = loJResp.StringOf("createdDateTime")
lcDisplayName = loJResp.StringOf("displayName")
lcLastModifiedDateTime = loJResp.StringOf("lastModifiedDateTime")
lnIsDefault = loJResp.BoolOf("isDefault")
lcPagesUrl = loJResp.StringOf("pagesUrl")
lcCreatedByUserId = loJResp.StringOf("createdBy.user.id")
lcCreatedByUserDisplayName = loJResp.StringOf("createdBy.user.displayName")
lcLastModifiedByUserId = loJResp.StringOf("lastModifiedBy.user.id")
lcLastModifiedByUserDisplayName = loJResp.StringOf("lastModifiedBy.user.displayName")
RELEASE loHttp
RELEASE loJson
RELEASE loResp
RELEASE loSbResponseBody
RELEASE loJResp