Sample code for 30+ languages & platforms
Tcl

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 Tcl Downloads

Tcl

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]

# 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:
CkHttp_SetUrlVar $http "userId" "4fe732c3-322e-4a6b-b729-2fd1eb5c6104"
set resp [CkHttp_quickGetStr $http "https://graph.microsoft.com/v1.0/users/{$userId}/drives"]
if {[CkHttp_get_LastMethodSuccess $http] != 1} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkJsonObject $json
    delete_CkHttp $http
    exit
}

# The response should be JSON.
CkJsonObject_put_EmitCompact $json 0
CkJsonObject_Load $json $resp

# A successful response should return a status code of 200.
if {[CkHttp_get_LastStatus $http] != 200} then {
    puts [CkJsonObject_emit $json]
    puts "Response status = [CkHttp_get_LastStatus $http]"
    delete_CkJsonObject $json
    delete_CkHttp $http
    exit
}

puts [CkJsonObject_emit $json]

# 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:
set i 0
set numDrives [CkJsonObject_SizeOfArray $json "value"]
while {$i < $numDrives} {
    CkJsonObject_put_I $json $i
    puts "-- Drive [expr $i + 1]"
    puts "id: [CkJsonObject_stringOf $json {value[i].id}]"
    # The size will be a number larger than what can fit in a 32-bit integer.
    # Get the integer as a string..
    puts "total: [CkJsonObject_stringOf $json {value[i].quota.total}]"
    set i [expr $i + 1]
}

delete_CkJsonObject $json
delete_CkHttp $http