Aktualisierung
[kivitendo-erp.git] / SL / Menu.pm
1 #=====================================================================
2 # LX-Office ERP
3 # Copyright (C) 2004
4 # Based on SQL-Ledger Version 2.1.9
5 # Web http://www.lx-office.org
6 #
7 #=====================================================================
8 # SQL-Ledger Accounting
9 # Copyright (C) 2001
10 #
11 #  Author: Dieter Simader
12 #   Email: dsimader@sql-ledger.org
13 #     Web: http://www.sql-ledger.org
14 #
15 #  Contributors:
16 #
17 # This program is free software; you can redistribute it and/or modify
18 # it under the terms of the GNU General Public License as published by
19 # the Free Software Foundation; either version 2 of the License, or
20 # (at your option) any later version.
21 #
22 # This program is distributed in the hope that it will be useful,
23 # but WITHOUT ANY WARRANTY; without even the implied warranty of
24 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
25 # GNU General Public License for more details.
26 # You should have received a copy of the GNU General Public License
27 # along with this program; if not, write to the Free Software
28 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
29 #=====================================================================
30 #
31 # routines for menu items
32 #
33 #=====================================================================
34
35 package Menu;
36
37 sub new {
38   $main::lxdebug->enter_sub();
39
40   my ($type, $menufile, $level) = @_;
41
42   use SL::Inifile;
43   my $self = Inifile->new($menufile, $level);
44
45   $main::lxdebug->leave_sub();
46
47   bless $self, $type;
48 }
49
50 sub menuitem {
51   $main::lxdebug->enter_sub();
52
53   my ($self, $myconfig, $form, $item) = @_;
54
55   my $module = $form->{script};
56   my $action = "section_menu";
57   my $target = "";
58
59   if ($self->{$item}{module}) {
60     $module = $self->{$item}{module};
61   }
62   if ($self->{$item}{action}) {
63     $action = $self->{$item}{action};
64   }
65   if ($self->{$item}{target}) {
66     $target = $self->{$item}{target};
67   }
68
69   my $level = $form->escape($item);
70
71   my $str =
72     qq|<a style="vertical-align:top" href=$module?path=$form->{path}&action=$action&level=$level&login=$form->{login}&password=$form->{password}|;
73
74   my @vars = qw(module action target href);
75
76   if ($self->{$item}{href}) {
77     $str  = qq|<a href=$self->{$item}{href}|;
78     @vars = qw(module target href);
79   }
80
81   map { delete $self->{$item}{$_} } @vars;
82
83   # add other params
84   foreach my $key (keys %{ $self->{$item} }) {
85     $str .= "&" . $form->escape($key, 1) . "=";
86     ($value, $conf) = split(/=/, $self->{$item}{$key}, 2);
87     $value = $myconfig->{$value} . "/$conf" if ($conf);
88     $str .= $form->escape($value, 1);
89   }
90
91   if ($target) {
92     $str .= qq| target=$target|;
93   }
94
95   $str .= ">";
96
97   $main::lxdebug->leave_sub();
98
99   return $str;
100 }
101
102 sub menuitem_v3 {
103   $main::lxdebug->enter_sub();
104
105   my ($self, $myconfig, $form, $item, $other) = @_;
106
107   my $module = $form->{script};
108   my $action = "section_menu";
109   my $target = "";
110
111   if ($self->{$item}{module}) {
112     $module = $self->{$item}{module};
113   }
114   if ($self->{$item}{action}) {
115     $action = $self->{$item}{action};
116   }
117   if ($self->{$item}{target}) {
118     $target = $self->{$item}{target};
119   }
120
121   my $level = $form->escape($item);
122
123   my $str = qq|<a href="$module?action=| . $form->escape($action) .
124     qq|&level=| . $form->escape($level);
125   map({ $str .= "&${_}=" . $form->escape($form->{$_}); } qw(path login password));
126
127   my @vars = qw(module action target href);
128
129   if ($self->{$item}{href}) {
130     $str  = qq|<a href=$self->{$item}{href}|;
131     @vars = qw(module target href);
132   }
133
134   map { delete $self->{$item}{$_} } @vars;
135
136   # add other params
137   foreach my $key (keys %{ $self->{$item} }) {
138     $str .= "&" . $form->escape($key, 1) . "=";
139     ($value, $conf) = split(/=/, $self->{$item}{$key}, 2);
140     $value = $myconfig->{$value} . "/$conf" if ($conf);
141     $str .= $form->escape($value, 1);
142   }
143
144   $str .= '"';
145
146   if ($target) {
147     $str .= qq| target="| . $form->quote($target) . qq|"|;
148   }
149
150   if ($other) {
151     foreach my $key (keys(%{$other})) {
152       $str .= qq| ${key}="| . $form->quote($other->{$key}) . qq|"|;
153     }
154   }
155
156   $str .= ">";
157
158   $main::lxdebug->leave_sub();
159
160   return $str;
161 }
162
163 sub menuitemNew {
164   my ($self, $myconfig, $form, $item) = @_;
165
166   my $module = $form->{script};
167   my $action = "section_menu";
168
169   #if ($self->{$item}{module}) {
170   $module = $self->{$item}{module};
171
172   #}
173   if ($self->{$item}{action}) {
174     $action = $self->{$item}{action};
175   }
176
177   my $level = $form->escape($item);
178   my $str   =
179     qq|$module?path=$form->{path}&action=$action&level=$level&login=$form->{login}&password=$form->{password}|;
180   my @vars = qw(module action target href);
181
182   if ($self->{$item}{href}) {
183     $str  = qq|$self->{$item}{href}|;
184     @vars = qw(module target href);
185   }
186
187   map { delete $self->{$item}{$_} } @vars;
188
189   # add other params
190   foreach my $key (keys %{ $self->{$item} }) {
191     $str .= "&" . $form->escape($key, 1) . "=";
192     ($value, $conf) = split(/=/, $self->{$item}{$key}, 2);
193     $value = $myconfig->{$value} . "/$conf" if ($conf);
194     $str .= $form->escape($value, 1);
195   }
196
197   $str .= " ";
198
199 }
200
201 sub access_control {
202   $main::lxdebug->enter_sub(2);
203
204   my ($self, $myconfig, $menulevel) = @_;
205
206   my @menu = ();
207
208   if ($menulevel eq "") {
209     @menu = grep { !/--/ } @{ $self->{ORDER} };
210   } else {
211     @menu = grep { /^${menulevel}--/ } @{ $self->{ORDER} };
212   }
213
214   my @a    = split(/;/, $myconfig->{acs});
215   my $excl = ();
216
217   # remove --AR, --AP from array
218   grep { ($a, $b) = split /--/; s/--$a$//; } @a;
219
220   map { $excl{$_} = 1 } @a;
221
222   @a = ();
223   map { push @a, $_ unless $excl{$_} } (@menu);
224
225   $main::lxdebug->leave_sub(2);
226
227   return @a;
228 }
229
230 sub generate_acl {
231   my ($self, $menulevel, $hash) = @_;
232
233   my @items = $self->access_control(\%main::myconfig, $menulevel);
234
235   $menulevel =~ s/[^A-Za-z_\/\.\+\-]/_/g;
236   $hash->{"access_" . lc($menulevel)} = 1 if ($menulevel);
237
238   foreach my $item (@items) {
239     $self->generate_acl($item, $hash); #unless ($menulevel);
240   }
241 }
242
243 1;
244