From c9608e6feaf3c6128fcc115e6db272b8fcde4978 Mon Sep 17 00:00:00 2001 From: Daniel Dimitrov Date: Sat, 9 Jun 2012 14:51:17 +0200 Subject: [PATCH] use the tmp path configured in the joomla config --- .../com_jedchecker/controllers/police.php | 4 +- .../com_jedchecker/controllers/uploads.php | 52 ++++++++++++------- .../language/en-GB/en-GB.com_jedchecker.ini | 3 ++ 3 files changed, 39 insertions(+), 20 deletions(-) diff --git a/source/administrator/components/com_jedchecker/controllers/police.php b/source/administrator/components/com_jedchecker/controllers/police.php index a083c3d..935c6cf 100644 --- a/source/administrator/components/com_jedchecker/controllers/police.php +++ b/source/administrator/components/com_jedchecker/controllers/police.php @@ -17,11 +17,11 @@ jimport('joomla.filesystem.archive'); class jedcheckerControllerPolice extends JController { public function check() { require_once JPATH_COMPONENT_ADMINISTRATOR . '/libraries/rules/htmlindexes.php'; - $path = JPATH_COMPONENT_ADMINISTRATOR . '/tmp/unzipped/'; + $path = JFactory::getConfig()->get('tmp_path') . '/jed_checker/unzipped'; $police = new jedcheckerRulesHtmlindexes; $folders = JFolder::folders($path); - $police->check($path.$folders[0]); + $police->check($path.'/'.$folders[0]); } } \ No newline at end of file diff --git a/source/administrator/components/com_jedchecker/controllers/uploads.php b/source/administrator/components/com_jedchecker/controllers/uploads.php index aeac545..c770488 100644 --- a/source/administrator/components/com_jedchecker/controllers/uploads.php +++ b/source/administrator/components/com_jedchecker/controllers/uploads.php @@ -16,9 +16,9 @@ class jedcheckerControllerUploads extends JController { public function __construct() { - $this->path = JPATH_COMPONENT_ADMINISTRATOR . '/tmp/'; - $this->pathArchive = $this->path . 'arhives/'; - $this->pathUnzipped = $this->path . 'unzipped/'; + $this->path = JFactory::getConfig()->get('tmp_path') . '/jed_checker'; + $this->pathArchive = $this->path . '/arhives'; + $this->pathUnzipped = $this->path . '/unzipped'; parent::__construct(); } @@ -28,18 +28,25 @@ class jedcheckerControllerUploads extends JController */ public function upload() { + $appl = JFactory::getApplication(); $file = JRequest::getVar('extension', '', 'files', 'array'); if ($file['tmp_name']) { $path = $this->pathArchive; - $filepath = $path . strtolower($file['name']); -// let us remove all previous uploads - $archiveFiles = JFolder::files($path); + // if the archive folder doesn't exist - create it! + if(!JFolder::exists($path)) { + JFolder::create($path); + } else { + // let us remove all previous uploads + $archiveFiles = JFolder::files($path); - foreach ($archiveFiles as $archive) { - if (!JFile::delete($this->pathArchive . $archive)) { - echo 'could not delete' . $archive; + foreach ($archiveFiles as $archive) { + if (!JFile::delete($this->pathArchive . '/'.$archive)) { + echo 'could not delete' . $archive; + } } } + $filepath = $path .'/'. strtolower($file['name']); + $object_file = new JObject($file); $object_file->filepath = $filepath; @@ -51,7 +58,7 @@ class jedcheckerControllerUploads extends JController JError::raiseWarning(100, JText::_('COM_JEDCHECKER_ERROR_UNABLE_TO_UPLOAD_FILE')); return false; } - + $appl->redirect('index.php?option=com_jedchecker&view=uploads', JText::_('COM_JEDCHECKER_UPLOAD_WAS_SUCCESSFUL')); return true; } @@ -64,22 +71,31 @@ class jedcheckerControllerUploads extends JController */ public function unzip() { - - // let us remove all previous unzipped files - $folders = JFolder::folders($this->pathUnzipped); - foreach ($folders as $folder) { - JFolder::delete($this->pathUnzipped . $folder); + $appl = JFactory::getApplication(); + // if folder doesn't exist - create it! + if(!JFolder::exists($this->pathUnzipped)) { + JFolder::create($this->pathUnzipped); + } else { + // let us remove all previous unzipped files + $folders = JFolder::folders($this->pathUnzipped); + foreach ($folders as $folder) { + JFolder::delete($this->pathUnzipped .'/'. $folder); + } } - $file = JFolder::files($this->pathArchive); - $result = JArchive::extract($this->pathArchive . $file[0], $this->pathUnzipped . $file[0]); + $result = JArchive::extract($this->pathArchive .'/'. $file[0], $this->pathUnzipped .'/'. $file[0]); if ($result) { // scan unzipped folders if we find zip file -> unzip them as well - $this->unzipAll($this->pathUnzipped . $file[0]); + $this->unzipAll($this->pathUnzipped .'/'. $file[0]); + $message = 'COM_JEDCHECKER_UNZIP_SUCCESS'; + } else { + $message = 'COM_JEDCHECKER_UNZIP_FAILED'; } + $appl->redirect('index.php?option=com_jedchecker&view=uploads', JText::_($message)); + return $result; } diff --git a/source/administrator/language/en-GB/en-GB.com_jedchecker.ini b/source/administrator/language/en-GB/en-GB.com_jedchecker.ini index 6525306..70acda3 100644 --- a/source/administrator/language/en-GB/en-GB.com_jedchecker.ini +++ b/source/administrator/language/en-GB/en-GB.com_jedchecker.ini @@ -1 +1,4 @@ ; Language files have to start with semicolon (;) otherwise we have problems with transifex +COM_JEDCHECKER_UPLOAD_WAS_SUCCESSFUL="Upload was successful" +COM_JEDCHECKER_UNZIP_SUCCESS="Unzip was successful! Now go ahead and click that check button!" +COM_JEDCHECKER_UNZIP_FAILED="Unzip failed"; \ No newline at end of file