source: trunk/admin/history.php @ 15951

Last change on this file since 15951 was 14688, checked in by rvelices, 12 years ago

feature 2601: Allow searching by ip in admin history
also remove php warnings when tags zere deleted after visits

  • Property svn:eol-style set to LF
File size: 19.0 KB
RevLine 
[1727]1<?php
2// +-----------------------------------------------------------------------+
[8728]3// | Piwigo - a PHP based photo gallery                                    |
[2297]4// +-----------------------------------------------------------------------+
[12922]5// | Copyright(C) 2008-2012 Piwigo Team                  http://piwigo.org |
[2297]6// | Copyright(C) 2003-2008 PhpWebGallery Team    http://phpwebgallery.net |
7// | Copyright(C) 2002-2003 Pierrick LE GALL   http://le-gall.net/pierrick |
8// +-----------------------------------------------------------------------+
9// | This program is free software; you can redistribute it and/or modify  |
10// | it under the terms of the GNU General Public License as published by  |
11// | the Free Software Foundation                                          |
12// |                                                                       |
13// | This program is distributed in the hope that it will be useful, but   |
14// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
15// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
16// | General Public License for more details.                              |
17// |                                                                       |
18// | You should have received a copy of the GNU General Public License     |
19// | along with this program; if not, write to the Free Software           |
20// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
21// | USA.                                                                  |
22// +-----------------------------------------------------------------------+
[1727]23
24/**
25 * Display filtered history lines
26 */
27
28// +-----------------------------------------------------------------------+
29// |                              functions                                |
30// +-----------------------------------------------------------------------+
31
32// +-----------------------------------------------------------------------+
33// |                           initialization                              |
34// +-----------------------------------------------------------------------+
35
36if (!defined('PHPWG_ROOT_PATH'))
37{
38  die('Hacking attempt!');
39}
40
41include_once(PHPWG_ROOT_PATH.'admin/include/functions.php');
[1881]42include_once(PHPWG_ROOT_PATH.'admin/include/functions_history.inc.php');
[1727]43
44if (isset($_GET['start']) and is_numeric($_GET['start']))
45{
46  $page['start'] = $_GET['start'];
47}
48else
49{
50  $page['start'] = 0;
51}
52
[1844]53$types = array('none', 'picture', 'high', 'other');
54
[5576]55$display_thumbnails = array('no_display_thumbnail' => l10n('No display'),
56                            'display_thumbnail_classic' => l10n('Classic display'),
57                            'display_thumbnail_hoverbox' => l10n('Hoverbox display')
58  );
59
[1727]60// +-----------------------------------------------------------------------+
61// | Check Access and exit when user status is not ok                      |
62// +-----------------------------------------------------------------------+
63
64check_status(ACCESS_ADMINISTRATOR);
65
66// +-----------------------------------------------------------------------+
67// | Build search criteria and redirect to results                         |
68// +-----------------------------------------------------------------------+
69
[1892]70$page['errors'] = array();
[1727]71$search = array();
72
73if (isset($_POST['submit']))
74{
75  // dates
76  if (!empty($_POST['start_year']))
77  {
78    $search['fields']['date-after'] = sprintf(
79      '%d-%02d-%02d',
80      $_POST['start_year'],
81      $_POST['start_month'],
82      $_POST['start_day']
83      );
84  }
85
86  if (!empty($_POST['end_year']))
87  {
88    $search['fields']['date-before'] = sprintf(
89      '%d-%02d-%02d',
90      $_POST['end_year'],
91      $_POST['end_month'],
92      $_POST['end_day']
93      );
94  }
95
[2157]96  if (empty($_POST['types']))
97  {
98    $search['fields']['types'] = $types;
99  }
100  else
101  {
102    $search['fields']['types'] = $_POST['types'];
103  }
[1890]104
105  $search['fields']['user'] = $_POST['user'];
[1892]106
107  if (!empty($_POST['image_id']))
108  {
109    $search['fields']['image_id'] = intval($_POST['image_id']);
110  }
[2245]111
[1892]112  if (!empty($_POST['filename']))
113  {
114    $search['fields']['filename'] = str_replace(
115      '*',
116      '%',
[4325]117      pwg_db_real_escape_string($_POST['filename'])
[1892]118      );
119  }
120
[14688]121  if (!empty($_POST['ip']))
122  {
123    $search['fields']['ip'] = str_replace(
124      '*',
125      '%',
126      pwg_db_real_escape_string($_POST['ip'])
127      );
128  }
129
[1992]130  $search['fields']['display_thumbnail'] = $_POST['display_thumbnail'];
131  // Display choise are also save to one cookie
[5576]132  if (!empty($_POST['display_thumbnail'])
133      and isset($display_thumbnails[$_POST['display_thumbnail']]))
134  {
135    $cookie_val = $_POST['display_thumbnail'];
136  }
137  else
138  {
139    $cookie_val = null;
140  }
[14688]141
[5576]142  pwg_set_cookie_var('display_thumbnail', $cookie_val, strtotime('+1 month') );
[1992]143
[1892]144  // TODO manage inconsistency of having $_POST['image_id'] and
145  // $_POST['filename'] simultaneously
[2245]146
[1727]147  if (!empty($search))
148  {
149    // register search rules in database, then they will be available on
150    // thumbnails page and picture page.
151    $query ='
152INSERT INTO '.SEARCH_TABLE.'
153  (rules)
154  VALUES
155  (\''.serialize($search).'\')
156;';
157    pwg_query($query);
158
[4892]159    $search_id = pwg_db_insert_id(SEARCH_TABLE);
[2245]160
[1727]161    redirect(
162      PHPWG_ROOT_PATH.'admin.php?page=history&search_id='.$search_id
163      );
164  }
165  else
166  {
[5021]167    array_push($page['errors'], l10n('Empty query. No criteria has been entered.'));
[1727]168  }
169}
170
171// +-----------------------------------------------------------------------+
172// |                             template init                             |
173// +-----------------------------------------------------------------------+
174
[2530]175$template->set_filename('history', 'history.tpl');
[1727]176
[1881]177// TabSheet initialization
178history_tabsheet();
179
[2245]180$template->assign(
[1727]181  array(
[5920]182    'U_HELP' => get_root_url().'admin/popuphelp.php?page=history',
[2245]183    'F_ACTION' => get_root_url().'admin.php?page=history'
[1727]184    )
185  );
186
187// +-----------------------------------------------------------------------+
188// |                             history lines                             |
189// +-----------------------------------------------------------------------+
190
191if (isset($_GET['search_id'])
192    and $page['search_id'] = (int)$_GET['search_id'])
193{
194  // what are the lines to display in reality ?
195  $query = '
196SELECT rules
197  FROM '.SEARCH_TABLE.'
198  WHERE id = '.$page['search_id'].'
199;';
[4325]200  list($serialized_rules) = pwg_db_fetch_row(pwg_query($query));
[1727]201
202  $page['search'] = unserialize($serialized_rules);
203
[1890]204  if (isset($_GET['user_id']))
205  {
206    if (!is_numeric($_GET['user_id']))
207    {
208      die('user_id GET parameter must be an integer value');
209    }
210
211    $page['search']['fields']['user'] = $_GET['user_id'];
[2157]212
[1890]213    $query ='
214INSERT INTO '.SEARCH_TABLE.'
215  (rules)
216  VALUES
217  (\''.serialize($page['search']).'\')
218;';
219    pwg_query($query);
220
[4892]221    $search_id = pwg_db_insert_id(SEARCH_TABLE);
[2245]222
[1890]223    redirect(
224      PHPWG_ROOT_PATH.'admin.php?page=history&search_id='.$search_id
225      );
226  }
227
[2157]228  $data = trigger_event('get_history', array(), $page['search'], $types);
229  usort($data, 'history_compare');
[1727]230
[2157]231  $page['nb_lines'] = count($data);
[1727]232
[1883]233  $history_lines = array();
234  $user_ids = array();
[1929]235  $username_of = array();
[1883]236  $category_ids = array();
237  $image_ids = array();
[14688]238  $has_tags = false;
[2157]239
240  foreach ($data as $row)
[1727]241  {
242    $user_ids[$row['user_id']] = 1;
243
244    if (isset($row['category_id']))
245    {
246      $category_ids[$row['category_id']] = 1;
247    }
248
249    if (isset($row['image_id']))
250    {
251      $image_ids[$row['image_id']] = 1;
252    }
253
[1891]254    if (isset($row['tag_ids']))
255    {
[14688]256      $has_tags = true;
[1891]257    }
258
[14688]259    $history_lines[] = $row;
[1727]260  }
261
262  // prepare reference data (users, tags, categories...)
263  if (count($user_ids) > 0)
264  {
265    $query = '
266SELECT '.$conf['user_fields']['id'].' AS id
267     , '.$conf['user_fields']['username'].' AS username
268  FROM '.USERS_TABLE.'
269  WHERE id IN ('.implode(',', array_keys($user_ids)).')
270;';
271    $result = pwg_query($query);
272
273    $username_of = array();
[4325]274    while ($row = pwg_db_fetch_assoc($result))
[1727]275    {
[4304]276      $username_of[$row['id']] = stripslashes($row['username']);
[1727]277    }
278  }
279
280  if (count($category_ids) > 0)
281  {
282    $query = '
283SELECT id, uppercats
284  FROM '.CATEGORIES_TABLE.'
285  WHERE id IN ('.implode(',', array_keys($category_ids)).')
286;';
287    $uppercats_of = simple_hash_from_query($query, 'id', 'uppercats');
288
289    $name_of_category = array();
[2245]290
[1727]291    foreach ($uppercats_of as $category_id => $uppercats)
292    {
293      $name_of_category[$category_id] = get_cat_display_name_cache(
294        $uppercats
295        );
296    }
297  }
298
299  if (count($image_ids) > 0)
300  {
301    $query = '
[1883]302SELECT
303    id,
304    IF(name IS NULL, file, name) AS label,
305    filesize,
[1991]306    high_filesize,
307    file,
308    path,
[12796]309    representative_ext
[1727]310  FROM '.IMAGES_TABLE.'
311  WHERE id IN ('.implode(',', array_keys($image_ids)).')
312;';
[1883]313    // $label_of_image = simple_hash_from_query($query, 'id', 'label');
314    $label_of_image = array();
315    $filesize_of_image = array();
316    $high_filesize_of_image = array();
[1991]317    $file_of_image = array();
318    $path_of_image = array();
[12796]319    $representative_ext_of_image = array();
[1991]320
[1883]321    $result = pwg_query($query);
[4325]322    while ($row = pwg_db_fetch_assoc($result))
[1883]323    {
324      $label_of_image[ $row['id'] ] = $row['label'];
325
326      if (isset($row['filesize']))
327      {
328        $filesize_of_image[ $row['id'] ] = $row['filesize'];
329      }
330
331      if (isset($row['high_filesize']))
332      {
333        $high_filesize_of_image[ $row['id'] ] = $row['high_filesize'];
334      }
[1991]335
336      $file_of_image[ $row['id'] ] = $row['file'];
337      $path_of_image[ $row['id'] ] = $row['path'];
[12796]338      $representative_ext_of_image[ $row['id'] ] = $row['representative_ext'];
[1883]339    }
340
341    // echo '<pre>'; print_r($high_filesize_of_image); echo '</pre>';
[1727]342  }
[1891]343
[14688]344  if ($has_tags > 0)
[1891]345  {
346    $query = '
347SELECT
348    id,
349    name
[14688]350  FROM '.TAGS_TABLE;
351    $name_of_tag = simple_hash_from_query($query, 'id', 'name');
[1891]352  }
[2245]353
[1727]354  $i = 0;
[1883]355  $first_line = $page['start'] + 1;
356  $last_line = $page['start'] + $conf['nb_logs_page'];
[1727]357
[1893]358  $summary['total_filesize'] = 0;
359  $summary['guests_IP'] = array();
[1883]360
[1727]361  foreach ($history_lines as $line)
362  {
[1893]363    // FIXME when we watch the representative of a non image element, it is
364    // the not the representative filesize that is counted (as it is
365    // unknown) but the non image element filesize. Proposed solution: add
366    // #images.representative_filesize and add 'representative' in the
367    // choices of #history.image_type.
[2245]368
[1883]369    if (isset($line['image_type']))
370    {
371      if ($line['image_type'] == 'high')
372      {
373        if (isset($high_filesize_of_image[$line['image_id']]))
374        {
[1893]375          $summary['total_filesize']+=
376            $high_filesize_of_image[$line['image_id']];
[1883]377        }
378      }
379      else
380      {
381        if (isset($filesize_of_image[$line['image_id']]))
382        {
[1893]383          $summary['total_filesize']+=
384            $filesize_of_image[$line['image_id']];
[1883]385        }
386      }
387    }
[1893]388
389    if ($line['user_id'] == $conf['guest_id'])
390    {
391      if (!isset($summary['guests_IP'][ $line['IP'] ]))
392      {
393        $summary['guests_IP'][ $line['IP'] ] = 0;
394      }
[2245]395
[1893]396      $summary['guests_IP'][ $line['IP'] ]++;
397    }
[2245]398
[1883]399    $i++;
[2245]400
[1883]401    if ($i < $first_line or $i > $last_line)
402    {
403      continue;
404    }
[1890]405
406    $user_string = '';
407    if (isset($username_of[$line['user_id']]))
408    {
409      $user_string.= $username_of[$line['user_id']];
410    }
411    else
412    {
413      $user_string.= $line['user_id'];
414    }
415    $user_string.= '&nbsp;<a href="';
416    $user_string.= PHPWG_ROOT_PATH.'admin.php?page=history';
417    $user_string.= '&amp;search_id='.$page['search_id'];
418    $user_string.= '&amp;user_id='.$line['user_id'];
419    $user_string.= '">+</a>';
[1891]420
421    $tags_string = '';
422    if (isset($line['tag_ids']))
423    {
424      $tags_string = preg_replace(
425        '/(\d+)/e',
[14688]426        'isset($name_of_tag["$1"]) ? $name_of_tag["$1"] : "$1"',
[1891]427        str_replace(
428          ',',
429          ', ',
430          $line['tag_ids']
431          )
432        );
433    }
[1896]434
435    $image_string = '';
436    if (isset($line['image_id']))
437    {
438      $picture_url = make_picture_url(
439        array(
440          'image_id' => $line['image_id'],
441          )
442        );
[1992]443
[9808]444      if (isset($file_of_image[$line['image_id']]))
445      {
446        $element = array(
447          'id' => $line['image_id'],
448          'file' => $file_of_image[$line['image_id']],
449          'path' => $path_of_image[$line['image_id']],
[12796]450          'representative_ext' => $representative_ext_of_image[$line['image_id']],
[9808]451          );
452        $thumbnail_display = $page['search']['fields']['display_thumbnail'];
453      }
454      else
455      {
456        $thumbnail_display = 'no_display_thumbnail';
457      }
[1992]458
459      $image_title = '('.$line['image_id'].')';
460
[1896]461      if (isset($label_of_image[$line['image_id']]))
462      {
[1992]463        $image_title.= ' '.$label_of_image[$line['image_id']];
[1896]464      }
465      else
466      {
[1992]467        $image_title.= ' unknown filename';
[1896]468      }
[1992]469
470      $image_string = '';
471
[9808]472      switch ($thumbnail_display)
[1992]473      {
474        case 'no_display_thumbnail':
475        {
476          $image_string= '<a href="'.$picture_url.'">'.$image_title.'</a>';
477          break;
478        }
479        case 'display_thumbnail_classic':
480        {
481          $image_string =
482            '<a class="thumbnail" href="'.$picture_url.'">'
[12796]483            .'<span><img src="'.DerivativeImage::thumb_url($element)
[1992]484            .'" alt="'.$image_title.'" title="'.$image_title.'">'
485            .'</span></a>';
486          break;
487        }
488        case 'display_thumbnail_hoverbox':
489        {
490          $image_string =
491            '<a class="over" href="'.$picture_url.'">'
[12796]492            .'<span><img src="'.DerivativeImage::thumb_url($element)
[1992]493            .'" alt="'.$image_title.'" title="'.$image_title.'">'
494            .'</span>'.$image_title.'</a>';
495          break;
496        }
497      }
[1896]498    }
[2245]499
500    $template->append(
501      'search_results',
[1727]502      array(
503        'DATE'      => $line['date'],
504        'TIME'      => $line['time'],
[1890]505        'USER'      => $user_string,
[1727]506        'IP'        => $line['IP'],
[1896]507        'IMAGE'     => $image_string,
[1844]508        'TYPE'      => $line['image_type'],
[1727]509        'SECTION'   => $line['section'],
510        'CATEGORY'  => isset($line['category_id'])
[1821]511          ? ( isset($name_of_category[$line['category_id']])
512                ? $name_of_category[$line['category_id']]
513                : 'deleted '.$line['category_id'] )
[1727]514          : '',
[1891]515        'TAGS'       => $tags_string,
[1727]516        )
517      );
518  }
[1883]519
[1893]520  $summary['nb_guests'] = 0;
521  if (count(array_keys($summary['guests_IP'])) > 0)
522  {
523    $summary['nb_guests'] = count(array_keys($summary['guests_IP']));
524
525    // we delete the "guest" from the $username_of hash so that it is
526    // avoided in next steps
527    unset($username_of[ $conf['guest_id'] ]);
528  }
[2245]529
[1893]530  $summary['nb_members'] = count($username_of);
531
532  $member_strings = array();
533  foreach ($username_of as $user_id => $user_name)
534  {
535    $member_string = $user_name.'&nbsp;<a href="';
[2245]536    $member_string.= get_root_url().'admin.php?page=history';
[1893]537    $member_string.= '&amp;search_id='.$page['search_id'];
538    $member_string.= '&amp;user_id='.$user_id;
539    $member_string.= '">+</a>';
540
541    $member_strings[] = $member_string;
542  }
[2245]543
544  $template->assign(
545    'search_summary',
[1883]546    array(
[1932]547      'NB_LINES' => l10n_dec(
548        '%d line filtered', '%d lines filtered',
[1893]549        $page['nb_lines']
550        ),
551      'FILESIZE' => $summary['total_filesize'].' KB',
[1932]552      'USERS' => l10n_dec(
553        '%d user', '%d users',
[1893]554        $summary['nb_members'] + $summary['nb_guests']
555        ),
556      'MEMBERS' => sprintf(
[1932]557        l10n_dec('%d member', '%d members', $summary['nb_members']).': %s',
[1893]558        implode(
559          ', ',
560          $member_strings
561          )
562        ),
[1932]563      'GUESTS' => l10n_dec(
564        '%d guest', '%d guests',
[1893]565        $summary['nb_guests']
566        ),
[1883]567      )
568    );
[1727]569}
570
571// +-----------------------------------------------------------------------+
572// |                            navigation bar                             |
573// +-----------------------------------------------------------------------+
574
575if (isset($page['search_id']))
576{
577  $navbar = create_navigation_bar(
[2245]578    get_root_url().'admin.php'.get_query_string_diff(array('start')),
[1727]579    $page['nb_lines'],
580    $page['start'],
581    $conf['nb_logs_page']
582    );
583
[3172]584  $template->assign('navbar', $navbar);
[1727]585}
586
587// +-----------------------------------------------------------------------+
588// |                             filter form                               |
589// +-----------------------------------------------------------------------+
590
591$form = array();
592
593if (isset($page['search']))
594{
595  if (isset($page['search']['fields']['date-after']))
596  {
597    $tokens = explode('-', $page['search']['fields']['date-after']);
[2245]598
[1727]599    $form['start_year']  = (int)$tokens[0];
600    $form['start_month'] = (int)$tokens[1];
601    $form['start_day']   = (int)$tokens[2];
602  }
603
604  if (isset($page['search']['fields']['date-before']))
605  {
606    $tokens = explode('-', $page['search']['fields']['date-before']);
[1817]607
608    $form['end_year']  = (int)$tokens[0];
609    $form['end_month'] = (int)$tokens[1];
610    $form['end_day']   = (int)$tokens[2];
[1727]611  }
[1817]612
[1844]613  $form['types'] = $page['search']['fields']['types'];
[1890]614
615  if (isset($page['search']['fields']['user']))
616  {
617    $form['user'] = $page['search']['fields']['user'];
618  }
619  else
620  {
621    $form['user'] = null;
622  }
[1892]623
624  $form['image_id'] = @$page['search']['fields']['image_id'];
625  $form['filename'] = @$page['search']['fields']['filename'];
[14688]626  $form['ip'] = @$page['search']['fields']['ip'];
[1992]627
628  $form['display_thumbnail'] = @$page['search']['fields']['display_thumbnail'];
[1727]629}
630else
631{
632  // by default, at page load, we want the selected date to be the current
633  // date
634  $form['start_year']  = $form['end_year']  = date('Y');
635  $form['start_month'] = $form['end_month'] = date('n');
636  $form['start_day']   = $form['end_day']   = date('j');
[1844]637  $form['types'] = $types;
[1992]638  // Hoverbox by default
639  $form['display_thumbnail'] =
[5576]640    pwg_get_cookie_var('display_thumbnail', 'no_display_thumbnail');
[1727]641}
642
643
[2245]644$month_list = $lang['month'];
645$month_list[0]='------------';
646ksort($month_list);
647
648$template->assign(
[1727]649  array(
[2245]650    'IMAGE_ID' => @$form['image_id'],
651    'FILENAME' => @$form['filename'],
[14688]652    'IP' => @$form['ip'],
[2245]653
654    'month_list' => $month_list,
655
656    'START_DAY_SELECTED' => @$form['start_day'],
657    'START_MONTH_SELECTED' => @$form['start_month'],
[1727]658    'START_YEAR' => @$form['start_year'],
[2245]659
660    'END_DAY_SELECTED' => @$form['end_day'],
661    'END_MONTH_SELECTED' => @$form['end_month'],
[1727]662    'END_YEAR'   => @$form['end_year'],
663    )
664  );
[1817]665
[2245]666$template->assign(
[1844]667    array(
[2245]668      'type_option_values' => $types,
669      'type_option_selected' => $form['types']
[1890]670    )
671  );
672
[2245]673
[1890]674$query = '
675SELECT
676    '.$conf['user_fields']['id'].' AS id,
677    '.$conf['user_fields']['username'].' AS username
678  FROM '.USERS_TABLE.'
679  ORDER BY username ASC
680;';
[2245]681$template->assign(
682  array(
683    'user_options' => simple_hash_from_query($query, 'id','username'),
684    'user_options_selected' => array(@$form['user'])
685  )
686);
[1890]687
[5576]688$template->assign('display_thumbnails', $display_thumbnails);
689$template->assign('display_thumbnail_selected', $form['display_thumbnail']);
[1890]690
[1727]691// +-----------------------------------------------------------------------+
692// |                           html code display                           |
693// +-----------------------------------------------------------------------+
694
695$template->assign_var_from_handle('ADMIN_CONTENT', 'history');
[2245]696?>
Note: See TracBrowser for help on using the repository browser.