|  | 
Chilkat  HOME  Android™  AutoIt  C  C#  C++  Chilkat2-Python  CkPython  Classic ASP  DataFlex  Delphi DLL  Go  Java  Node.js  Objective-C  PHP Extension  Perl  PowerBuilder  PowerShell  PureBasic  Ruby  SQL Server  Swift  Tcl  Unicode C  Unicode C++  VB.NET  VBScript  Visual Basic 6.0  Visual FoxPro  Xojo Plugin
| (Unicode C) OneDrive -- Create a New FolderSee more OneDrive ExamplesDemonstrates how to create a new folder.Note: This example requires Chilkat v11.0.0 or greater. 
 #include <C_CkJsonObjectW.h> #include <C_CkHttpW.h> #include <C_CkHttpResponseW.h> void ChilkatSample(void) { BOOL success; HCkJsonObjectW json; HCkHttpW http; const wchar_t *respStr; HCkJsonObjectW jsonReqBody; HCkJsonObjectW jObj; const wchar_t *url; HCkHttpResponseW resp; success = FALSE; // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // This example uses the OAuth client credentials flow. // See How to Create an Azure App Registration for OAuth 2.0 Client Credentials // Use your client ID, client secret, and tenant ID in the following lines json = CkJsonObjectW_Create(); CkJsonObjectW_UpdateString(json,L"client_id",L"2871da2c-8176-4b7f-869b-2311aa82e743"); CkJsonObjectW_UpdateString(json,L"client_secret",L"2hu9Q~r5QuryUcEkNbg1btLtnfU1VUXzhSCG6brH"); CkJsonObjectW_UpdateString(json,L"scope",L"https://graph.microsoft.com/.default"); CkJsonObjectW_UpdateString(json,L"token_endpoint",L"https://login.microsoftonline.com/114d7ed6-71bf-4dbe-a866-748364121bf2/oauth2/v2.0/token"); http = CkHttpW_Create(); CkHttpW_putAuthToken(http,CkJsonObjectW_emit(json)); // To create a new folder, send a POST request like this: // POST /users/{user-id}/drive/items/{parent-item-id}/children // We first need to get the item-id for the folder where the new folder will be created. // This example will create a new folder named "abc" within /TestDir, // so we need the item-id for /TestDir. CkHttpW_SetUrlVar(http,L"dir_path",L"/TestDir"); CkHttpW_SetUrlVar(http,L"user_id",L"4fe732c3-322e-4a6b-b729-2fd1eb5c6104"); respStr = CkHttpW_quickGetStr(http,L"https://graph.microsoft.com/v1.0/users/{$user_id}/drive/root:{$dir_path}"); if (CkHttpW_getLastMethodSuccess(http) == FALSE) { wprintf(L"%s\n",CkHttpW_lastErrorText(http)); CkJsonObjectW_Dispose(json); CkHttpW_Dispose(http); return; } CkJsonObjectW_Load(json,respStr); if (CkHttpW_getLastStatus(http) != 200) { wprintf(L"Failed to get parent folder item id, status code = %d\n",CkHttpW_getLastStatus(http)); CkJsonObjectW_Dispose(json); CkHttpW_Dispose(http); return; } // The HTTP request body should contain JSON like this: // { // "name": "abc", // "folder": { } // } jsonReqBody = CkJsonObjectW_Create(); CkJsonObjectW_AppendString(jsonReqBody,L"name",L"abc"); jObj = CkJsonObjectW_Create(); CkJsonObjectW_AppendObject2(jsonReqBody,L"folder",jObj); wprintf(L"JSON body:\n"); wprintf(L"%s\n",CkJsonObjectW_emit(jsonReqBody)); // Set the URL var for the next request which will create the new folder. CkHttpW_SetUrlVar(http,L"parent_item_id",CkJsonObjectW_stringOf(json,L"id")); url = L"https://graph.microsoft.com/v1.0/users/{$user_id}/drive/items/{$parent_item_id}/children"; resp = CkHttpResponseW_Create(); success = CkHttpW_HttpJson(http,L"POST",url,jsonReqBody,L"application/json",resp); if (success == FALSE) { wprintf(L"%s\n",CkHttpW_lastErrorText(http)); CkJsonObjectW_Dispose(json); CkHttpW_Dispose(http); CkJsonObjectW_Dispose(jsonReqBody); CkJsonObjectW_Dispose(jObj); CkHttpResponseW_Dispose(resp); return; } CkJsonObjectW_Load(json,CkHttpResponseW_bodyStr(resp)); wprintf(L"Response:\n"); wprintf(L"%s\n",CkJsonObjectW_emit(json)); // A 201 response indicates success. if (CkHttpResponseW_getStatusCode(resp) != 201) { wprintf(L"Failed to create folder.\n"); wprintf(L"Response status code = %d\n",CkHttpResponseW_getStatusCode(resp)); } else { wprintf(L"Successfully created folder.\n"); } // A successful response: // { // "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('me')/drive/items('3A33FCEB9B74CC15%214862')/children/$entity", // "createdBy": { // "application": { // "displayName": "Chilkat", // "id": "441c9990" // }, // "user": { // "displayName": "Matt Smith", // "id": "3a33fceb9b74cc15" // } // }, // "createdDateTime": "2017-06-04T16:02:22.203Z", // "cTag": "adDozQTMzRkNFQjlCNzRDQzE1ITQ4NzAuNjM2MzIxODg5NDIyMDMwMDAw", // "eTag": "aM0EzM0ZDRUI5Qjc0Q0MxNSE0ODcwLjA", // "id": "3A33FCEB9B74CC15!4870", // "lastModifiedBy": { // "application": { // "displayName": "Chilkat", // "id": "441c9990" // }, // "user": { // "displayName": "Matt Smith", // "id": "3a33fceb9b74cc15" // } // }, // "lastModifiedDateTime": "2017-06-04T16:02:22.203Z", // "name": "abc", // "parentReference": { // "driveId": "3a33fceb9b74cc15", // "id": "3A33FCEB9B74CC15!4862", // "name": "someFolder", // "path": "/drive/root:/someFolder" // }, // "size": 0, // "webUrl": "https://1drv.ms/f/s!ABXMdJvr_DM6pgY", // "fileSystemInfo": { // "createdDateTime": "2017-06-04T16:02:22.203Z", // "lastModifiedDateTime": "2017-06-04T16:02:22.203Z" // }, // "folder": { // "childCount": 0 // } // } // // Successfully created folder. CkJsonObjectW_Dispose(json); CkHttpW_Dispose(http); CkJsonObjectW_Dispose(jsonReqBody); CkJsonObjectW_Dispose(jObj); CkHttpResponseW_Dispose(resp); } | ||||||
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.