syntax & bug fixes (first startable version)
[PHP-P10.git] / Uplink / Uplink.class.php
index 586f9f665898821def007cda7c40928ec01cdde9..f0637b03d41ef32f7522f3643c626da4966b2204 100644 (file)
@@ -55,7 +55,7 @@ require_once("P10_User.class.php");
 require_once("P10_ModeSets.class.php");
 
 class Uplink {
-       private $client = new Client();
+       private $client;
        private $settings = array();
        private $server;
        
@@ -66,7 +66,8 @@ class Uplink {
        private $flags = 0;
        
        public function __construct() {
-               $this->setSettings("recv_timeout", 1000);
+               $this->client = new Client();
+               $this->setSetting("recv_timeout", 1000);
        }
        
        public function initialize() {
@@ -104,7 +105,7 @@ class Uplink {
                        if(($this->flags & self::FLAG_SECURITY_QUIT) || ($this->flags & self::FLAG_NOT_CONNECTABLE)) {
                                sleep(1);
                        }
-                       $state = $this->client->connect($host, $port, $this->getSettings("bind"), $this->getSettings("ssl"), $this->getSettings("recv_timeout"));
+                       $state = $this->client->connect($host, $port, $this->getSetting("bind"), $this->getSetting("ssl"), $this->getSetting("recv_timeout"));
                        if(!$state) {
                                usleep($this->getSetting("recv_timeout") / 1000);
                                $this->flags |= self::FLAG_NOT_CONNECTABLE;
@@ -121,7 +122,7 @@ class Uplink {
                }
        }
        
-       public function setUplink($host, $port, $ssl = false, $bind = null) {
+       public function setUplinkHost($host, $port, $ssl = false, $bind = null) {
                $this->setSetting("host", $host);
                $this->setSetting("port", $port);
                $this->setSetting("ssl", $ssl);
@@ -198,6 +199,12 @@ class Uplink {
                        case "EA":
                                $this->recv_end_of_burst_ack($from, $arguments);
                                break;
+                       case "SQ":
+                               $this->recv_server_quit($from, $arguments);
+                               break;
+                       case "Q":
+                               $this->recv_quit($from, $arguments);
+                               break;
                //default
                        default:
                                //unknown cmd
@@ -265,7 +272,7 @@ class Uplink {
        }
        
        private function recv_nick($from, $args) {
-               if(count($args) == 2) {
+               if(count($args) <= 2) {
                        //Nick change
                        $user = P10_User::getUserByNum($from);
                        if($user == null) {
@@ -308,6 +315,24 @@ class Uplink {
                //nothing to do here?
        }
        
+       private function recv_server_quit($from, $args) {
+               $server = P10_Server::getServerByName($args[0]);
+               if($server == null) {
+                       trigger_error("Server (".$args[0].") not found.", E_USER_ERROR);
+                       return;
+               }
+               $server->disconnectServer();
+       }
+       
+       private function recv_quit($from, $args) {
+               $user = P10_User::getUserByNum($from);
+               if($user == null) {
+                       trigger_error("Server tries to quit an user that does not exist or was not found on recv_quit.", E_USER_ERROR);
+                       return;
+               }
+               $user->quit($args[0]);
+       }
+       
        /********************************************************************************************
         *                                     SERVER FUNCTIONS                                     *
         ********************************************************************************************/