diff options
Diffstat (limited to 'perllib/FixMyStreet/App/Controller/Admin/Users.pm')
| -rw-r--r-- | perllib/FixMyStreet/App/Controller/Admin/Users.pm | 80 | 
1 files changed, 40 insertions, 40 deletions
| diff --git a/perllib/FixMyStreet/App/Controller/Admin/Users.pm b/perllib/FixMyStreet/App/Controller/Admin/Users.pm index 046e19126..7ebfb9bbd 100644 --- a/perllib/FixMyStreet/App/Controller/Admin/Users.pm +++ b/perllib/FixMyStreet/App/Controller/Admin/Users.pm @@ -29,17 +29,29 @@ sub index :Path : Args(0) {      if ($c->req->method eq 'POST') {          my @uids = $c->get_param_list('uid'); -        my @role_ids = $c->get_param_list('roles');          my $user_rs = FixMyStreet::DB->resultset("User")->search({ id => \@uids }); -        foreach my $user ($user_rs->all) { -            $user->admin_user_body_permissions->delete; -            $user->user_roles->search({ -                role_id => { -not_in => \@role_ids }, -            })->delete; -            foreach my $role (@role_ids) { -                $user->user_roles->find_or_create({ -                    role_id => $role, +        if ( $c->get_param('remove-staff') ) { +            foreach my $user ($user_rs->all) { +                $user->update({ +                    from_body => undef, +                    email_verified => 0, +                    phone_verified => 0,                  }); +                $user->user_roles->delete; +                $user->admin_user_body_permissions->delete; +            } +        } else { +            my @role_ids = $c->get_param_list('roles'); +            foreach my $user ($user_rs->all) { +                $user->admin_user_body_permissions->delete; +                $user->user_roles->search({ +                    role_id => { -not_in => \@role_ids }, +                })->delete; +                foreach my $role (@role_ids) { +                    $user->user_roles->find_or_create({ +                        role_id => $role, +                    }); +                }              }          }          $c->stash->{status_message} = _('Updated!'); @@ -47,28 +59,13 @@ sub index :Path : Args(0) {      my $search = $c->get_param('search');      my $role = $c->get_param('role'); +    my $users = $c->cobrand->users;      if ($search || $role) { -        my $users = $c->cobrand->users; -        my $isearch;          if ($search) {              $search = $self->trim($search);              $search =~ s/^<(.*)>$/$1/; # In case email wrapped in <...>              $c->stash->{searched} = $search; - -            $isearch = '%' . $search . '%'; -            my $search_n = 0; -            $search_n = int($search) if $search =~ /^\d+$/; - -            $users = $users->search( -                { -                    -or => [ -                        email => { ilike => $isearch }, -                        phone => { ilike => $isearch }, -                        name => { ilike => $isearch }, -                        from_body => $search_n, -                    ] -                } -            ); +            $users = $users->search_text($search);          }          if ($role) {              $c->stash->{role_selected} = $role; @@ -78,25 +75,23 @@ sub index :Path : Args(0) {                  join => 'user_roles',              });          } - -        my @users = $users->all; -        $c->stash->{users} = [ @users ]; -        if ($search) { -            $c->forward('/admin/add_flags', [ { email => { ilike => $isearch } } ]); -        } -      } else {          $c->forward('/auth/get_csrf_token');          $c->forward('/admin/fetch_all_bodies');          $c->cobrand->call_hook('admin_user_edit_extra_data');          # Admin users by default -        my $users = $c->cobrand->users->search( -            { from_body => { '!=', undef } }, -            { order_by => 'name' } -        ); -        my @users = $users->all; -        $c->stash->{users} = \@users; +        $users = $users->search({ from_body => { '!=', undef } }); +    } + +    $users = $users->search(undef, { +        prefetch => 'from_body', +        order_by => [ \"me.name = ''", 'me.name' ], +    }); +    my @users = $users->all; +    $c->stash->{users} = \@users; +    if ($search) { +        $c->forward('/admin/add_flags', [ { email => { ilike => "%$search%" } } ]);      }      my $rs; @@ -373,6 +368,11 @@ sub edit : Chained('user') : PathPart('') : Args(0) {              my @live_contact_ids = map { $_->id } @live_contacts;              my @new_contact_ids = grep { $c->get_param("contacts[$_]") } @live_contact_ids;              $user->set_extra_metadata('categories', \@new_contact_ids); +            if ($c->get_param('assigned_categories_only')) { +                $user->set_extra_metadata(assigned_categories_only => 1); +            } else { +                $user->unset_extra_metadata('assigned_categories_only'); +            }          } else {              $user->unset_extra_metadata('categories');          } @@ -396,7 +396,7 @@ sub edit : Chained('user') : PathPart('') : Args(0) {              id => $_->id,              category => $_->category,              active => $active_contacts{$_->id}, -            group => $_->get_extra_metadata('group') // '', +            group => $_->groups,          } } @live_contacts;          $c->stash->{contacts} = \@all_contacts;          $c->forward('/report/stash_category_groups', [ \@all_contacts, 1 ]) if $c->cobrand->enable_category_groups; | 
