You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1203 lines
29 KiB
1203 lines
29 KiB
9 years ago
|
<?php
|
||
|
|
||
|
/**
|
||
|
* @file
|
||
|
* TeamSpeak 3 PHP Framework
|
||
|
*
|
||
|
* $Id: Host.php 06/06/2016 22:27:13 scp@Svens-iMac $
|
||
|
*
|
||
|
* 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
|
||
|
* 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,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*
|
||
|
* @package TeamSpeak3
|
||
|
* @version 1.1.24
|
||
|
* @author Sven 'ScP' Paulsen
|
||
|
* @copyright Copyright (c) 2010 by Planet TeamSpeak. All rights reserved.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @class TeamSpeak3_Node_Host
|
||
|
* @brief Class describing a TeamSpeak 3 server instance and all it's parameters.
|
||
|
*/
|
||
|
class TeamSpeak3_Node_Host extends TeamSpeak3_Node_Abstract
|
||
|
{
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $whoami = null;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $version = null;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $serverList = null;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $permissionEnds = null;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $permissionList = null;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $permissionCats = null;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $predefined_query_name = null;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $exclude_query_clients = FALSE;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $start_offline_virtual = FALSE;
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected $sort_clients_channels = FALSE;
|
||
|
|
||
|
/**
|
||
|
* The TeamSpeak3_Node_Host constructor.
|
||
|
*
|
||
|
* @param TeamSpeak3_Adapter_ServerQuery $squery
|
||
|
* @return TeamSpeak3_Node_Host
|
||
|
*/
|
||
|
public function __construct(TeamSpeak3_Adapter_ServerQuery $squery)
|
||
|
{
|
||
|
$this->parent = $squery;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the primary ID of the selected virtual server.
|
||
|
*
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function serverSelectedId()
|
||
|
{
|
||
|
return $this->whoamiGet("virtualserver_id", 0);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the primary UDP port of the selected virtual server.
|
||
|
*
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function serverSelectedPort()
|
||
|
{
|
||
|
return $this->whoamiGet("virtualserver_port", 0);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the servers version information including platform and build number.
|
||
|
*
|
||
|
* @param string $ident
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function version($ident = null)
|
||
|
{
|
||
|
if($this->version === null)
|
||
|
{
|
||
|
$this->version = $this->request("version")->toList();
|
||
|
}
|
||
|
|
||
|
return ($ident && isset($this->version[$ident])) ? $this->version[$ident] : $this->version;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Selects a virtual server by ID to allow further interaction.
|
||
|
*
|
||
|
* @param integer $sid
|
||
|
* @param boolean $virtual
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverSelect($sid, $virtual = null)
|
||
|
{
|
||
|
if($this->whoami !== null && $this->serverSelectedId() == $sid) return;
|
||
|
|
||
|
$virtual = ($virtual !== null) ? $virtual : $this->start_offline_virtual;
|
||
|
$getargs = func_get_args();
|
||
|
|
||
|
$this->execute("use", array("sid" => $sid, $virtual ? "-virtual" : null));
|
||
|
|
||
|
if($sid != 0 && $this->predefined_query_name !== null)
|
||
|
{
|
||
|
$this->execute("clientupdate", array("client_nickname" => (string) $this->predefined_query_name));
|
||
|
}
|
||
|
|
||
|
$this->whoamiReset();
|
||
|
|
||
|
$this->setStorage("_server_use", array(__FUNCTION__, $getargs));
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyServerselected", $this);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Alias for serverSelect().
|
||
|
*
|
||
|
* @param integer $sid
|
||
|
* @param boolean $virtual
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverSelectById($sid, $virtual = null)
|
||
|
{
|
||
|
$this->serverSelect($sid, $virtual);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Selects a virtual server by UDP port to allow further interaction.
|
||
|
*
|
||
|
* @param integer $port
|
||
|
* @param boolean $virtual
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverSelectByPort($port, $virtual = null)
|
||
|
{
|
||
|
if($this->whoami !== null && $this->serverSelectedPort() == $port) return;
|
||
|
|
||
|
$virtual = ($virtual !== null) ? $virtual : $this->start_offline_virtual;
|
||
|
$getargs = func_get_args();
|
||
|
|
||
|
$this->execute("use", array("port" => $port, $virtual ? "-virtual" : null));
|
||
|
|
||
|
if($port != 0 && $this->predefined_query_name !== null)
|
||
|
{
|
||
|
$this->execute("clientupdate", array("client_nickname" => (string) $this->predefined_query_name));
|
||
|
}
|
||
|
|
||
|
$this->whoamiReset();
|
||
|
|
||
|
$this->setStorage("_server_use", array(__FUNCTION__, $getargs));
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyServerselected", $this);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Deselects the active virtual server.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverDeselect()
|
||
|
{
|
||
|
$this->serverSelect(0);
|
||
|
|
||
|
$this->delStorage("_server_use");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the ID of a virtual server matching the given port.
|
||
|
*
|
||
|
* @param integer $port
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function serverIdGetByPort($port)
|
||
|
{
|
||
|
$sid = $this->execute("serveridgetbyport", array("virtualserver_port" => $port))->toList();
|
||
|
|
||
|
return $sid["server_id"];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the port of a virtual server matching the given ID.
|
||
|
*
|
||
|
* @param integer $sid
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function serverGetPortById($sid)
|
||
|
{
|
||
|
if(!array_key_exists((string) $sid, $this->serverList()))
|
||
|
{
|
||
|
throw new TeamSpeak3_Adapter_ServerQuery_Exception("invalid serverID", 0x400);
|
||
|
}
|
||
|
|
||
|
return $this->serverList[intval((string) $sid)]["virtualserver_port"];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the TeamSpeak3_Node_Server object matching the currently selected ID.
|
||
|
*
|
||
|
* @return TeamSpeak3_Node_Server
|
||
|
*/
|
||
|
public function serverGetSelected()
|
||
|
{
|
||
|
return $this->serverGetById($this->serverSelectedId());
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the TeamSpeak3_Node_Server object matching the given ID.
|
||
|
*
|
||
|
* @param integer $sid
|
||
|
* @return TeamSpeak3_Node_Server
|
||
|
*/
|
||
|
public function serverGetById($sid)
|
||
|
{
|
||
|
$this->serverSelectById($sid);
|
||
|
|
||
|
return new TeamSpeak3_Node_Server($this, array("virtualserver_id" => intval($sid)));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the TeamSpeak3_Node_Server object matching the given port number.
|
||
|
*
|
||
|
* @param integer $port
|
||
|
* @return TeamSpeak3_Node_Server
|
||
|
*/
|
||
|
public function serverGetByPort($port)
|
||
|
{
|
||
|
$this->serverSelectByPort($port);
|
||
|
|
||
|
return new TeamSpeak3_Node_Server($this, array("virtualserver_id" => $this->serverSelectedId()));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the first TeamSpeak3_Node_Server object matching the given name.
|
||
|
*
|
||
|
* @param string $name
|
||
|
* @throws TeamSpeak3_Adapter_ServerQuery_Exception
|
||
|
* @return TeamSpeak3_Node_Server
|
||
|
*/
|
||
|
public function serverGetByName($name)
|
||
|
{
|
||
|
foreach($this->serverList() as $server)
|
||
|
{
|
||
|
if($server["virtualserver_name"] == $name) return $server;
|
||
|
}
|
||
|
|
||
|
throw new TeamSpeak3_Adapter_ServerQuery_Exception("invalid serverID", 0x400);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the first TeamSpeak3_Node_Server object matching the given unique identifier.
|
||
|
*
|
||
|
* @param string $uid
|
||
|
* @throws TeamSpeak3_Adapter_ServerQuery_Exception
|
||
|
* @return TeamSpeak3_Node_Server
|
||
|
*/
|
||
|
public function serverGetByUid($uid)
|
||
|
{
|
||
|
foreach($this->serverList() as $server)
|
||
|
{
|
||
|
if($server["virtualserver_unique_identifier"] == $uid) return $server;
|
||
|
}
|
||
|
|
||
|
throw new TeamSpeak3_Adapter_ServerQuery_Exception("invalid serverID", 0x400);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the first TeamSpeak3_Node_Server object matching the given TSDNS hostname. Like the
|
||
|
* TeamSpeak 3 Client, this method will start looking for a TSDNS server on the second-level
|
||
|
* domain including a fallback to the third-level domain of the specified $tsdns parameter.
|
||
|
*
|
||
|
* @param string $tsdns
|
||
|
* @throws TeamSpeak3_Adapter_ServerQuery_Exception
|
||
|
* @return TeamSpeak3_Node_Server
|
||
|
*/
|
||
|
public function serverGetByTSDNS($tsdns)
|
||
|
{
|
||
|
$parts = TeamSpeak3_Helper_Uri::getFQDNParts($tsdns);
|
||
|
$query = TeamSpeak3_Helper_String::factory(array_shift($parts));
|
||
|
|
||
|
while($part = array_shift($parts))
|
||
|
{
|
||
|
$query->prepend($part);
|
||
|
|
||
|
try
|
||
|
{
|
||
|
$port = TeamSpeak3::factory("tsdns://" . $query . "/?timeout=3")->resolve($tsdns)->section(":", 1);
|
||
|
|
||
|
return $this->serverGetByPort($port == "" ? 9987 : $port);
|
||
|
}
|
||
|
catch(TeamSpeak3_Transport_Exception $e)
|
||
|
{
|
||
|
/* skip "Connection timed out" and "Connection refused" */
|
||
|
if($e->getCode() != 10060 && $e->getCode() != 10061) throw $e;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
throw new TeamSpeak3_Adapter_ServerQuery_Exception("invalid serverID", 0x400);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Creates a new virtual server using given properties and returns an assoc
|
||
|
* array containing the new ID and initial admin token.
|
||
|
*
|
||
|
* @param array $properties
|
||
|
* @return array
|
||
|
*/
|
||
|
public function serverCreate(array $properties = array())
|
||
|
{
|
||
|
$this->serverListReset();
|
||
|
|
||
|
$detail = $this->execute("servercreate", $properties)->toList();
|
||
|
$server = new TeamSpeak3_Node_Server($this, array("virtualserver_id" => intval($detail["sid"])));
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyServercreated", $this, $detail["sid"]);
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyTokencreated", $server, $detail["token"]);
|
||
|
|
||
|
return $detail;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Deletes the virtual server specified by ID.
|
||
|
*
|
||
|
* @param integer $sid
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverDelete($sid)
|
||
|
{
|
||
|
$this->serverListReset();
|
||
|
|
||
|
$this->execute("serverdelete", array("sid" => $sid));
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyServerdeleted", $this, $sid);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Starts the virtual server specified by ID.
|
||
|
*
|
||
|
* @param integer $sid
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverStart($sid)
|
||
|
{
|
||
|
if($sid == $this->serverSelectedId())
|
||
|
{
|
||
|
$this->serverDeselect();
|
||
|
}
|
||
|
|
||
|
$this->execute("serverstart", array("sid" => $sid));
|
||
|
$this->serverListReset();
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyServerstarted", $this, $sid);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Stops the virtual server specified by ID.
|
||
|
*
|
||
|
* @param integer $sid
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverStop($sid)
|
||
|
{
|
||
|
if($sid == $this->serverSelectedId())
|
||
|
{
|
||
|
$this->serverDeselect();
|
||
|
}
|
||
|
|
||
|
$this->execute("serverstop", array("sid" => $sid));
|
||
|
$this->serverListReset();
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyServerstopped", $this, $sid);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Stops the entire TeamSpeak 3 Server instance by shutting down the process.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverStopProcess()
|
||
|
{
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyServershutdown", $this);
|
||
|
|
||
|
$this->execute("serverprocessstop");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns an array filled with TeamSpeak3_Node_Server objects.
|
||
|
*
|
||
|
* @param array $filter
|
||
|
* @return array
|
||
|
*/
|
||
|
public function serverList(array $filter = array())
|
||
|
{
|
||
|
if($this->serverList === null)
|
||
|
{
|
||
|
$servers = $this->request("serverlist -uid")->toAssocArray("virtualserver_id");
|
||
|
|
||
|
$this->serverList = array();
|
||
|
|
||
|
foreach($servers as $sid => $server)
|
||
|
{
|
||
|
$this->serverList[$sid] = new TeamSpeak3_Node_Server($this, $server);
|
||
|
}
|
||
|
|
||
|
$this->resetNodeList();
|
||
|
}
|
||
|
|
||
|
return $this->filterList($this->serverList, $filter);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Resets the list of virtual servers.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverListReset()
|
||
|
{
|
||
|
$this->resetNodeList();
|
||
|
$this->serverList = null;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a list of IP addresses used by the server instance on multi-homed machines.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function bindingList($subsystem = "voice")
|
||
|
{
|
||
|
return $this->execute("bindinglist", array("subsystem" => $subsystem))->toArray();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a list of permissions available on the server instance.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function permissionList()
|
||
|
{
|
||
|
if($this->permissionList === null)
|
||
|
{
|
||
|
$this->fetchPermissionList();
|
||
|
}
|
||
|
|
||
|
foreach($this->permissionList as $permname => $permdata)
|
||
|
{
|
||
|
if(isset($permdata["permcatid"]) && $permdata["permgrant"])
|
||
|
{
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
$this->permissionList[$permname]["permcatid"] = $this->permissionGetCategoryById($permdata["permid"]);
|
||
|
$this->permissionList[$permname]["permgrant"] = $this->permissionGetGrantById($permdata["permid"]);
|
||
|
|
||
|
$grantsid = "i_needed_modify_power_" . substr($permname, 2);
|
||
|
|
||
|
if(!$permdata["permname"]->startsWith("i_needed_modify_power_") && !isset($this->permissionList[$grantsid]))
|
||
|
{
|
||
|
$this->permissionList[$grantsid]["permid"] = $this->permissionList[$permname]["permgrant"];
|
||
|
$this->permissionList[$grantsid]["permname"] = TeamSpeak3_Helper_String::factory($grantsid);
|
||
|
$this->permissionList[$grantsid]["permdesc"] = null;
|
||
|
$this->permissionList[$grantsid]["permcatid"] = 0xFF;
|
||
|
$this->permissionList[$grantsid]["permgrant"] = $this->permissionList[$permname]["permgrant"];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return $this->permissionList;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a list of permission categories available on the server instance.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function permissionCats()
|
||
|
{
|
||
|
if($this->permissionCats === null)
|
||
|
{
|
||
|
$this->fetchPermissionCats();
|
||
|
}
|
||
|
|
||
|
return $this->permissionCats;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a list of permission category endings available on the server instance.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function permissionEnds()
|
||
|
{
|
||
|
if($this->permissionEnds === null)
|
||
|
{
|
||
|
$this->fetchPermissionList();
|
||
|
}
|
||
|
|
||
|
return $this->permissionCats;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns an array filled with all permission categories known to the server including
|
||
|
* their ID, name and parent.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function permissionTree()
|
||
|
{
|
||
|
$permtree = array();
|
||
|
|
||
|
foreach($this->permissionCats() as $key => $val)
|
||
|
{
|
||
|
$permtree[$val]["permcatid"] = $val;
|
||
|
$permtree[$val]["permcathex"] = "0x" . dechex($val);
|
||
|
$permtree[$val]["permcatname"] = TeamSpeak3_Helper_String::factory(TeamSpeak3_Helper_Convert::permissionCategory($val));
|
||
|
$permtree[$val]["permcatparent"] = $permtree[$val]["permcathex"]{3} == 0 ? 0 : hexdec($permtree[$val]["permcathex"]{2} . 0);
|
||
|
$permtree[$val]["permcatchilren"] = 0;
|
||
|
$permtree[$val]["permcatcount"] = 0;
|
||
|
|
||
|
if(isset($permtree[$permtree[$val]["permcatparent"]]))
|
||
|
{
|
||
|
$permtree[$permtree[$val]["permcatparent"]]["permcatchilren"]++;
|
||
|
}
|
||
|
|
||
|
if($permtree[$val]["permcatname"]->contains("/"))
|
||
|
{
|
||
|
$permtree[$val]["permcatname"] = $permtree[$val]["permcatname"]->section("/", 1)->trim();
|
||
|
}
|
||
|
|
||
|
foreach($this->permissionList() as $permission)
|
||
|
{
|
||
|
if($permission["permid"]["permcatid"] == $val)
|
||
|
{
|
||
|
$permtree[$val]["permcatcount"]++;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return $permtree;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the IDs of all clients, channels or groups using the permission with the
|
||
|
* specified ID.
|
||
|
*
|
||
|
* @param integer $permid
|
||
|
* @return array
|
||
|
*/
|
||
|
public function permissionFind($permid)
|
||
|
{
|
||
|
if(!is_array($permid))
|
||
|
{
|
||
|
$permident = (is_numeric($permid)) ? "permid" : "permsid";
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$permident = (is_numeric(current($permid))) ? "permid" : "permsid";
|
||
|
}
|
||
|
|
||
|
return $this->execute("permfind", array($permident => $permid))->toArray();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the ID of the permission matching the given name.
|
||
|
*
|
||
|
* @param string $name
|
||
|
* @throws TeamSpeak3_Adapter_ServerQuery_Exception
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function permissionGetIdByName($name)
|
||
|
{
|
||
|
if(!array_key_exists((string) $name, $this->permissionList()))
|
||
|
{
|
||
|
throw new TeamSpeak3_Adapter_ServerQuery_Exception("invalid permission ID", 0xA02);
|
||
|
}
|
||
|
|
||
|
return $this->permissionList[(string) $name]["permid"];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the name of the permission matching the given ID.
|
||
|
*
|
||
|
* @param integer $permid
|
||
|
* @throws TeamSpeak3_Adapter_ServerQuery_Exception
|
||
|
* @return TeamSpeak3_Helper_String
|
||
|
*/
|
||
|
public function permissionGetNameById($permid)
|
||
|
{
|
||
|
foreach($this->permissionList() as $name => $perm)
|
||
|
{
|
||
|
if($perm["permid"] == $permid) return new TeamSpeak3_Helper_String($name);
|
||
|
}
|
||
|
|
||
|
throw new TeamSpeak3_Adapter_ServerQuery_Exception("invalid permission ID", 0xA02);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the internal category of the permission matching the given ID.
|
||
|
*
|
||
|
* All pre-3.0.7 permission IDs are are 2 bytes wide. The first byte identifies the category while
|
||
|
* the second byte is the permission count within that group.
|
||
|
*
|
||
|
* @param integer $permid
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function permissionGetCategoryById($permid)
|
||
|
{
|
||
|
if(!is_numeric($permid))
|
||
|
{
|
||
|
$permid = $this->permissionGetIdByName($permid);
|
||
|
}
|
||
|
|
||
|
if($permid < 0x1000)
|
||
|
{
|
||
|
if($this->permissionEnds === null)
|
||
|
{
|
||
|
$this->fetchPermissionList();
|
||
|
}
|
||
|
|
||
|
if($this->permissionCats === null)
|
||
|
{
|
||
|
$this->fetchPermissionCats();
|
||
|
}
|
||
|
|
||
|
$catids = array_values($this->permissionCats());
|
||
|
|
||
|
foreach($this->permissionEnds as $key => $val)
|
||
|
{
|
||
|
if($val >= $permid && isset($catids[$key]))
|
||
|
{
|
||
|
return $catids[$key];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
return (int) $permid >> 8;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the internal ID of the i_needed_modify_power_* or grant permission.
|
||
|
*
|
||
|
* Every permission has an associated i_needed_modify_power_* permission, for example b_client_ban_create has an
|
||
|
* associated permission called i_needed_modify_power_client_ban_create.
|
||
|
*
|
||
|
* @param integer $permid
|
||
|
* @return integer
|
||
|
*/
|
||
|
public function permissionGetGrantById($permid)
|
||
|
{
|
||
|
if(!is_numeric($permid))
|
||
|
{
|
||
|
$permid = $this->permissionGetIdByName($permid);
|
||
|
}
|
||
|
|
||
|
if($permid < 0x1000)
|
||
|
{
|
||
|
return (int) $permid+0x8000;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
return (int) bindec(substr(decbin($permid), -8))+0xFF00;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Adds a set of specified permissions to all regular server groups on all virtual servers. The target groups will
|
||
|
* be identified by the value of their i_group_auto_update_type permission specified with $sgtype.
|
||
|
*
|
||
|
* @param integer $sgtype
|
||
|
* @param integer $permid
|
||
|
* @param integer $permvalue
|
||
|
* @param integer $permnegated
|
||
|
* @param integer $permskip
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverGroupPermAutoAssign($sgtype, $permid, $permvalue, $permnegated = FALSE, $permskip = FALSE)
|
||
|
{
|
||
|
if(!is_array($permid))
|
||
|
{
|
||
|
$permident = (is_numeric($permid)) ? "permid" : "permsid";
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$permident = (is_numeric(current($permid))) ? "permid" : "permsid";
|
||
|
}
|
||
|
|
||
|
$this->execute("servergroupautoaddperm", array("sgtype" => $sgtype, $permident => $permid, "permvalue" => $permvalue, "permnegated" => $permnegated, "permskip" => $permskip));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Removes a set of specified permissions from all regular server groups on all virtual servers. The target groups
|
||
|
* will be identified by the value of their i_group_auto_update_type permission specified with $sgtype.
|
||
|
*
|
||
|
* @param integer $sgtype
|
||
|
* @param integer $permid
|
||
|
* @return void
|
||
|
*/
|
||
|
public function serverGroupPermAutoRemove($sgtype, $permid)
|
||
|
{
|
||
|
if(!is_array($permid))
|
||
|
{
|
||
|
$permident = (is_numeric($permid)) ? "permid" : "permsid";
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$permident = (is_numeric(current($permid))) ? "permid" : "permsid";
|
||
|
}
|
||
|
|
||
|
$this->execute("servergroupautodelperm", array("sgtype" => $sgtype, $permident => $permid));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns an array containing the value of a specified permission for your own client.
|
||
|
*
|
||
|
* @param integer $permid
|
||
|
* @return array
|
||
|
*/
|
||
|
public function selfPermCheck($permid)
|
||
|
{
|
||
|
if(!is_array($permid))
|
||
|
{
|
||
|
$permident = (is_numeric($permid)) ? "permid" : "permsid";
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$permident = (is_numeric(current($permid))) ? "permid" : "permsid";
|
||
|
}
|
||
|
|
||
|
return $this->execute("permget", array($permident => $permid))->toAssocArray("permsid");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Changes the server instance configuration using given properties.
|
||
|
*
|
||
|
* @param array $properties
|
||
|
* @return void
|
||
|
*/
|
||
|
public function modify(array $properties)
|
||
|
{
|
||
|
$this->execute("instanceedit", $properties);
|
||
|
$this->resetNodeInfo();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sends a text message to all clients on all virtual servers in the TeamSpeak 3 Server instance.
|
||
|
*
|
||
|
* @param string $msg
|
||
|
* @return void
|
||
|
*/
|
||
|
public function message($msg)
|
||
|
{
|
||
|
$this->execute("gm", array("msg" => $msg));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Displays a specified number of entries (1-100) from the servers log.
|
||
|
*
|
||
|
* @param integer $lines
|
||
|
* @param integer $begin_pos
|
||
|
* @param boolean $reverse
|
||
|
* @param boolean $instance
|
||
|
* @return array
|
||
|
*/
|
||
|
public function logView($lines = 30, $begin_pos = null, $reverse = null, $instance = TRUE)
|
||
|
{
|
||
|
return $this->execute("logview", array("lines" => $lines, "begin_pos" => $begin_pos, "instance" => $instance, "reverse" => $reverse))->toArray();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Writes a custom entry into the server instance log.
|
||
|
*
|
||
|
* @param string $logmsg
|
||
|
* @param integer $loglevel
|
||
|
* @return void
|
||
|
*/
|
||
|
public function logAdd($logmsg, $loglevel = TeamSpeak3::LOGLEVEL_INFO)
|
||
|
{
|
||
|
$sid = $this->serverSelectedId();
|
||
|
|
||
|
$this->serverDeselect();
|
||
|
$this->execute("logadd", array("logmsg" => $logmsg, "loglevel" => $loglevel));
|
||
|
$this->serverSelect($sid);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Authenticates with the TeamSpeak 3 Server instance using given ServerQuery login credentials.
|
||
|
*
|
||
|
* @param string $username
|
||
|
* @param string $password
|
||
|
* @return void
|
||
|
*/
|
||
|
public function login($username, $password)
|
||
|
{
|
||
|
$this->execute("login", array("client_login_name" => $username, "client_login_password" => $password));
|
||
|
$this->whoamiReset();
|
||
|
|
||
|
$crypt = new TeamSpeak3_Helper_Crypt($username);
|
||
|
|
||
|
$this->setStorage("_login_user", $username);
|
||
|
$this->setStorage("_login_pass", $crypt->encrypt($password));
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyLogin", $this);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Deselects the active virtual server and logs out from the server instance.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function logout()
|
||
|
{
|
||
|
$this->request("logout");
|
||
|
$this->whoamiReset();
|
||
|
|
||
|
$this->delStorage("_login_user");
|
||
|
$this->delStorage("_login_pass");
|
||
|
|
||
|
TeamSpeak3_Helper_Signal::getInstance()->emit("notifyLogout", $this);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns information about your current ServerQuery connection.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function whoami()
|
||
|
{
|
||
|
if($this->whoami === null)
|
||
|
{
|
||
|
$this->whoami = $this->request("whoami")->toList();
|
||
|
}
|
||
|
|
||
|
return $this->whoami;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a single value from the current ServerQuery connection info.
|
||
|
*
|
||
|
* @param string $ident
|
||
|
* @param mixed $default
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function whoamiGet($ident, $default = null)
|
||
|
{
|
||
|
if(array_key_exists($ident, $this->whoami()))
|
||
|
{
|
||
|
return $this->whoami[$ident];
|
||
|
}
|
||
|
|
||
|
return $default;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets a single value in the current ServerQuery connection info.
|
||
|
*
|
||
|
* @param string $ident
|
||
|
* @param mixed $value
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public function whoamiSet($ident, $value = null)
|
||
|
{
|
||
|
$this->whoami();
|
||
|
|
||
|
$this->whoami[$ident] = (is_numeric($value)) ? (int) $value : TeamSpeak3_Helper_String::factory($value);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Resets the current ServerQuery connection info.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function whoamiReset()
|
||
|
{
|
||
|
$this->whoami = null;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the hostname or IPv4 address the adapter is connected to.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getAdapterHost()
|
||
|
{
|
||
|
return $this->getParent()->getTransportHost();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the network port the adapter is connected to.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getAdapterPort()
|
||
|
{
|
||
|
return $this->getParent()->getTransportPort();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected function fetchNodeList()
|
||
|
{
|
||
|
$servers = $this->serverList();
|
||
|
|
||
|
foreach($servers as $server)
|
||
|
{
|
||
|
$this->nodeList[] = $server;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected function fetchNodeInfo()
|
||
|
{
|
||
|
$info1 = $this->request("hostinfo")->toList();
|
||
|
$info2 = $this->request("instanceinfo")->toList();
|
||
|
|
||
|
$this->nodeInfo = array_merge($this->nodeInfo, $info1, $info2);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected function fetchPermissionList()
|
||
|
{
|
||
|
$reply = $this->request("permissionlist -new")->toArray();
|
||
|
$start = 1;
|
||
|
|
||
|
$this->permissionEnds = array();
|
||
|
$this->permissionList = array();
|
||
|
|
||
|
foreach($reply as $line)
|
||
|
{
|
||
|
if(array_key_exists("group_id_end", $line))
|
||
|
{
|
||
|
$this->permissionEnds[] = $line["group_id_end"];
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$this->permissionList[$line["permname"]->toString()] = array_merge(array("permid" => $start++), $line);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
protected function fetchPermissionCats()
|
||
|
{
|
||
|
$permcats = array();
|
||
|
$reflects = new ReflectionClass("TeamSpeak3");
|
||
|
|
||
|
foreach($reflects->getConstants() as $key => $val)
|
||
|
{
|
||
|
if(!TeamSpeak3_Helper_String::factory($key)->startsWith("PERM_CAT") || $val == 0xFF)
|
||
|
{
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
$permcats[$key] = $val;
|
||
|
}
|
||
|
|
||
|
$this->permissionCats = $permcats;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets a pre-defined nickname for ServerQuery clients which will be used automatically
|
||
|
* after selecting a virtual server.
|
||
|
*
|
||
|
* @param string $name
|
||
|
* @return void
|
||
|
*/
|
||
|
public function setPredefinedQueryName($name = null)
|
||
|
{
|
||
|
$this->setStorage("_query_nick", $name);
|
||
|
|
||
|
$this->predefined_query_name = $name;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the pre-defined nickname for ServerQuery clients which will be used automatically
|
||
|
* after selecting a virtual server.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getPredefinedQueryName()
|
||
|
{
|
||
|
return $this->predefined_query_name;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the option to decide whether ServerQuery clients should be excluded from node
|
||
|
* lists or not.
|
||
|
*
|
||
|
* @param boolean $exclude
|
||
|
* @return void
|
||
|
*/
|
||
|
public function setExcludeQueryClients($exclude = FALSE)
|
||
|
{
|
||
|
$this->setStorage("_query_hide", $exclude);
|
||
|
|
||
|
$this->exclude_query_clients = $exclude;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the option to decide whether ServerQuery clients should be excluded from node
|
||
|
* lists or not.
|
||
|
*
|
||
|
* @return boolean
|
||
|
*/
|
||
|
public function getExcludeQueryClients()
|
||
|
{
|
||
|
return $this->exclude_query_clients;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the option to decide whether offline servers will be started in virtual mode
|
||
|
* by default or not.
|
||
|
*
|
||
|
* @param boolean $virtual
|
||
|
* @return void
|
||
|
*/
|
||
|
public function setUseOfflineAsVirtual($virtual = FALSE)
|
||
|
{
|
||
|
$this->setStorage("_do_virtual", $virtual);
|
||
|
|
||
|
$this->start_offline_virtual = $virtual;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the option to decide whether offline servers will be started in virtual mode
|
||
|
* by default or not.
|
||
|
*
|
||
|
* @return boolean
|
||
|
*/
|
||
|
public function getUseOfflineAsVirtual()
|
||
|
{
|
||
|
return $this->start_offline_virtual;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the option to decide whether clients should be sorted before sub-channels to support
|
||
|
* the new TeamSpeak 3 Client display mode or not.
|
||
|
*
|
||
|
* @param boolean $first
|
||
|
* @return void
|
||
|
*/
|
||
|
public function setLoadClientlistFirst($first = FALSE)
|
||
|
{
|
||
|
$this->setStorage("_client_top", $first);
|
||
|
|
||
|
$this->sort_clients_channels = $first;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the option to decide whether offline servers will be started in virtual mode
|
||
|
* by default or not.
|
||
|
*
|
||
|
* @return boolean
|
||
|
*/
|
||
|
public function getLoadClientlistFirst()
|
||
|
{
|
||
|
return $this->sort_clients_channels;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the underlying TeamSpeak3_Adapter_ServerQuery object.
|
||
|
*
|
||
|
* @return TeamSpeak3_Adapter_ServerQuery
|
||
|
*/
|
||
|
public function getAdapter()
|
||
|
{
|
||
|
return $this->getParent();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a unique identifier for the node which can be used as a HTML property.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getUniqueId()
|
||
|
{
|
||
|
return "ts3_h";
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the name of a possible icon to display the node object.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getIcon()
|
||
|
{
|
||
|
return "host";
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a symbol representing the node.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getSymbol()
|
||
|
{
|
||
|
return "+";
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Re-authenticates with the TeamSpeak 3 Server instance using given ServerQuery login
|
||
|
* credentials and re-selects a previously selected virtual server.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function __wakeup()
|
||
|
{
|
||
|
$username = $this->getStorage("_login_user");
|
||
|
$password = $this->getStorage("_login_pass");
|
||
|
|
||
|
if($username && $password)
|
||
|
{
|
||
|
$crypt = new TeamSpeak3_Helper_Crypt($username);
|
||
|
|
||
|
$this->login($username, $crypt->decrypt($password));
|
||
|
}
|
||
|
|
||
|
$this->predefined_query_name = $this->getStorage("_query_nick");
|
||
|
$this->exclude_query_clients = $this->getStorage("_query_hide", FALSE);
|
||
|
$this->start_offline_virtual = $this->getStorage("_do_virtual", FALSE);
|
||
|
$this->sort_clients_channels = $this->getStorage("_client_top", FALSE);
|
||
|
|
||
|
if($server = $this->getStorage("_server_use"))
|
||
|
{
|
||
|
$func = array_shift($server);
|
||
|
$args = array_shift($server);
|
||
|
|
||
|
try
|
||
|
{
|
||
|
call_user_func_array(array($this, $func), $args);
|
||
|
}
|
||
|
catch(Exception $e)
|
||
|
{
|
||
|
$class = get_class($e);
|
||
|
|
||
|
throw new $class($e->getMessage(), $e->getCode());
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns a string representation of this node.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function __toString()
|
||
|
{
|
||
|
return (string) $this->getAdapterHost();
|
||
|
}
|
||
|
}
|
||
|
|