-<?php
-/*
- * Nucleus: PHP/MySQL Weblog CMS (http://nucleuscms.org/)
- * Copyright (C) 2002-2009 The Nucleus Group
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2
- * of the License, or (at your option) any later version.
- * (see nucleus/documentation/index.html#license for more info)
- */
-/**
- * PHP class responsible for ban-management.
- *
- * @license http://nucleuscms.org/license.txt GNU General Public License
- * @copyright Copyright (C) 2002-2009 The Nucleus Group
- * @version $Id: BAN.php 1525 2011-06-21 10:20:19Z sakamocchi $
- */
-
-class BAN {
-
- /**
- * Checks if a given IP is banned from commenting/voting
- *
- * Returns 0 when not banned, or a BANINFO object containing the
- * message and other information of the ban
- */
- function isBanned($blogid, $ip) {
- $blogid = intval($blogid);
- $query = 'SELECT * FROM '.sql_table('ban').' WHERE blogid='.$blogid;
- $res = sql_query($query);
- while ($obj = sql_fetch_object($res)) {
- $found = i18n::strpos ($ip, $obj->iprange);
- if (!($found === false))
- // found a match!
- return new BANINFO($obj->iprange, $obj->reason);
- }
- return 0;
- }
-
- /**
- * BAN::addBan()
- * Adds a new ban to the banlist. Returns 1 on success, 0 on error
- *
- * @param Integer $blogid ID for weblog
- * @param String $iprange IP range
- * @param String $reason reason for banning
- * @return Boolean
- *
- */
- function addBan($blogid, $iprange, $reason)
- {
- global $manager;
-
- $blogid = intval($blogid);
-
- $manager->notify(
- 'PreAddBan',
- array(
- 'blogid' => $blogid,
- 'iprange' => &$iprange,
- 'reason' => &$reason
- )
- );
-
- $query = "INSERT INTO %s (blogid, iprange, reason) VALUES (%d, '%s', '%s')";
- $query = sprintf($query, sql_table('ban'), $blogid, sql_real_escape_string($iprange), sql_real_escape_string($reason));
- $res = sql_query($query);
-
- $manager->notify(
- 'PostAddBan',
- array(
- 'blogid' => $blogid,
- 'iprange' => $iprange,
- 'reason' => $reason
- )
- );
- return $res ? 1 : 0;
- }
-
- /**
- * Removes a ban from the banlist (correct iprange is needed as argument)
- * Returns 1 on success, 0 on error
- */
- function removeBan($blogid, $iprange) {
- global $manager;
- $blogid = intval($blogid);
-
- $manager->notify('PreDeleteBan', array('blogid' => $blogid, 'range' => $iprange));
-
- $query = 'DELETE FROM '.sql_table('ban')." WHERE blogid=$blogid and iprange='" .sql_real_escape_string($iprange). "'";
- sql_query($query);
-
- $result = (sql_affected_rows() > 0);
-
- $manager->notify('PostDeleteBan', array('blogid' => $blogid, 'range' => $iprange));
-
- return $result;
- }
-}
-
-class BANINFO {
- var $iprange;
- var $message;
-
- function BANINFO($iprange, $message) {
- $this->iprange = $iprange;
- $this->message = $message;
- }
-}
-
-
-?>
\ No newline at end of file
+<?php\r
+/*\r
+ * Nucleus: PHP/MySQL Weblog CMS (http://nucleuscms.org/)\r
+ * Copyright (C) 2002-2012 The Nucleus Group\r
+ *\r
+ * This program is free software; you can redistribute it and/or\r
+ * modify it under the terms of the GNU General Public License\r
+ * as published by the Free Software Foundation; either version 2\r
+ * of the License, or (at your option) any later version.\r
+ * (see nucleus/documentation/index.html#license for more info)\r
+ */\r
+/**\r
+ * PHP class responsible for ban-management.\r
+ *\r
+ * @license http://nucleuscms.org/license.txt GNU General Public License\r
+ * @copyright Copyright (C) 2002-2012 The Nucleus Group\r
+ * @version $Id: BAN.php 1525 2011-06-21 10:20:19Z sakamocchi $\r
+ */\r
+\r
+class Ban\r
+{\r
+ /**\r
+ * Checks if a given IP is banned from commenting/voting\r
+ *\r
+ * Returns 0 when not banned, or a BanInfo object containing the\r
+ * message and other information of the ban\r
+ */\r
+ public function isBanned($blogid, $ip)\r
+ {\r
+ $blogid = intval($blogid);\r
+ $query = 'SELECT * FROM '.sql_table('ban').' WHERE blogid='.$blogid;\r
+ $res = sql_query($query);\r
+ while ($obj = sql_fetch_object($res)) {\r
+ $found = i18n::strpos ($ip, $obj->iprange);\r
+ if (!($found === false))\r
+ // found a match!\r
+ return new BanInfo($obj->iprange, $obj->reason);\r
+ }\r
+ return 0;\r
+ }\r
+\r
+ /**\r
+ * Ban::addBan()\r
+ * Adds a new ban to the banlist. Returns 1 on success, 0 on error\r
+ * \r
+ * @param Integer $blogid ID for weblog\r
+ * @param String $iprange IP range\r
+ * @param String $reason reason for banning\r
+ * @return Boolean\r
+ * \r
+ */\r
+ public function addBan($blogid, $iprange, $reason)\r
+ {\r
+ global $manager;\r
+ \r
+ $blogid = intval($blogid);\r
+ \r
+ $manager->notify(\r
+ 'PreAddBan',\r
+ array(\r
+ 'blogid' => $blogid,\r
+ 'iprange' => &$iprange,\r
+ 'reason' => &$reason\r
+ )\r
+ );\r
+ \r
+ $query = "INSERT INTO %s (blogid, iprange, reason) VALUES (%d, '%s', '%s')";\r
+ $query = sprintf($query, sql_table('ban'), $blogid, sql_real_escape_string($iprange), sql_real_escape_string($reason));\r
+ $res = sql_query($query);\r
+ \r
+ $manager->notify(\r
+ 'PostAddBan',\r
+ array(\r
+ 'blogid' => $blogid,\r
+ 'iprange' => $iprange,\r
+ 'reason' => $reason\r
+ )\r
+ );\r
+ return $res ? 1 : 0;\r
+ }\r
+ \r
+ /**\r
+ * Removes a ban from the banlist (correct iprange is needed as argument)\r
+ * Returns 1 on success, 0 on error\r
+ */\r
+ public function removeBan($blogid, $iprange)\r
+ {\r
+ global $manager;\r
+ $blogid = intval($blogid);\r
+ \r
+ $manager->notify('PreDeleteBan', array('blogid' => $blogid, 'range' => $iprange));\r
+ \r
+ $query = 'DELETE FROM '.sql_table('ban')." WHERE blogid=$blogid and iprange='" .sql_real_escape_string($iprange). "'";\r
+ sql_query($query);\r
+ \r
+ $result = (sql_affected_rows() > 0);\r
+ \r
+ $manager->notify('PostDeleteBan', array('blogid' => $blogid, 'range' => $iprange));\r
+ \r
+ return $result;\r
+ }\r
+}\r
+\r
+class BanInfo\r
+{\r
+ public $iprange;\r
+ public $message;\r
+ \r
+ public function __construct($iprange, $message)\r
+ {\r
+ $this->iprange = $iprange;\r
+ $this->message = $message;\r
+ return;\r
+ }\r
+}\r