projects
/
PHP-P10.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
format
[PHP-P10.git]
/
BotLoader
/
BotLoader.class.php
diff --git
a/BotLoader/BotLoader.class.php
b/BotLoader/BotLoader.class.php
index 0201e4c7f006199488b621ffc3b1b9b6278aae40..f7903d40e3762765a569d40351604afc9f5d23b0 100644
(file)
--- a/
BotLoader/BotLoader.class.php
+++ b/
BotLoader/BotLoader.class.php
@@
-1,12
+1,10
@@
<?php
<?php
-/********************************* PHP-P10 ******************************
- * P10 uplink class by pk910 (c)2011 pk910 *
- ************************************************************************
- * Version 2 (OOP) *
+/******************************* PHP-P10 v2 *****************************
+ * Copyright (C) 2011-2012 Philipp Kreil (pk910) *
* *
* *
- *
PHP-P10 is free software; you can redistribute it and/or modify
*
+ *
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 *
* it under the terms of the GNU General Public License as published by *
- * the Free Software Foundation
; either version 2
of the License, or *
+ * the Free Software Foundation
, either version 3
of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
@@
-15,11
+13,10
@@
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
- * along with PHP-P10; if not, write to the Free Software Foundation, *
- * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
+ * along with this program. If not, see <http://www.gnu.org/licenses/>. *
* *
************************************************************************
* *
************************************************************************
- *
+ *
* BotLoader/BotLoader.class.php
*
* This class loades / rehashs or unloads all Bots.
* BotLoader/BotLoader.class.php
*
* This class loades / rehashs or unloads all Bots.
@@
-37,7
+34,7
@@
class BotLoader {
private $loadedBots = array();
private $botDatabases = array();
private static $botloader;
private $loadedBots = array();
private $botDatabases = array();
private static $botloader;
-
+
public function __construct($uplink) {
$this->uplink = $uplink;
$this->saxdb = new saxdb();
public function __construct($uplink) {
$this->uplink = $uplink;
$this->saxdb = new saxdb();
@@
-46,7
+43,7
@@
class BotLoader {
self::$botloader = $this;
timer(60*10, array($this, "autosave"), array());
}
self::$botloader = $this;
timer(60*10, array($this, "autosave"), array());
}
-
+
public function loadBots() {
if(array_key_exists("bots", $this->botdb) && is_array($this->botdb["bots"])) {
foreach($this->botdb["bots"] as $name => $botfile) {
public function loadBots() {
if(array_key_exists("bots", $this->botdb) && is_array($this->botdb["bots"])) {
foreach($this->botdb["bots"] as $name => $botfile) {
@@
-56,35
+53,35
@@
class BotLoader {
$this->botdb["bots"] = array();
}
}
$this->botdb["bots"] = array();
}
}
-
+
public function unloadBots() {
foreach($this->loadedBots as $name => $bot) {
$this->unloadBot($name, false);
}
}
public function unloadBots() {
foreach($this->loadedBots as $name => $bot) {
$this->unloadBot($name, false);
}
}
-
+
public function save() {
$this->saxdb->setSection("BotLoader", $this->botdb);
$this->saxdb->writeDB("php_p10.db");
}
public function save() {
$this->saxdb->setSection("BotLoader", $this->botdb);
$this->saxdb->writeDB("php_p10.db");
}
-
+
public function autosave() {
foreach($this->loadedBots as $name => $bot) {
public function autosave() {
foreach($this->loadedBots as $name => $bot) {
- if(
array_key_exists(strtolower($name), $this->botDatabases
)) {
+ if(
$bot->getDBSection(
)) {
$db = $bot->writeDB();
$db = $bot->writeDB();
- $this->saxdb->setSection($
this->botDatabases[strtolower($name)]
,$db);
+ $this->saxdb->setSection($
bot->getDBSection()
,$db);
}
}
$this->save();
timer(60*10, array($this, "autosave"), array());
}
}
}
$this->save();
timer(60*10, array($this, "autosave"), array());
}
-
+
public function loop() {
foreach($this->loadedBots as $name => $bot) {
$bot->loop();
}
}
public function loop() {
foreach($this->loadedBots as $name => $bot) {
$bot->loop();
}
}
-
+
private function loadBot($name, $botfile) {
if(array_key_exists(strtolower($name), $this->loadedBots)) return false;
//load bot
private function loadBot($name, $botfile) {
if(array_key_exists(strtolower($name), $this->loadedBots)) return false;
//load bot
@@
-95,16
+92,16
@@
class BotLoader {
if(!array_key_exists($name, $this->botdb["bots"])) {
$this->botdb["bots"][$name] = $botfile;
}
if(!array_key_exists($name, $this->botdb["bots"])) {
$this->botdb["bots"][$name] = $botfile;
}
+ return true;
}
}
-
+
private function unloadBot($name, $delete = true) {
if(!(array_key_exists(strtolower($name), $this->loadedBots))) return false;
//unload bot
$bot = $this->loadedBots[strtolower($name)];
private function unloadBot($name, $delete = true) {
if(!(array_key_exists(strtolower($name), $this->loadedBots))) return false;
//unload bot
$bot = $this->loadedBots[strtolower($name)];
- if(
array_key_exists(strtolower($name), $this->botDatabases
)) {
+ if(
$bot->getDBSection(
)) {
$db = $bot->writeDB();
$db = $bot->writeDB();
- $this->saxdb->setSection($this->botDatabases[strtolower($name)],$db);
- unset($this->botDatabases[strtolower($name)]);
+ $this->saxdb->setSection($bot->getDBSection(),$db);
}
ModCMD::unbindBot($bot);
$bot->unload(false);
}
ModCMD::unbindBot($bot);
$bot->unload(false);
@@
-112,8
+109,9
@@
class BotLoader {
if(array_key_exists($name, $this->botdb["bots"]) && $delete) {
unset($this->botdb["bots"][$name]);
}
if(array_key_exists($name, $this->botdb["bots"]) && $delete) {
unset($this->botdb["bots"][$name]);
}
+ return true;
}
}
-
+
private function rehashBot($name) {
if(!(array_key_exists(strtolower($name), $this->loadedBots))) return false;
$botfile = null;
private function rehashBot($name) {
if(!(array_key_exists(strtolower($name), $this->loadedBots))) return false;
$botfile = null;
@@
-126,10
+124,9
@@
class BotLoader {
if(!$botfile) break;
//rehash bot
$bot = $this->loadedBots[strtolower($name)];
if(!$botfile) break;
//rehash bot
$bot = $this->loadedBots[strtolower($name)];
- if(
array_key_exists(strtolower($name), $this->botDatabases
)) {
+ if(
$bot->getDBSection(
)) {
$db = $bot->writeDB();
$db = $bot->writeDB();
- $this->saxdb->setSection($this->botDatabases[strtolower($name)],$db);
- unset($this->botDatabases[strtolower($name)]);
+ $this->saxdb->setSection($bot->getDBSection(),$db);
}
ModCMD::unbindBot($bot);
$data = $bot->unload(true);
}
ModCMD::unbindBot($bot);
$data = $bot->unload(true);
@@
-139,29
+136,19
@@
class BotLoader {
if(!$bot) return false;
$bot->load($this->uplink, $data);
$this->loadedBots[strtolower($name)] = $bot;
if(!$bot) return false;
$bot->load($this->uplink, $data);
$this->loadedBots[strtolower($name)] = $bot;
+ return true;
}
}
-
+
private function listLoadedBots() {
return $this->loadedBots;
}
private function listLoadedBots() {
return $this->loadedBots;
}
-
+
private function addDBsection($bot, $section) {
if(!is_a($bot, "Bot")) return false;
private function addDBsection($bot, $section) {
if(!is_a($bot, "Bot")) return false;
- $name = null;
- foreach($this->loadedBots as $botname => $cbot) {
- if($cbot === $bot) {
- $name = $botname;
- break;
- }
- }
- if($name == null) return false;
- if(array_key_exists(strtolower($name), $this->botDatabases)) {
- return false;
- }
- $this->botDatabases[strtolower($name)] = $section;
+ $bot->setDBSection($section);
$bot->readDB($this->saxdb->getSection($section));
}
$bot->readDB($this->saxdb->getSection($section));
}
-
+
private function loadClass($file, $classprefix) {
$dir = self::BOT_DIR;
$tmp = self::TMP_DIR;
private function loadClass($file, $classprefix) {
$dir = self::BOT_DIR;
$tmp = self::TMP_DIR;
@@
-181,23
+168,23
@@
class BotLoader {
unlink($tmp."/modules_".$classprefix."_".$class.".tmp.php");
return $newclass;
}
unlink($tmp."/modules_".$classprefix."_".$class.".tmp.php");
return $newclass;
}
-
+
public static function load($name, $botfile) {
return self::$botloader->loadBot($name, $botfile);
}
public static function load($name, $botfile) {
return self::$botloader->loadBot($name, $botfile);
}
-
+
public static function unload($name) {
return self::$botloader->unloadBot($name);
}
public static function unload($name) {
return self::$botloader->unloadBot($name);
}
-
+
public static function rehash($name) {
return self::$botloader->rehashBot($name);
}
public static function rehash($name) {
return self::$botloader->rehashBot($name);
}
-
+
public static function listBots() {
return self::$botloader->listLoadedBots();
}
public static function listBots() {
return self::$botloader->listLoadedBots();
}
-
+
public static function registerDB($bot, $name) {
return self::$botloader->addDBsection($bot, $name);
}
public static function registerDB($bot, $name) {
return self::$botloader->addDBsection($bot, $name);
}