Hello Varma,
If your requirement is to generate access token and use it in PowerShell script for checking user's group membership, you can follow the steps below:
Initially, register one Microsoft Entra ID application and add below API permissions of Application type with admin consent:
data:image/s3,"s3://crabby-images/8dafb/8dafbf4e487b68d2898b965674bc8d38f2a52d21" alt="enter image description here"
In my case, I have one user named Sri as a member of Global-Admins
group:
data:image/s3,"s3://crabby-images/1d475/1d47545ebbeb46f206595362f2a74391323ea328" alt="enter image description here"
You can make use of below PowerShell script to generate access token and check user's group membership:
function Get-Token {
$TenantID = "tenantId"
$ClientID = "appId"
$ClientSecret = "secretValue"
$TokenUri = "https://login.microsoftonline.com/$TenantID/oauth2/v2.0/token"
$Body = @{
client_id = $ClientID
client_secret = $ClientSecret
scope = "https://graph.microsoft.com/.default"
grant_type = "client_credentials"
}
try {
$Response = Invoke-RestMethod -Method Post -Uri $TokenUri -Body $Body
return $Response.access_token
}
catch {
return $null
}
}
function Is-UserInAADGroup {
param ([string]$UserEmail)
$aadtoken = Get-Token
if (-not $aadtoken) {
return $false
}
$GraphUri = "https://graph.microsoft.com/v1.0/users/$UserEmail/transitiveMemberOf"
$Headers = @{ Authorization = "Bearer $aadtoken"; "Content-Type" = "application/json" }
$AdminGroups = @("Global-Admins", "Security-Admins") | ForEach-Object { $_.ToLower().Trim() }
$AllGroups = @()
try {
do {
$Response = Invoke-RestMethod -Uri $GraphUri -Headers $Headers -Method Get
$AllGroups += $Response.value
$GraphUri = $Response.'@odata.nextLink'
} while ($GraphUri)
foreach ($Group in $AllGroups) {
if ($Group.PSObject.Properties["displayName"] -and $Group.displayName) {
$GroupName = $Group.displayName.Trim().ToLower()
if ($Group."@odata.type" -eq "#microsoft.graph.group" -and ($AdminGroups -contains $GroupName)) {
Write-Host "User: $UserEmail is a member of group $($Group.displayName), skipping deletion."
return $true
}
}
}
return $false
}
catch {
return $false
}
}
$UserEmail = "******@xxxxxxxxxxx.onmicrosoft.com"
$IsAdmin = Is-UserInAADGroup -UserEmail $UserEmail
if ($IsAdmin) {
Write-Host "$UserEmail is an admin."
} else {
Write-Host "$UserEmail is not an admin."
}
Response:
data:image/s3,"s3://crabby-images/e7901/e7901705a4df499c48a09c722d50a0f02163c7da" alt="enter image description here"
Please do not forget to "Accept the answer” and “up-vote” wherever the information provided helps you, this can be beneficial to other community members.
data:image/s3,"s3://crabby-images/73957/739570c7cf8026ef7281923057e69547866fee92" alt="User's image"
If you have any other questions or are still running into more issues, let me know in the "comments" and I would be happy to help you.