Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) Microsoft Graph -- List UsersSee more Microsoft Graph ExamplesRetrieve a list of Microsoft Graph user objects. Note: This example requires Chilkat v9.5.0.67 or greater. For more information, see https://docs.microsoft.com/en-us/graph/api/user-list?view=graph-rest-1.0&tabs=http
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Get an access token with the required scope using client credentials... Dim http As Chilkat.Http Set http = Chilkat.NewHttp Dim req As Chilkat.HttpRequest Set req = Chilkat.NewHttpRequest req.AddParam "client_secret","CLIENT_SECRET" req.AddParam "client_id","CLIENT_ID" req.AddParam "scope","https://graph.microsoft.com/.default" req.AddParam "grant_type","client_credentials" ' Use your own tenant ID, for example 4d8fdd66-66d1-43b0-ae5c-e31b4b7de5cd url = "https://login.microsoftonline.com/TENANT_ID/oauth2/v2.0/token" Set resp = http.PostUrlEncoded(url,req) If (http.LastMethodSuccess <> True) Then Debug.Print http.LastErrorText Exit Sub End If statusCode = resp.StatusCode Debug.Print "Response status code = "; statusCode Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject Dim success As Boolean success = json.Load(resp.BodyStr) ' ----------------------------------------------------- ' Use the access token obtained from above. ' Note: We don't need to re-fetch a new access token every time. An access token is valid ' for some amount of time, typically an hour (3600 seconds) ' Use your previously obtained access token here: http.AuthToken = json.StringOf("access_token") Debug.Print "access token: "; http.AuthToken Dim sbResponse As Chilkat.StringBuilder Set sbResponse = Chilkat.NewStringBuilder success = http.QuickGetSb("https://graph.microsoft.com/v1.0/users",sbResponse) If (success <> True) Then Debug.Print http.LastErrorText Exit Sub End If success = json.LoadSb(sbResponse) json.EmitCompact = False Debug.Print "Status code = "; http.LastStatus If (http.LastStatus <> 200) Then Debug.Print json.Emit() Debug.Print "Failed." End If Debug.Print json.Emit() ' Sample output ' { ' "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users", ' "value": [ ' { ' "@odata.id": "https://graph.microsoft.com/v2/6d8ddd66-68d1-43b0-af5c-e31b4b7dd5cd/directoryObjects/fca490d8-5918-4201-8079-c5dcbeafcdc9/Microsoft.DirectoryServices.User", ' "businessPhones": [ ' ], ' "displayName": "Joe Sample", ' "givenName": "Joe", ' "jobTitle": null, ' "mail": null, ' "mobilePhone": null, ' "officeLocation": null, ' "preferredLanguage": null, ' "surname": "Sample", ' "userPrincipalName": "admin_chilkatsoft.com#EXT#@adminchilkatsoft.onmicrosoft.com", ' "id": "fca490d8-5918-4201-8079-c5dcbeafcdc9" ' } ' ] ' } ' Use this online tool to generate parsing code from sample JSON: ' Generate Parsing Code from JSON odata_context = json.StringOf("""@odata.context""") i = 0 count_i = json.SizeOfArray("value") Do While i < count_i json.I = i odata_id = json.StringOf("value[i].""@odata.id""") displayName = json.StringOf("value[i].displayName") givenName = json.StringOf("value[i].givenName") jobTitle = json.StringOf("value[i].jobTitle") mail = json.StringOf("value[i].mail") mobilePhone = json.StringOf("value[i].mobilePhone") officeLocation = json.StringOf("value[i].officeLocation") preferredLanguage = json.StringOf("value[i].preferredLanguage") surname = json.StringOf("value[i].surname") userPrincipalName = json.StringOf("value[i].userPrincipalName") id = json.StringOf("value[i].id") j = 0 count_j = json.SizeOfArray("value[i].businessPhones") Do While j < count_j json.J = j j = j + 1 Loop i = i + 1 Loop |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.