mode handler
[PHP-P10.git] / Uplink / P10_Server.class.php
index 1603e4c84722a6455b7187e001a0e254addcab2f..f36bbeae3cc1c4092e251e0301f5e88ee3603be4 100644 (file)
  *     adds a Server to the server's "slave" list
  *
  * void delServer(P10_Server $server)
- *     removes a Server to the server's "slave" list
+ *     removes a Server from the server's "slave" list
+ *
+ * void addUser(P10_User $user)
+ *     adds a User to the server's userlist
+ *
+ * void delUser(P10_User $user)
+ *     removes a User from the server's userlist
+ *
+ * P10_User[] getUsers()
+ *     returns the server's userlist
  */
 
 class P10_Server {
@@ -76,6 +85,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;
@@ -103,6 +113,9 @@ class P10_Server {
        
        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 +149,22 @@ 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;
+       }
 }
 
 ?>
\ No newline at end of file