Microsoft Graph Explorer
MetaData
MetaData is like Get-Member which shows all properties can be called using Graph API. It includes Property Name, NavigationProperty Name [Related Object].
Open Browser
https://graph.microsoft.com/v1.0/$metadata
Look For :
EntityType name="User"
EntityType name="group"
data:image/s3,"s3://crabby-images/9ae12/9ae123cc6cbee2735185a7b65350a7ae48b684b5" alt=""
OData : Open Data is a protocol that is used for a creation of an API’s which is used to expose data over https.
$Var = Invoke-RestMethod -Uri "https://graph.microsoft.com/v1.0"
data:image/s3,"s3://crabby-images/5c24c/5c24c0192336481cf7a81b016be74ec0b2a11150" alt=""
Kind Property
DirectoryReadAll : Will provide you User license details
Microsoft Graph API
data:image/s3,"s3://crabby-images/9ca1c/9ca1c6087554c37cf4dca27730e948cde745ef4b" alt=""
HTTP Methods
data:image/s3,"s3://crabby-images/6a05a/6a05aa48f112c2da2514c022891b184a67b2f7c0" alt=""
Request Structure
data:image/s3,"s3://crabby-images/47f89/47f89c1b01e1d80890f611929bf27b8f4a7d0b10" alt=""
data:image/s3,"s3://crabby-images/927c2/927c2e1ed8e29e785b0b815afe8eb06f93e0be8d" alt=""
PATCH [Update] : Requires UserReadWriteAll Permission
data:image/s3,"s3://crabby-images/7e169/7e1696e50f0ae7c104d5adee83c3e87ab1a7dd70" alt=""
Microsoft Graph User
https://graph.microsoft.com/beta/$metadata
Find :
EntityType Name="user"
Property Name
NavigationProperty Name [Related Object]
data:image/s3,"s3://crabby-images/35e56/35e56aeb3bb2397cf6bdadc77be1ec5ecc6b7768" alt=""
https://graph.microsoft.com/beta/users/rohit@rohit.club/manageddevices
data:image/s3,"s3://crabby-images/e64bb/e64bb005f0ba7d084fff57d7f398be9ee9ecaad0" alt=""
Microsoft Graph Delta Endpoints
data:image/s3,"s3://crabby-images/69a9b/69a9bc0e4f61846e853f6d937088c2a3e7180a7d" alt=""
When you perform Delta then only the incremental value of all the users will be displayed.
'https://graph.microsoft.com/v1.0/users/delta'
If you want to have specific data which are changed then you have to Copy the @odata.nextLink value and paste it to the GET Box
Copy and keep the “@odata.nextLink” value which is generated this time if you want to see the incremental data changed for the day.
data:image/s3,"s3://crabby-images/12187/12187fd267dd18b0701ae7210394a05a3a003954" alt=""
Graph Explorer Query
https://docs.microsoft.com/en-us/graph/query-parameters#error-handling-for-query-parameters
data:image/s3,"s3://crabby-images/a351f/a351fb26c72066360f59b416a12ac328e8331c81" alt=""
data:image/s3,"s3://crabby-images/1ec61/1ec6121754f9f85947fda9d95b529be495984772" alt=""
data:image/s3,"s3://crabby-images/3195d/3195d7ba11a035aeb53d78b8df3eee6285712b74" alt=""
data:image/s3,"s3://crabby-images/c5d8a/c5d8a1191bbe25aadc01b00b67c8ec6ef0814550" alt=""
data:image/s3,"s3://crabby-images/402ca/402cadbb955711f5c5c49d1372235e15e5a84847" alt=""
data:image/s3,"s3://crabby-images/037ba/037ba62083f124534b53f6e6aa2e357ced465680" alt=""
Combining Two Query (&)
https://graph.microsoft.com/v1.0/users?$select=displayName,userPrincipalName&$count=true&$top=3
Microsoft Graph Pagination
data:image/s3,"s3://crabby-images/f7d32/f7d32ddf12097b43e3ff8665944383e19a5f2e6a" alt=""
When the API Server is unable to send all the data at once then the Server follows the paging process where it will send the 1st page with @odata.nextlink which is the link for the next page. This is called Server Side Paging.
data:image/s3,"s3://crabby-images/2a335/2a335e17901ae7a2191533228ac79321c2355ef7" alt=""
Client/Application defines the page size $top=2 which needs to be received by a Server called Client Side Pagination.
Microsoft Graph Batching
data:image/s3,"s3://crabby-images/1cb5c/1cb5c52081e5e65dfd461de21415420247c67970" alt=""
Batching is the process of combining multiple Queries into one single Query and sending it to Microsoft Graph API.
Example:data:image/s3,"s3://crabby-images/b1889/b18893b759f8d22fb728e752ec32b3c96e27ad1a" alt=""
data:image/s3,"s3://crabby-images/3f1a0/3f1a043742f480b436686e4a1215da360a4d97a8" alt=""
Oauth 2.0 Client Credential Flow
data:image/s3,"s3://crabby-images/181fa/181fa5ae02c10f6ae8c6ceed9ec625828cd61b4e" alt=""
This type of grant is commonly used for server-to-server interactions that must run in the background, without immediate interaction with a user. These types of applications are often referred to as daemons or service accounts.
The Endpoint will be used for this type of flow is Token endpoint.
&Grant_Type=Client_Credentials(check the below image)
data:image/s3,"s3://crabby-images/d5732/d5732c677d3bc5bc8eba5246075e88f570fc072b" alt=""
Open Id Connect
data:image/s3,"s3://crabby-images/9be3c/9be3cec0f10579e18f24359c5fc5af3bee0593f9" alt=""
data:image/s3,"s3://crabby-images/dc115/dc1157ba938cd914f5da68bc89f8987d00c53c81" alt=""