Server IP : 195.201.23.43 / Your IP : 3.15.11.205 Web Server : Apache System : Linux webserver2.vercom.be 5.4.0-192-generic #212-Ubuntu SMP Fri Jul 5 09:47:39 UTC 2024 x86_64 User : kdecoratie ( 1041) PHP Version : 7.1.33-63+ubuntu20.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /home/kdecoratie/public_html/administrator/components/com_slideshowck/helpers/ |
Upload File : |
<?php /** * @copyright Copyright (C) 2019. All rights reserved. * @license GNU General Public License version 2 or later; see LICENSE.txt * @author Cedric Keiflin - https://www.template-creator.com - https://www.joomlack.fr */ use \Slideshowck\CKPath; use \Slideshowck\CKFolder; use \Slideshowck\CKFile; defined('_JEXEC') or die; jimport('joomla.filesystem.folder'); jimport('joomla.filesystem.file'); class CKBrowse { static $isRestrictedUser = false; /* * Get a list of folders and files */ public static function getItemsList($type = 'image') { $input = JFactory::getApplication()->input; $type = $input->get('type', $type, 'string'); switch ($type) { case 'video' : $filetypes = array('.mp4', '.ogv', '.webm', '.MP4', '.OGV', '.WEBM'); break; case 'audio' : $filetypes = array('.mp3', '.ogg', '.MP3', '.OGG'); break; case 'image' : default : $filetypes = array('.jpg', '.jpeg', '.png', '.gif', '.tiff', '.JPG', '.JPEG', '.PNG', '.GIF', '.TIFF', '.ico'); break; } $folder = $input->get('folder', '', 'string') ? '/' . trim($input->get('folder', '', 'string'), '/') : '/' . trim(JComponentHelper::getParams('com_slideshowck')->get('imagespath', 'images/slideshowck'), '/'); // makes replacement if specific user management is set if (stristr($folder, '$userid')) { self::$isRestrictedUser = true; $user = JFactory::getUser(); $folder = str_replace('$userid', 'user_' . $user->id, $folder); if (! file_exists(JPATH_SITE . '/' . $folder)) { JFolder::create(JPATH_SITE . '/' . $folder); } } // no folder filtering if (JComponentHelper::getParams('com_slideshowck')->get('imagespathexclusive', '0') == '0') { $folder = $input->get('folder', 'images', 'string'); } $tree = new stdClass(); // list the files in the root folder self::getImagesInFolder(JPATH_SITE . '/' . $folder, $tree, implode('|', $filetypes), 1); // look for all folder and files self::getSubfolder(JPATH_SITE . '/' . $folder, $tree, implode('|', $filetypes), 2); $tree = self::prepareList($tree); return $tree; } /* * List the subfolders and files according to the filter */ private static function getSubfolder($folder, &$tree, $filter, $level) { $folders = JFolder::folders($folder, '.', $recurse = false, $fullpath = true); natcasesort($folders); if (! count($folders)) return; foreach ($folders as $f) { // list all authorized files from the folder self::getImagesInFolder($f, $tree, $filter, $level); // recursive loop self::getSubfolder($f, $tree, $filter, $level+1); } return; } /* * List the subfolders and files according to the filter */ private static function getImagesInFolder($f, &$tree, $filter, $level) { // list all authorized files from the folder $files = JFolder::files($f, $filter, $recurse = false, $fullpath = false); natcasesort($files); $fName = JFile::makeSafe(str_replace(JPATH_SITE, '', $f)); $tree->$fName = new stdClass(); $name = explode('/', $f); $name = end($name); $tree->$fName->name = ($level == 1 && self::$isRestrictedUser == true) ? 'images' : $name; $tree->$fName->path = $f; $tree->$fName->files = $files; $tree->$fName->level = $level; } /* * Set level diff and check for depth */ private static function prepareList($items) { if (! $items) return $items; $lastitem = 0; foreach ($items as $i => $item) { self::prepareItem($item); if ($item->level != 0) { if (isset($items->$lastitem)) { $items->$lastitem->deeper = ($item->level > $items->$lastitem->level); $items->$lastitem->shallower = ($item->level < $items->$lastitem->level); $items->$lastitem->level_diff = ($items->$lastitem->level - $item->level); } } $lastitem = $i; } // for the last item if (isset($items->$lastitem)) { $items->$lastitem->deeper = (1 > $items->$lastitem->level); $items->$lastitem->shallower = (1 < $items->$lastitem->level); $items->$lastitem->level_diff = ($item->level - 1); } return $items; } /* * Set the default values */ private static function prepareItem(&$item) { $item->deeper = false; $item->shallower = false; $item->level_diff = 0; $item->basepath = str_replace(JPATH_SITE, '', $item->path); $item->basepath = str_replace('\\', '/', $item->basepath); $item->basepath = trim($item->basepath, '/'); } /** * Get the file and store it on the server * * @return mixed, the method return */ public static function ajaxAddPicture() { // check the token for security if (! JSession::checkToken('get')) { $msg = JText::_('JINVALID_TOKEN'); echo '{"error" : "' . $msg . '"}'; exit; } $app = JFactory::getApplication(); $input = $app->input; $file = $input->files->get('file', '', 'array'); // $imgpath = '/' . trim($input->get('path', '', 'string'), '/') . '/'; $imgpath = $input->get('path', '', 'string') ? '/' . trim($input->get('path', '', 'string'), '/') . '/' : '/' . trim(JComponentHelper::getParams('com_slideshowck')->get('imagespath', 'images/slideshowck'), '/') . '/'; // makes replacement if specific user management is set $user = JFactory::getUser(); $imgpath = str_replace('$userid', 'user_' . $user->id, $imgpath); if (!is_array($file)) { $msg = JText::_('CK_NO_FILE_RECEIVED'); echo '{"error" : "' . $msg . '"}'; exit; } $filename = JFile::makeSafe($file['name']); // check the file extension // TODO recup preg_match de local dev // if (JFile::getExt($filename) != 'jpg') { // $msg = JText::_('CK_NOT_JPG_FILE'); // echo '{"error" : "' $msg '"}'; // exit; // } //Set up the source and destination of the file $src = $file['tmp_name']; // check if the file exists if (!$src || !JFile::exists($src)) { $msg = JText::_('CK_FILE_NOT_EXISTS'); echo '{"error" : "' . $msg . '"}'; exit; } // check if folder exists, if not then create it if (!JFolder::exists(JPATH_SITE . $imgpath)) { if (!JFolder::create(JPATH_SITE . $imgpath)) { $msg = JText::_('CK_UNABLE_TO_CREATE_FOLDER') . ' : ' . $imgpath; echo '{"error" : "' . $msg . '"}'; exit; } } // write the file if (! JFile::copy($src, JPATH_SITE . $imgpath . $filename)) { $msg = JText::_('CK_UNABLE_WRITE_FILE'); echo '{"error" : "' . $msg . '"}'; exit; } echo '{"img" : "' . $imgpath . $filename . '", "filename" : "' . $filename . '"}'; exit; } public static function createFolder($path, $folder) { $path = CKPath::clean(JPATH_SITE . '/' . $path . '/' . $folder); if (!is_dir($path) && !is_file($path)) { if (CKFolder::create($path)) { $data = "<html>\n<body bgcolor=\"#FFFFFF\">\n</body>\n</html>"; CKFile::write($path . '/index.html', $data); } else { return false; } } return true; } }Private