source: trunk/include/functions_notification.inc.php @ 25531

Last change on this file since 25531 was 25018, checked in by mistic100, 11 years ago

remove all array_push (50% slower than []) + some changes missing for feature:2978

  • Property svn:eol-style set to LF
File size: 16.7 KB
RevLine 
[1021]1<?php
2// +-----------------------------------------------------------------------+
[8728]3// | Piwigo - a PHP based photo gallery                                    |
[2297]4// +-----------------------------------------------------------------------+
[19703]5// | Copyright(C) 2008-2013 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// +-----------------------------------------------------------------------+
[1021]23
24// +-----------------------------------------------------------------------+
25// |                               functions                               |
26// +-----------------------------------------------------------------------+
[1789]27
28/*
[2159]29 * get standard sql where in order to
[1789]30 * restict an filter caregories and images
31 *
32 * IMAGE_CATEGORY_TABLE muste named ic in the query
33 *
34 * @param none
35 *
36 * @return string sql where
37 */
[2543]38function get_std_sql_where_restrict_filter($prefix_condition, $img_field='ic.image_id', $force_one_condition = false)
[1677]39{
40  return get_sql_condition_FandF
41          (
42            array
43              (
44                'forbidden_categories' => 'ic.category_id',
45                'visible_categories' => 'ic.category_id',
[2543]46                'visible_images' => $img_field
[1677]47              ),
48            $prefix_condition,
49            $force_one_condition
50          );
[1789]51}
[1021]52
[1112]53/*
54 * Execute custom notification query
[1021]55 *
[1112]56 * @param string action ('count' or 'info')
[8651]57 * @param string type of query ('new_comments', 'unvalidated_comments', 'new_elements', 'updated_categories', 'new_users')
[1021]58 * @param string start (mysql datetime format)
59 * @param string end (mysql datetime format)
[1112]60 *
61 * @return integer for action count
62 *         array for info
[1021]63 */
[1112]64function custom_notification_query($action, $type, $start, $end)
[1021]65{
66  global $user;
[1789]67
[1112]68  switch($type)
69  {
70    case 'new_comments':
71      $query = '
[1021]72  FROM '.COMMENTS_TABLE.' AS c
73     , '.IMAGE_CATEGORY_TABLE.' AS ic
[6597]74  WHERE c.image_id = ic.image_id';
75      if (!empty($start))
76      {
77        $query .= '
78    AND c.validation_date > \''.$start.'\'';
79      }
80      if (!empty($end))
81      {
[6668]82        $query .= '
[6597]83    AND c.validation_date <= \''.$end.'\'';
84      }
85      $query .= get_std_sql_where_restrict_filter('AND').'
[1021]86;';
[1112]87      break;
88    case 'unvalidated_comments':
89      $query = '
90  FROM '.COMMENTS_TABLE.'
[6597]91  WHERE 1=1';
92      if (!empty($start))
93      {
94        $query .= ' AND date> \''.$start.'\'';
95      }
96      if (!empty($end))
[6668]97      {
[6597]98        $query .= ' AND date <= \''.$end.'\'';
99      }
100      $query .= ' AND validated = \'false\'
[1112]101;';
102      break;
103    case 'new_elements':
104      $query = '
[1677]105  FROM '.IMAGES_TABLE.' INNER JOIN '.IMAGE_CATEGORY_TABLE.' AS ic ON image_id = id
[6597]106  WHERE 1=1';
107      if (!empty($start))
108      {
109        $query .= ' AND date_available > \''.$start.'\'';
110      }
111      if (!empty($end))
112      {
113        $query .= ' AND date_available <= \''.$end.'\'';
114      }
115      $query .= get_std_sql_where_restrict_filter('AND', 'id').'
[1112]116;';
117      break;
118    case 'updated_categories':
119      $query = '
[1677]120  FROM '.IMAGES_TABLE.' INNER JOIN '.IMAGE_CATEGORY_TABLE.' AS ic ON image_id = id
[6597]121  WHERE 1=1';
122      if (!empty($start))
123      {
124        $query .= ' AND date_available > \''.$start.'\'';
125      }
126      if (!empty($end))
127      {
128        $query .= ' AND date_available <= \''.$end.'\'';
129      }
130      $query .= get_std_sql_where_restrict_filter('AND', 'id').'
[1112]131;';
132      break;
[1432]133    case 'new_users':
[1112]134      $query = '
135  FROM '.USER_INFOS_TABLE.'
[6597]136  WHERE 1=1';
137      if (!empty($start))
138      {
139        $query .= ' AND registration_date > \''.$start.'\'';
140      }
141      if (!empty($end))
142      {
143        $query .= ' AND registration_date <= \''.$end.'\'';
144      }
145      $query .= '
[1112]146;';
147      break;
148    default:
149      // stop this function and return nothing
150      return;
151      break;
152  }
153
154  switch($action)
155  {
156    case 'count':
157      switch($type)
158      {
159        case 'new_comments':
160          $field_id = 'c.id';
161          break;
162        case 'unvalidated_comments':
163          $field_id = 'id';
164          break;
165        case 'new_elements':
166          $field_id = 'image_id';
167          break;
168        case 'updated_categories':
169          $field_id = 'category_id';
170          break;
[1432]171        case 'new_users':
[1112]172          $field_id = 'user_id';
173          break;
174    }
175    $query = 'SELECT count(distinct '.$field_id.') as CountId
176'.$query;
[4325]177    list($count) = pwg_db_fetch_row(pwg_query($query));
[1112]178    return $count;
[1549]179
[1112]180    break;
181    case 'info':
182      switch($type)
183      {
184        case 'new_comments':
185          $fields = array('c.id');
186          break;
187        case 'unvalidated_comments':
188          $fields = array('id');
189          break;
190        case 'new_elements':
191          $fields = array('image_id');
192          break;
193        case 'updated_categories':
194          $fields = array('category_id');
195          break;
[1432]196        case 'new_users':
[1112]197          $fields = array('user_id');
198          break;
199      }
200
[1549]201    $query = 'SELECT distinct '.implode(', ', $fields).'
[1112]202'.$query;
203    $result = pwg_query($query);
204
205    $infos = array();
[1549]206
[4325]207    while ($row = pwg_db_fetch_assoc($result))
[1112]208    {
[25018]209      $infos[] = $row;
[1112]210    }
211
212    return $infos;
213
214    break;
215  }
216
217  //return is done on previous switch($action)
[1021]218}
219
220/**
[1112]221 * new comments between two dates, according to authorized categories
222 *
223 * @param string start (mysql datetime format)
224 * @param string end (mysql datetime format)
225 * @param string forbidden categories (comma separated)
226 * @return count comment ids
227 */
228function nb_new_comments($start, $end)
229{
230  return custom_notification_query('count', 'new_comments', $start, $end);
231}
232
233/**
234 * new comments between two dates, according to authorized categories
235 *
236 * @param string start (mysql datetime format)
237 * @param string end (mysql datetime format)
238 * @param string forbidden categories (comma separated)
239 * @return array comment ids
240 */
241function new_comments($start, $end)
242{
243  return custom_notification_query('info', 'new_comments', $start, $end);
244}
245
246/**
[1021]247 * unvalidated at a precise date
248 *
249 * Comments that are registered and not validated yet on a precise date
250 *
[2159]251 * @param string start (mysql datetime format)
252 * @param string end (mysql datetime format)
[1112]253 * @return count comment ids
254 */
[2159]255function nb_unvalidated_comments($start, $end)
[1112]256{
[2159]257  return custom_notification_query('count', 'unvalidated_comments', $start, $end);
[1112]258}
259
[1021]260
261/**
262 * new elements between two dates, according to authorized categories
263 *
264 * @param string start (mysql datetime format)
265 * @param string end (mysql datetime format)
266 * @param string forbidden categories (comma separated)
[1112]267 * @return count element ids
268 */
269function nb_new_elements($start, $end)
270{
271  return custom_notification_query('count', 'new_elements', $start, $end);
272}
273
274/**
275 * new elements between two dates, according to authorized categories
276 *
277 * @param string start (mysql datetime format)
278 * @param string end (mysql datetime format)
279 * @param string forbidden categories (comma separated)
[1021]280 * @return array element ids
281 */
282function new_elements($start, $end)
283{
[1112]284  return custom_notification_query('info', 'new_elements', $start, $end);
[1021]285}
286
287/**
288 * updated categories between two dates, according to authorized categories
289 *
290 * @param string start (mysql datetime format)
291 * @param string end (mysql datetime format)
292 * @param string forbidden categories (comma separated)
[1112]293 * @return count element ids
294 */
295function nb_updated_categories($start, $end)
296{
297  return custom_notification_query('count', 'updated_categories', $start, $end);
298}
299
300/**
301 * updated categories between two dates, according to authorized categories
302 *
303 * @param string start (mysql datetime format)
304 * @param string end (mysql datetime format)
305 * @param string forbidden categories (comma separated)
[1021]306 * @return array element ids
307 */
308function updated_categories($start, $end)
309{
[1112]310  return custom_notification_query('info', 'updated_categories', $start, $end);
[1021]311}
312
313/**
314 * new registered users between two dates
315 *
316 * @param string start (mysql datetime format)
317 * @param string end (mysql datetime format)
[1112]318 * @return count user ids
319 */
320function nb_new_users($start, $end)
321{
322  return custom_notification_query('count', 'new_users', $start, $end);
323}
324
325/**
326 * new registered users between two dates
327 *
328 * @param string start (mysql datetime format)
329 * @param string end (mysql datetime format)
[1021]330 * @return array user ids
331 */
332function new_users($start, $end)
333{
[1112]334  return custom_notification_query('info', 'new_users', $start, $end);
[1021]335}
336
337/**
[1112]338 * There are new between two dates ?
339 *
340 * Informations : number of new comments, number of new elements, number of
341 * updated categories. Administrators are also informed about : number of
342 * unvalidated comments, number of new users (TODO : number of unvalidated
343 * elements)
344 *
345 * @param string start date (mysql datetime format)
346 * @param string end date (mysql datetime format)
347 *
348 * @return boolean : true if exist news else false
349 */
350function news_exists($start, $end)
351{
352  return (
353          (nb_new_comments($start, $end) > 0) or
354          (nb_new_elements($start, $end) > 0) or
355          (nb_updated_categories($start, $end) > 0) or
[2159]356          ((is_admin()) and (nb_unvalidated_comments($start, $end) > 0)) or
[8664]357          ((is_admin()) and (nb_new_users($start, $end) > 0)));
[1021]358}
359
360/**
[1549]361 * Formats a news line and adds it to the array (e.g. '5 new elements')
362 */
[1637]363function add_news_line(&$news, $count, $singular_fmt_key, $plural_fmt_key, $url='', $add_url=false)
[1549]364{
365  if ($count > 0)
366  {
[1637]367    $line = l10n_dec($singular_fmt_key, $plural_fmt_key, $count);
[1549]368    if ($add_url and !empty($url) )
369    {
370      $line = '<a href="'.$url.'">'.$line.'</a>';
371    }
[25018]372    $news[] = $line;
[1549]373  }
374}
375
376/**
[1021]377 * What's new between two dates ?
378 *
379 * Informations : number of new comments, number of new elements, number of
380 * updated categories. Administrators are also informed about : number of
381 * unvalidated comments, number of new users (TODO : number of unvalidated
382 * elements)
383 *
384 * @param string start date (mysql datetime format)
385 * @param string end date (mysql datetime format)
[1549]386 * @param bool exclude_img_cats if true, no info about new images/categories
387 * @param bool add_url add html A link around news
[1112]388 *
389 * @return array of news
[1021]390 */
[1549]391function news($start, $end, $exclude_img_cats=false, $add_url=false)
[1021]392{
[1112]393  $news = array();
[1021]394
[1549]395  if (!$exclude_img_cats)
[1021]396  {
[1639]397    add_news_line( $news,
[8665]398      nb_new_elements($start, $end), '%d new photo', '%d new photos',
[1789]399      make_index_url(array('section'=>'recent_pics')), $add_url );
[1021]400  }
401
[1549]402  if (!$exclude_img_cats)
[1639]403  {
404    add_news_line( $news,
[6951]405      nb_updated_categories($start, $end), '%d album updated', '%d albums updated',
[1789]406      make_index_url(array('section'=>'recent_cats')), $add_url );
[1021]407  }
408
[1549]409  add_news_line( $news,
[1637]410      nb_new_comments($start, $end), '%d new comment', '%d new comments',
[1549]411      get_root_url().'comments.php', $add_url );
412
[1070]413  if (is_admin())
[1021]414  {
[1549]415    add_news_line( $news,
[2159]416        nb_unvalidated_comments($start, $end), '%d comment to validate', '%d comments to validate',
[1549]417        get_root_url().'admin.php?page=comments', $add_url );
[1021]418
[1549]419    add_news_line( $news,
[1637]420        nb_new_users($start, $end), '%d new user', '%d new users',
[1550]421        get_root_url().'admin.php?page=user_list', $add_url );
[1021]422  }
423
424  return $news;
425}
426
[1639]427/**
428 * returns information about recently published elements grouped by post date
429 * @param int max_dates maximum returned number of recent dates
430 * @param int max_elements maximum returned number of elements per date
431 * @param int max_cats maximum returned number of categories per date
432 */
433function get_recent_post_dates($max_dates, $max_elements, $max_cats)
434{
[1789]435  global $conf, $user;
[1639]436
[2543]437  $where_sql = get_std_sql_where_restrict_filter('WHERE', 'i.id', true);
[1639]438
439  $query = '
440SELECT date_available,
[6652]441      COUNT(DISTINCT id) AS nb_elements,
442      COUNT(DISTINCT category_id) AS nb_cats
[2543]443  FROM '.IMAGES_TABLE.' i INNER JOIN '.IMAGE_CATEGORY_TABLE.' AS ic ON id=image_id
[1639]444  '.$where_sql.'
445  GROUP BY date_available
446  ORDER BY date_available DESC
[4334]447  LIMIT '.$max_dates.'
[1639]448;';
449  $result = pwg_query($query);
450  $dates = array();
[4325]451  while ($row = pwg_db_fetch_assoc($result))
[1639]452  {
[25018]453    $dates[] = $row;
[1639]454  }
455
456  for ($i=0; $i<count($dates); $i++)
457  {
458    if ($max_elements>0)
459    { // get some thumbnails ...
460      $query = '
[12917]461SELECT DISTINCT i.*
[2543]462  FROM '.IMAGES_TABLE.' i INNER JOIN '.IMAGE_CATEGORY_TABLE.' AS ic ON id=image_id
[1639]463  '.$where_sql.'
[6597]464    AND date_available=\''.$dates[$i]['date_available'].'\'
[4542]465  ORDER BY '.DB_RANDOM_FUNCTION.'()
[4334]466  LIMIT '.$max_elements.'
[1639]467;';
468      $dates[$i]['elements'] = array();
469      $result = pwg_query($query);
[4325]470      while ($row = pwg_db_fetch_assoc($result))
[1639]471      {
[25018]472        $dates[$i]['elements'][] = $row;
[1639]473      }
474    }
475
476    if ($max_cats>0)
477    {// get some categories ...
478      $query = '
[6870]479SELECT DISTINCT c.uppercats, COUNT(DISTINCT i.id) AS img_count
[1677]480  FROM '.IMAGES_TABLE.' i INNER JOIN '.IMAGE_CATEGORY_TABLE.' AS ic ON i.id=image_id
[1639]481    INNER JOIN '.CATEGORIES_TABLE.' c ON c.id=category_id
482  '.$where_sql.'
[6597]483    AND date_available=\''.$dates[$i]['date_available'].'\'
484  GROUP BY category_id, c.uppercats
[1639]485  ORDER BY img_count DESC
[4334]486  LIMIT '.$max_cats.'
[1639]487;';
488      $dates[$i]['categories'] = array();
489      $result = pwg_query($query);
[4325]490      while ($row = pwg_db_fetch_assoc($result))
[1639]491      {
[25018]492        $dates[$i]['categories'][] = $row;
[1639]493      }
494    }
495  }
496  return $dates;
[1789]497}
[1784]498
[1871]499/*
[2159]500  Call function get_recent_post_dates but
[1871]501  the parameters to be passed to the function, as an indexed array.
[2159]502
[1871]503*/
504function get_recent_post_dates_array($args)
505{
506  return
507    get_recent_post_dates
508    (
509      (empty($args['max_dates']) ? 3 : $args['max_dates']),
510      (empty($args['max_elements']) ? 3 : $args['max_elements']),
511      (empty($args['max_cats']) ? 3 : $args['max_cats'])
512    );
513}
514
515
[1789]516/**
517 * returns html description about recently published elements grouped by post date
518 * @param $date_detail: selected date computed by get_recent_post_dates function
519 */
520function get_html_description_recent_post_date($date_detail)
521{
522  global $conf;
523
[3257]524  $description = '<ul>';
[2159]525
[1789]526  $description .=
527        '<li>'
[8665]528        .l10n_dec('%d new photo', '%d new photos', $date_detail['nb_elements'])
[1789]529        .' ('
530        .'<a href="'.make_index_url(array('section'=>'recent_pics')).'">'
[8664]531          .l10n('Recent photos').'</a>'
[1789]532        .')'
[3185]533        .'</li><br>';
[1789]534
535  foreach($date_detail['elements'] as $element)
536  {
[12796]537    $tn_src = DerivativeImage::thumb_url($element);
[1802]538    $description .= '<a href="'.
[1814]539                    make_picture_url(array(
540                        'image_id' => $element['id'],
541                        'image_file' => $element['file'],
542                      ))
[3185]543                    .'"><img src="'.$tn_src.'"></a>';
[1789]544  }
[3185]545  $description .= '...<br>';
[1789]546
547  $description .=
548        '<li>'
[25018]549        .l10n_dec('%d album updated', '%d albums updated', $date_detail['nb_cats'])
[1789]550        .'</li>';
551
552  $description .= '<ul>';
553  foreach($date_detail['categories'] as $cat)
554  {
555    $description .=
556          '<li>'
557          .get_cat_display_name_cache($cat['uppercats'])
558          .' ('.
[25018]559          l10n_dec('%d new photo', '%d new photos', $cat['img_count']).')'
[1789]560          .'</li>';
561  }
562  $description .= '</ul>';
563
[3257]564  $description .= '</ul>';
565
[1789]566  return $description;
567}
568
569/**
570 * returns title about recently published elements grouped by post date
571 * @param $date_detail: selected date computed by get_recent_post_dates function
572 */
573function get_title_recent_post_date($date_detail)
574{
575  global $lang;
576
577  $date = $date_detail['date_available'];
[6662]578  $exploded_date = strptime($date, '%Y-%m-%d %H:%M:%S');
[1789]579
[8665]580  $title = l10n_dec('%d new photo', '%d new photos', $date_detail['nb_elements']);
[6668]581  $title .= ' ('.$lang['month'][1+$exploded_date['tm_mon']].' '.$exploded_date['tm_mday'].')';
[1789]582
583  return $title;
584}
585
[6668]586if(!function_exists("strptime"))
587{
588                function strptime($date, $fmt)
589                {
590                        if ($fmt != '%Y-%m-%d %H:%M:%S')
591                                die('Invalid strptime format '.$fmt);
592                        list($y,$m,$d,$H,$M,$S) = preg_split('/[-: ]/', $date);
593                        $res = localtime( mktime($H,$M,$S,$m,$d,$y), true );
594                        return $res;
595                }
596 }
[6951]597?>
Note: See TracBrowser for help on using the repository browser.