3 # Copyright 2016 Aleisha Amohia <aleisha@catalyst.net.nz>
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
24 use C4::Auth qw/check_cookie_auth/;
25 use C4::ImportExportFramework qw( ExportFramework ImportFramework createODS );
27 my %cookies = CGI::Cookie->fetch();
28 my ($auth_status, $sessionID);
29 if (exists $cookies{'CGISESSID'}) {
30 ($auth_status, $sessionID) = check_cookie_auth(
31 $cookies{'CGISESSID'}->value,
32 { parameters => 'parameters_remaining_permissions' },
38 unless ($auth_status eq 'ok') {
39 print $input->header(-type => 'text/plain', -status => '403 Forbidden');
43 my $authtypecode = $input->param('authtypecode') || 'default';
44 my $action = $input->param('action') || 'export';
47 if ($action eq 'export' && $input->request_method() eq 'GET') {
49 my $format = $input->param('type_export_' . $authtypecode);
50 if ($authtypecode eq 'default') {
51 $format = $input->param('type_export_');
52 ExportFramework('', \$strXml, $format, 'authority');
54 ExportFramework($authtypecode, \$strXml, $format, 'authority');
57 if ($format eq 'csv') {
60 # Correctly set the encoding to output plain text in UTF-8
61 binmode(STDOUT,':encoding(UTF-8)');
62 print $input->header(-type => 'application/vnd.ms-excel', -attachment => 'export_' . $authtypecode . '.csv');
67 createODS($strXml, 'en', \$strODS);
68 print $input->header(-type => 'application/vnd.oasis.opendocument.spreadsheet', -attachment => 'export_' . $authtypecode . '.ods');
72 } elsif ($input->request_method() eq 'POST') {
74 my $fieldname = 'file_import_' . $authtypecode;
75 if ($authtypecode eq 'default'){
76 $fieldname = 'file_import_';
78 my $filename = $input->param($fieldname);
79 # upload the input file
80 if ($filename && $filename =~ /\.(csv|ods)$/i) {
82 my $uploadFd = $input->upload($fieldname);
83 if ($uploadFd && !$input->cgi_error) {
84 my $tmpfilename = $input->tmpFileName(scalar $input->param($fieldname));
85 $filename = $tmpfilename . '.' . $extension; # rename the tmp file with the extension
86 if ($authtypecode eq 'default') {
87 $ok = ImportFramework($filename, '', 1, 'authority') if (rename($tmpfilename, $filename));
89 $ok = ImportFramework($filename, $authtypecode, 1, 'authority') if (rename($tmpfilename, $filename));
93 if ($ok >= 0) { # If everything went ok go to the authority type marc structure
94 if ($authtypecode eq 'default'){
95 print $input->redirect( -location => '/cgi-bin/koha/admin/auth_tag_structure.pl?authtypecode=');
97 print $input->redirect( -location => '/cgi-bin/koha/admin/auth_tag_structure.pl?authtypecode=' . $authtypecode);
100 # If something failed go to the list of authority types and show message
101 print $input->redirect( -location => '/cgi-bin/koha/admin/authtypes.pl?error_import_export=' . $authtypecode);