directoryservice-verifygroupmembers.ps1 - powershell script by ActiveXperts Software
directoryservice-verifygroupmembers.ps1 checks all members of a defined group.
Use directoryservice-verifygroupmembers.ps1 directly from ActiveXperts Network Monitor; in the Manager's 'Monitor' menu, select 'New Check (Script)' and select directoryservice-verifygroupmembers.ps1. Configure the required parameter, or press 'Load a working sample'.
In ActiveXperts Network Monitor, Administrators can use three different scripting languages: Powershell, VBScript and SSH.
directoryservice-verifygroupmembers.ps1 script code
#################################################################################
# ActiveXperts Network Monitor PowerShell script, © ActiveXperts Software B.V.
# For more information about ActiveXperts Network Monitor, visit the ActiveXperts
# Network Monitor web site at http://www.activexperts.com
# Last Modified:
#################################################################################
# Script
# DirectoryService-VerifyGroupMembers.ps1
# Description:
# Check all members of strGroup. If an element of this group is not member of the strMemberList, then False is returned.
# Use it to check if the Domain Admin or Enterprise Admin group has no unexpected members.
# Declare Parameters:
# 1) strDomain (string) - Domain that holds the user- and group account
# 2) strGroup (string) - Domain group name
# 3) strUser (string) - User name
# Usage:
# .\DirectoryService-VerifyGroupMembers.ps1 '<Domain>' '<Domain Group>' '<Domain User[,Domain User]*>'
# Sample:
# .\DirectoryService-VerifyGroupMembers.ps1 'DOMAIN01' 'Administrators' 'Administrator,James,William'
#################################################################################
# -- Declare Parameters
param( [string]$strDomain, [string]$strGroup, [string]$strMemberList )
# -- Use _activexperts.ps1 with common functions
. 'C:\Program Files\ActiveXperts\Network Monitor\Scripts\Monitor (ps1)\_activexperts.ps1'
#################################################################################
# // --- Main script ---
#################################################################################
# -- Clear screen and clear error
cls
$Error.Clear()
# -- Validate parameters, return on parameter mismatch
if( $strDomain -eq '' -or $strGroup -eq '' -or $strMemberList -eq '' )
{
$res = 'UNCERTAIN: Invalid number of parameters - Usage: .\DirectoryService-VerifyGroupMembers.ps1 "<Domain>" "<Domain Group>" "<Domain User>"'
echo $res
exit
}
$command = 'WinNT://' + $strDomain + '/' + $strGroup + ',group'
$objGroup = [ADSI]$command
if( $objGroup.Name -eq $null )
{
$res = 'UNCERTAIN: Domain [' + $strDomain + '] or Group [' + $strGroup + '] not found.'
echo $res
exit
}
$arrUsers = $strMemberList.Split( ',' )
$objMembers = @( $objGroup.psbase.Invoke( 'Members' ) )
$bError = 0
foreach( $objUser in $objMembers )
{
$memberName = $objUser.GetType().InvokeMember("Name", 'GetProperty', $null, $objUser , $null)
foreach( $user in $arrUsers )
{
$bMemberFound = $false
if( $user.ToUpper().Trim() -eq $memberName )
{
$bMemberFound = $true
break # Exit the foreach loop
}
}
if( -not $bMemberFound )
{
$result = $false
$res = 'ERROR:User [' + $memberName + '] is not allowed as a member of group [' + $strGroup + ']'
echo $res
exit # End the script
}
}
if( $bError -eq 0 )
{
$res = 'SUCCESS: All members of group [' + $strGroup + '] are allowed members.'
}
else
{
$res = $res.trimend(',') + '] where not found.'
}
# -- Print script result
echo $res
exit
#################################################################################
# // --- Catch script exceptions ---
#################################################################################
trap [Exception]
{
$res = 'UNCERTAIN: ' + $_.Exception.Message
echo $res
exit
}
