Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PowerBuilder) OneDrive -- List DrivesSee more OneDrive ExamplesExample 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. For more information, see https://learn.microsoft.com/en-us/onedrive/developer/rest-api/api/drive_list?view=odsp-graph-online
integer li_rc oleobject loo_Json oleobject loo_Http string ls_Resp integer i integer li_NumDrives // 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 // Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 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 // Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0 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 |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.