diff options
| author | Struan Donald <struan@exo.org.uk> | 2019-11-18 17:20:02 +0000 | 
|---|---|---|
| committer | Struan Donald <struan@exo.org.uk> | 2019-11-22 17:06:08 +0000 | 
| commit | a359cd913baacb46a20fef96053833aab086378a (patch) | |
| tree | ba5a476ca03c60904c65fd511cd54c454464e67f /bin | |
| parent | 09026f609ce28860d555967e0f5d7cd833fb20d0 (diff) | |
script to update permissions of a body's users
Allows adding or removing a list of permissions to the users belonging
to a body.
Diffstat (limited to 'bin')
| -rwxr-xr-x | bin/fixmystreet.com/update_council_user_permissions | 70 | 
1 files changed, 70 insertions, 0 deletions
| diff --git a/bin/fixmystreet.com/update_council_user_permissions b/bin/fixmystreet.com/update_council_user_permissions new file mode 100755 index 000000000..0463db8b7 --- /dev/null +++ b/bin/fixmystreet.com/update_council_user_permissions @@ -0,0 +1,70 @@ +#!/usr/bin/env perl +# +# script to add/remove a list of permissions to all staff belonging to a body. + +use strict; +use warnings; +use v5.14; + +BEGIN { +    use File::Basename qw(dirname); +    use File::Spec; +    my $d = dirname(File::Spec->rel2abs($0)); +    require "$d/../../setenv.pl"; +} + +use FixMyStreet::DB; + +use Getopt::Long::Descriptive; + +my ($opts, $usage) = describe_options( +    '%c %o', +    ['commit', 'whether to commit changes to the database'], +    ['permissions=s', 'comma seperated list of permissions to add/delete', { required => 1 }], +    ['council=s', 'name of council to update', { required => 1 }], +    ['mode' => 'hidden' => { one_of => [ +        ['add', 'add permissions to council\'s users'], +        ['remove', 'remove permissions from council\'s users'], +    ], required => 1 }], +    ['help|h', 'print usage message and exit'] +); +$usage->die if $opts->help; + +if (!$opts->commit) { +    say "*** DRY RUN ***"; +} + +my $body = FixMyStreet::DB->resultset("Body")->find({ name => $opts->council}); + +if ($body) { +    my @permissions_list = map { Utils::trim_text($_) } split(',', $opts->permissions); + +    my $staff = FixMyStreet::DB->resultset("User")->search({ from_body => $body->id }); +    for my $user ( $staff->all ) { +        my $permissions = $user->user_body_permissions->search({ +            body_id => $body->id, +            permission_type => { in => \@permissions_list} +        }); +        if ( $opts->mode eq 'remove') { +            next unless $permissions->count; +            if ($opts->commit) { +                $permissions->delete; +            } +        } elsif ( $opts->mode eq 'add' ) { +            my %existing = map { $_->permission_type => 1 } $permissions->all; +            my @permissions_to_add = grep { !$existing{$_} } @permissions_list; +            next unless @permissions_to_add; +            if ($opts->commit) { +                for my $permission ( @permissions_to_add ) { +                    $user->user_body_permissions->create({ +                        body_id => $body->id, +                        permission_type => $permission +                    }); +                } +            } +        } +        say "updated permissions for user id " . $user->id; +    } +} else { +    say STDERR "Could not find " . $opts->council; +} | 
