3 # Copyright 2011-2012 BibLibre
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU General Public License as published by the Free Software
9 # Foundation; either version 2 of the License, or (at your option) any later
12 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License along
17 # with Koha; if not, write to the Free Software Foundation, Inc.,
18 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
27 use C4::UploadedFiles;
29 sub plugin_parameters {
30 my ( $dbh, $record, $tagslib, $i, $tabloop ) = @_;
34 sub plugin_javascript {
35 my ( $dbh, $record, $tagslib, $field_number, $tabloop ) = @_;
36 my $function_name = $field_number;
38 <script type=\"text/javascript\">
39 function Focus$function_name(subfield_managed) {
43 function Blur$function_name(subfield_managed) {
47 function Clic$function_name(index) {
48 var id = document.getElementById(index).value;
49 if(id.match(/id=([0-9a-f]+)/)){
52 window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=upload.pl&index=\"+index+\"&id=\"+id, 'upload', 'width=600,height=400,toolbar=false,scrollbars=no');
58 return ( $function_name, $res );
63 my $index = $input->param('index');
64 my $id = $input->param('id');
65 my $delete = $input->param('delete');
66 my $uploaded_file = $input->param('uploaded_file');
68 my $template_name = ($id || $delete)
69 ? "upload_delete_file.tt"
72 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
73 { template_name => "cataloguing/value_builder/$template_name",
77 flagsrequired => { editcatalogue => '*' },
82 # Dealing with the uploaded file
84 my $fh = $input->upload('uploaded_file');
85 my $dir = $input->param('dir');
87 $id = C4::UploadedFiles::UploadFile($uploaded_file, $dir, $fh->handle);
89 my $OPACBaseURL = C4::Context->preference('OPACBaseURL');
90 $OPACBaseURL =~ s#/$##;
91 my $return = "$OPACBaseURL/cgi-bin/koha/opac-retrieve-file.pl?id=$id";
95 uploaded_file => $uploaded_file,
98 $template->param(error => 1);
100 } elsif ($delete || $id) {
101 # If there's already a file uploaded for this field,
102 # We handle its deletion
104 if(C4::UploadedFiles::DelUploadedFile($id)) {;
105 $template->param(success => 1);
107 $template->param(error => 1);
111 my $upload_path = C4::Context->config('upload_path');
113 my $filefield = CGI::filefield(
114 -name => 'uploaded_file',
121 dirs => finddirs($upload_path)
125 dirs_tree => $dirs_tree,
126 filefield => $filefield
129 $template->param( error_upload_path_not_configured => 1 );
138 output_html_with_http_headers $input, $cookie, $template->output;
141 # Build a hierarchy of directories
144 my $upload_path = C4::Context->config('upload_path');
147 my @files = glob("$base/*");
149 if (-d $_ and -w $_) {
150 my $lastdirname = basename($_);
152 $dirname =~ s/^$upload_path//g;
155 name => $lastdirname,
171 This plugin allow to upload files on the server and reference it in a marc
174 Two system preference are used:
178 =item * upload_path: the real absolute path where files will be stored
180 =item * OPACBaseURL: for building URLs to be stored in MARC