X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/de763d70b4b2e0501565e579fb4726e033594589..d1c335e9bb0a35d45acd03b29d1e759f26c5664c:/SL/Menu.pm diff --git a/SL/Menu.pm b/SL/Menu.pm index 0bdf945e4..bef524266 100644 --- a/SL/Menu.pm +++ b/SL/Menu.pm @@ -138,7 +138,7 @@ sub menuitemNew { } sub access_control { - $main::lxdebug->enter_sub(); + $main::lxdebug->enter_sub(2); my ($self, $myconfig, $menulevel) = @_; @@ -150,21 +150,31 @@ sub access_control { @menu = grep { /^${menulevel}--/ } @{ $self->{ORDER} }; } - my @a = split /;/, $myconfig->{acs}; - my $excl = (); - - # remove --AR, --AP from array - grep { ($a, $b) = split /--/; s/--$a$//; } @a; + my @a = split /;/, $myconfig->{acs}; + my %excl; map { $excl{$_} = 1 } @a; @a = (); map { push @a, $_ unless $excl{$_} } (@menu); - $main::lxdebug->leave_sub(); + $main::lxdebug->leave_sub(2); return @a; } +sub generate_acl { + my ($self, $menulevel, $hash) = @_; + + my @items = $self->access_control(\%main::myconfig, $menulevel); + + $menulevel =~ s/[^A-Za-z_\/\.\+\-]/_/g; + $hash->{"access_" . lc($menulevel)} = 1 if ($menulevel); + + foreach my $item (@items) { + $self->generate_acl($item, $hash); #unless ($menulevel); + } +} + 1;