Files
conservatorio-tomadini/components/com_phocadownload/models/play.php
2024-12-17 17:34:10 +01:00

175 lines
5.8 KiB
PHP

<?php
/*
* @package Joomla 1.5
* @copyright Copyright (C) 2005 Open Source Matters. All rights reserved.
* @license http://www.gnu.org/copyleft/gpl.html GNU/GPL, see LICENSE.php
*
* @component Phoca Component
* @copyright Copyright (C) Jan Pavelka www.phoca.cz
* @license http://www.gnu.org/copyleft/gpl.html GNU/GPL
*/
defined('_JEXEC') or die();
use Joomla\CMS\MVC\Model\BaseDatabaseModel;
use Joomla\CMS\Factory;
use Joomla\CMS\Language\Text;
use Joomla\CMS\Router\Route;
use Joomla\CMS\Plugin\PluginHelper;
jimport('joomla.application.component.model');
class PhocaDownloadModelPlay extends BaseDatabaseModel
{
var $_file = null;
var $_category = null;
var $_section = null;
var $_filename = null;
function __construct() {
$app = Factory::getApplication();
parent::__construct();
$this->setState('filter.language',$app->getLanguageFilter());
}
function getFile( $fileId) {
if (empty($this->_file)) {
$query = $this->_getFileQuery( $fileId );
$this->_file = $this->_getList( $query, 0 , 1 );
/* // Don't display file if user has no access
// - - - - - - - - - - - - - - -
if (empty($this->_file)) {
return null;
}
if (isset($this->_file[0]->access)) {
if ($aid !== null) {
if ($this->_file[0]->access > (int) $aid) {
$app->redirect(Route::_('index.php?option=com_users&view=login', false), Text::_("Please login to download the file"));
exit;
}
} else {
return null;
}
} else {
return null;
}
// - - - - - - - - - - - - - - - -*/
}
return $this->_file;
}
function _getFileQuery( $fileId ) {
$app = Factory::getApplication();
$params = $app->getParams();
$categoryId = 0;
$category = $this->getCategory($fileId);
if (isset($category[0]->id)) {
$categoryId = $category[0]->id;
}
$pQ = $params->get( 'enable_plugin_query', 0 );
$wheres[] = " c.catid= ".(int) $categoryId;
$wheres[] = " c.catid= cc.id";
/*if ($aid !== null) {
// Should be not displayed, only in case user will add direct url
// IF unaccessible file = 1 then display unaccessible file for all
// IF unaccessible file = 0 then display it only for them who have access to this file
$wheres[] = '( (unaccessible_file = 1 ) OR (unaccessible_file = 0 AND c.access <= ' . (int) $aid.') )';
$wheres[] = '( (unaccessible_file = 1 ) OR (unaccessible_file = 0 AND cc.access <= ' . (int) $aid.') )';
//$wheres[] = "c.access <= " . (int) $aid;
//$wheres[] = "cc.access <= " . (int) $aid;
}*/
$wheres[] = " c.published = 1";
$wheres[] = " c.approved = 1";
$wheres[] = " cc.published = 1";
$wheres[] = " c.id = " . (int) $fileId;
if ($this->getState('filter.language')) {
$wheres[] = ' c.language IN ('.$this->_db->Quote(Factory::getLanguage()->getTag()).','.$this->_db->Quote('*').')';
$wheres[] = ' cc.language IN ('.$this->_db->Quote(Factory::getLanguage()->getTag()).','.$this->_db->Quote('*').')';
}
// Active
$jnow = Factory::getDate();
$now = $jnow->toSql();
$nullDate = $this->_db->getNullDate();
$wheres[] = ' ( c.publish_up = '.$this->_db->Quote($nullDate).' OR c.publish_up <= '.$this->_db->Quote($now).' )';
$wheres[] = ' ( c.publish_down = '.$this->_db->Quote($nullDate).' OR c.publish_down >= '.$this->_db->Quote($now).' )';
if ($pQ == 1) {
// GWE MOD - to allow for access restrictions
PluginHelper::importPlugin("phoca");
//$dispatcher = JEventDispatcher::getInstance();
$joins = array();
$results = Factory::getApplication()->triggerEvent('onGetFile', array (&$wheres, &$joins, $fileId, $params));
// END GWE MOD
}
$query = ' SELECT c.*, cc.id AS categoryid, cc.title AS categorytitle, cc.alias AS categoryalias, cc.access as cataccess, cc.accessuserid as cataccessuserid, lc.title AS licensetitle, lc.description AS licensetext'
.' FROM #__phocadownload AS c'
.' LEFT JOIN #__phocadownload_categories AS cc ON cc.id = c.catid'
.' LEFT JOIN #__phocadownload_licenses AS lc ON lc.id = c.confirm_license'
. ($pQ == 1 ? ((count($joins)>0?( " LEFT JOIN " .implode( " LEFT JOIN ", $joins )):"")):"") // GWE MOD
.' WHERE ' . implode( ' AND ', $wheres )
.' ORDER BY c.ordering';
return $query;
}
function getCategory($fileId) {
if (empty($this->_category)) {
$query = $this->_getCategoryQuery( $fileId );
$this->_category= $this->_getList( $query, 0, 1 );
}
return $this->_category;
}
function _getCategoryQuery( $fileId ) {
$wheres = array();
$app = Factory::getApplication();
$params = $app->getParams();
$user = Factory::getUser();
$userLevels = implode (',', $user->getAuthorisedViewLevels());
$pQ = $params->get( 'enable_plugin_query', 0 );
$wheres[] = " c.id= ".(int)$fileId;
$wheres[] = " cc.access IN (".$userLevels.")";
$wheres[] = " cc.published = 1";
if ($this->getState('filter.language')) {
$wheres[] = ' c.language IN ('.$this->_db->Quote(Factory::getLanguage()->getTag()).','.$this->_db->Quote('*').')';
$wheres[] = ' cc.language IN ('.$this->_db->Quote(Factory::getLanguage()->getTag()).','.$this->_db->Quote('*').')';
}
if ($pQ == 1) {
// GWE MOD - to allow for access restrictions
PluginHelper::importPlugin("phoca");
//$dispatcher = JEventDispatcher::getInstance();
$joins = array();
$results = Factory::getApplication()->triggerEvent('onGetCategory', array (&$wheres, &$joins,$categoryId, $params));
// END GWE MOD
}
$query = " SELECT cc.id, cc.title, cc.alias, cc.image, cc.image_position, cc.description"
. " FROM #__phocadownload_categories AS cc"
. " LEFT JOIN #__phocadownload AS c ON c.catid = cc.id"
. ($pQ == 1 ? ((count($joins)>0?( " LEFT JOIN " .implode( " LEFT JOIN ", $joins )):"")):"") // GWE MOD
. " WHERE " . implode( " AND ", $wheres )
. " ORDER BY cc.ordering";
return $query;
}
}
?>