X-Git-Url: http://git.pk910.de/?p=PHP-P10.git;a=blobdiff_plain;f=Uplink%2FP10_Server.class.php;h=183fb6ef3be71a9b6b7caffba152604c2bf3b5e9;hp=1603e4c84722a6455b7187e001a0e254addcab2f;hb=0f30e96ae37491aee19e72b89cc54a6798d1f254;hpb=64245b7638b8ac32229ccc67856b45a6b79afd35 diff --git a/Uplink/P10_Server.class.php b/Uplink/P10_Server.class.php index 1603e4c..183fb6e 100644 --- a/Uplink/P10_Server.class.php +++ b/Uplink/P10_Server.class.php @@ -1,22 +1,19 @@ . * * * ************************************************************************ * @@ -24,50 +21,36 @@ * * This class represents a IRC Server * - ************************************************************************ - * accessable methods: - * - * static P10_Server getServerByNum(String $numeric) - * searches and returns the Server with the provided Numeric - * - * __construct(String $name, String $numeric, P10_Server $parent_server, int $start_time, $link_time, $description) - * *** nothing to say here *** - * - * void disconnectServer(bool $linked_only = false) - * DISCONNECT EVENT (if $linked_only is true, only the Servers connected to the actual Server get disconnected.) - * - * String getNumeric() - * returns the Numeric of the Server - * - * String getName() - * returns the Name of the Server - * - * String getStartTime() - * returns the startup time of the Server - * - * String getLinkTime() - * returns the link time of the Server - * - * String getDescription() - * returns the Description of the Server - * - * void addServer(P10_Server $server) - * adds a Server to the server's "slave" list - * - * void delServer(P10_Server $server) - * removes a Server to the server's "slave" list */ class P10_Server { private static $static_servers = array(); - public static getServerByNum($numeric) { + public static function getServerByNum($numeric) { if(array_key_exists($numeric, self::$static_servers)) { return self::$static_servers[$numeric]; } return NULL; } + public static function getServerByName($name) { + $name = strtolower($name); + foreach(self::$static_servers as $server) { + if(strtolower($server->getName()) == $name) { + return $server; + } + } + return NULL; + } + + public static function getServerCount() { + return count(self::$static_servers); + } + + public static function getServers() { + return self::$static_servers; + } + private $name; private $numeric; @@ -76,6 +59,7 @@ class P10_Server { private $link_time; private $description; private $servers = array(); //all Servers connected to this Server + private $users = array(); //all Users connected to this Server public function __construct($name, $numeric, $parent_server, $start_time, $link_time, $description) { $this->name = $name; @@ -88,8 +72,10 @@ class P10_Server { self::$static_servers[$numeric] = $this; } - public function disconnectServer($linked_only = false) { + public function disconnectServer($eventHandler, $linked_only = false) { if(!$linked_only) { + if($eventHandler) + $eventHandler->event_squit($this); if($this->parent_server) { $this->parent_server->delServer($this); } @@ -97,12 +83,15 @@ class P10_Server { unset(self::$static_servers[$this->numeric]); } foreach($this->servers as $server) { - $server->disconnectServer(); + $server->disconnectServer($eventHandler); } } public function disconnectUsers() { //disconnect all Users connected to the actual Server + foreach($this->users as $user) { + $user->quit("*.net *.split"); + } } public function getNumeric() { @@ -136,6 +125,26 @@ class P10_Server { trigger_error("Tried to remove a Server, that does NOT exist.", E_USER_WARNING); } } + + public function addUser($user) { + $this->users[$user->getNumeric()] = $user; + } + + public function delUser($user) { + if(array_key_exists($user->getNumeric(), $this->users)) { + unset($this->users[$user->getNumeric()]); + } else { + trigger_error("Tried to remove a User, that does NOT exist.", E_USER_WARNING); + } + } + + public function getUsers() { + return $this->users; + } + + public function getUserCount() { + return count($this->users); + } } ?> \ No newline at end of file