<?php
/**
* @package Joomla.Site
* @subpackage com_content
* @copyright Copyright (C) 2005 - 2014 Open Source Matters, Inc. All rights reserved.
* @license GNU General Public License version 2 or later; see LICENSE.txt
*/
defined('_JEXEC') or die;
/**
* Content Component Controller
*
* @package Joomla.Site
* @subpackage com_content
* @since 1.5
*/
class ContentController extends JControllerLegacy
{
function __construct($config = array())
{
// Article frontpage Editor pagebreak proxying:
if (JRequest::getCmd('view') === 'article' && JRequest::getCmd('layout') === 'pagebreak') {
$config['base_path'] = JPATH_COMPONENT_ADMINISTRATOR;
}
// Article frontpage Editor article proxying:
elseif(JRequest::getCmd('view') === 'articles' && JRequest::getCmd('layout') === 'modal') {
JHtml::_('stylesheet', 'system/adminlist.css', array(), true);
$config['base_path'] = JPATH_COMPONENT_ADMINISTRATOR;
}
parent::__construct($config);
}
/**
* Method to display a view.
*
* @param boolean If true, the view output will be cached
* @param array An array of safe url parameters and their variable types, for valid values see {@link JFilterInput::clean()}.
*
* @return JController This object to support chaining.
* @since 1.5
*/
public function display($cachable = false, $urlparams = false)
{
$cachable = true;
JHtml::_('behavior.caption');
// Set the default view name and format from the Request.
// Note we are using a_id to avoid collisions with the router and the return page.
// Frontend is a bit messier than the backend.
$id = JRequest::getInt('a_id');
$vName = JRequest::getCmd('view', 'categories');
JRequest::setVar('view', $vName);
$user = JFactory::getUser();
if ($user->get('id') ||
($_SERVER['REQUEST_METHOD'] == 'POST' &&
(($vName == 'category' && JRequest::getCmd('layout') != 'blog') || $vName == 'archive' ))) {
$cachable = false;
}
$safeurlparams = array('catid'=>'INT', 'id'=>'INT', 'cid'=>'ARRAY', 'year'=>'INT', 'month'=>'INT', 'limit'=>'UINT', 'limitstart'=>'UINT',
'showall'=>'INT', 'return'=>'BASE64', 'filter'=>'STRING', 'filter_order'=>'CMD', 'filter_order_Dir'=>'CMD', 'filter-search'=>'STRING', 'print'=>'BOOLEAN', 'lang'=>'CMD', 'Itemid'=>'INT');
// Check for edit form.
if ($vName == 'form' && !$this->checkEditId('com_content.edit.article', $id)) {
// Somehow the person just went to the form - we don't allow that.
return JError::raiseError(403, JText::sprintf('JLIB_APPLICATION_ERROR_UNHELD_ID', $id));
}
parent::display($cachable, $safeurlparams);
return $this;
}
}