#
# This file is part of Koha.
#
-# Koha is free software; you can redistribute it and/or modify it under the
-# terms of the GNU General Public License as published by the Free Software
-# Foundation; either version 3 of the License, or (at your option) any later
-# version.
+# Koha is free software; you can redistribute it and/or modify it
+# under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
#
-# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
-# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
-# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
+# Koha is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
#
-# You should have received a copy of the GNU General Public License along
-# with Koha; if not, write to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
use Modern::Perl;
-use C4::Koha;
+use C4::Koha qw( GetAuthorisedValues );
use Koha::Database;
-use Koha::DateUtils;
+use Koha::DateUtils qw( dt_from_string );
use Koha::UploadedFile;
use parent qw(Koha::Objects);
# We use the individual delete on each resultset record
my $rv = 0;
while( my $row = $self->next ) {
- my $delete= $row->delete( $params ); # 1, 0E0 or -1
- $rv = ( $delete < 0 || $rv < 0 ) ? -1 : ( $rv + $delete );
+ my $deleted = eval { $row->delete( $params ) };
+ $rv++ if $deleted && !$@;
}
return $rv==0 ? "0E0" : $rv;
}
})->delete;
}
+=head3 delete_missing
+
+ $cnt = Koha::UploadedFiles->delete_missing();
+
+ $cnt = Koha::UploadedFiles->delete_missing({ keep_record => 1 });
+
+Deletes all records where the actual file is not found.
+
+Supports a keep_record hash parameter to do a check only.
+
+Return value: If you pass keep_record, it returns the number of records where
+the file is not found, or 0E0. Otherwise it returns a number, 0E0 or -1 just
+as delete does.
+
+=cut
+
+sub delete_missing {
+ my ( $self, $params ) = @_;
+ $self = Koha::UploadedFiles->new if !ref($self); # handle class call
+ my $rv = 0;
+ while( my $row = $self->next ) {
+ my $file = $row->full_path;
+ next if -e $file;
+ if( $params->{keep_record} ) {
+ $rv++;
+ next;
+ }
+ # We are passing keep_file since we already know that the file
+ # is missing and we do not want to see the warning
+ # Apply the same logic as in delete for the return value
+ my $deleted = eval { $row->delete({ keep_file => 1 }) };
+ $rv++ if $deleted && !$@;
+ }
+ return $rv==0 ? "0E0" : $rv;
+}
+
=head3 search_term
Search_term allows you to pass a term to search in filename and hashvalue.