?
Path : /home/admin/public_html/old/happy2/administrator/components/com_checkin/models/ |
Current File : /home/admin/public_html/old/happy2/administrator/components/com_checkin/models/checkin.php |
<?php /** * @package Joomla.Administrator * @subpackage com_checkin * @copyright Copyright (C) 2005 - 2013 Open Source Matters, Inc. All rights reserved. * @license GNU General Public License version 2 or later; see LICENSE.txt */ defined('_JEXEC') or die; jimport('joomla.application.component.modellist'); /** * 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. * * @since 1.6 */ protected function populateState($ordering = null, $direction = null) { $app = JFactory::getApplication(); $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 An array of table names. Optional. * @return int 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->getCfg('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'); if (isset($fields[$tn]['editor'])) { $query->set('editor = NULL'); } $db->setQuery($query); if ($db->query()) { $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; $nullDate = $db->getNullDate(); $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->getCfg('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->query()) { $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; } }