PSScripts/Disable-OldUsers.ps1
2023-12-18 18:01:11 +00:00

31 lines
1.9 KiB
PowerShell

# Disables Active directory Users that have not been logged into for a given amount of days and saves a report to a given file path.
$threashold = -180 # Negative Integer, the age threshold of accounts that any older will be disabled.
$logPath = "C:\Logs" # String, the file path for the log to be saved to. If it does not exist it will be created.
$date = Get-Date -Format yyyy-MM-dd
$age = (Get-Date).AddDays($threashold)
$DomainCheck = Get-CimInstance -ClassName Win32_OperatingSystem
if ($DomainCheck.ProductType -ne "2") { Write-Host "Not a domain controller. Soft exiting." ; exit 0 }
$blacklistU = @(
"Administrator"
)
New-Item -ItemType Directory -Force -Path $logPath
$OldUsers = Get-ADuser -Filter * -properties Name, UserPrincipalName, SamAccountName, Enabled, WhenCreated, LastLogonDate, msDS-LastSuccessfulInteractiveLogonTime | Select-Object Name, UserPrincipalName, SamAccountName, Enabled, WhenCreated, LastLogonDate, msDS-LastSuccessfulInteractiveLogonTime | Where-Object { $_.LastLogonDate -lt $age } | Where-Object { $_.Enabled -eq $True}| Where-Object { $_.UserPrincipalName -ne $null} | Where-Object { $_.Name -notin $blacklistU} | Where-Object { $_.SamAccountName -notin $blacklistU} | Where-Object { $_.WhenCreated -lt ((Get-Date).AddDays(-14))}
foreach ($user in $OldUsers){Set-ADUser -Identity $user.SamAccountName -Enabled $false}
$OldUsers | ConvertTo-html -Property Name, UserPrincipalName, SamAccountName, WhenCreated, LastLogonDate | Out-File $logPath\$date-OldUsers.html
if (!$OldUsers) {Write-Host "No Users Accounts Disabled"; exit 0}
else {Write-Host "User accounts found that have not logged on for 180 days have been disabled. Pleased see log on Device to see details: $logPath"
if ($Host.Version.Major -gt 4){foreach ($message in $OldUsers){Write-Host $message}}
elseif ($Host.Version.Major -lt 5){foreach ($message in $OldUsers){$message}}
else {foreach ($message in $OldUsers){Write-Host $message}}
exit 1
}