* @github Joomla Component Builder * @copyright Copyright (C) 2015. All Rights Reserved * @license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html */ // No direct access to this file defined('_JEXEC') or die('Restricted access'); // import Joomla controllerform library jimport('joomla.application.component.controller'); /** * Membersmanager Ajax Controller */ class MembersmanagerControllerAjax extends JControllerLegacy { public function __construct($config) { parent::__construct($config); // make sure all json stuff are set JFactory::getDocument()->setMimeEncoding( 'application/json' ); JResponse::setHeader('Content-Disposition','attachment;filename="getajax.json"'); JResponse::setHeader("Access-Control-Allow-Origin", "*"); // load the tasks $this->registerTask('checkUnique', 'ajax'); $this->registerTask('getRegion', 'ajax'); $this->registerTask('getUser', 'ajax'); $this->registerTask('setUser', 'ajax'); $this->registerTask('getCreateUserFields', 'ajax'); $this->registerTask('createUser', 'ajax'); $this->registerTask('uploadfile', 'ajax'); $this->registerTask('removeFile', 'ajax'); } public function ajax() { $user = JFactory::getUser(); $jinput = JFactory::getApplication()->input; // Check Token! $token = JSession::getFormToken(); $call_token = $jinput->get('token', 0, 'ALNUM'); if($token == $call_token) { $task = $this->getTask(); switch($task) { case 'checkUnique': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $fieldValue = $jinput->get('field', NULL, 'WORD'); $valueValue = $jinput->get('value', NULL, 'WORD'); if($fieldValue && $valueValue && $user->id != 0) { $result = $this->getModel('ajax')->checkUnique($fieldValue, $valueValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; case 'getRegion': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $countryValue = $jinput->get('country', NULL, 'INT'); if($countryValue && $user->id != 0) { $result = $this->getModel('ajax')->getRegion($countryValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; case 'getUser': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $idValue = $jinput->get('id', NULL, 'INT'); if($idValue && $user->id != 0) { $result = $this->getModel('ajax')->getUser($idValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; case 'setUser': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $idValue = $jinput->get('id', NULL, 'INT'); $dataValue = $jinput->get('data', NULL, 'STRING'); if($idValue && $dataValue && $user->id != 0) { $result = $this->getModel('ajax')->setUser($idValue, $dataValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; case 'getCreateUserFields': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $idValue = $jinput->get('id', NULL, 'INT'); if($idValue && $user->id != 0) { $result = $this->getModel('ajax')->getCreateUserFields($idValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; case 'createUser': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $dataValue = $jinput->get('data', NULL, 'STRING'); $keyValue = $jinput->get('key', NULL, 'INT'); if($dataValue && $keyValue && $user->id != 0) { $result = $this->getModel('ajax')->createUser($dataValue, $keyValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; case 'uploadfile': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $targetValue = $jinput->get('target', NULL, 'WORD'); $typeValue = $jinput->get('type', NULL, 'WORD'); if($targetValue && $typeValue && $user->id != 0) { $result = $this->getModel('ajax')->uploadfile($targetValue, $typeValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; case 'removeFile': try { $returnRaw = $jinput->get('raw', false, 'BOOLEAN'); $filenameValue = $jinput->get('filename', NULL, 'CMD'); $targetValue = $jinput->get('target', NULL, 'WORD'); $flushValue = $jinput->get('flush', NULL, 'INT'); $typeValue = $jinput->get('type', NULL, 'WORD'); if($filenameValue && $targetValue && $flushValue && $typeValue && $user->id != 0) { $result = $this->getModel('ajax')->removeFile($filenameValue, $targetValue, $flushValue, $typeValue); } else { $result = false; } if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback . "(".json_encode($result).");"; } elseif($returnRaw) { echo json_encode($result); } else { echo "(".json_encode($result).");"; } } catch(Exception $e) { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode($e).");"; } else { echo "(".json_encode($e).");"; } } break; } } else { if($callback = $jinput->get('callback', null, 'CMD')) { echo $callback."(".json_encode(false).");"; } else { echo "(".json_encode(false).");"; } } } }