349 lines
8.6 KiB
PHP
349 lines
8.6 KiB
PHP
<?php
|
|
/*--------------------------------------------------------------------------------------------------------| www.vdm.io |------/
|
|
__ __ _ _____ _ _ __ __ _ _ _
|
|
\ \ / / | | | __ \ | | | | | \/ | | | | | | |
|
|
\ \ / /_ _ ___| |_ | | | | _____ _____| | ___ _ __ _ __ ___ ___ _ __ | |_ | \ / | ___| |_| |__ ___ __| |
|
|
\ \/ / _` / __| __| | | | |/ _ \ \ / / _ \ |/ _ \| '_ \| '_ ` _ \ / _ \ '_ \| __| | |\/| |/ _ \ __| '_ \ / _ \ / _` |
|
|
\ / (_| \__ \ |_ | |__| | __/\ V / __/ | (_) | |_) | | | | | | __/ | | | |_ | | | | __/ |_| | | | (_) | (_| |
|
|
\/ \__,_|___/\__| |_____/ \___| \_/ \___|_|\___/| .__/|_| |_| |_|\___|_| |_|\__| |_| |_|\___|\__|_| |_|\___/ \__,_|
|
|
| |
|
|
|_|
|
|
/-------------------------------------------------------------------------------------------------------------------------------/
|
|
|
|
@version 1.0.x
|
|
@build 2nd March, 2022
|
|
@created 30th January, 2017
|
|
@package Questions and Answers
|
|
@subpackage ajax.json.php
|
|
@author Llewellyn van der Merwe <https://www.vdm.io/>
|
|
@copyright Copyright (C) 2015. All Rights Reserved
|
|
@license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
|
|
|
Questions & Answers
|
|
|
|
/-----------------------------------------------------------------------------------------------------------------------------*/
|
|
|
|
// No direct access to this file
|
|
defined('_JEXEC') or die('Restricted access');
|
|
|
|
use Joomla\Utilities\ArrayHelper;
|
|
|
|
/**
|
|
* Questionsanswers Ajax Controller
|
|
*/
|
|
class QuestionsanswersControllerAjax extends JControllerLegacy
|
|
{
|
|
public function __construct($config)
|
|
{
|
|
parent::__construct($config);
|
|
// make sure all json stuff are set
|
|
JFactory::getDocument()->setMimeEncoding( 'application/json' );
|
|
// get the application
|
|
$app = JFactory::getApplication();
|
|
$app->setHeader('Content-Disposition','attachment;filename="getajax.json"');
|
|
$app->setHeader('Access-Control-Allow-Origin', '*');
|
|
// load the tasks
|
|
$this->registerTask('uploadfile', 'ajax');
|
|
$this->registerTask('removeFile', 'ajax');
|
|
$this->registerTask('getRows', 'ajax');
|
|
$this->registerTask('getColumns', 'ajax');
|
|
$this->registerTask('getItemData', 'ajax');
|
|
$this->registerTask('sendMessage', 'ajax');
|
|
}
|
|
|
|
public function ajax()
|
|
{
|
|
// get the user for later use
|
|
$user = JFactory::getUser();
|
|
// get the input values
|
|
$jinput = JFactory::getApplication()->input;
|
|
// check if we should return raw
|
|
$returnRaw = $jinput->get('raw', false, 'BOOLEAN');
|
|
// return to a callback function
|
|
$callback = $jinput->get('callback', null, 'CMD');
|
|
// Check Token!
|
|
$token = JSession::getFormToken();
|
|
$call_token = $jinput->get('token', 0, 'ALNUM');
|
|
if($jinput->get($token, 0, 'ALNUM') || $token === $call_token)
|
|
{
|
|
// get the task
|
|
$task = $this->getTask();
|
|
switch($task)
|
|
{
|
|
case 'uploadfile':
|
|
try
|
|
{
|
|
$targetValue = $jinput->get('target', NULL, 'WORD');
|
|
$typeValue = $jinput->get('type', NULL, 'WORD');
|
|
if($targetValue && $user->id != 0 && $typeValue)
|
|
{
|
|
$result = $this->getModel('ajax')->uploadfile($targetValue, $typeValue);
|
|
}
|
|
else
|
|
{
|
|
$result = false;
|
|
}
|
|
if($callback)
|
|
{
|
|
echo $callback . "(".json_encode($result).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($result);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($result).");";
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
if($callback)
|
|
{
|
|
echo $callback."(".json_encode($e).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($e);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($e).");";
|
|
}
|
|
}
|
|
break;
|
|
case 'removeFile':
|
|
try
|
|
{
|
|
$filenameValue = $jinput->get('filename', NULL, 'STRING');
|
|
$targetValue = $jinput->get('target', NULL, 'WORD');
|
|
$flushValue = $jinput->get('flush', NULL, 'INT');
|
|
$typeValue = $jinput->get('type', NULL, 'WORD');
|
|
if($filenameValue && $user->id != 0 && $targetValue && $flushValue && $typeValue)
|
|
{
|
|
$result = $this->getModel('ajax')->removeFile($filenameValue, $targetValue, $flushValue, $typeValue);
|
|
}
|
|
else
|
|
{
|
|
$result = false;
|
|
}
|
|
if($callback)
|
|
{
|
|
echo $callback . "(".json_encode($result).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($result);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($result).");";
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
if($callback)
|
|
{
|
|
echo $callback."(".json_encode($e).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($e);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($e).");";
|
|
}
|
|
}
|
|
break;
|
|
case 'getRows':
|
|
try
|
|
{
|
|
$keyValue = $jinput->get('key', NULL, 'ALNUM');
|
|
$pageValue = $jinput->get('page', NULL, 'WORD');
|
|
if($keyValue && $pageValue)
|
|
{
|
|
$result = $this->getModel('ajax')->getRows($keyValue, $pageValue);
|
|
}
|
|
else
|
|
{
|
|
$result = false;
|
|
}
|
|
if($callback)
|
|
{
|
|
echo $callback . "(".json_encode($result).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($result);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($result).");";
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
if($callback)
|
|
{
|
|
echo $callback."(".json_encode($e).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($e);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($e).");";
|
|
}
|
|
}
|
|
break;
|
|
case 'getColumns':
|
|
try
|
|
{
|
|
$pageValue = $jinput->get('page', NULL, 'WORD');
|
|
if($pageValue)
|
|
{
|
|
$result = $this->getModel('ajax')->getColumns($pageValue);
|
|
}
|
|
else
|
|
{
|
|
$result = false;
|
|
}
|
|
if($callback)
|
|
{
|
|
echo $callback . "(".json_encode($result).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($result);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($result).");";
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
if($callback)
|
|
{
|
|
echo $callback."(".json_encode($e).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($e);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($e).");";
|
|
}
|
|
}
|
|
break;
|
|
case 'getItemData':
|
|
try
|
|
{
|
|
$idValue = $jinput->get('id', NULL, 'INT');
|
|
$typeValue = $jinput->get('type', NULL, 'WORD');
|
|
if($idValue && $typeValue)
|
|
{
|
|
$result = $this->getModel('ajax')->getItemData($idValue, $typeValue);
|
|
}
|
|
else
|
|
{
|
|
$result = false;
|
|
}
|
|
if($callback)
|
|
{
|
|
echo $callback . "(".json_encode($result).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($result);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($result).");";
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
if($callback)
|
|
{
|
|
echo $callback."(".json_encode($e).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($e);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($e).");";
|
|
}
|
|
}
|
|
break;
|
|
case 'sendMessage':
|
|
try
|
|
{
|
|
$eposcodeValue = $jinput->get('eposcode', NULL, 'STRING');
|
|
$senderNameValue = $jinput->get('senderName', NULL, 'STRING');
|
|
$senderEmailValue = $jinput->get('senderEmail', NULL, 'STRING');
|
|
$messageValue = $jinput->get('message', NULL, 'STRING');
|
|
if($eposcodeValue && $senderNameValue && $senderEmailValue && $messageValue)
|
|
{
|
|
$result = $this->getModel('ajax')->sendMessage($eposcodeValue, $senderNameValue, $senderEmailValue, $messageValue);
|
|
}
|
|
else
|
|
{
|
|
$result = false;
|
|
}
|
|
if($callback)
|
|
{
|
|
echo $callback . "(".json_encode($result).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($result);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($result).");";
|
|
}
|
|
}
|
|
catch(Exception $e)
|
|
{
|
|
if($callback)
|
|
{
|
|
echo $callback."(".json_encode($e).");";
|
|
}
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode($e);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode($e).");";
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// return to a callback function
|
|
if($callback)
|
|
{
|
|
echo $callback."(".json_encode(false).");";
|
|
}
|
|
// return raw
|
|
elseif($returnRaw)
|
|
{
|
|
echo json_encode(false);
|
|
}
|
|
else
|
|
{
|
|
echo "(".json_encode(false).");";
|
|
}
|
|
}
|
|
}
|
|
}
|