From 05c9fbdaede9af10f7f166880d4f7208b502b107 Mon Sep 17 00:00:00 2001 From: pcanterino <> Date: Fri, 31 Dec 2010 12:57:29 +0000 Subject: [PATCH 1/1] Allow to unpack a file after uploading --- modules/Command.pm | 23 +++++++++++++++++------ templates/about.htm | 4 ++-- templates/upload.htm | 5 ++++- 3 files changed, 23 insertions(+), 9 deletions(-) diff --git a/modules/Command.pm b/modules/Command.pm index ec7ca69..2a8ceb9 100644 --- a/modules/Command.pm +++ b/modules/Command.pm @@ -6,7 +6,7 @@ package Command; # Execute Dev-Editor's commands # # Author: Patrick Canterino -# Last modified: 2010-10-30 +# Last modified: 2010-12-31 # # Copyright (C) 1999-2000 Roland Bluethgen, Frank Schoenmann # Copyright (C) 2003-2009 Patrick Canterino @@ -614,6 +614,15 @@ sub exec_upload($$) $data =~ s/\015\012|\012|\015/\n/g if($ascii); # Replace line separators if transferring in ASCII mode file_save($file_phys,\$data,not $ascii) or return error($config->{'errors'}->{'mkfile_failed'},$virtual,{FILE => $file_virt}); + if($cgi->param('unpack') && $File::Access::has_archive_extract) + { + return error($config->{'errors'}->{'no_archive'},$virtual,{FILE => encode_html($file_virt)}) unless(is_archive($file_phys)); + + my $return_unpack = archive_unpack($file_phys,$physical); + + return error($config->{'errors'}->{'unpack_failed'},$virtual,{FILE => encode_html($file_virt), AE_ERROR => ''}) unless($return_unpack); + } + return devedit_reload({command => 'show', file => $virtual}); } else @@ -626,6 +635,8 @@ sub exec_upload($$) $tpl->fillin('URL',encode_html(equal_url($config->{'httproot'},$virtual))); $tpl->fillin('SCRIPT',$script); + $tpl->parse_if_block('PERL_ARCHIVE_EXTRACT',$File::Access::has_archive_extract); + my $output = header(-type => 'text/html'); $output .= $tpl->get_template; @@ -654,15 +665,15 @@ sub exec_unpack($$) return error($config->{'errors'}->{'no_ae'},$dir) unless($File::Access::has_archive_extract); return error($config->{'errors'}->{'no_archive'},$dir,{FILE => encode_html($virtual)}) unless(is_archive($physical)); - + if($new_physical) { return error($config->{'errors'}->{'unpack_no_dir'},$dir,{FILE => encode_html($virtual), NEW_FILE => encode_html($new_virtual)}) if(-l $new_physical || not -d $new_physical); - + my $return_unpack = archive_unpack($physical,$new_physical); - + return error($config->{'errors'}->{'unpack_failed'},$dir,{FILE => encode_html($virtual), AE_ERROR => ''}) unless($return_unpack); - + return devedit_reload({command => 'show', file => $new_virtual}); } else @@ -1222,7 +1233,7 @@ sub exec_about($$) $tpl->fillin('PERL_PROG',encode_html($^X)); $tpl->fillin('PERL_VER', sprintf('%vd',$^V)); - + $tpl->parse_if_block('PERL_ARCHIVE_EXTRACT',$File::Access::has_archive_extract); # Information about the server diff --git a/templates/about.htm b/templates/about.htm index da7de13..1160cf5 100644 --- a/templates/about.htm +++ b/templates/about.htm @@ -183,8 +183,8 @@ WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. -Perl module Archive::Extract available: -{IF PERL_ARCHIVE_EXTRACT}Yes{ELSE}No{ENDIF} +Perl module Archive::Extract: +{IF PERL_ARCHIVE_EXTRACT}Available{ELSE}Not available{ENDIF} diff --git a/templates/upload.htm b/templates/upload.htm index 494bbb4..9e0abe3 100644 --- a/templates/upload.htm +++ b/templates/upload.htm @@ -31,7 +31,9 @@

Transfer mode (see below):

-

+

{IF PERL_ARCHIVE_EXTRACT} + +

{ENDIF}

@@ -49,6 +51,7 @@
-- 2.34.1