source: extensions/event_cats/main.inc.php @ 6425

Last change on this file since 6425 was 6425, checked in by LucMorizur, 14 years ago

Re-fix bug 1432

File size: 11.9 KB
RevLine 
[3969]1<?php
[3964]2
3/*
4Plugin Name: Event Cats
[6269]5Version: 1.2.1
[3970]6Description: A single URL can be enough to be identified, and a user can duplicate his account to create a new one getting immediately the same properties. / On peut être identifié grâce à un simple URL, et on peut dupliquer son compte pour créer un nouveau compte ayant immédiatement les mêmes propriétés.
[6269]7Plugin URI: http://piwigo.org/ext/extension_view.php?eid=326
[4418]8Author: LucMorizur
9Author URI: http://lucmorizur.free.fr
[3964]10*/
11
12// +-----------------------------------------------------------------------+
13// | Piwigo - a PHP based picture gallery                                  |
14// +-----------------------------------------------------------------------+
15// | Copyright(C) 2008-2009 Piwigo Team                  http://piwigo.org |
16// | Copyright(C) 2003-2008 PhpWebGallery Team    http://phpwebgallery.net |
17// | Copyright(C) 2002-2003 Pierrick LE GALL   http://le-gall.net/pierrick |
18// +-----------------------------------------------------------------------+
19// | This program is free software; you can redistribute it and/or modify  |
20// | it under the terms of the GNU General Public License as published by  |
21// | the Free Software Foundation                                          |
22// |                                                                       |
23// | This program is distributed in the hope that it will be useful, but   |
24// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
25// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
26// | General Public License for more details.                              |
27// |                                                                       |
28// | You should have received a copy of the GNU General Public License     |
29// | along with this program; if not, write to the Free Software           |
30// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
31// | USA.                                                                  |
32// +-----------------------------------------------------------------------+
33
[4421]34// Keeps file coded in UTF-8 without BOM : é
35
[3964]36if (!defined('PHPWG_ROOT_PATH')) die('Hacking attempt!');
37
38// pour faciliter le debug - make debug easier :o)
39//ini_set('error_reporting', E_ALL);
40//ini_set('display_errors', true);
41
[5058]42global $conf, $prefixeTable, $ec_lists, $template;
[3964]43
[4329]44define( // -------------------------------------------------------------------
45  'EVNTCATS_INFO_VERSION', // VERSION HISTORY :
[6425]46   '1.2.3' // Re-fix bug 1432 :-/ ...
[6269]47// '2.1.0' // When done, will simplfy and allow EC management from categories
48//            management pages in admin pages... yes yes...
[6425]49// '1.2.2' // Corrections for Piwigo 2.1 compatibility
[6269]50// '1.2.1' // Improve EN translation thanks to Tosca
[4612]51// '1.2.0' // Add feature 1335, Possibility to display the 'Connection'
52//         // link in identification block menu for generic users ;
53//         // finish (yes !) english translation
[4553]54// '1.1.5' // Fix bugs 1324 and 1325
55// '1.1.4' // Improve help banner
56// '1.1.3' // Better help banner management ; finalize banner texts
57// '1.1.2' // Better help banner example : some examples
58// '1.1.1' // Better help banner example ; but still no text in it
59// '1.1.0' // First bugs (1305 and 1306) corrected ;
60           // add newly created user/group association with cat/AP (was
61           // forgotten) ; begin help banner
62// '1.0.0' // Conception version
[4329]63); // ------------------------------------------------------------------------
64define(
65  'EVNTCATS_PATH',
66   PHPWG_PLUGINS_PATH.basename(dirname(__FILE__)).'/'
67);
68define(
69  'EVNTCATS_TABLE',
70   $prefixeTable.'event_cats'
71);
72define(
73  'ROOT_URL',
74   get_absolute_root_url()
75);
[3964]76
[4169]77include_once(EVNTCATS_PATH.'include/evntcats_main_funcs.inc.php');
[3964]78
79class event_cats {
80// Sets the administration panel of the plugin
81  function plugin_admin_menu($menu) {
82    array_push($menu,
83      array(
84        'NAME' => 'Event Cats',
85        'URL'  => get_admin_plugin_menu_link(dirname(__FILE__).
86                  '/admin/evntcats_admin.php')
87      )
88    );
89    return $menu;
90  }
91} // End class
92
93$obj = new event_cats();
94
[4282]95// Adds the translation of "duplicate" link
[4338]96load_language('duplic.lang', EVNTCATS_PATH);
[4282]97
[3964]98// Admin help management
99add_event_handler('get_popup_help_content', 'ec_popup_help_content',
100 EVENT_HANDLER_PRIORITY_NEUTRAL, 2);
101
102function ec_popup_help_content($popup_help_content, $page) {
103  return (
[6425]104   $help_content = (is_admin() and $page == 'help') ?
[6269]105    load_language($page.'.html', EVNTCATS_PATH, array('return' => true)) : false
[3964]106  ) ? $popup_help_content.$help_content : $popup_help_content;
107}
108
109//----------------------------------
110
111/**
112 *
113 * auto_log_user()
114 * the function uses the value of the argument "autolog" of the posted URL, as a code
115 * to know which username has to be logged in.
116 *
117 * @param no parameter
118 * @return no return value
119 */
120
121add_event_handler('init', 'auto_log_user');
122
123function auto_log_user() {
[4554]124  global $ec_lists;
[3964]125
126  $ec_ap  = NULL;
127  $ec_cat = NULL;
128  $ec_img = NULL;
[4247]129 
[3971]130  if (isset($_GET['autolog']) and (read_ec_conf('activated') == 1)) {
[3975]131    if (!is_a_guest()) {
132      $url = '';
[6269]133      foreach ($_GET as $item => $value) {
134        $url.= '&'.$item.'='.$value;
135      }
[3975]136      logout_user();
137      redirect(make_index_url().$url);
138    }
[3964]139    build_ec_lists();
140    foreach ($ec_lists['ec_table'] as $ec_entry) {
141      if ($code_exists = ($ec_entry['code'] == $_GET['autolog'])) break;
142    }
143    if ($code_exists) {
[3985]144      if (is_in($ec_entry['action'], 'ec_ok')) {
[3964]145        log_user($ec_entry['user_id'], false);
[3971]146        if (isset($_GET['ap'])) $ec_ap = $_GET['ap'];
[3964]147        if (isset($_GET['cat'])) $ec_cat = $_GET['cat'];
148        if (isset($_GET['img'])) $ec_img = $_GET['img'];
[4092]149        if ($ec_entry['forced'] == 'true') {
[3964]150          if (empty($ec_entry['arg1']) and !empty($ec_entry['arg2'])) {
151            $ec_ap = $ec_entry['arg2'];
152          }
153          elseif (!empty($ec_entry['arg1'])) {
154            $ec_cat = $ec_entry['arg1'];
155            if (!empty($ec_entry['arg2'])) $ec_img = $ec_entry['arg2'];
156          }
157        }
158        if (isset($ec_ap)) {
159          if (array_key_exists($ec_ap,$ec_lists['add_pages'])) {
160            redirect(
161             PHPWG_ROOT_PATH.'index.php?/additional_page/'.$ec_ap);
162          }
163        }
164        elseif (isset($ec_cat)) {
165          if (array_key_exists($ec_cat, $ec_lists['categories'])) {
166            if (isset($ec_img)) {
[4157]167              if (ec_image_exists($ec_cat, $ec_img)) {
[3964]168                redirect(PHPWG_ROOT_PATH.'picture.php?/'.$ec_img.'/category/'.$ec_cat);
169              }
170            }
[4554]171            redirect(PHPWG_ROOT_PATH.'index.php?/category/'.$ec_cat);
[3964]172          }
173        }
[3971]174        redirect(make_index_url());
[3964]175      }
176      else {
[3971]177        if (
178         $ec_entry['action'] == 'ec_nok' or
179         $ec_entry['action'] == 'ec_nok_ap_pb'
180        ) {
181          if ($ec_entry['action'] == 'ec_nok_ap_pb') access_denied();
182          $ec_ap = $ec_entry['arg2'];
183          if (array_key_exists($ec_ap, $ec_lists['add_pages'])) {
184            redirect(
185             PHPWG_ROOT_PATH.'index.php?/additional_page/'.$ec_ap);
[3964]186          }
187          access_denied();
188        }
189        else {
190          redirect(make_index_url());
191        }
192      }
193    }
194    else {
195      if (
[4371]196       read_ec_conf('unknown_code') == '2' and
[3964]197        array_key_exists(
[3971]198         read_ec_conf('unknown_code_ap_id'), $ec_lists['add_pages']
[3964]199        )
200       ) {
201        redirect(
202         PHPWG_ROOT_PATH.
[3971]203         'index.php?/additional_page/'.read_ec_conf('unknown_code_ap_id')
[3964]204        );
205      }
[4371]206      elseif (read_ec_conf('unknown_code') == '1' or
207       read_ec_conf('unknown_code') == '2') {
[3964]208        access_denied();
209      }
210      else {
211        redirect(make_index_url());
212      }
213    }
214  }
215}
216
217/**
218 *
219 * assign_perm_for_new_user()
220 * copies/paste groups+access+properties associations of previously connected
221 * username, to newly created username.
222 *
223 * @param no parameter
224 * @return no return value
225 */
226
227add_event_handler('register_user', 'assign_perm_for_new_user');
228
[4371]229function assign_perm_for_new_user($new_user) {
[3964]230  global $user;
231
[4371]232  if (!is_a_guest() and !is_admin()) if (
233    read_ec_conf('dup_allow') == '1' or (
234      read_ec_conf('dup_allow') == '2' and
235      dup_allowed($user['id'])
236    )
237  ) {
[3964]238    // User access
[4371]239    $result = pwg_query("
240      SELECT `cat_id`
241      FROM `".USER_ACCESS_TABLE."`
242      WHERE `user_id` = ".$user['id'].";
243    ");
[3964]244    $insert = array();
245    while ($row = mysql_fetch_assoc($result))
[4371]246     $insert[] = "(".$new_user['id'].",".$row['cat_id'].")";
247    if (!empty($insert)) pwg_query("
248      INSERT INTO `".USER_ACCESS_TABLE."`
249      VALUES ".implode(',', $insert).";
250    ");
[3964]251
252    // User groups
[4371]253    $result = pwg_query("
254      SELECT `group_id`
255      FROM `".USER_GROUP_TABLE."`
256      WHERE `user_id` = ".$user['id'].";
257    ");
[3964]258    $insert = array();
259    while ($row = mysql_fetch_assoc($result))
[4371]260     $insert[] = "(".$new_user['id'].",".$row['group_id'].")";
261    if (!empty($insert)) pwg_query("
262      INSERT INTO `".USER_GROUP_TABLE."`
263      VALUES ".implode(',', $insert).";
264    ");
[3964]265
266    // User infos
[4371]267    $result = pwg_query("
268      SELECT `level`
269      FROM `".USER_INFOS_TABLE."`
270      WHERE `user_id` = ".$user['id'].";
271    ");
[3964]272    $insert = array();
273    while ($row = mysql_fetch_assoc($result))
[4371]274     $insert[] = "(".$new_user['id'].",".$row['level'].")";
275    if (!empty($insert)) pwg_query("
276      UPDATE `".USER_INFOS_TABLE."`
277      SET `level` = ".$user['level']."
278      WHERE `user_id` = ".$new_user['id'].";
279    ");
[3971]280  }
[3964]281}
282
283/**
284 *
285 * duplicate_account_url()
[4553]286 * adds a link for duplicating the currently identified user in
287 * Identification block menu, in case the identifed user is granted to
288 * duplication. Displays also the connection link for generic users, if
289 * required in the configuration.
[3964]290 *
[6269]291 * ec_duplicate_prefilter
292 * is used to modify the "quick connect" block in identification menu block,
293 * so that visitors identifying themselves this way, are redirected to the
294 * page they're currently displaying, instead of home page. This
295 * functionnality has been added at version 2.1.0 in Piwigo core
296 * (see bug:1484 Redirection after quickconnect), thus it is useless to
297 * implement it from here for Piwigo versions higher or equal to 2.1.0.
298 *
[3964]299 * @param no parameter
300 * @return no return value
301 */
302
303add_event_handler('blockmanager_apply', 'duplicate_account_url');
304
[6269]305function ec_duplicate_prefilter($content, &$smarty) {
306  $search = "<legend>{'Quick connect'|@translate}</legend>";
307  $addon = '<input type="hidden" name="redirect" value="{$U_REDIRECT}">';
308  $replacement = "<legend>{'Quick connect'|@translate}</legend>".$addon;
309  return str_replace($search, $replacement, $content);
310}
311
[3971]312function duplicate_account_url() {
[4554]313  global $lang, $template, $user;
[6269]314 
315  if (version_compare(PHPWG_VERSION, '2.1.0', '<')) {
[5058]316    // Makes the "quick connect" fieldset able to redirect to current page
[6269]317    // after user identification, just as does the "connection" link.
[5058]318    $template->assign(array('U_REDIRECT' => $_SERVER['REQUEST_URI']));
319    $template->set_prefilter('menubar', 'ec_duplicate_prefilter');
[6269]320  }
[4233]321 
[4553]322  // Adds duplication link, if needed
[4329]323  if (!is_admin() and !is_a_guest()) if (
324    read_ec_conf('dup_allow') == '1' or (
325      read_ec_conf('dup_allow') == '2' and
326      dup_allowed($user['id'])
327    )
328  ) {
[4336]329    $template->assign('U_REGISTER', get_root_url().'register.php');
[4329]330    if (
331      read_ec_conf('duplic_display') == '1' or (
332        read_ec_conf('duplic_display') == '2' and
333        !is_generic()
334      )
335    ) {
[4336]336      $lang['Register'] = $lang['Duplicate'];
[4553]337      $lang['Create a new account'] =
338       $lang['Create a new account with same properties'];
[4329]339    }
[3971]340  }
[4553]341 
342  // Adds connection link, if needed
343  if (read_ec_conf('display_connection') == '1' and is_generic()) {
344    // Adds connection link
345    $template->assign(
346      'U_LOGIN',
347      get_root_url().'identification.php?redirect='.$_SERVER['REQUEST_URI']
348    );
349  }
[3964]350}
351
[4553]352add_event_handler(
353 'get_admin_plugin_menu_links',
354 array(&$obj, 'plugin_admin_menu')
355);
[3964]356set_plugin_data($plugin['id'], $obj);
357
358?>
Note: See TracBrowser for help on using the repository browser.