continued burst() method & Numerics.class.php
[PHP-P10.git] / Uplink / P10_Server.class.php
1 <?php
2 /********************************* PHP-P10 ******************************
3  *    P10 uplink class by pk910   (c)2011 pk910                         *
4  ************************************************************************
5  *                          Version 2 (OOP)                             *
6  *                                                                      *
7  * PHP-P10 is free software; you can redistribute it and/or modify      *
8  * it under the terms of the GNU General Public License as published by *
9  * the Free Software Foundation; either version 2 of the License, or    *
10  * (at your option) any later version.                                  *
11  *                                                                      *
12  * This program is distributed in the hope that it will be useful,      *
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of       *
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        *
15  * GNU General Public License for more details.                         *
16  *                                                                      *
17  * You should have received a copy of the GNU General Public License    *
18  * along with PHP-P10; if not, write to the Free Software Foundation,   *
19  * Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA.       *
20  *                                                                      *
21  ************************************************************************
22  * 
23  *  Uplink/P10_Server.class.php
24  *
25  * This class represents a IRC Server
26  *
27  ************************************************************************
28  * accessable methods:
29  *
30  * static P10_Server getServerByNum(String $numeric) 
31  *     searches and returns the Server with the provided Numeric
32  *
33  * __construct(String $name, String $numeric, P10_Server $parent_server, int $start_time, $link_time, $description)
34  *     *** nothing to say here ***
35  *
36  * void disconnectServer(bool $linked_only = false)
37  *     DISCONNECT EVENT (if $linked_only is true, only the Servers connected to the actual Server get disconnected.)
38  *
39  * String getNumeric()
40  *     returns the Numeric of the Server
41  *
42  * String getName()
43  *     returns the Name of the Server
44  *
45  * String getStartTime()
46  *     returns the startup time of the Server
47  *
48  * String getLinkTime()
49  *     returns the link time of the Server
50  *
51  * String getDescription()
52  *     returns the Description of the Server
53  *
54  * void addServer(P10_Server $server)
55  *     adds a Server to the server's "slave" list
56  *
57  * void delServer(P10_Server $server)
58  *     removes a Server from the server's "slave" list
59  *
60  * void addUser(P10_User $user)
61  *     adds a User to the server's userlist
62  *
63  * void delUser(P10_User $user)
64  *     removes a User from the server's userlist
65  *
66  * P10_User[] getUsers()
67  *     returns the server's userlist
68  */
69
70 class P10_Server {
71         private static $static_servers = array();
72         
73         public static getServerByNum($numeric) {
74                 if(array_key_exists($numeric, self::$static_servers)) {
75                         return self::$static_servers[$numeric];
76                 }
77                 return NULL;
78         }
79         
80         
81         private $name;
82         private $numeric;
83         private $parent_server;
84         private $start_time;
85         private $link_time;
86         private $description;
87         private $servers = array(); //all Servers connected to this Server
88         private $users = array(); //all Users connected to this Server
89         
90         public function __construct($name, $numeric, $parent_server, $start_time, $link_time, $description) {
91                 $this->name = $name;
92                 $this->numeric = $numeric;
93                 $this->parent_server = $parent_server;
94                 $this->start_time = $start_time;
95                 $this->link_time = $link_time;
96                 $this->description = $description;
97                 
98                 self::$static_servers[$numeric] = $this;
99         }
100         
101         public function disconnectServer($linked_only = false) {
102                 if(!$linked_only) {
103                         if($this->parent_server) {
104                                 $this->parent_server->delServer($this);
105                         }
106                         $this->disconnectUsers();
107                         unset(self::$static_servers[$this->numeric]);
108                 }
109                 foreach($this->servers as $server) {
110                         $server->disconnectServer();
111                 }
112         }
113         
114         public function disconnectUsers() {
115                 //disconnect all Users connected to the actual Server
116                 foreach($this->users as $user) {
117                         $user->quit("*.net *.split");
118                 }
119         }
120         
121         public function getNumeric() {
122                 return $this->numeric;
123         }
124         
125         public function getName() {
126                 return $this->name;
127         }
128         
129         public function getStartTime() {
130                 return $this->start_time;
131         }
132         
133         public function getLinkTime() {
134                 return $this->link_time;
135         }
136         
137         public function getDescription() {
138                 return $this->description;
139         }
140         
141         public function addServer($server) {
142                 $this->servers[$server->getNumeric()] = $server;
143         }
144         
145         public function delServer($server) {
146                 if(array_key_exists($server->getNumeric(), $this->servers)) {
147                         unset($this->servers[$server->getNumeric()]);
148                 } else {
149                         trigger_error("Tried to remove a Server, that does NOT exist.", E_USER_WARNING);
150                 }
151         }
152         
153         public function addUser($user) {
154                 $this->users[$user->getNumeric()] = $user;
155         }
156         
157         public function delUser($user) {
158                 if(array_key_exists($user->getNumeric(), $this->users)) {
159                         unset($this->users[$user->getNumeric()]);
160                 } else {
161                         trigger_error("Tried to remove a User, that does NOT exist.", E_USER_WARNING);
162                 }
163         }
164         
165         public function getUsers() {
166                 return $this->users;
167         }
168 }
169
170 ?>