I was investigating an issue with our identity provider and out of date passwords the other day. I needed to do a date comparison to find accounts with expired passwords. In the past I’d used (Get-Date).AddDays() and done an evaluation. It works, but to me the code is hard to read.

I stumbled on the New-Timespan cmdlet which creates a timespan object. Creating a timespan object and referencing the days property is so much easier to read when you look at the code.

Here’s an example of it in use to find accounts with expired passwords.

$OU = ""
$AllUsers = Get-ADUser -Filter * -SearchBase $OU -Properties passwordlastset | Where-Object Enabled -eq $True
$Over90 = @()
foreach ($User in $AllUsers) {
$DateCheck = (New-TimeSpan -Start $User.passwordlastset -End (Get-Date)).Days
if ($DateCheck -gt 90) {
$OutObjectParams = [ordered]@{
SamAccountName = $User.SamAccountName
DaysPast90 = $DateCheck
PasswordLastSet = $User.PasswordLastSet
}
$Over90 += New-Object -TypeName psobject -Property $OutObjectParams
}
}
$Over90
view raw NewTimeSpan hosted with ❤ by GitHub

The $DateCheck variable is an integer of the number of days between the PasswordLastSet and Today.

The result is easy to check, and it makes the If condition simple too . It’s a number.

I was happy to find something new in PowerShell.