source: branches/branch-1_5/include/category_default.inc.php @ 1003

Last change on this file since 1003 was 1003, checked in by nikrou, 18 years ago

Improve security of sessions:

  • use only cookies to store session id on client side
  • use default php session system with database handler to store sessions on server side
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.6 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | PhpWebGallery - a PHP based picture gallery                           |
4// | Copyright (C) 2002-2003 Pierrick LE GALL - pierrick@phpwebgallery.net |
5// | Copyright (C) 2003-2005 PhpWebGallery Team - http://phpwebgallery.net |
6// +-----------------------------------------------------------------------+
7// | branch        : BSF (Best So Far)
8// | file          : $RCSfile$
9// | last update   : $Date: 2006-01-15 12:52:55 +0000 (Sun, 15 Jan 2006) $
10// | last modifier : $Author: nikrou $
11// | revision      : $Revision: 1003 $
12// +-----------------------------------------------------------------------+
13// | This program is free software; you can redistribute it and/or modify  |
14// | it under the terms of the GNU General Public License as published by  |
15// | the Free Software Foundation                                          |
16// |                                                                       |
17// | This program is distributed in the hope that it will be useful, but   |
18// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
19// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
20// | General Public License for more details.                              |
21// |                                                                       |
22// | You should have received a copy of the GNU General Public License     |
23// | along with this program; if not, write to the Free Software           |
24// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
25// | USA.                                                                  |
26// +-----------------------------------------------------------------------+
27
28/**
29 * This file is included by category.php to show thumbnails for the default
30 * case
31 *
32 */
33
34/**
35 * $array_cat_directories is a cache hash associating category id with their
36 * complete directory
37 */
38$array_cat_directories = array();
39 
40$query = '
41SELECT DISTINCT(id),path,file,date_available
42       ,tn_ext,name,filesize,storage_category_id,average_rate
43  FROM '.IMAGES_TABLE.' AS i
44    INNER JOIN '.IMAGE_CATEGORY_TABLE.' AS ic ON id=ic.image_id
45  '.$page['where'].'
46  '.$conf['order_by'].'
47  LIMIT '.$page['start'].','.$page['nb_image_page'].'
48;';
49//echo '<pre>'.$query.'</pre>';
50$result = pwg_query($query);
51
52// template thumbnail initialization
53if ( mysql_num_rows($result) > 0 )
54{
55  $template->assign_block_vars('thumbnails', array());
56  // first line
57  $template->assign_block_vars('thumbnails.line', array());
58  // current row displayed
59  $row_number = 0;
60}
61
62while ($row = mysql_fetch_array($result))
63{
64  $thumbnail_url = get_thumbnail_src($row['path'], @$row['tn_ext']);
65 
66  // message in title for the thumbnail
67  $thumbnail_title = $row['file'];
68  if (isset($row['filesize']))
69  {
70    $thumbnail_title .= ' : '.$row['filesize'].' KB';
71  }
72  // url link on picture.php page
73  $url_link = PHPWG_ROOT_PATH.'picture.php?cat='.$page['cat'];
74  $url_link.= '&amp;image_id='.$row['id'];
75  if ($page['cat'] == 'search')
76  {
77    $url_link.= '&amp;search='.$_GET['search'];
78  }
79  else if ($page['cat'] == 'list')
80  {
81    $url_link.= '&amp;list='.$_GET['list'];
82  }
83   
84  $template->assign_block_vars(
85    'thumbnails.line.thumbnail',
86    array(
87      'IMAGE'              => $thumbnail_url,
88      'IMAGE_ALT'          => $row['file'],
89      'IMAGE_TITLE'        => $thumbnail_title,
90      'IMAGE_TS'           => get_icon($row['date_available']),
91     
92      'U_IMG_LINK'         => $url_link
93      )
94    );
95
96  if ($conf['show_thumbnail_caption'])
97  {
98    // name of the picture
99    if (isset($row['name']) and $row['name'] != '')
100    {
101      $name = $row['name'];
102    }
103    else
104    {
105      $name = str_replace('_', ' ', get_filename_wo_extension($row['file']));
106    }
107    if ($page['cat'] == 'best_rated')
108    {
109      $name = '('.$row['average_rate'].') '.$name;
110    }
111   
112    if ($page['cat'] == 'search')
113    {
114      $name = replace_search($name, $_GET['search']);
115    }
116 
117    $template->assign_block_vars(
118      'thumbnails.line.thumbnail.element_name',
119      array(
120        'NAME' => $name
121        )
122      );
123  }
124   
125  if ($user['show_nb_comments']
126      and is_numeric($page['cat'])
127      and $page['cat_commentable'])
128  {
129    $query = '
130SELECT COUNT(*) AS nb_comments
131  FROM '.COMMENTS_TABLE.'
132  WHERE image_id = '.$row['id'].'
133    AND validated = \'true\'
134;';
135    $row = mysql_fetch_array(pwg_query($query));
136    $template->assign_block_vars(
137      'thumbnails.line.thumbnail.nb_comments',
138      array('NB_COMMENTS'=>$row['nb_comments']));
139  }
140
141  // create a new line ?
142  if (++$row_number == $user['nb_image_line'])
143  {
144    $template->assign_block_vars('thumbnails.line', array());
145    $row_number = 0;
146  }
147}
148?>
Note: See TracBrowser for help on using the repository browser.