forked from joomla/Members-Manager
379 lines
9.1 KiB
PHP
379 lines
9.1 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* @package Joomla.Component.Builder
|
||
|
*
|
||
|
* @created 6th September, 2015
|
||
|
* @author Llewellyn van der Merwe <https://www.joomlacomponentbuilder.com/>
|
||
|
* @github Joomla Component Builder <https://github.com/vdm-io/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).");";
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|