Spade

Mini Shell

Directory:~$ /proc/self/root/home/lmsyaran/public_html/joomla5/components/com_fabrik/controllers/
Upload File

[Home] [System Details] [Kill Me]
Current File:~$ //proc/self/root/home/lmsyaran/public_html/joomla5/components/com_fabrik/controllers/details.php

<?php
/**
 * Fabrik Details Controller
 *
 * @package     Joomla
 * @subpackage  Fabrik
 * @copyright   Copyright (C) 2005-2020  Media A-Team, Inc. - All rights
reserved.
 * @license     GNU/GPL http://www.gnu.org/copyleft/gpl.html
 */

// No direct access
defined('_JEXEC') or die('Restricted access');

use Joomla\CMS\Language\Text;
use Joomla\CMS\MVC\Controller\BaseController;
use Joomla\CMS\Component\ComponentHelper;
use Joomla\CMS\Filter\InputFilter;
use Joomla\CMS\Router\Route;
use Joomla\CMS\Session\Session;
use Joomla\CMS\Factory;
use \Joomla\Utilities\ArrayHelper;
use \Fabrik\Helpers\Html;
use \Fabrik\Helpers\Worker;

jimport('joomla.application.component.controller');

/**
 * Fabrik Details Controller
 *
 * @static
 * @package     Joomla
 * @subpackage  Fabrik
 * @since       1.5
 */
class FabrikControllerDetails extends BaseController
{
	/**
	 * Is the view rendered from the J content plugin
	 *
	 * @var  bool
	 */
	public $isMambot = false;

	/**
	 * Id used from content plugin when caching turned on to ensure correct
element rendered)
	 *
	 * @var  int
	 */
	public $cacheId = 0;

	/**
	 * Display the view
	 *
	 * @param   boolean          $cachable   If true, the view output will be
cached - NOTE not actually used to control caching!!!
	 * @param   array|boolean    $urlparams  An array of safe url parameters
and their variable types, for valid values see {@link
InputFilter::clean()}.
	 *
	 * @return  JController  A JController object to support chaining.
	 */
	public function display($cachable = false, $urlparams = false)
	{
		$session = Factory::getSession();
		$document = Factory::getDocument();
		$app = Factory::getApplication();
		$package = $app->getUserState('com_fabrik.package',
'fabrik');
		$input = $app->getInput();
		$viewName = 'form';
		$modelName = 'form';

		$viewType = $document->getType();

		if ($viewType == 'pdf')
		{
			// In PDF view only shown the main component content.
			$input->set('tmpl', 'component');
		}

		// Set the default view name from the Request
		$view = $this->getView($viewName, $viewType);

		// Push a model into the view
		/** @var FabrikFEModelForm $model */
		$model = !isset($this->_model) ? $this->getModel($modelName,
'FabrikFEModel') : $this->_model;

		// If errors made when submitting from a J plugin they are stored in the
session lets get them back and insert them into the form model
		if (!empty($model->errors))
		{
			$context = 'com_' . $package . '.form.' .
$input->getInt('formid');
			$model->errors = $session->get($context . '.errors',
array());
			$session->clear($context . '.errors');
		}

		$view->setModel($model, true);
		$view->isMambot = $this->isMambot;

		// Get data as it will be needed for ACL when testing if current row is
editable.
		// $model->getData();

		// Display the view
		//$view->error = $this->getError();

		// $$$ hugh - added disable caching option, and no caching if not logged
in (unless we can come up with a unique cacheid for guests)
		// NOTE - can't use IP of client, as could be two users behind same
NAT'ing proxy / firewall.
		$listModel = $model->getListModel();
		$listParams = $listModel->getParams();

		$user = Factory::getUser();

		// don't cache for certain formats, or if used in social profile
(CB, JomSocial)
		if (!Worker::useCache($listModel)
			|| $input->get('fabrik_social_profile_hash', '')
!== ''
		)
		{
			$view->display();
		}
		else
		{
			$user = Factory::getUser();
			$uri = JURI::getInstance();
			$uri = $uri->toString(array('path', 'query'));
			$cacheId = serialize(array($uri, $input->post,
$user->get('id'), get_class($view), 'display',
$this->cacheId));
			$cache = Factory::getCache('com_' . $package,
'view');
			Html::addToSessionCacheIds($cacheId);
			$cache->get($view, 'display', $cacheId);
		}
	}

	/**
	 * Process the form
	 *
	 * @return  null
	 */
	public function process()
	{
		@set_time_limit(300);
		$app = Factory::getApplication();
		$session = Factory::getSession();
		$package = $app->getUserState('com_fabrik.package',
'fabrik');
		$input = $app->getInput();
		$document = Factory::getDocument();
		$viewName = $input->get('view', 'form');
		$viewType = $document->getType();
		$view = $this->getView($viewName, $viewType);

		/** @var FabrikFEModelForm $model */
		if ($model = $this->getModel('form',
'FabrikFEModel'))
		{
			$view->setModel($model, true);
		}

		$model->setId($input->getInt('formid', 0));

		$this->isMambot = $input->get('isMambot', 0);
		$model->getForm();
		$model->setRowId($input->get('rowid', '',
'string'));

		// Check for request forgeries
		$fbConfig = ComponentHelper::getParams('com_fabrik');

		if ($model->getParams()->get('spoof_check',
$fbConfig->get('spoofcheck_on_formsubmission', true)) == true)
		{
			Session::checkToken() or die('Invalid Token');
		}

		if ($input->getBool('fabrik_ignorevalidation', false) !=
true)
		{
			// Put in when saving page of form
			if (!$model->validate())
			{
				// If its in a module with ajax or in a package
				if ($input->getInt('packageId') !== 0)
				{
					$data = array('modified' =>
$model->modifiedValidationData);

					// Validating entire group when navigating form pages
					$data['errors'] = $model->errors;
					echo json_encode($data);

					return;
				}

				if ($this->isMambot)
				{
					// Store errors in session
					$context = 'com_' . $package . '.form.' .
$model->get('id') . '.';
					$session->set($context . 'errors', $model->errors);
					/**
					 * $$$ hugh - testing way of preserving form values after validation
fails with form plugin
					 * might as well use the 'savepage' mechanism, as it's
already there!
					 */
					$session->set($context . 'session.on', true);
					$this->savepage();
					$this->makeRedirect($model, '');
				}
				else
				{
					/**
					 * $$$ rob - http://fabrikar.com/forums/showthread.php?t=17962
					 * couldn't determine the exact set up that triggered this, but
we need to reset the rowid to -1
					 * if reshowing the form, otherwise it may not be editable, but rather
show as a detailed view
					 */
					if ($input->get('usekey', '') !== '')
					{
						$input->set('rowid', -1);
					}

					$view->display();
				}

				return;
			}
		}

		// Reset errors as validate() now returns ok validations as empty arrays
		$model->errors = array();
		$model->process();

		// Check if any plugin has created a new validation error
		if (!empty($model->errors))
		{
			FabrikWorker::getPluginManager()->runPlugins('onError',
$model);
			$view->display();

			return;
		}

		/**
		 * $$$ rob 31/01/2011
		 * Now redirect always occurs even with redirect thx message,
$this->setRedirect
		 * will look up any redirect url specified in the session by a plugin and
use that or
		 * fall back to the url defined in $this->makeRedirect()
		 */

		$listModel = $model->getListModel();
		$listModel->set('_table', null);

		$msg = $model->getSuccessMsg();

		if ($input->getInt('packageId') !== 0)
		{
			echo json_encode(array('msg' => $msg));

			return;
		}

		if ($input->get('format') == 'raw')
		{
			$input->set('view', 'list');
			$this->display();

			return;
		}
		else
		{
			$this->makeRedirect($model, $msg);
		}
	}

	/**
	 * Set the redirect url
	 *
	 * @param   string  $url   Default url
	 * @param   string  $msg   Optional message to apply on redirect
	 * @param   string  $type  Optional message type
	 *
	 * @return  null
	 */
	public function setRedirect($url, $msg = null, $type =
'message')
	{
		$session = Factory::getSession();
		$app = Factory::getApplication();
		$package = $app->getUserState('com_fabrik.package',
'fabrik');
		$formData = $session->get('com_' . $package .
'.form.data');
		$context = 'com_' . $package . '.form.' .
$formData['fabrik'] . '.redirect.';

		// If the redirect plug-in has set a url use that in preference to the
default url
		$sUrl = $session->get($context . 'url', array($url));

		if (!is_array($sUrl))
		{
			$sUrl = array($sUrl);
		}

		if (empty($sUrl))
		{
			$sUrl[] = $url;
		}

		$sMsg = $session->get($context . 'msg', array($msg));

		if (!is_array($sMsg))
		{
			$sMsg = array($sMsg);
		}

		if (empty($sMsg))
		{
			$sMsg[] = $msg;
		}

		$url = array_shift($sUrl);
		$msg = array_shift($sMsg);

		$app = Factory::getApplication();
		$q = $app->getMessageQueue();
		$found = false;

		foreach ($q as $m)
		{
			// Custom message already queued - unset default msg
			if ($m['type'] == 'message' &&
trim($m['message']) !== '')
			{
				$found = true;
				break;
			}
		}

		if ($found)
		{
			$msg = null;
		}

		$session->set($context . 'url', $sUrl);
		$session->set($context . 'msg', $sMsg);
		$showMsg = array_shift($session->get($context .
'showsystemmsg', array(true)));
		$msg = $showMsg ? $msg : null;
		parent::setRedirect($url, $msg, $type);
	}

	/**
	 * Generic function to redirect
	 *
	 * @param   object  &$model  Form model
	 * @param   string  $msg     Redirection message to show
	 *
	 * @return  null
	 */
	protected function makeRedirect(&$model, $msg = null)
	{
		$app = Factory::getApplication();
		$package = $app->getUserState('com_fabrik.package',
'fabrik');
		$input = $app->getInput();
		$formId = $input->getInt('formid');
		$listId = $input->getInt('listid');
		$rowId = $input->getString('rowid');

		if (is_null($msg))
		{
			$msg = Text::_('COM_FABRIK_RECORD_ADDED_UPDATED');
		}

		if ($app->isClient('administrator'))
		{
			// Admin links use com_fabrik over package option
			if (array_key_exists('apply', $model->formData))
			{
				$url =
'index.php?option=com_fabrik&c=form&task=form&formid='
. $formId . '&listid=' . $listId . '&rowid=' .
$rowId;
			}
			else
			{
				$url =
'index.php?option=com_fabrik&c=table&task=viewTable&cid[]='
. $model->getTable()->id;
			}

			$this->setRedirect($url, $msg);
		}
		else
		{
			if (array_key_exists('apply', $model->formData))
			{
				$url = 'index.php?option=com_' . $package .
'&c=form&view=form&formid=' . $formId .
'&rowid=' . $rowId . '&listid=' . $listId;
			}
			else
			{
				if ($this->isMambot)
				{
					// Return to the same page
					$url = filter_var(ArrayHelper::getValue($_SERVER,
'HTTP_REFERER', 'index.php'), FILTER_SANITIZE_URL);
				}
				else
				{
					// Return to the page that called the form
					$url = urldecode($input->post->get('fabrik_referrer',
'index.php', 'string'));
				}

				$itemId = FabrikWorker::itemId();

				if ($url == '')
				{
					$url = 'index.php?option=com_' . $package .
'&Itemid=' . $itemId;
				}
			}

			$config = Factory::getApplication()->getConfig();

			if ($config->get('sef'))
			{
				$url = Route::_($url);
			}

			$this->setRedirect($url, $msg);
		}
	}

	/**
	 * Validate via ajax
	 *
	 * @return  null
	 */
	public function ajax_validate()
	{
		$app = Factory::getApplication();
		$input = $app->getInput();
		$model = $this->getModel('form', 'FabrikFEModel');
		$model->setId($input->getInt('formid', 0));
		$model->getForm();
		$model->setRowId($input->get('rowid', '',
'string'));
		$model->validate();
		$data = array('modified' =>
$model->modifiedValidationData);

		// Validating entire group when navigating form pages
		$data['errors'] = $model->errors;
		echo json_encode($data);
	}

	/**
	 * Save a form's page to the session table
	 *
	 * @return  null
	 */
	public function savepage()
	{
		$app = Factory::getApplication();
		$input = $app->getInput();
		$model = $this->getModel('Formsession',
'FabrikFEModel');
		$formModel = $this->getModel('Form',
'FabrikFEModel');
		$formModel->setId($input->getInt('formid'));
		$model->savePage($formModel);
	}

	/**
	 * Clear down any temp db records or cookies
	 * containing partially filled in form data
	 *
	 * @return  null
	 */
	public function removeSession()
	{
		$app = Factory::getApplication();
		$input = $app->getInput();
		$sessionModel = $this->getModel('Formsession',
'FabrikFEModel');
		$sessionModel->setFormId($input->getInt('formid', 0));
		$sessionModel->setRowId($input->get('rowid',
'', 'string'));
		$sessionModel->remove();
		$this->display();
	}

	/**
	 * Called via ajax to page through form records
	 *
	 * @return  null
	 */
	public function paginate()
	{
		$app = Factory::getApplication();
		$input = $app->getInput();
		$model = $this->getModel('Form', 'FabrikFEModel');
		$model->setId($input->getInt('formid'));
		$model->paginateRowId($input->get('dir'));
		$this->display();
	}

	/**
	 * Delete a record from a form
	 *
	 * @return  null
	 */
	public function delete()
	{
		// Check for request forgeries
		Session::checkToken() or die('Invalid Token');
		$app = Factory::getApplication();
		$package = $app->getUserState('com_fabrik.package',
'fabrik');
		$input = $app->getInput();
		$model = $this->getModel('list', 'FabrikFEModel');
		$ids = array($input->get('rowid', 0, 'string'));

		$listId = $input->getInt('listid');
		$limitStart = $input->getInt('limitstart' . $listId);
		$length = $input->getInt('limit' . $listId);

		$oldTotal = $model->getTotalRecords();
		$model->setId($listId);
		$model->deleteRows($ids);

		$total = $oldTotal - count($ids);

		$ref = $input->get('fabrik_referrer',
"index.php?option=com_' . $package .
'&view=table&listid=$listId", 'string');

		if ($total >= $limitStart)
		{
			$newLimitStart = $limitStart - $length;

			if ($newLimitStart < 0)
			{
				$newLimitStart = 0;
			}

			$ref = str_replace("limitstart$listId=$limitStart",
"limitstart$listId=$newLimitStart", $ref);
			$app = Factory::getApplication();
			$context = 'com_' . $package . '.list.' .
$model->getRenderContext() . '.';
			$app->setUserState($context . 'limitstart',
$newLimitStart);
		}

		if ($input->get('format') == 'raw')
		{
			$input->set('view', 'list');
			$this->display();
		}
		else
		{
			// @TODO: test this
			$app->enqueueMessage(count($ids) . " " .
Text::_('COM_FABRIK_RECORDS_DELETED'));
			$app->redirect($ref);
		}
	}
}