Unicode C++
Unicode C++
OneNote - Create Section
See more OneNote Examples
Creates a new notebook section in Microsoft OneNoteChilkat Unicode C++ Downloads
#include <CkHttpW.h>
#include <CkJsonObjectW.h>
#include <CkHttpResponseW.h>
#include <CkStringBuilderW.h>
void ChilkatSample(void)
{
bool success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
CkHttpW 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"
CkJsonObjectW json;
json.UpdateString(L"displayName",L"Ddd");
http.SetRequestHeader(L"Content-type",L"application/json");
// Adds the "Authorization: Bearer ACCESS_TOKEN" header.
http.put_AuthToken(L"ACCESS_TOKEN");
http.SetUrlVar(L"notebook_id",L"0-3A33FCEB9B74CC15!20344");
CkHttpResponseW resp;
success = http.HttpJson(L"POST",L"https://graph.microsoft.com/v1.0/me/onenote/notebooks/{$notebook_id}/sections",json,L"application/json",resp);
if (success == false) {
wprintf(L"%s\n",http.lastErrorText());
return;
}
CkStringBuilderW sbResponseBody;
resp.GetBodySb(sbResponseBody);
CkJsonObjectW jResp;
jResp.LoadSb(sbResponseBody);
jResp.put_EmitCompact(false);
wprintf(L"Response Body:\n");
wprintf(L"%s\n",jResp.emit());
int respStatusCode = resp.get_StatusCode();
wprintf(L"Response Status Code = %d\n",respStatusCode);
if (respStatusCode >= 400) {
wprintf(L"Response Header:\n");
wprintf(L"%s\n",resp.header());
wprintf(L"Failed.\n");
return;
}
// 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
// Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.
// See this example explaining how this memory should be used: const char * functions.
const wchar_t *odata_context = jResp.stringOf(L"\"@odata.context\"");
const wchar_t *id = jResp.stringOf(L"id");
const wchar_t *self = jResp.stringOf(L"self");
const wchar_t *createdDateTime = jResp.stringOf(L"createdDateTime");
const wchar_t *displayName = jResp.stringOf(L"displayName");
const wchar_t *lastModifiedDateTime = jResp.stringOf(L"lastModifiedDateTime");
bool isDefault = jResp.BoolOf(L"isDefault");
const wchar_t *pagesUrl = jResp.stringOf(L"pagesUrl");
const wchar_t *createdByUserId = jResp.stringOf(L"createdBy.user.id");
const wchar_t *createdByUserDisplayName = jResp.stringOf(L"createdBy.user.displayName");
const wchar_t *lastModifiedByUserId = jResp.stringOf(L"lastModifiedBy.user.id");
const wchar_t *lastModifiedByUserDisplayName = jResp.stringOf(L"lastModifiedBy.user.displayName");
}