summaryrefslogtreecommitdiff
path: root/httemplate/edit/process/access_user.html
blob: 7fc7c25e13e5ffa6077c0493404abb5e922e91ca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
%  if ( $cgi->param('_password') ne $cgi->param('_password2') ) {
%    $cgi->param('error', "The passwords do not match");
%    print $cgi->redirect(popurl(2) . "access_user.html?" . $cgi->query_string);
%  } else {
<%   include( 'elements/process.html',
                 'table'          => 'access_user',
                 'viewall_dir'    => 'browse',
                 'copy_on_empty'  => [ '_password', '_password_encoding' ],
                 'clear_on_error' => [ '_password', '_password2' ],
                 'process_m2m'    => { 'link_table'   => 'access_usergroup',
                                       'target_table' => 'access_group',
                                     },
                 'precheck_callback'        => \&precheck_callback,
                 'post_new_object_callback' => \&post_new_object_callback,
             )
%>
%   }
<%init>

die "access denied"
  unless $FS::CurrentUser::CurrentUser->access_right('Configuration');

if ( FS::Conf->new->exists('disable_acl_changes') ) {
  errorpage('ACL changes disabled in public demo.');
  die "shouldn't be reached";
}

sub precheck_callback {
  my $cgi = shift;

  my $o = FS::access_user->new({username => $cgi->param('username')});
  if( $o->is_system_user and !$cgi->param('usernum') ) {
    $cgi->param('username','');
    return "username '".$o->username."' reserved for system account."
  }

  return '';
}

sub post_new_object_callback {
  my( $cgi, $access_user ) = @_;

  if ( length($cgi->param('_password')) ) {
    my $password = scalar($cgi->param('_password'));
    $access_user->change_password_fields($password);
  }

}

</%init>