<?xml version="1.0" encoding="windows-1252"?>
<node id="66689" title="Compare Directories/Permissions across all servers" created="2001-03-23 17:16:45" updated="2005-08-15 07:20:43">
<type id="1748">
sourcecode</type>
<author id="21786">
OzzyOsbourne</author>
<data>
<field name="doctext">
&lt;code&gt;
use strict;
use Win32::FileSecurity qw(Get EnumerateRights);
use File::Find;

my $share=$ARGV[0];
my $out=$ARGV[1];
my ($name,$mask,@rights,%hash,$server,%rights2,@folders,$subfolder,$servsplit,$subsplit,$right,$item);
my @servers=('SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX','SERVERXX');
@servers=map ("//$_/$share",@servers);
my @rightsmatch=('DELETE','READ_CONTROL','WRITE_DAC','WRITE_OWNER','SYNCHRONIZE','STANDARD_RIGHTS_REQUIRED','STANDARD_RIGHTS_READ','STANDARD_RIGHTS_WRITE','STANDARD_RIGHTS_EXECUTE','STANDARD_RIGHTS_ALL','SPECIFIC_RIGHTS_ALL','ACCESS_SYSTEM_SECURITY','MAXIMUM_ALLOWED','GENERIC_READ','GENERIC_WRITE','GENERIC_EXECUTE','GENERIC_ALL','FULL','READ','CHANGE');

open (OUT, "&gt;$out") or die "can't open log file!";    

foreach $server( @servers ) {
print "$server\n";
@folders='';
    find(\&amp;wanted, $server);
    foreach $subfolder (@folders){
	print "\t:$subfolder\n";
        next unless -e $subfolder ;
    if ( Get( $subfolder, \%hash ) ) {
        while( ($name, $mask) = each %hash ) {
	    ($servsplit,$servsplit,$servsplit,$subsplit)=split(/\//,$subfolder,4);
	    print OUT "$servsplit\t$subsplit\t$name\t"; 
	    EnumerateRights( $mask, \@rights ) ;#creates @rights, a list of rights for the account
	    %rights2=();
	    foreach $right (@rights){
                $rights2{$right} = 1;
	    }
	    foreach $item (@rightsmatch){
		if (exists $rights2{$item}){
			print OUT "$item\t";
		}else{
			print OUT "\'\t";
		}
	    }  
	    print OUT "\n";
	}
    	
    }
    else {
        print( "Error #", int( $! ), ": $!" ) ;
    }
    }
}

close OUT;

sub wanted {
	if (-d){
		push @folders, "$File::Find::dir/$_";
    	}
}
&lt;/code&gt;</field>
<field name="codedescription">
&lt;p&gt;Uses File::Find and Win32::FileSecurity to dump file permissions to a text file on shares that you specify.&lt;/p&gt;
&lt;p&gt;Usage code.pl {share} {outputlog}&lt;/p&gt;
&lt;p&gt;Output:server(tab)share(tab)account(tab)permission1(tab)permission2(tab)...(enter)&lt;/p&gt;
&lt;p&gt;If the account does not have a permission, the script double tabs, for easy visual inspection.&lt;/p&gt;
&lt;p&gt;By importing the resultant tab-delimited log into a spreadsheet program, you can sort by account(colC), then share(colB), then server(colA), to very simply compare directory rights across your file and prints.&lt;/p&gt;
&lt;p&gt;Thanks to [Tyke].&lt;/p&gt;</field>
<field name="codecategory">
NT Admin</field>
<field name="codeauthor">
[OzzyOsbourne]</field>
</data>
</node>
