[ Mini Kiebo ]
Server: Windows NT DESKTOP-5B8S0D4 6.2 build 9200 (Windows 8 Professional Edition) i586
Path:
D:
/
Backup
/
14082024
/
Data
/
htdocs
/
htdocs
/
ojs
/
248
/
lib
/
pkp
/
classes
/
file
/
[
Home
]
File: PKPTemporaryFileManager.inc.php
<?php /** * @file classes/file/TemporaryFileManager.inc.php * * Copyright (c) 2013-2019 Simon Fraser University * Copyright (c) 2000-2019 John Willinsky * Distributed under the GNU GPL v2. For full terms see the file docs/COPYING. * * @class PKPTemporaryFileManager * @ingroup file * @see TemporaryFileDAO * * @brief Class defining operations for temporary file management. */ import('lib.pkp.classes.file.PrivateFileManager'); class PKPTemporaryFileManager extends PrivateFileManager { /** * Constructor */ function PKPTemporaryFileManager() { parent::FileManager(); $this->_performPeriodicCleanup(); } /** * Get the base path for temporary file storage. * @return string */ function getBasePath() { return parent::getBasePath() . '/temp/'; } /** * Retrieve file information by file ID. * @return TemporaryFile */ function &getFile($fileId, $userId) { $temporaryFileDao =& DAORegistry::getDAO('TemporaryFileDAO'); $temporaryFile =& $temporaryFileDao->getTemporaryFile($fileId, $userId); return $temporaryFile; } /** * Read a file's contents. * @param $output boolean output the file's contents instead of returning a string * @return boolean */ function readFile($fileId, $userId, $output = false) { $temporaryFile =& $this->getFile($fileId, $userId); if (isset($temporaryFile)) { $filePath = $this->getBasePath() . $temporaryFile->getFileName(); return parent::readFile($filePath, $output); } else { return false; } } /** * Delete a file by ID. * @param $fileId int */ function deleteFile($fileId, $userId) { $temporaryFile =& $this->getFile($fileId, $userId); parent::deleteFile($this->getBasePath() . $temporaryFile->getFileName()); $temporaryFileDao =& DAORegistry::getDAO('TemporaryFileDAO'); $temporaryFileDao->deleteTemporaryFileById($fileId, $userId); } /** * Download a file. * @param $fileId int the file id of the file to download * @param $inline print file as inline instead of attachment, optional * @return boolean */ function downloadFile($fileId, $userId, $inline = false) { $temporaryFile =& $this->getFile($fileId, $userId); if (isset($temporaryFile)) { $filePath = $this->getBasePath() . $temporaryFile->getFileName(); return parent::downloadFile($filePath, null, $inline); } else { return false; } } /** * Upload the file and add it to the database. * @param $fileName string index into the $_FILES array * @param $userId int * @return object The new TemporaryFile or false on failure */ function handleUpload($fileName, $userId) { // Get the file extension, then rename the file. $fileExtension = $this->parseFileExtension($this->getUploadedFileName($fileName)); if (!$this->fileExists($this->getBasePath(), 'dir')) { // Try to create destination directory $this->mkdirtree($this->getBasePath()); } $newFileName = basename(tempnam($this->getBasePath(), $fileExtension)); if (!$newFileName) return false; if ($this->uploadFile($fileName, $this->getBasePath() . $newFileName)) { $temporaryFileDao =& DAORegistry::getDAO('TemporaryFileDAO'); $temporaryFile = $temporaryFileDao->newDataObject(); $temporaryFile->setUserId($userId); $temporaryFile->setFileName($newFileName); $temporaryFile->setFileType(PKPString::mime_content_type($this->getBasePath() . $newFileName)); $temporaryFile->setFileSize($_FILES[$fileName]['size']); $temporaryFile->setOriginalFileName($this->truncateFileName($_FILES[$fileName]['name'], 127)); $temporaryFile->setDateUploaded(Core::getCurrentDate()); $temporaryFileDao->insertTemporaryFile($temporaryFile); return $temporaryFile; } else { return false; } } /** * Perform periodic cleanup tasks. This is used to occasionally * remove expired temporary files. */ function _performPeriodicCleanup() { if (time() % 100 == 0) { $temporaryFileDao =& DAORegistry::getDAO('TemporaryFileDAO'); $expiredFiles = $temporaryFileDao->getExpiredFiles(); foreach ($expiredFiles as $expiredFile) { $this->deleteFile($expiredFile->getId(), $expiredFile->getUserId()); } } } } ?>