Sample code for 30+ languages & platforms
Perl

OneDrive -- List Drives

See more OneDrive Examples

Example to retrieve the list of Drive resources available for a target User or Group.

Note: This example requires Chilkat v9.5.0.97 or greater.

Chilkat Perl Downloads

Perl
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());

# List drives.
# You can specify a {siteId}, {groupId}, or {userId} in the URL
# to access document libraries for a group, a site, or a specific user.
# Use your specific Id instead of what we're using here:
$http->SetUrlVar("userId","4fe732c3-322e-4a6b-b729-2fd1eb5c6104");
$resp = $http->quickGetStr("https://graph.microsoft.com/v1.0/users/{$userId}/drives");
if ($http->get_LastMethodSuccess() != 1) {
    print $http->lastErrorText() . "\r\n";
    exit;
}

# The response should be JSON.
$json->put_EmitCompact(0);
$json->Load($resp);

# A successful response should return a status code of 200.
if ($http->get_LastStatus() != 200) {
    print $json->emit() . "\r\n";
    print "Response status = " . $http->get_LastStatus() . "\r\n";
    exit;
}

print $json->emit() . "\r\n";

# Sample output:

# 	{
# 	  "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#drives",
# 	  "value": [
# 	    {
# 	      "id": "3a33fceb9b74cc15",
# 	      "driveType": "personal",
# 	      "owner": {
# 	        "user": {
# 	          "displayName": "Matt Smith",
# 	          "id": "3a33fceb9b74cc15"
# 	        }
# 	      },
# 	      "quota": {
# 	        "deleted": 0,
# 	        "remaining": 1114571275977,
# 	        "state": "normal",
# 	        "total": 1115617755136,
# 	        "used": 1046479159
# 	      }
# 	    }
# 	  ]
# 	}

# Iterate over the drives in the JSON response:
$i = 0;
$numDrives = $json->SizeOfArray("value");
while ($i < $numDrives) {
    $json->put_I($i);
    print "-- Drive " . ($i + 1) . "\r\n";
    print "id: " . $json->stringOf("value[i].id") . "\r\n";
    # The size will be a number larger than what can fit in a 32-bit integer.
    # Get the integer as a string..
    print "total: " . $json->stringOf("value[i].quota.total") . "\r\n";
    $i = $i + 1;
}