# 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 CGI qw ( -utf8 );
use CGI::Cookie;
use C4::Context;
-use C4::Auth qw/check_cookie_auth/;
-use C4::ImportExportFramework;
+use C4::Auth qw( check_cookie_auth );
+use C4::ImportExportFramework qw( createODS ExportFramework ImportFramework );
my %cookies = CGI::Cookie->fetch();
-my $authenticated = 0;
-my ($auth_status, $sessionID);
+my ($auth_status);
if (exists $cookies{'CGISESSID'}) {
- ($auth_status, $sessionID) = check_cookie_auth(
+ ($auth_status, undef) = check_cookie_auth(
$cookies{'CGISESSID'}->value,
{ parameters => 'manage_marc_frameworks' },
);
}
-if ($auth_status eq 'ok') {
- $authenticated = 1;
-}
-my $input = new CGI;
+my $input = CGI->new;
-unless ($authenticated) {
+unless ($auth_status eq 'ok') {
print $input->header(-type => 'text/plain', -status => '403 Forbidden');
exit 0;
}
-my $framework_name = $input->param('frameworkcode') || 'default';
-my $frameworkcode = ($framework_name eq 'default') ? q{} : $framework_name;
+my $frameworkcode = $input->param('frameworkcode') || 'default';
my $action = $input->param('action') || 'export';
## Exporting
if ($action eq 'export' && $input->request_method() eq 'GET') {
my $strXml = '';
- my $format = $input->param('type_export_' . $framework_name);
- ExportFramework($frameworkcode, \$strXml, $format);
+ my $format = $input->param('type_export_' . $frameworkcode);
+ if ($frameworkcode eq 'default') {
+ ExportFramework('', \$strXml, $format, 'biblio');
+ } else {
+ ExportFramework($frameworkcode, \$strXml, $format, 'biblio');
+ }
if ($format eq 'csv') {
# CSV file
# Correctly set the encoding to output plain text in UTF-8
binmode(STDOUT,':encoding(UTF-8)');
- print $input->header(-type => 'application/vnd.ms-excel', -attachment => 'export_' . $framework_name . '.csv');
- print $strXml;
- } elsif ($format eq 'excel') {
- # Excel-xml file
- print $input->header(-type => 'application/excel', -attachment => 'export_' . $framework_name . '.xml');
+ print $input->header(-type => 'application/vnd.ms-excel', -attachment => 'export_' . $frameworkcode . '.csv');
print $strXml;
} else {
# ODS file
my $strODS = '';
createODS($strXml, 'en', \$strODS);
- print $input->header(-type => 'application/vnd.oasis.opendocument.spreadsheet', -attachment => 'export_' . $framework_name . '.ods');
+ print $input->header(-type => 'application/vnd.oasis.opendocument.spreadsheet', -attachment => 'export_' . $frameworkcode . '.ods');
print $strODS;
}
## Importing
} elsif ($input->request_method() eq 'POST') {
my $ok = -1;
- my $fieldname = 'file_import_' . $framework_name;
+ my $fieldname = 'file_import_' . $frameworkcode;
my $filename = $input->param($fieldname);
# upload the input file
- if ($filename && $filename =~ /\.(csv|ods|xml)$/i) {
+ if ($filename && $filename =~ /\.(csv|ods)$/i) {
my $extension = $1;
my $uploadFd = $input->upload($fieldname);
if ($uploadFd && !$input->cgi_error) {
my $tmpfilename = $input->tmpFileName(scalar $input->param($fieldname));
$filename = $tmpfilename . '.' . $extension; # rename the tmp file with the extension
- $ok = ImportFramework($filename, $frameworkcode, 1) if (rename($tmpfilename, $filename));
+ $ok = ImportFramework($filename, $frameworkcode, 1, 'biblio') if (rename($tmpfilename, $filename));
}
}
if ($ok >= 0) { # If everything went ok go to the framework marc structure