X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/b735f45033d8daef70ee2c82365a86cc06281f4c..5c0c9e6763bc9f129cdeff5cbaa564787af0a9bc:/bin/mozilla/admin_groups.pl diff --git a/bin/mozilla/admin_groups.pl b/bin/mozilla/admin_groups.pl index b75af930e..d84e2e541 100644 --- a/bin/mozilla/admin_groups.pl +++ b/bin/mozilla/admin_groups.pl @@ -32,6 +32,8 @@ # #====================================================================== +use List::MoreUtils qw(uniq); + sub edit_groups { $lxdebug->enter_sub(); @@ -114,9 +116,9 @@ sub edit_group { my %all_users = $auth->read_all_users(); my %users_by_id = map { $_->{id} => $_ } values %all_users; - my @members = sort { lc $a->{login} cmp lc $b->{login} } @users_by_id{ @{ $group->{members} } }; + my @members = uniq sort { lc $a->{login} cmp lc $b->{login} } @users_by_id{ @{ $group->{members} } }; - my %grouped = map { $_ => 1 } @{ $group->{members} }; + my %grouped = map { $_ => 1 } uniq @{ $group->{members} }; my @non_members = sort { lc $a->{login} cmp lc $b->{login} } grep { !$grouped{$_->{id}} } values %all_users; my @rights = map { @@ -173,7 +175,7 @@ sub add_to_group { } $group = $groups->{$form->{group_id}}; - push @{ $group->{members} }, $form->{user_id_not_in_group}; + $group->{members} = [ uniq @{ $group->{members} }, $form->{user_id_not_in_group} ]; $auth->save_group($group); @@ -195,7 +197,7 @@ sub remove_from_group { } $group = $groups->{$form->{group_id}}; - $group->{members} = [ grep { $_ ne $form->{user_id_in_group} } @{ $group->{members} } ]; + $group->{members} = [ uniq grep { $_ ne $form->{user_id_in_group} } @{ $group->{members} } ]; $auth->save_group($group);