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

Last change on this file since 4104 was 4092, checked in by LucMorizur, 15 years ago

[Event Cats] PNG, JS, TPL and CSS normally finished now. Remains "only" PHP and SQL...

File size: 9.0 KB
Line 
1<?php
2
3/*
4Plugin Name: Event Cats
5Version: 1.0.0
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.
7Plugin URI: http://piwigo.org/svn/extensions/event_cats
8Author: P@t, LucMorizur
9Author URI: http://www.gauchon.fr, http://lucmorizur.free.fr
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
34if (!defined('PHPWG_ROOT_PATH')) die('Hacking attempt!');
35
36// pour faciliter le debug - make debug easier :o)
37//ini_set('error_reporting', E_ALL);
38//ini_set('display_errors', true);
39
40global
41  $conf, $prefixeTable,
42  $ec_ap_ok;   // whether Additional Pages is installed and activated
43
44define('EVNTCATS_INFO_VERSION','1.0.0');
45define('EVNTCATS_PATH',PHPWG_PLUGINS_PATH.basename(dirname(__FILE__)). '/');
46define('EVNTCATS_TABLE',$prefixeTable.'event_cats');
47define('ROOT_URL',get_absolute_root_url());
48
49$ec_ap_ok = defined('AP_DIR');
50
51if (!isset($ec_lists)) {
52  $ec_lists = array();
53}
54
55include_once(EVNTCATS_PATH.'include/evntcats_funcs.inc.php');
56
57class event_cats {
58// Sets the administration panel of the plugin
59  function plugin_admin_menu($menu) {
60    array_push($menu,
61      array(
62        'NAME' => 'Event Cats',
63        'URL'  => get_admin_plugin_menu_link(dirname(__FILE__).
64                  '/admin/evntcats_admin.php')
65      )
66    );
67    return $menu;
68  }
69} // End class
70
71$obj = new event_cats();
72
73// Admin help management
74add_event_handler('get_popup_help_content', 'ec_popup_help_content',
75 EVENT_HANDLER_PRIORITY_NEUTRAL, 2);
76
77function ec_popup_help_content($popup_help_content, $page) {
78  return (
79   $help_content = ($page == 'event_cats' and is_admin()) ?
80    load_language('help.html', EVNTCATS_PATH, array('return' => true)) : false
81  ) ? $popup_help_content.$help_content : $popup_help_content;
82}
83
84//----------------------------------
85
86/**
87 *
88 * auto_log_user()
89 * the function uses the value of the argument "autolog" of the posted URL, as a code
90 * to know which username has to be logged in.
91 *
92 * @param no parameter
93 * @return no return value
94 */
95
96add_event_handler('init', 'auto_log_user');
97
98function auto_log_user() {
99  global $ec_lists;
100
101  $ec_ap  = NULL;
102  $ec_cat = NULL;
103  $ec_img = NULL;
104
105  if (isset($_GET['autolog']) and (read_ec_conf('activated') == 1)) {
106    if (!is_a_guest()) {
107      $url = '';
108      foreach ($_GET as $item => $value) {
109        $url.= '&'.$item.'='.$value;
110      }
111      logout_user();
112      redirect(make_index_url().$url);
113    }
114    build_ec_lists();
115    foreach ($ec_lists['ec_table'] as $ec_entry) {
116      if ($code_exists = ($ec_entry['code'] == $_GET['autolog'])) break;
117    }
118    if ($code_exists) {
119      if (is_in($ec_entry['action'], 'ec_ok')) {
120        log_user($ec_entry['user_id'], false);
121        if (isset($_GET['ap'])) $ec_ap = $_GET['ap'];
122        if (isset($_GET['cat'])) $ec_cat = $_GET['cat'];
123        if (isset($_GET['img'])) $ec_img = $_GET['img'];
124        if ($ec_entry['forced'] == 'true') {
125          if (empty($ec_entry['arg1']) and !empty($ec_entry['arg2'])) {
126            $ec_ap = $ec_entry['arg2'];
127          }
128          elseif (!empty($ec_entry['arg1'])) {
129            $ec_cat = $ec_entry['arg1'];
130            if (!empty($ec_entry['arg2'])) $ec_img = $ec_entry['arg2'];
131          }
132        }
133        if (isset($ec_ap)) {
134          if (array_key_exists($ec_ap,$ec_lists['add_pages'])) {
135            redirect(
136             PHPWG_ROOT_PATH.'index.php?/additional_page/'.$ec_ap);
137          }
138        }
139        elseif (isset($ec_cat)) {
140          if (array_key_exists($ec_cat, $ec_lists['categories'])) {
141            if (isset($ec_img)) {
142              if (mysql_fetch_row(pwg_query('
143               SELECT *
144               FROM `'.IMAGE_CATEGORY_TABLE.'`
145               WHERE `category_id` = '.$ec_cat.'
146                AND `image_id` = '.$ec_img
147              ))) {
148                redirect(PHPWG_ROOT_PATH.'picture.php?/'.$ec_img.'/category/'.$ec_cat);
149              }
150            }
151            redirect(PHPWG_ROOT_PATH.'index.php?/category/'.$ec_cat);
152          }
153        }
154        redirect(make_index_url());
155      }
156      else {
157        if (
158         $ec_entry['action'] == 'ec_nok' or
159         $ec_entry['action'] == 'ec_nok_ap_pb'
160        ) {
161          if ($ec_entry['action'] == 'ec_nok_ap_pb') access_denied();
162          $ec_ap = $ec_entry['arg2'];
163          if (array_key_exists($ec_ap, $ec_lists['add_pages'])) {
164            redirect(
165             PHPWG_ROOT_PATH.'index.php?/additional_page/'.$ec_ap);
166          }
167          access_denied();
168        }
169        else {
170          redirect(make_index_url());
171        }
172      }
173    }
174    else {
175      if (
176       read_ec_conf('unknown_code') == 2 and
177        array_key_exists(
178         read_ec_conf('unknown_code_ap_id'), $ec_lists['add_pages']
179        )
180       ) {
181        redirect(
182         PHPWG_ROOT_PATH.
183         'index.php?/additional_page/'.read_ec_conf('unknown_code_ap_id')
184        );
185      }
186      elseif (read_ec_conf('unknown_code') == 1 or
187       read_ec_conf('unknown_code') == 2) {
188        access_denied();
189      }
190      else {
191        redirect(make_index_url());
192      }
193    }
194  }
195}
196
197/**
198 *
199 * assign_perm_for_new_user()
200 * copies/paste groups+access+properties associations of previously connected
201 * username, to newly created username.
202 *
203 * @param no parameter
204 * @return no return value
205 */
206
207add_event_handler('register_user', 'assign_perm_for_new_user');
208
209function assign_perm_for_new_user($new_user)
210{
211  global $user;
212
213  if (!is_a_guest() and !is_admin())
214  {
215    // User access
216    $query = 'SELECT cat_id FROM '.USER_ACCESS_TABLE.' WHERE user_id = '.$user['id'].';';
217    $result = pwg_query($query);
218    $insert = array();
219    while ($row = mysql_fetch_assoc($result))
220    {
221      $insert[] = '('.$new_user['id'].','.$row['cat_id'].')';
222    }
223    if (!empty($insert))
224    {
225      pwg_query('INSERT INTO '.USER_ACCESS_TABLE.' VALUES '.implode(',', $insert).';');
226    }
227
228    // User groups
229    $query = 'SELECT group_id FROM '.USER_GROUP_TABLE.' WHERE user_id = '.$user['id'].';';
230    $result = pwg_query($query);
231    $insert = array();
232    while ($row = mysql_fetch_assoc($result))
233    {
234      $insert[] = '('.$new_user['id'].','.$row['group_id'].')';
235    }
236    if (!empty($insert))
237    {
238      pwg_query('INSERT INTO '.USER_GROUP_TABLE.' VALUES '.implode(',', $insert).';');
239    }
240
241    // User infos
242    $query = 'SELECT level FROM '.USER_INFOS_TABLE.' WHERE user_id = '.$user['id'].';';
243    $result = pwg_query($query);
244    $insert = array();
245    while ($row = mysql_fetch_assoc($result))
246    {
247      $insert[] = '('.$new_user['id'].','.$row['level'].')';
248    }
249    if (!empty($insert))
250    {
251      $query = 'UPDATE '.USER_INFOS_TABLE.' SET level = '.$user['level'].' WHERE user_id = '.$new_user['id'].';';
252      pwg_query($query);
253    }
254  }
255}
256
257/**
258 *
259 * duplicate_account_url()
260 * adds a link "Duplicate" in Identification block menu.
261 *
262 * @param no parameter
263 * @return no return value
264 */
265
266add_event_handler('blockmanager_apply', 'duplicate_account_url');
267
268function duplicate_account_url() {
269  global $lang, $template;
270
271  if (!is_admin() and !is_a_guest()) {
272    $template->assign( 'U_REGISTER', get_root_url().'register.php');
273    $lang['Create a new account'] = l10n('Duplicate account');
274    $lang['Register'] = l10n('Duplicate');
275  }
276}
277
278add_event_handler('get_admin_plugin_menu_links', array(&$obj, 'plugin_admin_menu') );
279set_plugin_data($plugin['id'], $obj);
280
281?>
Note: See TracBrowser for help on using the repository browser.