This commit was generated by cvs2svn to compensate for changes in r5562,
[freeside.git] / httemplate / browse / access_group.html
1 <% include( 'elements/browse.html',
2                  'title'       => 'Internal Access Groups',
3                  'menubar'     => [ # 'Main menu' => $p,
4                                     'Internal users' => $p.'browse/access_user.html',
5                                   ],
6                  'html_init'   => $html_init,
7                  'name'        => 'internal access groups',
8                  'query'       => { 'table'     => 'access_group',
9                                     'hashref'   => {},
10                                     'extra_sql' => 'ORDER BY groupname', #??
11                                   },
12                  'count_query' => $count_query,
13                  'header'      => [ '#',
14                                     'Group name',
15                                     'Agents',
16                                     'Rights',
17                                   ],
18                  'fields'      => [ 'groupnum',
19                                     'groupname',
20                                     $agents_sub,
21                                     $rights_sub,
22                                   ],
23                  'links'       => [ $link,
24                                     $link,
25                                     '',
26                                     '',
27                                   ],
28              )
29 %>
30 <%once>
31
32 my $html_init = 
33   "Internal access groups control access to the back-office interface.<BR><BR>".
34   qq!<A HREF="${p}edit/access_group.html"><I>Add an internal access group</I></A><BR><BR>!;
35
36 #false laziness w/access_user.html & agent_type.cgi
37 my $agents_sub = sub {
38   my $access_group = shift;
39
40   [ map {
41           my $access_groupagent = $_;
42           my $agent = $access_groupagent->agent;
43           [
44             {
45               'data'  => $agent->agent,
46               'align' => 'left',
47               'link'  => $p. 'edit/agent.cgi?'. $agent->agentnum,
48             },
49           ];
50         }
51     grep { $_->agent } #?
52     $access_group->access_groupagent,
53
54   ];
55   
56 };
57
58 tie my %rights, 'Tie::IxHash', FS::AccessRight->rights_info;
59
60 my $rights_sub = sub {
61   my $access_group = shift;
62
63   #[ map { my $access_right = $_;
64   #        [
65   #          { 
66   #            'data'  => $access_right->rightname,
67   #            'align' => 'left',
68   #          },
69   #        ];
70   #      }
71   #  $access_group->access_rights,
72   #];
73
74   #some false laziness w/edit/access_group.html
75   my $columns = 3;
76   my $count = 0;
77
78   #include('/elements/table-grid.html', bgcolor=>'#cccccc' ).
79   '<TABLE>'.
80   '<TR>'. join( '', map {
81     
82     '<TD CLASS="inv" VALIGN="top"><TABLE WIDTH=100%>'.
83     '<TR><TH BGCOLOR="#dcdcdc">'. $_. '</TH></TR>'.
84     '<TR><TD>'.
85
86      join('<BR>', grep { warn "$access_group->access_right($_): ".
87                               $access_group->access_right($_). "\n";
88                          $access_group->access_right($_); }
89                    map { ref($_) ? $_->{'rightname'} : $_; }
90                        @{ $rights{$_} }
91          ).
92
93     '</TD></TR></TABLE></TD>'.
94     ( ++$count % $columns ? '' : '</TR><TR>')
95   
96   } keys %rights ). '</TR></TABLE>';
97
98 };
99
100 my $count_query = 'SELECT COUNT(*) FROM access_group';
101
102 my $link = [ $p.'edit/access_group.html?', 'groupnum' ];
103
104 </%once>
105 <%init>
106
107 die "access denied"
108   unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
109
110 </%init>