Bug 21150: Search for item types inconsistencies
search_for_data_inconsistencies.pl will now display errors if: 1.item-level_itypes is set to "specific item" and items.itype is not set or not set to an item type defined in the system (itemtypes.itemtype) 2.item-level_itypes is set to "biblio record" and biblioitems.itemtype is not set or not set to an item type defined in the system (itemtypes.itemtype) Test plan: Use the script and the different possible combinations to display the errors Signed-off-by: Owen Leonard <oleonard@myacpl.org> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Nick Clemens <nick@bywatersolutions.com>
This commit is contained in:
parent
9b73cc2289
commit
6fd1a8c114
1 changed files with 65 additions and 0 deletions
|
@ -18,6 +18,8 @@
|
|||
use Modern::Perl;
|
||||
|
||||
use Koha::Items;
|
||||
use Koha::Biblioitems;
|
||||
use Koha::ItemTypes;
|
||||
use Koha::Authorities;
|
||||
|
||||
{
|
||||
|
@ -46,6 +48,65 @@ use Koha::Authorities;
|
|||
if ( $authorities->count ) {new_hint("Go to 'Home › Administration › Authority types' to define them")}
|
||||
}
|
||||
|
||||
{
|
||||
if ( C4::Context->preference('item-level_itypes') ) {
|
||||
my $items_without_itype = Koha::Items->search( { itype => undef } );
|
||||
if ( $items_without_itype->count ) {
|
||||
new_section("Items do not have itype defined");
|
||||
while ( my $item = $items_without_itype->next ) {
|
||||
new_item(
|
||||
sprintf "Item with itemnumber=%s does not have a itype value, biblio's item type will be used (%s)",
|
||||
$item->itemnumber, $item->biblioitem->itemtype
|
||||
);
|
||||
}
|
||||
new_hint("The system preference item-level_itypes expects item types to be defined at item level");
|
||||
}
|
||||
}
|
||||
else {
|
||||
my $biblioitems_without_itemtype = Koha::Biblioitems->search( { itemtype => undef } );
|
||||
if ( $biblioitems_without_itemtype->count ) {
|
||||
new_section("Biblioitems do not have itemtype defined");
|
||||
while ( my $biblioitem = $biblioitems_without_itemtype->next ) {
|
||||
new_item(
|
||||
sprintf "Biblioitem with biblioitemnumber=%s does not have a itemtype value",
|
||||
$biblioitem->biblioitemnumber
|
||||
);
|
||||
}
|
||||
new_hint("The system preference item-level_itypes expects item types to be defined at biblio level");
|
||||
}
|
||||
}
|
||||
|
||||
my @itemtypes = Koha::ItemTypes->search->get_column('itemtype');
|
||||
if ( C4::Context->preference('item-level_itypes') ) {
|
||||
my $items_with_invalid_itype = Koha::Items->search( { itype => { not_in => \@itemtypes } } );
|
||||
if ( $items_with_invalid_itype->count ) {
|
||||
new_section("Items have invalid itype defined");
|
||||
while ( my $item = $items_with_invalid_itype->next ) {
|
||||
new_item(
|
||||
sprintf "Item with itemnumber=%s does not have a valid itype value (%s)",
|
||||
$item->itemnumber, $item->itype
|
||||
);
|
||||
}
|
||||
new_hint("The items must have a itype value that is defined in the item types of Koha (Home › Administration › Item types administration)");
|
||||
}
|
||||
}
|
||||
else {
|
||||
my $biblioitems_with_invalid_itemtype = Koha::Biblioitems->search(
|
||||
{ itemtype => { not_in => \@itemtypes } }
|
||||
);
|
||||
if ( $biblioitems_with_invalid_itemtype->count ) {
|
||||
new_section("Biblioitems do not have itemtype defined");
|
||||
while ( my $biblioitem = $biblioitems_with_invalid_itemtype->next ) {
|
||||
new_item(
|
||||
sprintf "Biblioitem with biblioitemnumber=%s does not have a valid itemtype value",
|
||||
$biblioitem->biblioitemnumber
|
||||
);
|
||||
}
|
||||
new_hint("The biblioitems must have a itemtype value that is defined in the item types of Koha (Home › Administration › Item types administration)");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
sub new_section {
|
||||
my ( $name ) = @_;
|
||||
say "\n== $name ==";
|
||||
|
@ -74,5 +135,9 @@ Catch data inconsistencies in Koha database
|
|||
|
||||
* Items with undefined homebranch and/or holdingbranch
|
||||
* Authorities with undefined authtypecodes/authority types
|
||||
* Item types:
|
||||
* if item types are defined at item level (item-level_itypes=specific item),
|
||||
then items.itype must be set else biblioitems.itemtype must be set
|
||||
* Item types defined in items or biblioitems must be defined in the itemtypes table
|
||||
|
||||
=cut
|
||||
|
|
Loading…
Reference in a new issue