ProjectManagementScripts/RemoveUser.ps1

65 lines
1.4 KiB
PowerShell
Raw Permalink Normal View History

2024-07-14 20:00:05 +02:00
[CmdletBinding()]
param (
[string]
$Identity,
[string]
$Server,
[string]
$ProjectName
2024-07-14 20:00:05 +02:00
)
$User = $null
$Group = $null
if(!$PSBoundParameters.ContainsKey("ProjectName")){
throw "ProjectName Parameter not specified, aborting"
return
}
if(!$PSBoundParameters.ContainsKey("Identity")){
throw "Identity Parameter not specified, aborting"
return
}
if($PSBoundParameters.ContainsKey("Server")){
$User = Get-ADUser -Server $Server -Identity $Identity
} else {
$User = Get-ADUser -Identity $Identity
}
if($null -eq $User){
throw "Didn't find the user, aborting"
return
}
if($PSBoundParameters.ContainsKey("Server")){
2024-07-15 22:47:13 +02:00
$Group = . .\GetRoles.ps1 -Server $Server -ProjectName $ProjectName
2024-07-14 20:00:05 +02:00
} else {
2024-07-15 22:47:13 +02:00
$Group = . .\GetRoles.ps1 -ProjectName $ProjectName
2024-07-14 20:00:05 +02:00
}
if($null -eq $Group){
throw "Can't find Project, aborting"
return
}
$targeGroup =$null
if($PSBoundParameters.ContainsKey("Server")){
$targeGroup = . .\GetRoles.ps1 -Server $Server -ProjectName $ProjectName
} else {
$targeGroup = . .\GetRoles.ps1 -ProjectName $ProjectName
}
if($null -eq $Group){
throw "Filter for Type was empty, aborting"
return
}
if($PSBoundParameters.ContainsKey("Server")){
$targeGroup | ForEach-Object {Remove-ADGroupMember -Identity $_ -Members $Identity -Server $Server}
2024-07-14 20:00:05 +02:00
} else {
$targeGroup | ForEach-Object {Remove-ADGroupMember -Identity $_ -Members $Identity}
2024-07-14 20:00:05 +02:00
}