Difference between revisions of "Inactive AD accounts"

From UVOO Tech Wiki
Jump to navigation Jump to search
Line 31: Line 31:
  
 
# Delete account and associated resources from AD
 
# Delete account and associated resources from AD
```
+
param (
# Define the username of the account to be removed
+
    [Parameter(Mandatory=$true)]
$username = "username_to_remove"
+
    [string]$UserName
 +
)
  
# Get the user account
+
Import-Module ActiveDirectory
$user = Get-ADUser -Identity $username -Properties MemberOf, HomeDirectory
 
  
if ($user) {
+
try {
     $groups = $user.MemberOf
+
     $user = Get-ADUser -Identity $UserName -Properties MemberOf, HomeDirectory
  
     foreach ($group in $groups) {
+
     if ($user) {
        Remove-ADGroupMember -Identity $group -Members $user -Confirm:$false
+
        $groups = $user.MemberOf
    }
+
 
 +
        foreach ($group in $groups) {
 +
            $groupObj = Get-ADGroup -Identity $group
 +
            Remove-ADGroupMember -Identity $groupObj -Members $user -Confirm:$false
 +
        }
  
    # if ($user.HomeDirectory -and (Test-Path $user.HomeDirectory)) {
+
        if ($user.HomeDirectory -and (Test-Path $user.HomeDirectory)) {
    #    Remove-Item -Path $user.HomeDirectory -Recurse -Force
+
            Remove-Item -Path $user.HomeDirectory -Recurse -Force
    #    Write-Output "Home directory $($user.HomeDirectory) has been removed."
+
            Write-Output "Home directory $($user.HomeDirectory) has been removed."
    # }
+
        }
  
    Remove-ADUser -Identity $username -Confirm:$false
+
        Remove-ADUser -Identity $UserName -Confirm:$false
  
    Write-Output "User $username has been removed from all groups and deleted from AD."
+
        Write-Output "User $UserName has been removed from all groups and deleted from AD."
} else {
+
    } else {
    Write-Output "User $username not found in AD."
+
        Write-Output "User $UserName not found in AD."
 +
    }
 +
} catch {
 +
    Write-Error "An error occurred: $_"
 +
    exit 1
 
}
 
}
 
```
 
```

Revision as of 16:29, 19 August 2024

Get inactive accounts

Import-Module ActiveDirectory
$ouPath = "OU=Some Accounts,DC=example,DC=com"
$usersNoPasswordReset = Get-ADUser -Filter {
    PasswordLastSet -gt "7/11/2023 00:00:00 AM" -and
    LastLogonDate -lt "7/11/2023 00:00:00 AM" -and
    SamAccountName -like "somesvc-*" -and
    Enabled -eq $true
} -SearchBase $ouPath -Properties PasswordLastSet, LastLogonDate, Enabled |
    Select-Object Name, SamAccountName, PasswordLastSet, LastLogonDate, Enabled
$usersNoPasswordReset | Format-Table -AutoSize

Disable Account

Import-Module ActiveDirectory

$textFilePath = "users.txt"
$usernames = Get-Content -Path $textFilePath
foreach ($username in $usernames) {
    try {
        Disable-ADAccount -Identity $username -ErrorAction Stop
        # Remove-ADUser -Identity $username -Confirm:$false -ErrorAction Stop
        Write-Output "Disabled account: $username"
    } catch {
        Write-Error "Failed to disable account: $username. Error: $_"
    }
}

Delete account and associated resources from AD

param (

   [Parameter(Mandatory=$true)]
   [string]$UserName

)

Import-Module ActiveDirectory

try {

   $user = Get-ADUser -Identity $UserName -Properties MemberOf, HomeDirectory
if ($user) {
    $groups = $user.MemberOf

    foreach ($group in $groups) {
        $groupObj = Get-ADGroup -Identity $group
        Remove-ADGroupMember -Identity $groupObj -Members $user -Confirm:$false
    }

    if ($user.HomeDirectory -and (Test-Path $user.HomeDirectory)) {
        Remove-Item -Path $user.HomeDirectory -Recurse -Force
        Write-Output "Home directory $($user.HomeDirectory) has been removed."
    }

    Remove-ADUser -Identity $UserName -Confirm:$false

    Write-Output "User $UserName has been removed from all groups and deleted from AD."
} else {
    Write-Output "User $UserName not found in AD."
}

} catch {

   Write-Error "An error occurred: $_"
   exit 1

}

<br /># more

# Remove user and remove SID from all AD Groups

Define the username of the account to be removed

$username = "username_to_remove"

Get the user account

$user = Get-ADUser -Identity $username

if ($user) {

   $groups = Get-ADUser -Identity $username -Property MemberOf | Select-Object -ExpandProperty MemberOf
foreach ($group in $groups) {
    Remove-ADGroupMember -Identity $group -Members $user -Confirm:$false
}

Remove-ADUser -Identity $username -Confirm:$false

Write-Output "User $username has been removed from all groups and deleted from AD."

} else {

   Write-Output "User $username not found in AD."

} ```