Koha/installer/data/mysql/atomicupdate/bug_29509.pl
Kyle M Hall 0505531cde
Bug 29509: (QA follow-up) Tidy atomic update
Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
2024-07-22 10:28:03 +01:00

77 lines
4.4 KiB
Perl
Executable file

use Modern::Perl;
use Array::Utils qw( array_minus );
return {
bug_number => "29509",
description => "Update users with list_borrowers permission where required",
up => sub {
my ($args) = @_;
my ( $dbh, $out ) = @$args{qw(dbh out)};
# Users to exclude from update, (superlibrarians or borrowers flags)
my $sth = $dbh->prepare("SELECT borrowernumber FROM borrowers WHERE flags = 1 OR flags & 16");
$sth->execute();
my @exclusions = map { $_->[0] } @{ $sth->fetchall_arrayref };
# Prepare insert
my $insert_sth =
$dbh->prepare("INSERT IGNORE INTO user_permissions (borrowernumber, module_bit, code) VALUES (?, ?, ?)");
# Check for 'borrowers > edit_borrowers' permission
my $sth2 = $dbh->prepare("SELECT borrowernumber FROM user_permissions WHERE code = 'edit_borrowers'");
$sth2->execute();
my @edit_borrowers = map { $_->[0] } @{ $sth2->fetchall_arrayref };
my @reduced = array_minus( @edit_borrowers, @exclusions );
my @rows_to_insert = ( map { [ $_, 4, "list_borrowers" ] } array_minus( @edit_borrowers, @exclusions ) );
foreach my $row (@rows_to_insert) { $insert_sth->execute( @{$row} ); }
say $out "list_borrowers added to all users with edit_borrowers";
# Check for 'circulate' or 'circulate > manage_bookings' permission
my $sth3 = $dbh->prepare("SELECT borrowernumber FROM user_permissions WHERE code = 'manage_bookings'");
$sth3->execute();
my @manage_bookings = map { $_->[0] } @{ $sth3->fetchall_arrayref };
my $sth3_1 = $dbh->prepare("SELECT borrowernumber FROM borrowers WHERE flags & (1<<1)");
$sth3_1->execute();
my @circulate = map { $_->[0] } @{ $sth3_1->fetchall_arrayref };
my @bookings = ( @manage_bookings, @circulate );
@rows_to_insert = ( map { [ $_, 4, "list_borrowers" ] } array_minus( @bookings, @exclusions ) );
foreach my $row (@rows_to_insert) { $insert_sth->execute( @{$row} ); }
say $out "list_borrowers added to all users with manage_bookings";
# Check for 'tools' or 'tools > label_creator' permission
my $sth4 = $dbh->prepare("SELECT borrowernumber FROM user_permissions WHERE code = 'label_creator'");
$sth4->execute();
my @label_creator = map { $_->[0] } @{ $sth4->fetchall_arrayref };
my $sth4_1 = $dbh->prepare("SELECT borrowernumber FROM borrowers WHERE flags & (1<<13)");
$sth4_1->execute();
my @tools = map { $_->[0] } @{ $sth4_1->fetchall_arrayref };
my @labels = ( @label_creator, @tools );
@rows_to_insert = ( map { [ $_, 4, "list_borrowers" ] } array_minus( @labels, @exclusions ) );
foreach my $row (@rows_to_insert) { $insert_sth->execute( @{$row} ); }
say $out "list_borrowers added to all users with label_creator";
# Check for 'serials' or 'serials > routing' permission
my $sth5 = $dbh->prepare("SELECT borrowernumber FROM user_permissions WHERE code = 'routing'");
$sth5->execute();
my @routing = map { $_->[0] } @{ $sth5->fetchall_arrayref };
my $sth5_1 = $dbh->prepare("SELECT borrowernumber FROM borrowers WHERE flags & (1<<15)");
$sth5_1->execute();
my @serials = map { $_->[0] } @{ $sth5_1->fetchall_arrayref };
my @routing_lists = ( @routing, @serials );
@rows_to_insert = ( map { [ $_, 4, "list_borrowers" ] } array_minus( @routing_lists, @exclusions ) );
foreach my $row (@rows_to_insert) { $insert_sth->execute( @{$row} ); }
say $out "list_borrowers added to all users with routing";
# Check for 'acquisitions' or 'acquisitions > order_manage' permission
my $sth6 = $dbh->prepare("SELECT borrowernumber FROM user_permissions WHERE code = 'order_manage'");
$sth6->execute();
my @order_manage = map { $_->[0] } @{ $sth6->fetchall_arrayref };
my $sth6_1 = $dbh->prepare("SELECT borrowernumber FROM borrowers WHERE flags & (1<<11)");
$sth6_1->execute();
my @acquisitions = map { $_->[0] } @{ $sth6_1->fetchall_arrayref };
my @orders = ( @order_manage, @acquisitions );
@rows_to_insert = ( map { [ $_, 4, "list_borrowers" ] } array_minus( @orders, @exclusions ) );
foreach my $row (@rows_to_insert) { $insert_sth->execute( @{$row} ); }
say $out "list_borrowers added to all users with order_manage";
},
};