source: extensions/HistoryIPExcluder/branches/2.2/main.inc.php @ 12151

Last change on this file since 12151 was 12151, checked in by Eric, 13 years ago
  • Use data serialization for database storage
  • Use pwg_db_real_escape_string() instead of addslashes()
  • Property svn:eol-style set to LF
File size: 4.3 KB
Line 
1<?php
2/*
3Plugin Name: History IP Excluder
4Version: 2.2.3
5Description: Permet l'exclusion d'une IP ou d'une plage d'IP de l'historique et de les blacklister à l'inscription / Excludes one IP or a range of IP from the history and to blacklist them on registration
6Plugin URI: http://piwigo.org/ext/extension_view.php?eid=147
7Author: Nicco, Eric
8Author URI: http://gallery-nicco.no-ip.org - http://www.infernoweb.net
9*/
10
11/*
12:: HISTORY
13
141.0.x to 1.6.x          - Plugin only for PWG 1.7.x
15
162.0.0             - Compliance with Piwigo 2.0.x
17
182.1.0             - Compliance with Piwigo 2.1.x
19                  - Multiple database support
20                  - Removing "nbc_" prefix in plugin code and display in piwigo's plugin manager
21                  - Displaying the good plugin name and current version in admin panel
22                 
232.1.1             - Bug 1792 fixed (Thx to TOnin)
24                  - Bug 1511 fixed - New function to blacklist excluded IPs or ranged IPs for registration
25
262.2.0             - Compliance with Piwigo 2.2.x
27                  - Plugin directory renamed from nbc_HistoryIPExcluder to HistoryIPExcluder
28
292.2.1             - Bug fixed on plugin upgrade from 2.1.x version
30
312.2.2             - Another bug fixed on plugin upgrade from 2.2.x version
32
332.2.3             - Improved update mechanism. When no structural update of database is necessary, it sets the correct version number in plugin's configuration
34--------------------------------------------------------------------------------
35*/
36
37if (!defined('PHPWG_ROOT_PATH')) die('Hacking attempt!');
38
39if (!defined('HIPE_PATH')) define('HIPE_PATH' , PHPWG_PLUGINS_PATH.basename(dirname(__FILE__)).'/');
40
41include_once (HIPE_PATH.'/include/functions.inc.php');
42
43load_language('plugin.lang', HIPE_PATH);
44
45add_event_handler('get_admin_plugin_menu_links', 'HIPE_admin_menu');
46
47/* Set the administration panel of the plugin */
48function HIPE_admin_menu($menu)
49{
50// +-----------------------------------------------------------------------+
51// |                      Getting plugin name                              |
52// +-----------------------------------------------------------------------+
53  $plugin =  HIPE_infos(HIPE_PATH);
54  $name = $plugin['name'];
55 
56  array_push($menu,
57    array(
58      'NAME' => $name,
59      'URL' => get_root_url().'admin.php?page=plugin-'.basename(HIPE_PATH)
60    )
61  );
62   
63  return $menu;
64}
65
66// IP exclusion from logs
67add_event_handler('pwg_log_allowed', 'HIPE_IP_Filtrer');
68
69function HIPE_IP_Filtrer($do_log)
70{
71  global $conf;
72
73  $conf_HIPE = explode("," , $conf['HistoryIPExcluder']);
74
75  if (!$do_log)
76    return $do_log;
77  else
78  {
79    $IP_Client = explode('.', $_SERVER['REMOTE_ADDR']);
80 
81    foreach ($conf_HIPE as $Exclusion)
82    {
83      $IP_Exclude = explode('.', $Exclusion);
84 
85      if (
86        (($IP_Client[0] == $IP_Exclude[0]) or ($IP_Exclude[0] == '%')) and
87        (!isset($IP_Exclude[1]) or ($IP_Client[1] == $IP_Exclude[1]) or ($IP_Exclude[1] == '%')) and
88        (!isset($IP_Exclude[2]) or ($IP_Client[2] == $IP_Exclude[2]) or ($IP_Exclude[2] == '%')) and
89        (!isset($IP_Exclude[3]) or ($IP_Client[3] == $IP_Exclude[3]) or ($IP_Exclude[3] == '%'))
90      )
91      {
92        $do_log = false;
93      }   
94    }
95     
96    return $do_log;
97  }
98}
99
100/* Check users registration */
101add_event_handler('register_user_check', 'HIPE_RegistrationCheck', EVENT_HANDLER_PRIORITY_NEUTRAL +2, 2);
102
103function HIPE_RegistrationCheck($err, $user)
104{
105  global $errors, $conf;
106  load_language('plugin.lang', HIPE_PATH);
107 
108  if (count($err)!=0 ) return $err;
109 
110  $IP_Client = explode('.', $_SERVER['REMOTE_ADDR']);
111  $HIPE_Config = unserialize($conf['HistoryIPConfig']);
112  $conf_HIPE = explode("," , $conf['HistoryIPExcluder']);
113 
114  if (isset($HIPE_Config['Blacklist']) and $HIPE_Config['Blacklist'] == true)
115  {
116    foreach ($conf_HIPE as $Exclusion)
117    {
118      $IP_Exclude = explode('.', $Exclusion);
119 
120      if (
121        (($IP_Client[0] == $IP_Exclude[0]) or ($IP_Exclude[0] == '%')) and
122        (!isset($IP_Exclude[1]) or ($IP_Client[1] == $IP_Exclude[1]) or ($IP_Exclude[1] == '%')) and
123        (!isset($IP_Exclude[2]) or ($IP_Client[2] == $IP_Exclude[2]) or ($IP_Exclude[2] == '%')) and
124        (!isset($IP_Exclude[3]) or ($IP_Client[3] == $IP_Exclude[3]) or ($IP_Exclude[3] == '%'))
125      )
126      {
127        $err = l10n('Error_HIPE_BlacklistedIP');
128      }
129    }
130    return $err;
131  }
132}
133?>
Note: See TracBrowser for help on using the repository browser.