Perl
Perl
OneDrive -- Create a New Folder
See more OneDrive Examples
Demonstrates how to create a new folder.Chilkat Perl Downloads
use chilkat();
$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
$json = chilkat::CkJsonObject->new();
$json->UpdateString("client_id","2871da2c-8176-4b7f-869b-2311aa82e743");
$json->UpdateString("client_secret","2hu9Q~r5QuryUcEkNbg1btLtnfU1VUXzhSCG6brH");
$json->UpdateString("scope","https://graph.microsoft.com/.default");
$json->UpdateString("token_endpoint","https://login.microsoftonline.com/114d7ed6-71bf-4dbe-a866-748364121bf2/oauth2/v2.0/token");
$http = chilkat::CkHttp->new();
$http->put_AuthToken($json->emit());
# 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.
$http->SetUrlVar("dir_path","/TestDir");
$http->SetUrlVar("user_id","4fe732c3-322e-4a6b-b729-2fd1eb5c6104");
$respStr = $http->quickGetStr("https://graph.microsoft.com/v1.0/users/{$user_id}/drive/root:{$dir_path}");
if ($http->get_LastMethodSuccess() == 0) {
print $http->lastErrorText() . "\r\n";
exit;
}
$json->Load($respStr);
if ($http->get_LastStatus() != 200) {
print "Failed to get parent folder item id, status code = " . $http->get_LastStatus() . "\r\n";
exit;
}
# The HTTP request body should contain JSON like this:
# {
# "name": "abc",
# "folder": { }
# }
$jsonReqBody = chilkat::CkJsonObject->new();
$jsonReqBody->AppendString("name","abc");
$jObj = chilkat::CkJsonObject->new();
$jsonReqBody->AppendObject2("folder",$jObj);
print "JSON body:" . "\r\n";
print $jsonReqBody->emit() . "\r\n";
# Set the URL var for the next request which will create the new folder.
$http->SetUrlVar("parent_item_id",$json->stringOf("id"));
$url = "https://graph.microsoft.com/v1.0/users/{$user_id}/drive/items/{$parent_item_id}/children";
$resp = chilkat::CkHttpResponse->new();
$success = $http->HttpJson("POST",$url,$jsonReqBody,"application/json",$resp);
if ($success == 0) {
print $http->lastErrorText() . "\r\n";
exit;
}
$json->Load($resp->bodyStr());
print "Response:" . "\r\n";
print $json->emit() . "\r\n";
# A 201 response indicates success.
if ($resp->get_StatusCode() != 201) {
print "Failed to create folder." . "\r\n";
print "Response status code = " . $resp->get_StatusCode() . "\r\n";
}
else {
print "Successfully created folder." . "\r\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.