X-Git-Url: https://jasonwoof.com/gitweb/?p=wfpl.git;a=blobdiff_plain;f=tar.php;h=d5f7021d154a1bf0763f2e3310ad9b9b661674d6;hp=f514a6b95df47e510d28761b6fa9f4892327df6b;hb=6be2bf0ba344177f0d1e57d9135bcb97579c54a3;hpb=22d5fb7ab7d4ee86bd59e194387dca268bd577a1 diff --git a/tar.php b/tar.php index f514a6b..d5f7021 100644 --- a/tar.php +++ b/tar.php @@ -1,22 +1,9 @@ $file_data) { - $filename_fixed = ereg_replace('[^a-zA-Z0-9_.-]', '', $filename); + if(substr($filename, -3) == ' ->') { + $filename = substr($filename, 0, -3); + $link = true; + } else { + $link = false; + } + $filename_fixed = preg_replace('|[^a-z0-9_.-]|i', '', $filename); if($filename != $filename_fixed) { die("Invalid filename for tar archive"); } - write_file("$tmpdir/$dirname/$filename", $file_data); + if($link) { + $target = preg_replace('|[^a-z0-9_./-]|i', '', $file_data); + system("/bin/ln -s $file_data \"$tmpdir/$dirname/$filename\""); + } else { + write_file("$tmpdir/$dirname/$filename", $file_data); + } } - if(function_exists($extra)) { - $extra("$tmpdir/$dirname"); + if($pre_archive_func && function_exists($pre_archive_func)) { + $pre_archive_func("$tmpdir/$dirname"); } header("Content-type: application/x-gzip"); passthru("tar -C $tmpdir -czf - $dirname/"); - system("/bin/rm -rf '$tmpdir/$dirname'"); + system('/bin/rm -rf ' . escapeshellarg($tmpdir)); } -# like make_tar above, except it includes a copy of code/wfpl +# like make_tar above, except it includes a copy of wfpl function make_wfpl_tar($dirname, $files) { make_tar($dirname, $files, 'add_wfpl_dir'); } function add_wfpl_dir($dir) { mkdir("$dir/code"); - system("/bin/cp -HRp 'code/wfpl' '$dir/code/'", $return_code); + system("rsync -plr --exclude=\".git\" --exclude=\"*.swp\" 'inc/wfpl/' '$dir/inc/wfpl/'", $return_code); if($return_code != 0) { - die("ERROR: while trying to copy wfpl into archive: cp returned $return_code"); + die("ERROR: while trying to copy wfpl into archive: rsync returned $return_code"); } - system("/bin/rm -rf '$dir/code/wfpl/.git'"); }