Bug 32336: (QA follow-up) Use $metadata->schema
[srvgit] / course_reserves / course-details.pl
index af1eb62..c5d74f9 100755 (executable)
@@ -22,26 +22,24 @@ use Modern::Perl;
 
 use CGI qw ( -utf8 );
 
-use C4::Auth;
-use C4::Output;
-use C4::Koha;
+use C4::Auth qw( get_template_and_user );
+use C4::Output qw( output_html_with_http_headers );
 
-use C4::CourseReserves qw(DelCourseReserve GetCourse GetCourseReserves);
+use C4::CourseReserves qw( DelCourse DelCourseReserve GetCourse GetCourseReserve GetCourseReserves );
 
-my $cgi = new CGI;
+my $cgi = CGI->new;
 
 my $action = $cgi->param('action') || '';
 my $course_id = $cgi->param('course_id');
 
 my $flagsrequired;
-$flagsrequired->{coursereserves} = 'delete_reserves' if ( $action eq 'del_reserve' );
+$flagsrequired->{coursereserves} = 'delete_reserves' if ( $action eq 'del_reserve' or $action eq 'rm_all' );
 
 my $tmpl = ($course_id) ? "course-details.tt" : "invalid-course.tt";
 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
     {   template_name   => "course_reserves/$tmpl",
         query           => $cgi,
         type            => "intranet",
-        authnotrequired => 0,
         flagsrequired   => $flagsrequired,
     }
 );
@@ -49,6 +47,14 @@ my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
 if ( $action eq 'del_reserve' ) {
     DelCourseReserve( cr_id => scalar $cgi->param('cr_id') );
 }
+elsif ( $action eq 'rm_all' ) {
+    my $course_res = GetCourseReserves(course_id => $course_id);
+    foreach my $cr (@$course_res) {
+        if(exists $cr->{'cr_id'}) {
+            DelCourseReserve(cr_id => $cr->{cr_id});
+        }
+    }
+}
 
 my $course          = GetCourse($course_id);
 my $course_reserves = GetCourseReserves(
@@ -60,6 +66,7 @@ my $course_reserves = GetCourseReserves(
 $template->param(
     course          => $course,
     course_reserves => $course_reserves,
+    user            => Koha::Patrons->find( $loggedinuser ),
 );
 
 output_html_with_http_headers $cgi, $cookie, $template->output;