koha-cvs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Koha-cvs] CVS: koha/admin checkmarc.pl,NONE,1.1


From: Paul POULAIN
Subject: [Koha-cvs] CVS: koha/admin checkmarc.pl,NONE,1.1
Date: Tue, 21 Jan 2003 05:45:40 -0800

Update of /cvsroot/koha/koha/admin
In directory sc8-pr-cvs1:/tmp/cvs-serv6540/admin

Added Files:
        checkmarc.pl 
Log Message:
add in parameters a "check marc" link.
this script checks MARC parameters and try to detect tome errors in 
configuration.
currently checks 7 differents things.

The 1.3.3 MARC21 parameters fails miserabily to this test : 3 errors !!!


--- NEW FILE ---
#!/usr/bin/perl


# Copyright 2000-2002 Katipo Communications
#
# 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 2 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.
#
# You should have received a copy of the GNU General Public License along with
# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
# Suite 330, Boston, MA  02111-1307 USA

use strict;
use C4::Output;
use C4::Charset;
use C4::Auth;
use CGI;
use C4::Search;
use C4::Context;
use C4::Biblio;
use HTML::Template;

my $input = new CGI;

my ($template, $borrowernumber, $cookie)
    = get_template_and_user({template_name => "parameters/checkmarc.tmpl",
                             query => $input,
                             type => "intranet",
                             authnotrequired => 0,
                             flagsrequired => {parameters => 1},
                             debug => 1,
                             });

my $dbh = C4::Context->dbh;
my $total;
# checks itemnum field
my $sth = $dbh->prepare("select tab from marc_subfield_structure where 
kohafield=\"items.itemnumber\"");
$sth->execute;
my ($res) = $sth->fetchrow;
if ($res==-1) {
        $template->param(itemnum => 0);
} else {
        $template->param(itemnum => 1);
        $total++;
}

# checks biblio.biblionumber and biblioitem.biblioitemnumber (same tag and 
tab=-1)
$sth = $dbh->prepare("select tagfield,tab from marc_subfield_structure where 
kohafield=\"biblio.biblionumber\"");
$sth->execute;
my $tab;
($res,$tab) = $sth->fetchrow;
$sth = $dbh->prepare("select tagfield,tab from marc_subfield_structure where 
kohafield=\"biblioitems.biblioitemnumber\"");
$sth->execute;
my ($res2,$tab2) = $sth->fetchrow;
if ($res && $res2 && ($res eq $res2) && $tab==-1 && $tab2==-1) {
        $template->param(biblionumber => 0);
} else {
        $template->param(biblionumber => 1);
        $total++;
}

# checks all item fields are in the same tag and in tab 10
$sth = $dbh->prepare("select tagfield,tab,kohafield from 
marc_subfield_structure where kohafield like \"items.%\"");
$sth->execute;
my $field;
($res,$res2,$field) = $sth->fetchrow;
my $tagfield = $res;
my $tab = $res2;
my $subtotal=0;
while (($res,$res2,$field) = $sth->fetchrow) {
        # (ignore itemnumber, that must be in -1 tab)
        if (($res ne $tagfield or $res2 ne $tab ) && $field ne 
"items.itemnumber") {
                $subtotal++;
        }
}
if ($subtotal eq 0) {
        $template->param(itemfields => 0);
} else {
        $template->param(itemfields => 1);
        $total++;
}
# checks biblioitems.itemtype must be mapped and use authorised_value=itemtype
$sth = $dbh->prepare("select tagfield,tab,authorised_value from 
marc_subfield_structure where kohafield = \"biblioitems.itemtype\"");
$sth->execute;
($res,$res2,$field) = $sth->fetchrow;
warn "==> $res / $res2 / $field";
if ($res && $res2>=0 && $field eq "itemtypes") {
        $template->param(itemtype => 0);
} else {
        $template->param(itemtype => 1);
        $total++;
}

# checks items.homebranch must be mapped and use authorised_value=branches
$sth = $dbh->prepare("select tagfield,tab,authorised_value from 
marc_subfield_structure where kohafield = \"items.homebranch\"");
$sth->execute;
($res,$res2,$field) = $sth->fetchrow;
if ($res && $res2 eq 10 && $field eq "branches") {
        $template->param(branch => 0);
} else {
        $template->param(branch => 1);
        $total++;
}
# checks items.homebranch must be mapped and use authorised_value=branches
$sth = $dbh->prepare("select tagfield,tab,authorised_value from 
marc_subfield_structure where kohafield = \"items.holdingbranch\"");
$sth->execute;
($res,$res2,$field) = $sth->fetchrow;
if ($res && $res2 eq 10 && $field eq "branches") {
        $template->param(holdingbranch => 0);
} else {
        $template->param(holdingbranch => 1);
        $total++;
}

$template->param(total => $total);
print $input->header(
    -type => guesstype($template->output),
    -cookie => $cookie
), $template->output;




reply via email to

[Prev in Thread] Current Thread [Next in Thread]