its all about control
[freeside.git] / httemplate / browse / access_user.html
1 <% include( 'elements/browse.html',
2                  'title'          => 'Internal Users',
3                  'menubar'        => [ #'Main menu' => $p,
4                                        'Internal access groups' => $p.'browse/access_group.html',
5                                      ],
6                  'html_init'      => $html_init,
7                  'html_posttotal' => $posttotal,
8                  'name'           => 'internal users',
9                  'query'          => { 'table'     => 'access_user',
10                                        'hashref'   => \%search,
11                                        'extra_sql' => 'ORDER BY last, first',
12                                      },
13                  'count_query'    => $count_query,
14                  'header'         => \@header,
15                  'fields'         => \@fields,
16                  'links'          => \@links,
17                  'style'          => \@style,
18              )
19 %>
20 <%init>
21
22 die "access denied"
23   unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
24
25 my $html_init = 
26   "Internal users have access to the back-office interface.  Typically, this is your employees and contractors, but in a VISP setup, you can also add accounts for your reseller's employees.  It is <B>highly recommended</B> to add a <B>separate account for each person</B> rather than using role accounts.<BR><BR>".
27   qq!<A HREF="${p}edit/access_user.html"><I>Add an internal user</I></A><BR><BR>!;
28
29 #false laziness w/part_pkg.cgi
30 my %search = ();
31 my $search = '';
32 unless ( $cgi->param('showdisabled') ) {
33   %search = ( 'disabled' => '' );
34   $search = "( disabled = '' OR disabled IS NULL )";
35 }
36
37 #false laziness w/access_group.html & agent_type.cgi
38 my $groups_sub = sub {
39   my $access_user = shift;
40
41   [ map {
42           my $access_usergroup = $_;
43           my $access_group = $access_usergroup->access_group;
44           [
45             {
46               'data'  => $access_group->groupname,
47               'align' => 'left',
48               'link'  =>
49                 $p. 'edit/access_group.html?'. $access_usergroup->groupnum,
50             },
51           ];
52         }
53     grep { $_->access_group # and ! $_->access_group->disabled
54          }
55     $access_user->access_usergroup,
56
57   ];
58
59 };
60
61 my $posttotal;
62 if ( $cgi->param('showdisabled') ) {
63   $cgi->param('showdisabled', 0);
64   $posttotal = '( <a href="'. $cgi->self_url. '">hide disabled users</a> )';
65   $cgi->param('showdisabled', 1);
66 } else {
67   $cgi->param('showdisabled', 1);
68   $posttotal = '( <a href="'. $cgi->self_url. '">show disabled users</a> )';
69   $cgi->param('showdisabled', 0);
70 }
71
72 my $count_query = 'SELECT COUNT(*) FROM access_user';
73 $count_query .= " WHERE $search"
74   if $search;
75
76 my $link = [ $p.'edit/access_user.html?', 'usernum' ];
77
78 my @header = ( '#', 'Username' );
79 my @fields = ( 'usernum', 'username' );
80 my $align = 'rl';
81 my @links = ( $link, $link );
82 my @style = ( '', '' );
83
84 #false laziness w/part_pkg.cgi
85 #unless ( $cgi->param('showdisabled') ) { #its been reversed already
86 if ( $cgi->param('showdisabled') ) { #its been reversed already
87   push @header, 'Status';
88   push @fields, sub { shift->disabled
89                         ? '<FONT COLOR="#FF0000">DISABLED</FONT>'
90                         : '<FONT COLOR="#00CC00">Active</FONT>'
91                     };
92   push @links, '';
93   $align .= 'c';
94   push @style, 'b';
95 }
96
97 push @header, 'Full name', 'Groups';
98 push @fields, 'name',      $groups_sub;
99 push @links,  $link,       '';
100 $align .= 'll';
101
102 </%init>