Tcl
Tcl
OneDrive -- Create a New Folder
See more OneDrive Examples
Demonstrates how to create a new folder.Chilkat Tcl Downloads
load ./chilkat.dll
set success 0
# 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
set json [new_CkJsonObject]
CkJsonObject_UpdateString $json "client_id" "2871da2c-8176-4b7f-869b-2311aa82e743"
CkJsonObject_UpdateString $json "client_secret" "2hu9Q~r5QuryUcEkNbg1btLtnfU1VUXzhSCG6brH"
CkJsonObject_UpdateString $json "scope" "https://graph.microsoft.com/.default"
CkJsonObject_UpdateString $json "token_endpoint" "https://login.microsoftonline.com/114d7ed6-71bf-4dbe-a866-748364121bf2/oauth2/v2.0/token"
set http [new_CkHttp]
CkHttp_put_AuthToken $http [CkJsonObject_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.
CkHttp_SetUrlVar $http "dir_path" "/TestDir"
CkHttp_SetUrlVar $http "user_id" "4fe732c3-322e-4a6b-b729-2fd1eb5c6104"
set respStr [CkHttp_quickGetStr $http "https://graph.microsoft.com/v1.0/users/{$user_id}/drive/root:{$dir_path}"]
if {[CkHttp_get_LastMethodSuccess $http] == 0} then {
puts [CkHttp_lastErrorText $http]
delete_CkJsonObject $json
delete_CkHttp $http
exit
}
CkJsonObject_Load $json $respStr
if {[CkHttp_get_LastStatus $http] != 200} then {
puts "Failed to get parent folder item id, status code = [CkHttp_get_LastStatus $http]"
delete_CkJsonObject $json
delete_CkHttp $http
exit
}
# The HTTP request body should contain JSON like this:
# {
# "name": "abc",
# "folder": { }
# }
set jsonReqBody [new_CkJsonObject]
CkJsonObject_AppendString $jsonReqBody "name" "abc"
set jObj [new_CkJsonObject]
CkJsonObject_AppendObject2 $jsonReqBody "folder" $jObj
puts "JSON body:"
puts [CkJsonObject_emit $jsonReqBody]
# Set the URL var for the next request which will create the new folder.
CkHttp_SetUrlVar $http "parent_item_id" [CkJsonObject_stringOf $json "id"]
set url "https://graph.microsoft.com/v1.0/users/{$user_id}/drive/items/{$parent_item_id}/children"
set resp [new_CkHttpResponse]
set success [CkHttp_HttpJson $http "POST" $url $jsonReqBody "application/json" $resp]
if {$success == 0} then {
puts [CkHttp_lastErrorText $http]
delete_CkJsonObject $json
delete_CkHttp $http
delete_CkJsonObject $jsonReqBody
delete_CkJsonObject $jObj
delete_CkHttpResponse $resp
exit
}
CkJsonObject_Load $json [CkHttpResponse_bodyStr $resp]
puts "Response:"
puts [CkJsonObject_emit $json]
# A 201 response indicates success.
if {[CkHttpResponse_get_StatusCode $resp] != 201} then {
puts "Failed to create folder."
puts "Response status code = [CkHttpResponse_get_StatusCode $resp]"
} else {
puts "Successfully created folder."
}
# 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.
delete_CkJsonObject $json
delete_CkHttp $http
delete_CkJsonObject $jsonReqBody
delete_CkJsonObject $jObj
delete_CkHttpResponse $resp