Sample code for 30+ languages & platforms
PowerBuilder

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

PowerBuilder
integer li_rc
integer li_Success
oleobject loo_Json
oleobject loo_Http
string ls_Resp
integer i
integer li_NumDrives

li_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
loo_Json = create oleobject
li_rc = loo_Json.ConnectToNewObject("Chilkat.JsonObject")
if li_rc < 0 then
    destroy loo_Json
    MessageBox("Error","Connecting to COM object failed")
    return
end if
loo_Json.UpdateString("client_id","2871da2c-8176-4b7f-869b-2311aa82e743")
loo_Json.UpdateString("client_secret","2hu9Q~~r5QuryUcEkNbg1btLtnfU1VUXzhSCG6brH")
loo_Json.UpdateString("scope","https://graph.microsoft.com/.default")
loo_Json.UpdateString("token_endpoint","https://login.microsoftonline.com/114d7ed6-71bf-4dbe-a866-748364121bf2/oauth2/v2.0/token")

loo_Http = create oleobject
li_rc = loo_Http.ConnectToNewObject("Chilkat.Http")

loo_Http.AuthToken = loo_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:
loo_Http.SetUrlVar("userId","4fe732c3-322e-4a6b-b729-2fd1eb5c6104")
ls_Resp = loo_Http.QuickGetStr("https://graph.microsoft.com/v1.0/users/{$userId}/drives")
if loo_Http.LastMethodSuccess <> 1 then
    Write-Debug loo_Http.LastErrorText
    destroy loo_Json
    destroy loo_Http
    return
end if

// The response should be JSON.
loo_Json.EmitCompact = 0
loo_Json.Load(ls_Resp)

// A successful response should return a status code of 200.
if loo_Http.LastStatus <> 200 then
    Write-Debug loo_Json.Emit()
    Write-Debug "Response status = " + string(loo_Http.LastStatus)
    destroy loo_Json
    destroy loo_Http
    return
end if

Write-Debug loo_Json.Emit()

// 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
li_NumDrives = loo_Json.SizeOfArray("value")
do while i < li_NumDrives
    loo_Json.I = i
    Write-Debug "-- Drive " + string(i + 1)
    Write-Debug "id: " + loo_Json.StringOf("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..
    Write-Debug "total: " + loo_Json.StringOf("value[i].quota.total")
    i = i + 1
loop


destroy loo_Json
destroy loo_Http