{"id":281,"date":"2014-11-25T11:59:00","date_gmt":"2014-11-25T11:59:00","guid":{"rendered":"https:\/\/blogs.technet.microsoft.com\/heyscriptingguy\/2014\/11\/25\/powertip-use-powershell-to-find-if-user-is-nested-group-member\/"},"modified":"2019-02-18T10:36:56","modified_gmt":"2019-02-18T17:36:56","slug":"powertip-use-powershell-to-find-if-user-is-nested-group-member","status":"publish","type":"post","link":"https:\/\/devblogs.microsoft.com\/scripting\/powertip-use-powershell-to-find-if-user-is-nested-group-member\/","title":{"rendered":"PowerTip: Use PowerShell to Find if User Is Nested Group Member"},"content":{"rendered":"<p><span style=\"font-size:12px\"><strong>Summary<\/strong>: U<span>se Windows PowerShell to find if a user is a nested member of a particular group.<\/span><\/span>\n<span style=\"font-size:12px\"><img decoding=\"async\" src=\"https:\/\/devblogs.microsoft.com\/wp-content\/uploads\/sites\/29\/2019\/02\/q-for-powertip.jpg\" alt=\"Hey, Scripting Guy! Question\">&nbsp;How can I use Windows PowerShell to quickly find if a user is a nested member of a particular group, <br \/>&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;for example, Domain Admins?<\/span><\/p>\n<p style=\"margin-left:30px\"><img decoding=\"async\" src=\"https:\/\/devblogs.microsoft.com\/wp-content\/uploads\/sites\/29\/2019\/02\/a-for-powertip.jpg\" alt=\"Hey, Scripting Guy! Answer\">&nbsp;Use the&nbsp;<b>-RecursiveMatch<\/b>&nbsp;LDAP filter operator:<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">Get-ADUser -Filter &#8216;memberOf &#8209;RecursiveMatch &#8220;CN=Administrators,CN=Builtin,DC=Fabrikam,DC=com&#8221;&#8216; &#8209;SearchBase &#8220;CN=Administrator,CN=Users,DC=Fabrikam,DC=com&#8221;<\/p>\n<p style=\"margin-left:60px\">If the user is a member of the group, the query returns an AD object representing the user. <br \/>If not a member of the group, the query returns nothing.<\/p>\n<p style=\"margin-left:60px\">You can even use it in a function:<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">Function Test-ADGroupMember {<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">Param ($User,$Group)<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">&nbsp; Trap {Return &#8220;error&#8221;}<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">&nbsp; If (<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">&nbsp;&nbsp;&nbsp; Get-ADUser `<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; -Filter &#8220;memberOf -RecursiveMatch &#8216;$((Get-ADGroup $Group).DistinguishedName)'&#8221; `<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; -SearchBase $((Get-ADUser $User).DistinguishedName)<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">&nbsp;&nbsp;&nbsp; ) {$true}<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">&nbsp;&nbsp;&nbsp; Else {$false}<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">}<\/p>\n<p style=\"margin-left:60px\">Now we have a simple function to check if a user is nested into a privileged group:<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">PS C:&gt; Test-ADGroupMember -User Guest -Group &#8220;Domain Admins&#8221;<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">True<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">PS C:&gt; Test-ADGroupMember -User JoeJrAdmin -Group &#8220;Domain Admins&#8221;<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">False<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">PS C:&gt; Test-ADGroupMember -User bogus -Group &#8220;Domain Admins&#8221;<\/p>\n<p class=\"Code\" style=\"margin-left:120px\">error\n&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Summary: Use Windows PowerShell to find if a user is a nested member of a particular group. &nbsp;How can I use Windows PowerShell to quickly find if a user is a nested member of a particular group, &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;for example, Domain Admins? &nbsp;Use the&nbsp;-RecursiveMatch&nbsp;LDAP filter operator: Get-ADUser -Filter &#8216;memberOf &#8209;RecursiveMatch &#8220;CN=Administrators,CN=Builtin,DC=Fabrikam,DC=com&#8221;&#8216; [&hellip;]<\/p>\n","protected":false},"author":596,"featured_media":87096,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[1],"tags":[7,313,56,3,45],"class_list":["post-281","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-scripting","tag-active-directory","tag-ashley-mcglone","tag-guest-blogger","tag-scripting-guy","tag-windows-powershell"],"acf":[],"blog_post_summary":"<p>Summary: Use Windows PowerShell to find if a user is a nested member of a particular group. &nbsp;How can I use Windows PowerShell to quickly find if a user is a nested member of a particular group, &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;for example, Domain Admins? &nbsp;Use the&nbsp;-RecursiveMatch&nbsp;LDAP filter operator: Get-ADUser -Filter &#8216;memberOf &#8209;RecursiveMatch &#8220;CN=Administrators,CN=Builtin,DC=Fabrikam,DC=com&#8221;&#8216; [&hellip;]<\/p>\n","_links":{"self":[{"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/posts\/281","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/users\/596"}],"replies":[{"embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/comments?post=281"}],"version-history":[{"count":0,"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/posts\/281\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/media\/87096"}],"wp:attachment":[{"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/media?parent=281"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/categories?post=281"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/devblogs.microsoft.com\/scripting\/wp-json\/wp\/v2\/tags?post=281"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}