| Server IP : 127.0.1.1 / Your IP : 216.73.216.83 Web Server : Apache/2.4.58 (Ubuntu) System : Linux nepub 6.8.0-88-generic #89-Ubuntu SMP PREEMPT_DYNAMIC Sat Oct 11 01:02:46 UTC 2025 x86_64 User : root ( 0) PHP Version : 8.2.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /var/www/html/public_html/lib/pkp/classes/file/ |
Upload File : |
<?php
/**
* @file classes/file/FileArchive.inc.php
*
* Copyright (c) 2014-2021 Simon Fraser University
* Copyright (c) 2000-2021 John Willinsky
* Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
*
* @class FileArchive
* @ingroup file
*
* @brief Class provides functionality for creating an archive of files.
*/
class FileArchive {
/**
* Assembles an array of filenames into either a tar.gz or a .zip
* file, based on what is available. Returns a string representing
* the path to the archive on disk.
* @param array $files the files to add, in an associative array of the
* format ('serverPath' => 'clientFilename')
* @param string $filesDir a path to the files on disk.
* @return string the path to the archive.
*/
function create($files, $filesDir) {
// Create a temporary file.
$archivePath = tempnam('/tmp', 'sf-');
if ($archivePath === false) return false;
unlink($archivePath);
// attempt to use Zip first, if it is available. Otherwise
// fall back to the tar CLI.
$zipTest = false;
if (self::zipFunctional()) {
$zipTest = true;
$zip = new ZipArchive();
if ($zip->open($archivePath, ZIPARCHIVE::CREATE) == true) {
foreach ($files as $serverPath => $clientFilename) {
$zip->addFile($filesDir . '/' . $serverPath, $clientFilename);
}
$zip->close();
}
} elseif (self::tarFunctional()) {
// Create the archive and download the file.
exec(Config::getVar('cli', 'tar') . ' -c -z ' .
'-f ' . escapeshellarg($archivePath) . ' ' .
'-C ' . escapeshellarg($filesDir) . ' ' .
implode(' ', array_map('escapeshellarg', array_keys($files)))
);
} else {
throw new Exception('No archive tool is available!');
}
return $archivePath;
}
/**
* Return true if the zip extension is loaded.
* @return boolean
*/
static function zipFunctional() {
return (extension_loaded('zip'));
}
/**
* Return true if the tar tools are configured.
*/
static function tarFunctional() {
$tarBinary = Config::getVar('cli', 'tar');
return !empty($tarBinary) && file_exists($tarBinary);
}
static function isFunctional() {
return self::zipFunctional() || self::tarFunctional();
}
}