AnonSec Shell
Server IP : 54.36.91.62  /  Your IP : 216.73.217.112
Web Server : Apache
System : Linux webm013.cluster127.gra.hosting.ovh.net 5.15.206-ovh-vps-grsec-zfs-classid #1 SMP Fri May 15 02:41:25 UTC 2026 x86_64
User : coopiak ( 151928)
PHP Version : 8.3.23
Disable Function : _dyuweyrj4,_dyuweyrj4r,dl
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/coopiak/amisdesseniors-fr/toulouse/administrator/components/com_djcatalog2/models/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     

Current File : /home/coopiak/amisdesseniors-fr/toulouse/administrator/components/com_djcatalog2/models/items.php
<?php
/**
 * @package DJ-Catalog2
 * @copyright Copyright (C) DJ-Extensions.com, All rights reserved.
 * @license http://www.gnu.org/licenses GNU/GPL
 * @author url: http://dj-extensions.com
 * @author email contact@dj-extensions.com
 *
 */

// no direct access
defined('_JEXEC') or die;
use Joomla\CMS\MVC\Model\ListModel;
use Joomla\CMS\Factory;
use Joomla\CMS\Component\ComponentHelper;
use Joomla\CMS\Language\Associations;
use Joomla\CMS\Pagination\Pagination;

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

class Djcatalog2ModelItems extends ListModel
{
	public function __construct($config = array())
	{
		if (empty($config['filter_fields'])) {
			$config['filter_fields'] = array(
				'id', 'a.id',
				'name', 'a.name',
				'alias', 'a.alias',
				'category_name',
				'producer_name',
				'ordering', 'a.ordering',
				'checked_out', 'a.checked_out',
				'checked_out_time', 'a.checked_out_time',
				'published', 'a.published',
				'a.featured',
				'access', 'a.access', 'access_level',
				'created', 'a.created',
				'created_by', 'a.created_by',
				'language', 'a.language',
				'hits', 'a.hits', 'a.available', 'a.access', 'a.price', 'a.special_price',
				'association', 'a.association', 'additional', 'category', 'producer'
			);
		}

		parent::__construct($config);
	}

	protected function populateState($ordering = null, $direction = null)
	{
		// Initialise variables.
		$app = Factory::getApplication();
		$session = Factory::getSession();

		$search = $this->getUserStateFromRequest($this->context . '.filter.search', 'filter_search');
		$this->setState('filter.search', $search);

		$published = $this->getUserStateFromRequest($this->context . '.filter.published', 'filter_published', '');
		$this->setState('filter.published', $published);

		$category = $this->getUserStateFromRequest($this->context . '.filter.category', 'filter_category', '');
		$this->setState('filter.category', $category);

		$producer = $this->getUserStateFromRequest($this->context . '.filter.producer', 'filter_producer', '');
		$this->setState('filter.producer', $producer);

		$additional = $this->getUserStateFromRequest($this->context . '.filter.additional', 'filter_additional', '');
		$this->setState('filter.additional', $additional);

		$parent = $this->getUserStateFromRequest($this->context . '.filter.parent', 'filter_parent', 0);
		$this->setState('filter.parent', $parent);

		$language = $this->getUserStateFromRequest($this->context . '.filter.language', 'filter_language', '');
		$this->setState('filter.language', $language);

		// Load the parameters.
		$params = ComponentHelper::getParams('com_djcatalog2');
		$this->setState('params', $params);

		/*
		 * Multilang
		 */
		if ($layout = $app->input->get('layout')) {
			$this->context .= '.' . $layout;
		}

		$forcedLanguage = $app->input->get('forcedLanguage', '', 'CMD');
		if ($forcedLanguage) {
			$this->context .= '.' . $forcedLanguage;
		}

		// List state information.
		parent::populateState('a.name', 'asc');

		// If there's a forced language then define that filter for the query where clause
		if (!empty($forcedLanguage)) {
			$this->setState('filter.language', $forcedLanguage);
		}
	}

	protected function getStoreId($id = '')
	{
		// Compile the store id.
		$id .= ':' . $this->getState('filter.search');
		$id .= ':' . $this->getState('filter.published');
		$id .= ':' . $this->getState('filter.category');
		$id .= ':' . $this->getState('filter.producer');
		$id .= ':' . $this->getState('filter.parent');
		$id .= ':' . $this->getState('filter.ids');
		$id .= ':' . $this->getState('filter.additional');
		$id .= ':' . $this->getState('filter.language');

		return parent::getStoreId($id);
	}

	protected function _getList($query, $limitstart = 0, $limit = 0)
	{
		$this->_db->setQuery($query, $limitstart, $limit);
		$result = $this->_db->loadObjectList('id');

		return $result;
	}

	protected function _getListCount($query)
	{
		// Use fast COUNT(*) on JDatabaseQuery objects if there no GROUP BY or HAVING clause:
		if ($query instanceof JDatabaseQuery
			&& $query->type == 'select'
			&& $query->group === null
			&& $query->having === null) {

			$query = clone $query;
			$query->clear('select')->clear('order')->select('COUNT(distinct(a.id))');
			$this->_db->setQuery($query);
			return (int)$this->_db->loadResult();
		}

		// Otherwise fall back to inefficient way of counting all results.
		$this->_db->setQuery($query);
		$this->_db->execute();

		return (int)$this->_db->getNumRows();
	}

	public function getItems()
	{
		// Get a storage key.
		$store = $this->getStoreId();

		// Try to load the data from internal storage.
		if (isset($this->cache[$store])) {
			return $this->cache[$store];
		}
		// Load the list items.
		$query = $this->_getListQuery();
		//echo str_replace('#_', 'jos',(string)$query);die();

		try {
			$items = $this->_getList($query, $this->getStart(), $this->getState('list.limit'));
		} catch (\RuntimeException $e) {
			$this->setError($e->getMessage());
			return false;
		}

		// Add the items to the internal cache.
		$this->cache[$store] = $items;

		$task = Factory::getApplication()->input->get('task');

		if ($task == 'export_filtered' || $task == 'export_selected') {
			$this->bindAttributes($store);
		}
		if ($task != 'export_filtered' && $task != 'export_selected') {
			$this->bindImages($store);
		}

		$this->bindCombinationsCount($store);
		return $this->cache[$store];
	}

	protected function getListQuery()
	{

		// Create a new query object.
		$db = $this->getDbo();
		$query = $db->getQuery(true);
		$user = Factory::getUser();

		// Select the required fields from the table.

		//$select_default = 'a.*, c.name AS category_name, c.id AS cat_id, p.name AS producer_name, uc.name AS editor, img.fullname AS item_image, img.caption AS image_caption, img.path as image_path, img.fullpath as image_fullpath ';
		$select_default = 'a.*, c.name AS category_name, c.id AS cat_id, p.name AS producer_name, uc.name AS editor ';

		$query->select($this->getState('list.select', $select_default));
		$query->from('#__djc2_items AS a');

		// Join over the categories.
		//$query->select('c.name AS category_name, c.id AS cat_id');
		//$query->join('INNER', '#__djc2_items_categories AS ic ON a.id = ic.item_id AND ic.default=1');
		//$query->join('LEFT', '#__djc2_categories AS c ON c.id = ic.category_id');
		$query->join('LEFT', '#__djc2_categories AS c ON c.id = a.cat_id');

		// Join over the producers.
		//$query->select('p.name AS producer_name');
		$query->join('LEFT', '#__djc2_producers AS p ON p.id = a.producer_id');

		// Join over the users for the checked out user.
		//$query->select('uc.name AS editor');
		$query->join('LEFT', '#__users AS uc ON uc.id=a.checked_out');

		$query->select('ag.title AS access_level');
		$query->join('LEFT', '#__viewlevels AS ag ON ag.id = a.access');

		//$query->select('img.fullname AS item_image, img.caption AS image_caption');
		//$query->join('LEFT', '#__djc2_images AS img ON img.item_id=a.id AND img.type=\'item\' AND img.ordering=1');
		//$query->join('left', '(SELECT im1.* from #__djc2_images as im1 GROUP BY im1.item_id, im1.type ORDER BY im1.ordering asc) AS img ON img.item_id = a.id AND img.type=\'item\'');
		//$query->join('left', '(select im1.fullname, im1.caption, im1.type, im1.item_id, im1.path, im1.fullpath from #__djc2_images as im1, (select item_id, type, min(ordering) as lowest_order from #__djc2_images group by item_id, type) as im2 where im1.item_id = im2.item_id and im1.type=im2.type and im1.ordering = im2.lowest_order group by im1.type, im1.item_id, im1.path, im1.fullpath) AS img ON img.item_id = a.id AND img.type=\'item\'');
		//$query->join('left', '#__djc2_images as img on img.id = (select id from #__djc2_images where type=\'item\' and item_id = a.id order by ordering asc limit 1)');

		// Filter by published state
		$published = $this->getState('filter.published');
		if (is_numeric($published)) {
			$query->where('a.published = ' . (int)$published);
		}
		/*else if ($published === '') {
		 $query->where('(a.published = 0 OR a.published = 1)');
		}*/


		// Filter by search in title.
		$search = $this->getState('filter.search');
		if (!empty($search)) {
			if (stripos($search, 'id:') === 0) {
				$query->where('a.id = ' . (int)substr($search, 3));
			} else {
				$search = $db->quote('%' . $db->escape($search, true) . '%');
				$query->where('(a.name LIKE ' . $search . ' OR a.alias LIKE ' . $search . ' OR a.sku LIKE ' . $search . ')');
			}
		}

		// Filter by category state
		$category = $this->getState('filter.category');
		if (is_numeric($category) && $category != 0) {

			$category_subquery = 'SELECT DISTINCT ic.item_id '
				. 'FROM #__djc2_items_categories AS ic '
				. 'INNER JOIN #__djc2_categories AS cc ON cc.id=ic.category_id ';

			$categories = Djc2Categories::getInstance();
			if ($parent = $categories->get((int)$category)) {
				$childrenList = array($parent->id);
				$parent->makeChildrenList($childrenList);
				if ($childrenList) {
					$cids = implode(',', $childrenList);
					$category_subquery .= ' WHERE ic.category_id IN (' . $cids . ')';

					$query->join('inner', '(' . $category_subquery . ') as category_filter ON a.id = category_filter.item_id');

				}
			}
		}

		// Filter by producer state
		$producer = $this->getState('filter.producer');
		if (is_numeric($producer) && $producer != 0) {
			$query->where('a.producer_id = ' . (int)$producer);
		}

		$parent = $this->getState('filter.parent');
		if (is_numeric($parent) && $parent > 0) {
			$query->where('a.parent_id = ' . (int)$parent);
		}

		// Filter by primary keys
		$item_ids = $this->getState('filter.ids');
		if ($item_ids != '') {
			$query->where('a.id IN (' . $item_ids . ')');
		}

		if (!$user->authorise('core.admin')) {
			$groups = implode(',', $user->getAuthorisedViewLevels());
			$query->where('a.access IN (' . $groups . ')');
		}

		$additional = $this->getState('filter.additional');
		if ($additional) {
			switch ($additional) {
				case 'FTR':
				{
					$query->where('a.featured=1');
					break;
				}
				case 'NFTR':
				{
					$query->where('a.featured=0');
					break;
				}
				case 'AVL':
				{
					$query->where('a.available=1');
					break;
				}
				case 'NAVL':
				{
					$query->where('a.available=0');
					break;
				}
				case 'HCHILD':
				{
					if (!is_numeric($parent) || $parent < 1) {
						$subquery = $db->getQuery(true);
						$subquery->select('parent_id, COUNT(*) as child_count');
						$subquery->from('#__djc2_items');
						$subquery->group('parent_id');

						$query->join('LEFT', '(' . (string)$subquery . ') AS chl ON chl.parent_id=a.id');
						$query->where('chl.child_count > 0');
						break;
					}
				}
				case 'NHCHILD':
				{
					if (!is_numeric($parent) || $parent < 1) {
						$subquery = $db->getQuery(true);
						$subquery->select('parent_id, COUNT(*) as child_count');
						$subquery->from('#__djc2_items');
						$subquery->group('parent_id');

						$query->join('LEFT', '(' . (string)$subquery . ') AS chl ON chl.parent_id=a.id');
						$query->where('(chl.child_count = 0 OR chl.child_count IS NULL)');
						break;
					}
				}
				default:
					break;
			}
		}

		/*
		 * Multilang
		 */
		if (Associations::isEnabled()) {
			/*$query->select('COUNT(asso2.id)>1 as association')
			 ->join('LEFT', '#__associations AS asso ON asso.id = a.id AND asso.context=' . $db->quote('com_djcatalog2.item'))
			 ->join('LEFT', '#__associations AS asso2 ON asso2.key = asso.key')
			 ->group('a.id');*/

			$subQuery = $db->getQuery(true)
				->select('COUNT(' . $db->quoteName('asso1.id') . ') > 1')
				->from($db->quoteName('#__associations', 'asso1'))
				->join('INNER', $db->quoteName('#__associations', 'asso2') . ' ON ' . $db->quoteName('asso1.key') . ' = ' . $db->quoteName('asso2.key'))
				->where(
					array(
						$db->quoteName('asso1.id') . ' = ' . $db->quoteName('a.id'),
						$db->quoteName('asso1.context') . ' = ' . $db->quote('com_djcatalog2.item'),
					)
				);
			$query->select('(' . $subQuery . ') AS ' . $db->quoteName('association'));
		}

		$query
			->select(array('l.title AS language_title', 'l.image AS language_image'))
			->join('LEFT', $db->quoteName('#__languages', 'l') . ' ON lang_code = a.language');


		// Filter by lang
		$app = Factory::getApplication();
		$requestLang = $app->input->get('language');
		$lang = $this->getState('filter.language');
		$fullOrdering = $this->state->get('list.fullordering');

		if ($requestLang) {
			$query->where('a.language = ' . $db->quote($requestLang));
		} elseif ($lang) {
			$query->where('a.language = ' . $db->quote($lang));
		}

		// Add the list ordering clause.
		$orderCol = $this->state->get('list.ordering', 'a.name');
		$orderDirn = $this->state->get('list.direction', 'asc');
		if ($orderCol == 'a.ordering' || $orderCol == 'category_name') {
			$orderCol = 'c.name ' . $orderDirn . ', a.ordering';
		}

		// Quickfix - modal filtering wasn't working until fullOrdering is set. /M.H
		if(isset($fullOrdering) && $fullOrdering !== null){
			$query->order($db->escape($fullOrdering));
		}else {
			$query->order($db->escape($orderCol . ' ' . $orderDirn));
		}
		return $query;

	}

	public function getCategories()
	{
		if (empty($this->_categories)) {
			$query = "SELECT * FROM #__djc2_categories ORDER BY name";
			$this->_categories = $this->_getList($query, 0, 0);
		}
		return $this->_categories;
	}

	public function getProducers()
	{
		if (empty($this->_producers)) {
			$query = "SELECT * FROM #__djc2_producers ORDER BY name";
			$this->_producers = $this->_getList($query, 0, 0);
		}
		return $this->_producers;
	}

	function recreateThumbnails($cid = array())
	{
		if (count($cid)) {
			Joomla\Utilities\ArrayHelper::toInteger($cid);
			$cids = implode(',', $cid);

			$query = 'SELECT fullname FROM #__djc2_images'
				. ' WHERE item_id IN ( ' . $cids . ' )'
				. ' AND type=\'item\'';
			$this->_db->setQuery($query);
			if (!$this->_db->execute()) {
				$this->setError($this->_db->getErrorMsg());
				return false;
			}
			$items = $this->_db->loadObjectList();
			$params = ComponentHelper::getParams('com_djcatalog2');

			foreach ($items as $item) {
				DJCatalog2ImageHelper::processImage(DJCATIMGFOLDER, $item->fullname, 'item', $params);
			}
		}
		return true;
	}

	function bindCombinationsCount($store)
	{
		if (!empty($this->cache[$store])) {
			$ids = array_keys($this->cache[$store]);
			if (empty($ids)) {
				return;
			}

			$db = Factory::getDbo();
			$db->setQuery('SELECT Count(*) AS combinations_count,item_id FROM #__djc2_items_combinations WHERE item_id IN (' . implode(',', $ids) . ') GROUP by item_id');
			$combinationsCount = $db->loadObjectList('item_id');


			foreach ($combinationsCount as $itemId => $combinations) {
				$this->cache[$store][$itemId]->combinationsCount = $combinations->combinations_count;
			}
		}
	}

	function bindAttributes($store)
	{
		if (!empty($this->cache[$store])) {
			$ids = array_keys($this->cache[$store]);
			if (empty($ids)) {
				return;
			}
			$db = Factory::getDbo();

			$query_int = $db->getQuery(true);
			$query_text = $db->getQuery(true);
			$query_date = $db->getQuery(true);

			$query_int->select('fields.alias, fields.type, fields.ordering, fieldvalues.item_id, fieldvalues.field_id, fieldvalues.id as value_id, fieldoptions.id as option_id, fieldoptions.value');
			$query_int->from('#__djc2_items_extra_fields_values_int as fieldvalues');
			$query_int->join('inner', '#__djc2_items as items on items.id=fieldvalues.item_id');
			$query_int->join('inner', '#__djc2_items_extra_fields as fields ON fields.id = fieldvalues.field_id');
			$query_int->join('left', '#__djc2_items_extra_fields_options as fieldoptions ON fieldoptions.id = fieldvalues.value AND fieldoptions.field_id = fields.id');
			$query_int->where('fieldvalues.item_id IN (' . implode(',', $ids) . ')');
			$query_int->order('fieldvalues.field_id asc, fieldvalues.field_id asc');

			$query_text->select('fields.alias, fields.type, fields.ordering, fieldvalues.item_id, fieldvalues.field_id, fieldvalues.id as value_id, 0 as option_id, fieldvalues.value');
			$query_text->from('#__djc2_items_extra_fields_values_text as fieldvalues');
			$query_text->join('inner', '#__djc2_items as items on items.id=fieldvalues.item_id');
			$query_text->join('inner', '#__djc2_items_extra_fields as fields ON fields.id = fieldvalues.field_id');
			$query_text->where('fieldvalues.item_id IN (' . implode(',', $ids) . ')');
			$query_text->order('fieldvalues.field_id asc, fieldvalues.field_id asc');

			$query_date->select('fields.alias, fields.type, fields.ordering, fieldvalues.item_id, fieldvalues.field_id, fieldvalues.id as value_id, 0 as option_id, fieldvalues.value');
			$query_date->from('#__djc2_items_extra_fields_values_date as fieldvalues');
			$query_date->join('inner', '#__djc2_items as items on items.id=fieldvalues.item_id');
			$query_date->join('inner', '#__djc2_items_extra_fields as fields ON fields.id = fieldvalues.field_id');
			$query_date->where('fieldvalues.item_id IN (' . implode(',', $ids) . ')');
			$query_date->order('fieldvalues.field_id asc, fieldvalues.field_id asc');

			//$query = 'SELECT * FROM (('.(string)$query_int.') UNION DISTINCT ('.(string)$query_text.')) as list ORDER BY list.field_id asc, list.item_id asc';
			//echo str_replace('#_','jos',$query);die();

			// I decided not to use UNION because of FaLang translation issues

			$db->setQuery($query_int);
			$int_attributes = $db->loadObjectList();

			$db->setQuery($query_text);
			$text_attributes = $db->loadObjectList();

			$db->setQuery($query_date);
			$date_attributes = $db->loadObjectList();


			foreach ($text_attributes as $attribute) {
				$field = '_' . $attribute->alias;
				$this->cache[$store][$attribute->item_id]->$field = $attribute->value;
				//$this->cache[$store][$attribute->item_id]->$field = $attribute->optionvalues ? $attribute->optionvalues : $attribute->value;
			}
			foreach ($date_attributes as $attribute) {
				$field = '_' . $attribute->alias;
				$this->cache[$store][$attribute->item_id]->$field = $attribute->value;
			}
			foreach ($int_attributes as $attribute) {
				$field = '_' . $attribute->alias;
				if (!isset($this->cache[$store][$attribute->item_id]->$field) || !is_array($this->cache[$store][$attribute->item_id]->$field)) {
					$this->cache[$store][$attribute->item_id]->$field = array();
				}
				$tmp_arr = $this->cache[$store][$attribute->item_id]->$field;
				$tmp_arr[] = $attribute->value;
				$this->cache[$store][$attribute->item_id]->$field = $tmp_arr;
			}
		}
	}

	public function getPagination()
	{
		// Get the total number of items.
		$total = $this->getTotal();

		$limitstart = $this->getState('list.start', 0);
		$limit = $this->getState('list.limit', 10);

		// Create the pagination object.
		$pagination = new Pagination($total, $limitstart, $limit);

		return $pagination;
	}

	public function getTotal()
	{
		// Get the database object.
		$db = $this->getDbo();

		// Get the query.
		$query = $db->getQuery(true);
		$query = $this->getListQuery();


		// Clear the select part and set it to count.
		$query->clear('select')->clear('order');
		$query->select('COUNT(*)');

		// Set the query and get the result.
		$db->setQuery($query);

		$total = (int) $db->loadResult();
		return $total;
	}

	function bindImages($store)
	{
		if (!empty($this->cache[$store])) {
			foreach ($this->cache[$store] as $item) {
				$ids[] = $item->id;
			}
			if (empty($ids)) {
				return;
			}
			$db = Factory::getDbo();

			$query = $db->getQuery(true);
			$query->select('i.id, img.fullname as item_image, img.caption AS image_caption, img.path AS image_path, img.fullpath AS image_fullpath');
			$query->from('#__djc2_items as i');
			$query->join('inner', '#__djc2_images as img on img.id=(select id from #__djc2_images where type=\'item\' and item_id=i.id order by ordering asc limit 1)');
			$query->where('i.id IN (' . implode(',', $ids) . ')');
			$db->setQuery($query);
			$image_list = $db->loadObjectList('id');

			foreach ($this->cache[$store] as $k => $row) {
				$this->cache[$store][$k]->item_image = isset($image_list[$row->id]) ? $image_list[$row->id]->item_image : null;
				$this->cache[$store][$k]->image_caption = isset($image_list[$row->id]) ? $image_list[$row->id]->image_caption : null;
				$this->cache[$store][$k]->image_path = isset($image_list[$row->id]) ? $image_list[$row->id]->image_path : null;
				$this->cache[$store][$k]->image_fullpath = isset($image_list[$row->id]) ? $image_list[$row->id]->image_fullpath : null;
			}
		}
	}

}

Anon7 - 2022
AnonSec Team