Solved

Limit depth of -recurse when using -get-childitem

Posted on 2007-03-29
4
3,317 Views
Last Modified: 2008-01-09
Hello - I'm trying to dump out directories and owners for my helpdesk.
I found this script:
PS C:\> get-childitem \\server\c$\work  –recurse | get-acl |
select-object path,owner,accesstostring,group | export-csv c:\ACL.csv

from this site:http://www.microsoft.com/technet/scriptcenter/csc/tips/ps/acl.mspx

That's great, but I don't really need it to recurse the entire structure. All they want is the top two folder layers. Is there something equivalent to linux's --max-depth?  I also only need directories, not all objects, and really just want the folder owners, not the whole acl. If someone can assist with those additional items that would be great. I've only just looked at powershell for the first time today, so this is a learning process!

I'm running this on XP SP2, but the target will be Win2K and 2003 file servers.

thanks

0
Comment
Question by:JammyPak
  • 3
4 Comments
 
LVL 70

Expert Comment

by:Chris Dent
Comment Utility

It's all possible, but it would have to be a custom script, there's nothing built into limit recursion as far as I know.

I'm still a bit slow writing in PowerShell, but if you give me a day or so I'm sure I can come up with something.

Chris
0
 
LVL 70

Accepted Solution

by:
Chris Dent earned 500 total points
Comment Utility

Sorry for the wait. Basically you just want the Owner and the Path in a csv file?

I'm sure there's going to be a better / neater / easier way to do this.

Copy this to a .ps1 file and modify the $Start bit:


function do-recurse($Item, $i, $j)
{
      $Owner = $Item | Get-ACL | Select-Object owner

      Write-Output "$Item,$Owner"

      if ((get-item $Item).PSIsContainer -eq "True")
      {
            $i++
            if ($i -le $j)
            {
            foreach ($ChildItem in (get-childitem $Item))
                  {
                        $Path = $Item + "\" + $ChildItem
                        if ((get-item $Path).PSIsContainer -eq "True")
                        {
                              do-recurse $Path $i $j
                        }
                  }
            }
      }
}

$Start = "<Path>"
do-recurse $Start 0 3


Once you've done that you must change the Execution Policy. I haven't signed the code because I'm not going to buy a digital signature so you must turn down the execution policy. I suggest setting it to Unrestricted so you can test this with:

Set-ExecutionPolicy Unrestricted

You can always turn it back up to the default, Restricted, after we're done.

After that you can execute the script above with:

./<scriptname>

And if you want the output in a file, do:

./<scriptname> | Out-File <FileName>

I'm afraid Export-CSV doesn't work for this at the moment, still trying to understand out to properly control output.

In the script you configure the maximum depth by modifying this line:

do-recurse $Start 0 3

Where 3 is the maximum depth. As I mentioned above I'm sure there are better ways to do all this, but it's tricky to find them.

HTH

Chris
0
 
LVL 16

Author Comment

by:JammyPak
Comment Utility
Chris, this seems to be working well. Thanks for putting the time in, much appreciated.
0
 
LVL 70

Expert Comment

by:Chris Dent
Comment Utility

You're welcome, happy to help.

Chris
0

Featured Post

6 Surprising Benefits of Threat Intelligence

All sorts of threat intelligence is available on the web. Intelligence you can learn from, and use to anticipate and prepare for future attacks.

Join & Write a Comment

Hi all.   The other day I had to change the passwords for a bunch of users on the fly. Because they were so many, I decided to do it in an automated way and I would like to share it with you all.   If you are not doing it directly in a Domain Co…
Synchronize a new Active Directory domain with an existing Office 365 tenant
This is Part 3 in a 3-part series on Experts Exchange to discuss error handling in VBA code written for Excel. Part 1 of this series discussed basic error handling code using VBA. http://www.experts-exchange.com/videos/1478/Excel-Error-Handlin…
Excel styles will make formatting consistent and let you apply and change formatting faster. In this tutorial, you'll learn how to use Excel's built-in styles, how to modify styles, and how to create your own. You'll also learn how to use your custo…

772 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now