| Server IP : 213.186.33.4 / Your IP : 216.73.216.193 Web Server : Apache System : Linux webm006.cluster103.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 : awebpaca ( 35430) PHP Version : 8.5.0 Disable Function : _dyuweyrj4,_dyuweyrj4r,dl MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/awebpaca/visitevirtuelle/administrator/components/com_checkin/models/ |
Upload File : |
<?php
/**
* @package Joomla.Administrator
* @subpackage com_checkin
*
* @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;
/**
* Checkin Model
*
* @package Joomla.Administrator
* @subpackage com_checkin
* @since 1.6
*/
class CheckinModelCheckin extends JModelList
{
protected $total;
protected $tables;
/**
* Method to auto-populate the model state.
*
* @Note. Calling getState in this method will result in recursion.
* @param string $ordering An optional ordering field.
* @param string $direction An optional direction (asc|desc).
*
* @return void
*
* @since 1.6
*/
protected function populateState($ordering = null, $direction = null)
{
$search = $this->getUserStateFromRequest($this->context . '.filter.search', 'filter_search');
$this->setState('filter.search', $search);
// List state information.
parent::populateState('table', 'asc');
}
/**
* Checks in requested tables
*
* @param array $ids An array of table names. Optional.
*
* @return integer Checked in item count
*
* @since 1.6
*/
public function checkin($ids = array())
{
$app = JFactory::getApplication();
$db = $this->_db;
$nullDate = $db->getNullDate();
if (!is_array($ids))
{
return;
}
// this int will hold the checked item count
$results = 0;
foreach ($ids as $tn)
{
// make sure we get the right tables based on prefix
if (stripos($tn, $app->get('dbprefix')) !== 0)
{
continue;
}
$fields = $db->getTableColumns($tn);
if (!(isset($fields['checked_out']) && isset($fields['checked_out_time'])))
{
continue;
}
$query = $db->getQuery(true)
->update($db->quoteName($tn))
->set('checked_out = 0')
->set('checked_out_time = ' . $db->quote($nullDate))
->where('checked_out > 0');
$db->setQuery($query);
if ($db->execute())
{
$results = $results + $db->getAffectedRows();
}
}
return $results;
}
/**
* Get total of tables
*
* @return int Total to check-in tables
*
* @since 1.6
*/
public function getTotal()
{
if (!isset($this->total))
{
$this->getItems();
}
return $this->total;
}
/**
* Get tables
*
* @return array Checked in table names as keys and checked in item count as values
*
* @since 1.6
*/
public function getItems()
{
if (!isset($this->items))
{
$app = JFactory::getApplication();
$db = $this->_db;
$tables = $db->getTableList();
// this array will hold table name as key and checked in item count as value
$results = array();
foreach ($tables as $i => $tn)
{
// make sure we get the right tables based on prefix
if (stripos($tn, $app->get('dbprefix')) !== 0)
{
unset($tables[$i]);
continue;
}
if ($this->getState('filter.search') && stripos($tn, $this->getState('filter.search')) === false)
{
unset($tables[$i]);
continue;
}
$fields = $db->getTableColumns($tn);
if (!(isset($fields['checked_out']) && isset($fields['checked_out_time'])))
{
unset($tables[$i]);
continue;
}
}
foreach ($tables as $tn)
{
$query = $db->getQuery(true)
->select('COUNT(*)')
->from($db->quoteName($tn))
->where('checked_out > 0');
$db->setQuery($query);
if ($db->execute())
{
$results[$tn] = $db->loadResult();
}
else
{
continue;
}
}
$this->total = count($results);
if ($this->getState('list.ordering') == 'table')
{
if ($this->getState('list.direction') == 'asc')
{
ksort($results);
}
else
{
krsort($results);
}
}
else
{
if ($this->getState('list.direction') == 'asc')
{
asort($results);
}
else
{
arsort($results);
}
}
$results = array_slice($results, $this->getState('list.start'), $this->getState('list.limit') ? $this->getState('list.limit') : null);
$this->items = $results;
}
return $this->items;
}
}