PoshCode Archive  Artifact [e833bcafea]

Artifact e833bcafea797cad547e84433b128c031dc82b7fca9ee28c4f143d5de6a73274:

  • File Get-NestedGroups.ps1 — part of check-in [4cd8841824] at 2018-06-10 13:26:01 on branch trunk — Returns AD group membership, including nested groupmembership (excluding circular nested groups). (user: Jules_74 size: 3181)

# encoding: ascii
# api: powershell
# title: Get-NestedGroups
# description: Returns AD group membership, including nested groupmembership (excluding circular nested groups).
# version: 0.1
# type: script
# author: Jules_74
# license: CC0
# x-poshcode-id: 3460
# x-archived: 2012-06-22T05:41:48
# x-published: 2012-06-17T02:33:00
#
#
<#
	.SYNOPSIS
		Enumerate all AD group memberships of an account (including nested membership).
	.DESCRIPTION
		This script will return all the AD groups an account is member of.
	.PARAMETER UserName
		The username whose group memberships to find.
	.EXAMPLE
		.\Get-NestedGroups.ps1 'johndoe'

		Name                                                        DistinguishedName
		----                                                        -----------------
		Domain Users                                                CN=Domain Users,CN=Users,DC=contoso,DC=com
		Finance                                                     CN=Finance,OU=Department,OU=Groups,DC=contos...
		
	.NOTES
		ScriptName : Get-NestedGroups
		Created By : Gilbert van Griensven
		Date Coded : 06/17/2012
		
		The script iterates through all nested groups and skips circular nested groups.
	.LINK
#>
Param
	(
	[Parameter(Mandatory=$true)]$UserName
	)
Begin
	{
		Function LoadADModule {
			If (!(Get-Module ActiveDirectory)) {
				If (Get-Module -ListAvailable | ? {$_.Name -eq "ActiveDirectory"}) {
					Import-Module ActiveDirectory
					Return $True
				} Else {
					Return $False
				}
			} Else {
				Return $True
			}
		}

		Function GetNestedGroups ($strGroupDN) {
			$currentGroupmemberships = (Get-ADGroup $strGroupDN -Properties MemberOf | Select-Object MemberOf).MemberOf
			foreach ($groupDN in $currentGroupmemberships) {
				if (!(($Script:UserGroupMembership | Select-Object -ExpandProperty DistinguishedName) -contains $groupDN)) {
					$arrProps = @{
						Name = (Get-ADGroup $groupDN).Name
						DistinguishedName = $groupDN
					}
					$Script:UserGroupMembership += (New-Object psobject -Property $arrProps)
					GetNestedGroups $groupDN
				}
			}
		}

		Function FindGroupMembership ($strUsername) {
			$Script:UserGroupMembership = @()
			$arrProps = @{
				Name = "Domain Users"
				DistinguishedName = (Get-ADGroup "Domain Users").DistinguishedName
			}
			$Script:UserGroupMembership += (New-Object psobject -Property $arrProps)
			GetNestedGroups (Get-ADGroup "Domain Users").DistinguishedName
			$directMembershipGroups = (Get-ADUser $strUsername -Properties MemberOf | Select-Object MemberOf).MemberOf
			foreach ($groupDN in $directMembershipGroups) {
				$arrProps = @{
					Name = (Get-ADGroup $groupDN).Name
					DistinguishedName = $groupDN
				}
				$Script:UserGroupMembership += (New-Object psobject -Property $arrProps)
				GetNestedGroups $groupDN
			}
		}
	}
Process
	{
		If (!(LoadADModule)) {
			Write-Host "Could not load module ActiveDirectory!"
			Return
		}
		If ($UserName) {
			FindGroupMembership $UserName
			Return $Script:UserGroupMembership
		}
	}
End
	{
		Remove-Module ActiveDirectory -ErrorAction SilentlyContinue
	}