Sample code for 30+ languages & platforms
Visual Basic 6.0

OneDrive -- List Non-Root Directory

See more OneDrive Examples

This gets the collection of DriveItem children for a non-root DriveItem. This is the same as for getting the children for the root DriveItem, except the URL includes the path to the desired non-root DriveItem.

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

Chilkat Visual Basic 6.0 Downloads

Visual Basic 6.0
Dim success As Long
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
Dim json As New ChilkatJsonObject
success = json.UpdateString("client_id","2871da2c-8176-4b7f-869b-2311aa82e743")
success = json.UpdateString("client_secret","2hu9Q~r5QuryUcEkNbg1btLtnfU1VUXzhSCG6brH")
success = json.UpdateString("scope","https://graph.microsoft.com/.default")
success = json.UpdateString("token_endpoint","https://login.microsoftonline.com/114d7ed6-71bf-4dbe-a866-748364121bf2/oauth2/v2.0/token")

Dim http As New ChilkatHttp
http.AuthToken = json.Emit()

' Send a Get request like this:
' GET /users/{user-id}/drive/root:/{item-path}:/children

' This example will get the DriveItems in /TestDir
' (In other words, we're getting the directory listing for /TestDir.)
success = http.SetUrlVar("item_path","/TestDir")
success = http.SetUrlVar("user_id","4fe732c3-322e-4a6b-b729-2fd1eb5c6104")

Dim resp As String
resp = http.QuickGetStr("https://graph.microsoft.com/v1.0/users/{$user_id}/drive/root:{$item_path}:/children")
If (http.LastMethodSuccess <> 1) Then
    Debug.Print http.LastErrorText
    Exit Sub
End If

' The response should be JSON.
json.EmitCompact = 0
success = json.Load(resp)

' A successful response should return a status code of 200.
If (http.LastStatus <> 200) Then
    Debug.Print json.Emit()
    Debug.Print "Response status = " & http.LastStatus
    Exit Sub
End If

Debug.Print json.Emit()

Dim lastMod As New CkDateTime
Dim photoTaken As New CkDateTime

' Iterate over the DriveItems in the JSON response:
Dim i As Long
i = 0
Dim numItems As Long
numItems = json.SizeOfArray("value")
Do While i < numItems
    json.I = i
    Debug.Print "-- DriveItem " & (i + 1)
    Debug.Print "id: " & json.StringOf("value[i].id")
    Debug.Print "name: " & json.StringOf("value[i].name")
    Debug.Print "size: " & json.IntOf("value[i].size")

    ' Get the lastModifiedDateTime
    success = lastMod.SetFromTimestamp(json.StringOf("value[i].fileSystemInfo.lastModifiedDateTime"))

    ' Is this a folder?
    If (json.HasMember("value[i].folder") = 1) Then
        Debug.Print "This is a folder with " & json.IntOf("value[i].folder.childCount") & " children"
    End If

    If (json.HasMember("value[i].file") = 1) Then
        Debug.Print "This is a file."
        Debug.Print "SHA1 hash: " & json.StringOf("value[i].file.hashes.sha1Hash")
        Debug.Print "mimeType: " & json.StringOf("value[i].mimeType")
    End If

    If (json.HasMember("value[i].image") = 1) Then
        Debug.Print "This is an image."
        Debug.Print "height: " & json.IntOf("value[i].image.height")
        Debug.Print "width: " & json.IntOf("value[i].image.width")
    End If

    If (json.HasMember("value[i].photo") = 1) Then
        Debug.Print "This is a photo."
        success = photoTaken.SetFromTimestamp(json.StringOf("value[i].photo.takenDateTime"))
        Debug.Print "photo taken on " & photoTaken.GetAsRfc822(1)
    End If

    If (json.HasMember("value[i].audio") = 1) Then
        Debug.Print "This is an audio file."
        Debug.Print "duration: " & json.IntOf("value[i].audio.duration")
    End If

    i = i + 1
Loop