Current File : /home/pacjaorg/.trash/components/com_hikashop/controllers/upload.php |
<?php
/**
* @package HikaShop for Joomla!
* @version 4.4.0
* @author hikashop.com
* @copyright (C) 2010-2020 HIKARI SOFTWARE. All rights reserved.
* @license GNU/GPLv3 http://www.gnu.org/licenses/gpl-3.0.html
*/
defined('_JEXEC') or die('Restricted access');
?><?php
class uploadController extends hikashopController {
var $display = array('upload','image','galleryimage','');
var $modify_views = array('addimage','galleryselect');
var $add = array();
var $modify = array('upload');
var $delete = array();
protected $base_controller = null;
public function __construct($config = array(),$skip=false) {
parent::__construct($config, $skip);
if(!$skip)
$this->registerDefaultTask('galleryimage');
$this->config = hikashop_config();
$this->base_controller = null;
$this->initController();
}
private function initController() {
if($this->base_controller != null)
return;
$controllerName = hikaInput::get()->getVar('uploader', '');
if(!empty($controllerName)) {
if(substr($controllerName, 0, 4) == 'plg.') {
JPluginHelper::importPlugin('hikashop');
$app = JFactory::getApplication();
$app->triggerEvent('onUploadControllerGet', array($controllerName, &$this->base_controller));
} else
$this->base_controller = hikashop_get('controller.'.$controllerName, array(), true);
if(!method_exists($this->base_controller, 'getUploadSetting'))
$this->base_controller = false;
}
}
public function image() {
$this->initController();
$upload_key = hikaInput::get()->getVar('field', '');
if(empty($this->base_controller))
return false;
$uploadConfig = $this->base_controller->getUploadSetting($upload_key, 'image');
if($uploadConfig === false)
return false;
if(!empty($uploadConfig['type']) && $uploadConfig['type'] != 'image')
return false;
hikaInput::get()->set('layout', 'sendfile');
hikaInput::get()->set('uploadConfig', $uploadConfig);
return parent::display();
}
public function galleryimage() {
$this->initController();
$upload_key = hikaInput::get()->getVar('field', '');
if(empty($this->base_controller))
return false;
$uploadConfig = $this->base_controller->getUploadSetting($upload_key, 'galleryimage');
if($uploadConfig === false)
return false;
if(!empty($uploadConfig['type']) && $uploadConfig['type'] != 'image')
return false;
hikaInput::get()->set('layout', 'galleryimage');
hikaInput::get()->set('uploadConfig', $uploadConfig);
return parent::display();
}
public function addImage() {
$this->initController();
$upload_key = hikaInput::get()->getVar('field', '');
if(empty($this->base_controller))
return false;
$options = array();
$uploadConfig = $this->base_controller->getUploadSetting($upload_key, 'addimage');
if($uploadConfig === false)
return false;
if(!empty($uploadConfig['type']) && $uploadConfig['type'] != 'image')
return false;
$layout = 'upload';
if(!empty($uploadConfig['layout']))
$layout = $uploadConfig['layout'];
$viewName = '';
if(!empty($uploadConfig['view']))
$viewName = $uploadConfig['view'];
$type = 'image';
if(!empty($uploadConfig['type']))
$type = $uploadConfig['type'];
if(empty($viewName))
$viewName = ($type == 'image') ? 'image_entry' : 'file_entry';
$extra_data = array();
if(!empty($uploadConfig['extra']))
$extra_data = $uploadConfig['extra'];
if(empty($extra_data['field']))
$extra_data['field'] = $upload_key;
$this->processUploadOption($options, $type);
if(empty($options) || empty($options['upload_dir']))
return false;
$uploadHelper = hikashop_get('helper.upload');
$ret = $uploadHelper->processFallback($options);
$output = '[]';
if($ret !== false && empty($ret->error)) {
$imageHelper = null;
if($type == 'image') {
$imageHelper = hikashop_get('helper.image');
}
$out = array();
foreach($ret as &$r) {
if(!empty($r->error))
continue;
$file = new stdClass();
$file->file_description = '';
$file->file_name = $r->name;
$file->file_type = $type;
$file->file_path = $options['sub_folder'].$r->name;
$file->file_url = $options['upload_url'].$options['sub_folder'];
foreach($extra_data as $k => $v) {
$file->$k = $v;
}
if(strpos($file->file_name, '.') !== false) {
$file->file_name = substr($file->file_name, 0, strrpos($file->file_name, '.'));
}
$r->html = '';
$js = '';
if($type == 'image') {
$imageHelper->autoRotate($file->file_path);
$img = $imageHelper->getThumbnail($file->file_path, array(100, 100), array('default' => true));
$r->thumbnail_url = $img->url;
$params = new stdClass();
$params->file_path = $file->file_path;
$params->file_name = $file->file_name;
$params->file_url = $file->file_url;
} else {
$params = new stdClass();
$params->file_name = $file->file_name;
$params->file_path = $file->file_path;
$params->file_url = $file->file_url;
$params->file_limit = -1;
$params->file_size = @filesize($options['upload_dir'] . $options['sub_folder'] . $file->file_name);
}
foreach($extra_data as $k => $v) {
$params->$k = $v;
}
$r->params = $params;
$this->base_controller->manageUpload($upload_key, $r, $uploadConfig, 'addimage');
if(empty($r->html))
$r->html = hikashop_getLayout($layout, $viewName, $params, $js);
$out[] = $r->html;
unset($r->path);
unset($r->params);
unset($r);
}
if(!empty($out))
$output = json_encode($out);
unset($out);
unset($ret);
}
$js = 'window.hikashop.ready(function(){window.parent.hikashop.submitBox({images:'.$output.'});});';
$doc = JFactory::getDocument();
$doc->addScriptDeclaration($js);
return true;
}
public function galleryselect() {
$this->initController();
$upload_key = hikaInput::get()->getVar('field', '');
if(empty($this->base_controller))
return false;
$uploadConfig = $this->base_controller->getUploadSetting($upload_key, 'galleryselect');
if($uploadConfig === false)
return false;
if(!empty($uploadConfig['type']) && $uploadConfig['type'] != 'image')
return false;
$layout = 'upload';
if(!empty($uploadConfig['layout']))
$layout = $uploadConfig['layout'];
$viewName = '';
if(!empty($uploadConfig['view']))
$viewName = $uploadConfig['view'];
$type = 'image';
if(!empty($uploadConfig['type']))
$type = $uploadConfig['type'];
if(empty($viewName))
$viewName = ($type == 'image') ? 'image_entry' : 'file_entry';
$options = array();
if(!empty($uploadConfig['options']))
$options = $uploadConfig['options'];
$extra_data = array();
if(!empty($uploadConfig['extra']))
$extra_data = $uploadConfig['extra'];
if(empty($extra_data['field']))
$extra_data['field'] = $upload_key;
$this->processUploadOption($options, $type);
if(empty($options) || empty($options['upload_dir']))
return false;
$filesData = hikaInput::get()->get('files', array(), 'array');
$output = '[]';
if(!empty($filesData)) {
$imageHelper = hikashop_get('helper.image');
$ret = array();
$out = array();
foreach($filesData as $filename) {
$r = new stdClass();
$r->name = $filename;
$r->url = str_replace('//', '/', $options['upload_url'].$options['sub_folder'].rawurlencode($filename));
$r->path = str_replace('//', '/', $options['upload_dir'].$options['sub_folder'].$filename);
$r->type = $type;
$r->size = filesize($r->path);
$params = new stdClass();
$params->file_path = str_replace('//', '/', $options['sub_folder'].$filename);
$params->file_name = $filename;
$params->file_url = $r->url;
foreach($extra_data as $k => $v) {
$params->$k = $v;
}
$js = '';
$r->params = $params;
$this->base_controller->manageUpload($upload_key, $r, $uploadConfig, 'galleryselect');
if(empty($r->html))
$r->html = hikashop_getLayout($layout, $viewName, $r->params, $js);
unset($r->params);
$ret[] = $r;
$out[] = $r->html;
unset($r);
}
if(!empty($out))
$output = json_encode($out);
unset($out);
unset($ret);
}
$js = 'window.hikashop.ready(function(){window.parent.hikashop.submitBox({images:'.$output.'});});';
$doc = JFactory::getDocument();
$doc->addScriptDeclaration($js);
return true;
}
public function upload() {
JSession::checkToken() || die('Invalid Token');
$this->initController();
$config = hikashop_config();
$upload_key = hikaInput::get()->getVar('field', '');
if(empty($this->base_controller))
exit;
$uploadConfig = $this->base_controller->getUploadSetting($upload_key, 'upload');
if($uploadConfig === false) {
header('HTTP/1.1 403 Forbidden');
exit;
}
$layout = 'upload';
if(!empty($uploadConfig['layout']))
$layout = $uploadConfig['layout'];
$viewName = '';
if(!empty($uploadConfig['view']))
$viewName = $uploadConfig['view'];
$type = 'image';
if(!empty($uploadConfig['type']))
$type = $uploadConfig['type'];
$options = array();
if(!empty($uploadConfig['options']))
$options = $uploadConfig['options'];
$extra_data = array();
if(!empty($uploadConfig['extra']))
$extra_data = $uploadConfig['extra'];
if(empty($extra_data['field']))
$extra_data['field'] = $upload_key;
if(empty($viewName))
$viewName = ($type == 'image') ? 'image_entry' : 'file_entry';
$this->processUploadOption($options, $type);
if(empty($options) || empty($options['upload_dir']))
return false;
$max_width = (int)$config->get('max_image_size_width', 0);
$max_height = (int)$config->get('max_image_size_height', 0);
$uploadHelper = hikashop_get('helper.upload');
$ret = $uploadHelper->process($options);
if($ret !== false && empty($ret->error) && empty($ret->partial)) {
$imageHelper = null;
if($type == 'image') {
$imageHelper = hikashop_get('helper.image');
}
$file = new stdClass();
$file->file_description = '';
$file->file_name = $ret->name;
$file->file_type = $type;
$file->file_path = $options['sub_folder'].$ret->name;
$file->file_url = $options['upload_url'].$options['sub_folder'];
foreach($extra_data as $k => $v) {
$file->$k = $v;
}
if(strpos($file->file_name, '.') !== false) {
$file->file_name = substr($file->file_name, 0, strrpos($file->file_name, '.'));
}
$ret->file = $file;
$ret->html = '';
$js = '';
if($type == 'image') {
if($max_height > 0 || $max_width > 0) {
}
$imageHelper->autoRotate($file->file_path);
$img = $imageHelper->getThumbnail($file->file_path, array(100, 100), array('default' => true));
$ret->thumbnail_url = $img->url;
$params = new stdClass();
$params->file_path = $file->file_path;
$params->file_name = $file->file_name;
$params->file_url = $file->file_url;
} else {
$params = new stdClass();
$params->file_name = $file->file_name;
$params->file_path = $file->file_path;
$params->file_url = $file->file_url;
$params->file_limit = -1;
$params->file_size = @filesize($options['upload_dir'] . $options['sub_folder'] . $file->file_name);
}
foreach($extra_data as $k => $v) {
$params->$k = $v;
}
$ret->params = $params;
$this->base_controller->manageUpload($upload_key, $ret, $uploadConfig, 'upload');
if(empty($r->html))
$ret->html = hikashop_getLayout($layout, $viewName, $ret->params, $js);
}
unset($ret->path);
unset($ret->params);
echo json_encode($ret);
exit;
}
private function processUploadOption(&$options, $type = 'image') {
$this->initController();
$shopConfig = hikashop_config(false);
if($type == 'image') {
if(empty($options['upload_dir']))
$options['upload_dir'] = $shopConfig->get('uploadfolder');
if(empty($options['type']))
$options['type'] = 'image';
} else {
if(empty($options['upload_dir']))
$options['upload_dir'] = $shopConfig->get('uploadsecurefolder');
if(empty($options['type']))
$options['type'] = 'file';
}
if(empty($options) || empty($options['upload_dir']))
return false;
if(empty($options['sub_folder']))
$options['sub_folder'] = '';
else
$options['sub_folder'] = str_replace(DS,'/',rtrim($options['sub_folder'], DS).DS);
$options['upload_url'] = ltrim(JPath::clean(html_entity_decode($options['upload_dir'])),DS);
$options['upload_url'] = str_replace(DS,'/',rtrim($options['upload_url'],DS).DS);
$app = JFactory::getApplication();
if(hikashop_isClient('administrator')) {
$options['upload_url'] = '../'.$options['upload_url'];
} else {
$options['upload_url'] = rtrim(JURI::base(true),'/').'/'.$options['upload_url'];
}
$options['upload_dir'] = rtrim(JPath::clean(html_entity_decode($options['upload_dir'])), DS.' ').DS;
if(!preg_match('#^([A-Z]:)?/.*#',$options['upload_dir']) && (substr($options['upload_dir'], 0, 1) != '/' || !is_dir($options['upload_dir']))) {
$options['upload_dir'] = JPath::clean(HIKASHOP_ROOT.DS.trim($options['upload_dir'], DS.' ').DS);
}
return true;
}
}