5 # Script for handling import of MARC data into Koha db
8 # Koha library project www.koha.org
10 # Licensed under the GPL
13 # Copyright 2000-2002 Katipo Communications
15 # This file is part of Koha.
17 # Koha is free software; you can redistribute it and/or modify it under the
18 # terms of the GNU General Public License as published by the Free Software
19 # Foundation; either version 2 of the License, or (at your option) any later
22 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
23 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
24 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
26 # You should have received a copy of the GNU General Public License along with
27 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
28 # Suite 330, Boston, MA 02111-1307 USA
32 # standard or CPAN modules used
35 use MARC::File::USMARC;
48 my $includes = C4::Context->config('includes') ||
49 "/usr/local/www/hdl/htdocs/includes";
51 # HTML colors for alternating lines
59 my $userid=$ENV{'REMOTE_USER'};
62 my $dbh = C4::Context->dbh;
64 my $uploadmarc=$input->param('uploadmarc');
65 my $overwrite_biblio = $input->param('overwrite_biblio');
66 my $filename = $input->param('filename');
67 my $syntax = $input->param('syntax');
68 my ($template, $loggedinuser, $cookie)
69 = get_template_and_user({template_name => "tools/breeding.tmpl",
73 flagsrequired => {tools => 1},
77 $template->param(SCRIPT_NAME => $ENV{'SCRIPT_NAME'},
78 uploadmarc => $uploadmarc);
79 if ($uploadmarc && length($uploadmarc)>0) {
81 while (<$uploadmarc>) {
84 my ($notmarcrecord,$alreadyindb,$alreadyinfarm,$imported) = ImportBreeding($marcrecord,$overwrite_biblio,$filename,$syntax,int(rand(99999)));
86 $template->param(imported => $imported,
87 alreadyindb => $alreadyindb,
88 alreadyinfarm => $alreadyinfarm,
89 notmarcrecord => $notmarcrecord,
90 total => $imported+$alreadyindb+$alreadyinfarm+$notmarcrecord,
95 output_html_with_http_headers $input, $cookie, $template->output;
101 # log cleared, as marcimport is (almost) rewritten from scratch.
103 # Revision 1.3 2007/04/24 13:54:30 hdl
104 # functions that were in C4::Interface::CGI::Output are now in C4::Output.
105 # So this implies quite a change for files.
106 # Sorry about conflicts which will be caused.
107 # directory Interface::CGI should now be dropped.
108 # I noticed that many scripts (reports ones, but also some circ/stats.pl or opac-topissues) still use Date::Manip.
110 # Revision 1.2 2007/03/09 15:47:55 tipaul
111 # rel_3_0 moved to HEAD (introducing new files)
113 # Revision 1.1.2.3 2006/12/22 17:13:49 tipaul
114 # removing "management" permission, that is useless (replaced by tools & admin)
116 # Revision 1.1.2.2 2006/12/18 16:35:20 toins
117 # removing use HTML::Template from *.pl.
119 # Revision 1.1.2.1 2006/09/26 13:35:33 toins
120 # breeding.pl moving from import/ to tools/
122 # Revision 1.5.2.1 2006/09/26 13:10:35 toins
123 # script was writed 2 times on the same file !
125 # Revision 1.5 2006/07/04 14:36:52 toins
126 # Head & rel_2_2 merged
128 # Revision 1.4 2005/05/04 08:52:13 tipaul
129 # synch'ing 2.2 and head
131 # Revision 1.2.4.1 2005/04/07 10:10:52 tipaul
132 # copying processz3950queue from 2.0 branch. The 2.2 version misses an important fix
134 # Revision 1.2 2003/10/06 09:10:38 slef
135 # Removing config info from z3950*sh and using C4::Context in processz3950queue (Fixed bug 39)
137 # Revision 1.1 2003/06/04 13:46:25 tipaul
138 # moving breeding farm import to parameters page (GUI) and to new import/ directory (code structure)
140 # Revision 1.33 2003/04/29 16:48:36 tipaul
141 # really proud of this commit :-)
142 # z3950 search and import seems to works fine.
143 # Let me explain how :
144 # * a "search z3950" button is added in the addbiblio template.
145 # * when clicked, a popup appears and z3950/search.pl is called
146 # * z3950/search.pl calls addz3950search in the DB
147 # * the z3950 daemon retrieve the records and stores them in z3950results AND in marc_breeding table.
148 # * as long as there as searches pending, the popup auto refresh every 2 seconds, and says how many searches are pending.
149 # * when the user clicks on a z3950 result => the parent popup is called with the requested biblio, and auto-filled
152 # * character encoding support : (It's a nightmare...) In the z3950servers table, a "encoding" column has been added. You can put "UNIMARC" or "USMARC" in this column. Depending on this, the char_decode in C4::Biblio.pm replaces marc-char-encode by an iso 8859-1 encoding. Note that in the breeding import this value has been added too, for a better support.
153 # * the marc_breeding and z3950* tables have been modified : they have an encoding column and the random z3950 number is stored too for convenience => it's the key I use to list only requested biblios in the popup.
155 # Revision 1.32 2003/04/22 12:22:54 tipaul
156 # 1st draft for z3950 client import.
157 # moving Breeding farm script to a perl package C4/Breeding.pm
159 # Revision 1.31 2003/02/19 01:01:07 wolfpac444
160 # Removed the unecessary $dbh argument from being passed.
161 # Resolved a few minor FIXMEs.
163 # Revision 1.30 2003/02/02 07:18:38 acli
164 # Moved C4/Charset.pm to C4/Interface/CGI/Output.pm
166 # Create output_html_with_http_headers function to contain the "print $query
167 # ->header(-type => guesstype...),..." call. This is in preparation for
168 # non-HTML output (e.g., text/xml) and charset conversion before output in
171 # Created C4/Interface/CGI/Template.pm to hold convenience functions specific
172 # to the CGI interface using HTML::Template
174 # Modified moremembers.pl to make the "sex" field localizable for languages
175 # where M and F doesn't make sense
177 # Revision 1.29 2003/01/28 15:28:31 tipaul
178 # removing use MARC::Charset
181 # Revision 1.28 2003/01/28 15:00:31 tipaul
182 # user can now search in breeding farm with isbn/issn or title. Title/name are stored in breeding farm and showed when a search is done
184 # Revision 1.27 2003/01/26 23:21:49 acli
185 # Handle non-latin1 charsets
187 # Revision 1.26 2003/01/23 12:26:41 tipaul
188 # upgrading import in breeding farm (you can now search on ISBN or on title) AND character encoding.
190 # Revision 1.25 2003/01/21 08:13:50 tipaul
191 # character encoding ISO646 => 8859-1, first draft
193 # Revision 1.24 2003/01/14 16:41:17 tipaul
194 # bugfix : use gettemplate_and_user instead of gettemplate.
195 # fix a blank screen in 1.3.3 in "import in breeding farm"
197 # Revision 1.23 2003/01/06 13:06:28 tipaul
198 # removing trailing #
200 # Revision 1.22 2002/11/12 15:58:43 tipaul
203 # * adding value_builder : you can map a subfield in the marc_subfield_structure to a sub stored in "value_builder" directory. In this directory you can create screen used to build values with any method. In this commit is a 1st draft of the builder for 100$a unimarc french subfield, which is composed of 35 digits, with 12 differents values (only the 4th first are provided for instance)
205 # Revision 1.21 2002/10/22 15:50:23 tipaul
206 # road to 1.3.2 : adding a biblio in MARC format.
207 # seems to work a few.
209 # * manage html checks (mandatory subfields...)
210 # * add list of acceptable values (authorities)
211 # * manage ## in MARC format
212 # * manage correctly repeatable fields
213 # and probably a LOT of bugfixes
215 # Revision 1.20 2002/10/16 12:46:19 arensb
216 # Added a FIXME comment.
218 # Revision 1.19 2002/10/15 10:14:44 tipaul
219 # road to 1.3.2. Full rewrite of marcimport.pl.
220 # The acquisition system in MARC version will work like this :
221 # * marcimport will put marc records into a "breeding farm" table.
222 # * when the user want to add a biblio, he enters first the ISBN/ISSN of the biblio. koha searches into breeding farm and if the record exists, it is shown to the user to help him adding the biblio. When the biblio is added, it's deleted from the breeding farm.
225 # * modify acqui.simple home page (addbooks.pl)
226 # * adds import into breeding farm
229 # * z3950 functionnality is dropped from "marcimport" will be added somewhere else.
230 # * templates are in a new acqui.simple sub directory, and the marcimport template directory will become obsolete soon.I think this is more logic