Analyze AzureAD SignIn Logs with PowerShell
Hi All,
I recently had a case where i needed to access the AzureAD Signin Logs with PowerShell.
I've started at the Azure AD Signin Logs and filtered by UPN
data:image/s3,"s3://crabby-images/322da/322daa5b17ef18c82767ed609ae493e559d97ff8" alt=""
Next step was Graph Explorer where i found the needed Permissions
###############################################################################
# Graph Explorer
###############################################################################
#Go to https://aka.ms/ge
https://graph.microsoft.com/v1.0/auditLogs/signIns
https://graph.microsoft.com/v1.0/auditLogs/signIns?&$filter=startsWith(userPrincipalName,'a.bohren@icewolf.ch')
# Graph Explorer
###############################################################################
#Go to https://aka.ms/ge
https://graph.microsoft.com/v1.0/auditLogs/signIns
https://graph.microsoft.com/v1.0/auditLogs/signIns?&$filter=startsWith(userPrincipalName,'a.bohren@icewolf.ch')
data:image/s3,"s3://crabby-images/d2d29/d2d29616c7ec81062643be40794c3f22ea612d2f" alt=""
Let's connect with these Permissions (they need Admin Consent and i already have that)
#Import-Module and Connect to Microsoft Graph
Import-Module Microsoft.Graph.Reports
Connect-MgGraph -Scope AuditLog.Read.All,Directory.Read.All
Import-Module Microsoft.Graph.Reports
Connect-MgGraph -Scope AuditLog.Read.All,Directory.Read.All
data:image/s3,"s3://crabby-images/75ad9/75ad9c66e81808e95298cc57f92c571368d60352" alt=""
By default you only get 1000 Rows
#Get Signins
$Signins = Get-MgAuditLogSignIn
$Signins.Count
$Signins = Get-MgAuditLogSignIn
$Signins.Count
data:image/s3,"s3://crabby-images/ea280/ea28068a94c2bbe08526aa308fb832ae57b8e057" alt=""
Let's check the Details of one Record
#Show Details of one Record
$Signins[0] | fl
$Signins[0] | fl
data:image/s3,"s3://crabby-images/0a5de/0a5defa6efeb5235443c8db09eea46ffdae0bae2" alt=""
Do we have SignIns where RiskState is set?
#List RiskState
$Signins | where {$_.RiskState -ne "none"}
$Signins | where {$_.RiskState -ne "none"}
data:image/s3,"s3://crabby-images/29cdb/29cdb38b76bb30f982b7aaf9016554aba35279c7" alt=""
By using a Filter you can search for UPN and with the "-All" Parameter you get all Records that match the Filter
###############################################################################
# Use query parameters to customize responses
# https://docs.microsoft.com/en-us/graph/query-parameters
###############################################################################
# Use query parameters to customize responses
# https://docs.microsoft.com/en-us/graph/query-parameters
###############################################################################
#Search for a specific User
$Signins = Get-MgAuditLogSignIn -Filter "startsWith(userPrincipalName,'a.bohren@icewolf.ch')"
$Signins.Count
$Signins = Get-MgAuditLogSignIn -Filter "startsWith(userPrincipalName,'a.bohren@icewolf.ch')" -All
$Signins.Count
$Signins = Get-MgAuditLogSignIn -Filter "startsWith(userPrincipalName,'a.bohren@icewolf.ch')"
$Signins.Count
$Signins = Get-MgAuditLogSignIn -Filter "startsWith(userPrincipalName,'a.bohren@icewolf.ch')" -All
$Signins.Count
data:image/s3,"s3://crabby-images/c87fe/c87feb255d88998aa035d08c0119766f977a8216" alt=""
Now we filter for only successfull Logins, sort by date and use only the Attributes i am interested in
#List Details
$Signins | where {$_.ConditionalAccessStatus -eq "success"} | sort-Object CreatedDateTime -Descending | Format-Table UserPrincipalName, ClientAppUsed, AppDisplayName, ConditionalAccessStatus, CreatedDateTime
$Signins | where {$_.ConditionalAccessStatus -eq "success"} | sort-Object CreatedDateTime -Descending | Format-Table UserPrincipalName, ClientAppUsed, AppDisplayName, ConditionalAccessStatus, CreatedDateTime
data:image/s3,"s3://crabby-images/4eddf/4eddfef7a1d8d921f6bd9a07a530b597b0a8ab9e" alt=""
If you just need the last couple SignIns use this command
#Get latest 10 Signins for a specific User
$Signins = Get-MgAuditLogSignIn -Filter "startsWith(userPrincipalName,'a.bohren@icewolf.ch')" -Top 10
$Signins | sort-Object CreatedDateTime -Descending | Format-Table UserPrincipalName, ClientAppUsed, AppDisplayName, ConditionalAccessStatus, CreatedDateTime
$Signins = Get-MgAuditLogSignIn -Filter "startsWith(userPrincipalName,'a.bohren@icewolf.ch')" -Top 10
$Signins | sort-Object CreatedDateTime -Descending | Format-Table UserPrincipalName, ClientAppUsed, AppDisplayName, ConditionalAccessStatus, CreatedDateTime
data:image/s3,"s3://crabby-images/fa41c/fa41c9fbf8cc020d74f43efc8672c3f9b7a9feec" alt=""
Hope that help you to get startet. Now you can create your own querys built on top of that.
Happy coding.
Regards
Andres Bohren
data:image/s3,"s3://crabby-images/ad11e/ad11e6cd3cf4065dfa72ff1ff2dcf0f9f62e919c" alt=""