feature 262: new user cached information nb_total_pictures
git-svn-id: http://piwigo.org/svn/trunk@1081 68402e56-0260-453c-a942-63ccdbb3a9ee
This commit is contained in:
parent
1d22950cf6
commit
88e3b36e2f
5 changed files with 62 additions and 23 deletions
|
|
@ -212,7 +212,7 @@ else
|
|||
|
||||
$template->assign_vars(
|
||||
array(
|
||||
'NB_PICTURE' => count_user_total_images(),
|
||||
'NB_PICTURE' => $user['nb_total_images'],
|
||||
'TITLE' => $template_title,
|
||||
'USERNAME' => $user['username'],
|
||||
'TOP_NUMBER'=>$conf['top_number'],
|
||||
|
|
|
|||
|
|
@ -103,26 +103,6 @@ SELECT name,id,date_last,nb_images,global_rank
|
|||
return get_html_menu_category($cats);
|
||||
}
|
||||
|
||||
/**
|
||||
* returns the total number of elements viewable in the gallery by the
|
||||
* connected user
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
function count_user_total_images()
|
||||
{
|
||||
global $user;
|
||||
|
||||
$query = '
|
||||
SELECT COUNT(DISTINCT(image_id)) as total
|
||||
FROM '.IMAGE_CATEGORY_TABLE.'
|
||||
WHERE category_id NOT IN ('.$user['forbidden_categories'].')
|
||||
;';
|
||||
list($total) = mysql_fetch_array(pwg_query($query));
|
||||
|
||||
return $total;
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve informations about a category in the database
|
||||
*
|
||||
|
|
|
|||
|
|
@ -188,6 +188,13 @@ SELECT ui.*, uc.*
|
|||
$userdata['forbidden_categories'] =
|
||||
calculate_permissions($userdata['id'], $userdata['status']);
|
||||
|
||||
$query = '
|
||||
SELECT COUNT(DISTINCT(image_id)) as total
|
||||
FROM '.IMAGE_CATEGORY_TABLE.'
|
||||
WHERE category_id NOT IN ('.$userdata['forbidden_categories'].')
|
||||
;';
|
||||
list($userdata['nb_total_images']) = mysql_fetch_array(pwg_query($query));
|
||||
|
||||
// update user cache
|
||||
$query = '
|
||||
DELETE FROM '.USER_CACHE_TABLE.'
|
||||
|
|
@ -197,9 +204,10 @@ DELETE FROM '.USER_CACHE_TABLE.'
|
|||
|
||||
$query = '
|
||||
INSERT INTO '.USER_CACHE_TABLE.'
|
||||
(user_id,need_update,forbidden_categories)
|
||||
(user_id,need_update,forbidden_categories,nb_total_images)
|
||||
VALUES
|
||||
('.$userdata['id'].',\'false\',\''.$userdata['forbidden_categories'].'\')
|
||||
('.$userdata['id'].',\'false\',\''
|
||||
.$userdata['forbidden_categories'].'\','.$userdata['nb_total_images'].')
|
||||
;';
|
||||
pwg_query($query);
|
||||
}
|
||||
|
|
|
|||
50
install/db/15-database.php
Normal file
50
install/db/15-database.php
Normal file
|
|
@ -0,0 +1,50 @@
|
|||
<?php
|
||||
// +-----------------------------------------------------------------------+
|
||||
// | PhpWebGallery - a PHP based picture gallery |
|
||||
// | Copyright (C) 2002-2003 Pierrick LE GALL - pierrick@phpwebgallery.net |
|
||||
// | Copyright (C) 2003-2005 PhpWebGallery Team - http://phpwebgallery.net |
|
||||
// +-----------------------------------------------------------------------+
|
||||
// | branch : BSF (Best So Far)
|
||||
// | file : $RCSfile$
|
||||
// | last update : $Date: 2005-09-21 00:04:57 +0200 (mer, 21 sep 2005) $
|
||||
// | last modifier : $Author: plg $
|
||||
// | revision : $Revision: 870 $
|
||||
// +-----------------------------------------------------------------------+
|
||||
// | This program is free software; you can redistribute it and/or modify |
|
||||
// | it under the terms of the GNU General Public License as published by |
|
||||
// | the Free Software Foundation |
|
||||
// | |
|
||||
// | This program is distributed in the hope that it will be useful, but |
|
||||
// | WITHOUT ANY WARRANTY; without even the implied warranty of |
|
||||
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
||||
// | General Public License for more details. |
|
||||
// | |
|
||||
// | You should have received a copy of the GNU General Public License |
|
||||
// | along with this program; if not, write to the Free Software |
|
||||
// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
|
||||
// | USA. |
|
||||
// +-----------------------------------------------------------------------+
|
||||
|
||||
if (!defined('PHPWG_ROOT_PATH'))
|
||||
{
|
||||
die('Hacking attempt!');
|
||||
}
|
||||
|
||||
$upgrade_description = '#user_cache, add column nb_total_pictures (feature 262)';
|
||||
|
||||
$query = "
|
||||
ALTER TABLE ".PREFIX_TABLE."user_cache ADD COLUMN `nb_total_images` MEDIUMINT(8) UNSIGNED;";
|
||||
pwg_query($query);
|
||||
|
||||
$query = "
|
||||
UPDATE ".PREFIX_TABLE."user_cache SET need_update='true'";
|
||||
pwg_query($query);
|
||||
|
||||
|
||||
echo
|
||||
"\n"
|
||||
.'"'.$upgrade_description.'"'.' ended'
|
||||
."\n"
|
||||
;
|
||||
|
||||
?>
|
||||
|
|
@ -260,6 +260,7 @@ CREATE TABLE `phpwebgallery_user_cache` (
|
|||
`user_id` smallint(5) NOT NULL default '0',
|
||||
`need_update` enum('true','false') NOT NULL default 'true',
|
||||
`forbidden_categories` text,
|
||||
`nb_total_images` mediumint(8),
|
||||
PRIMARY KEY (`user_id`)
|
||||
) TYPE=MyISAM;
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue