No changes
This commit is contained in:
parent
8680a02b13
commit
b6b398f5bf
17374 changed files with 2475441 additions and 0 deletions
270
ControlPanel/modules/mysql/mysql_database.php
Normal file
270
ControlPanel/modules/mysql/mysql_database.php
Normal file
|
|
@ -0,0 +1,270 @@
|
|||
<?php
|
||||
/*
|
||||
*
|
||||
* OGP - Open Game Panel
|
||||
* Copyright (C) 2008 - 2018 The OGP Development Team
|
||||
*
|
||||
* http://www.opengamepanel.org/
|
||||
*
|
||||
* 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 2
|
||||
* of the License, or 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, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
*
|
||||
*/
|
||||
|
||||
class MySQLModuleDatabase extends OGPDatabaseMySQL
|
||||
{
|
||||
protected $link;
|
||||
protected $table_prefix;
|
||||
|
||||
public function __construct() {
|
||||
|
||||
}
|
||||
|
||||
public function __destruct() {
|
||||
parent::__destruct();
|
||||
}
|
||||
|
||||
public function connect($db_host, $db_user, $db_pass, $db_name, $table_prefix = NULL) {
|
||||
if ( !extension_loaded("mysql") )
|
||||
return -99;
|
||||
|
||||
$this->table_prefix = $table_prefix;
|
||||
|
||||
/// \todo We might want to do other checks here as well?
|
||||
if ( $db_host === NULL )
|
||||
return -1;
|
||||
|
||||
$this->link = mysql_connect($db_host, $db_user, $db_pass);
|
||||
|
||||
if ( $this->link === FALSE )
|
||||
return -11;
|
||||
|
||||
if ( mysql_select_db($db_name,$this->link) === FALSE )
|
||||
return -12;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
private function listQuery($query) {
|
||||
if ( !$this->link ) return FALSE;
|
||||
|
||||
++$this->queries_;
|
||||
$result = mysql_query($query, $this->link);
|
||||
|
||||
if ( mysql_errno($this->link) > 0 )
|
||||
print mysql_error($this->link);
|
||||
|
||||
if ( $result === FALSE )
|
||||
return FALSE;
|
||||
|
||||
if ( mysql_num_rows($result) == 0 )
|
||||
return FALSE;
|
||||
|
||||
$results = array();
|
||||
|
||||
while ( $row = mysql_fetch_assoc( $result ) )
|
||||
array_push($results,$row);
|
||||
|
||||
return $results;
|
||||
}
|
||||
|
||||
public function addMysqlServer($remote_server_id,$mysql_name,$mysql_ip,$mysql_port,$mysql_root_passwd,$privilegies_str)
|
||||
{
|
||||
if ( empty($mysql_ip) )
|
||||
return false;
|
||||
else if ( empty($mysql_port) )
|
||||
return false;
|
||||
else if ( empty($mysql_root_passwd) )
|
||||
return false;
|
||||
|
||||
$query = sprintf("INSERT INTO `%smysql_servers` (`remote_server_id`,`mysql_name`,`mysql_ip`,`mysql_port`,`mysql_root_passwd`,`privilegies_str`)
|
||||
VALUES('%s','%s','%s','%s','%s','%s');",
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($remote_server_id,$this->link),
|
||||
mysql_real_escape_string($mysql_name,$this->link),
|
||||
mysql_real_escape_string($mysql_ip,$this->link),
|
||||
mysql_real_escape_string($mysql_port,$this->link),
|
||||
mysql_real_escape_string($mysql_root_passwd,$this->link),
|
||||
mysql_real_escape_string($privilegies_str,$this->link));
|
||||
++$this->queries_;
|
||||
mysql_query($query,$this->link);
|
||||
|
||||
if( mysql_errno($this->link) != 0 )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return mysql_insert_id($this->link);
|
||||
}
|
||||
|
||||
public function editMysqlServer($mysql_server_id,$remote_server_id,$mysql_name,$mysql_ip,$mysql_port,$mysql_root_passwd,$privilegies_str)
|
||||
{
|
||||
$query = sprintf("UPDATE `%smysql_servers` SET `remote_server_id` = '%s',
|
||||
`mysql_name` = '%s', `mysql_ip` = '%s', `mysql_port` = '%s',
|
||||
`mysql_root_passwd` = '%s', `privilegies_str` = '%s'
|
||||
WHERE `mysql_server_id` = %s;",
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($remote_server_id,$this->link),
|
||||
mysql_real_escape_string($mysql_name,$this->link),
|
||||
mysql_real_escape_string($mysql_ip,$this->link),
|
||||
mysql_real_escape_string($mysql_port,$this->link),
|
||||
mysql_real_escape_string($mysql_root_passwd,$this->link),
|
||||
mysql_real_escape_string($privilegies_str,$this->link),
|
||||
mysql_real_escape_string($mysql_server_id,$this->link));
|
||||
|
||||
++$this->queries_;
|
||||
if ( mysql_query($query) === FALSE )
|
||||
return FALSE;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
public function getMysqlServers(){
|
||||
$query = sprintf("SELECT * FROM %smysql_servers;",
|
||||
$this->table_prefix);
|
||||
return $this->listQuery($query);
|
||||
}
|
||||
|
||||
public function getMysqlServer($id) {
|
||||
if ( !$this->link ) return FALSE;
|
||||
|
||||
$query = sprintf("SELECT * FROM `%smysql_servers` WHERE `mysql_server_id` = %d",
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($id,$this->link));
|
||||
|
||||
++$this->queries_;
|
||||
$result = mysql_query($query, $this->link);
|
||||
|
||||
// If there are no servers then we can stop here.
|
||||
if ( mysql_num_rows($result) != 1 )
|
||||
return FALSE;
|
||||
|
||||
return mysql_fetch_assoc( $result );
|
||||
}
|
||||
|
||||
public function removeMysqlServer($mysql_server_id){
|
||||
$mysql_server_id = mysql_real_escape_string($mysql_server_id, $this->link);
|
||||
|
||||
$return = TRUE;
|
||||
|
||||
$queries = array("DELETE FROM `%smysql_databases` WHERE mysql_server_id = %d;",
|
||||
"DELETE FROM `%smysql_servers` WHERE mysql_server_id = %d;");
|
||||
|
||||
foreach ( $queries as $query )
|
||||
{
|
||||
$query = sprintf($query,$this->table_prefix,$mysql_server_id);
|
||||
++$this->queries_;
|
||||
$result = mysql_query($query,$this->link);
|
||||
$return = ($result === FALSE) ? FALSE : $return;
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
|
||||
public function getMysqlServerDBs($mysql_server_id){
|
||||
$query = sprintf("SELECT * FROM `%smysql_databases` WHERE mysql_server_id = %d;",
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($mysql_server_id,$this->link));
|
||||
return $this->listQuery($query);
|
||||
}
|
||||
|
||||
public function addMysqlServerDB($mysql_server_id, $home_id, $db_user, $db_passwd, $db_name, $enabled){
|
||||
$query = sprintf("INSERT INTO `%smysql_databases` (`mysql_server_id`, `home_id`, `db_user`, `db_passwd`, `db_name`, `enabled`)
|
||||
VALUES('%d','%d','%s','%s','%s','%d');",
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($mysql_server_id,$this->link),
|
||||
mysql_real_escape_string($home_id,$this->link),
|
||||
mysql_real_escape_string($db_user,$this->link),
|
||||
mysql_real_escape_string($db_passwd,$this->link),
|
||||
mysql_real_escape_string($db_name,$this->link),
|
||||
mysql_real_escape_string($enabled,$this->link));
|
||||
++$this->queries_;
|
||||
mysql_query($query,$this->link);
|
||||
|
||||
if( mysql_errno($this->link) != 0 )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return mysql_insert_id($this->link);
|
||||
}
|
||||
|
||||
public function getMysqlDBbyId($db_id){
|
||||
$query = sprintf('SELECT * FROM `%1$smysql_databases` NATURAL JOIN `%1$smysql_servers` WHERE db_id = %2$d;',
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($db_id,$this->link));
|
||||
$db_info = $this->listQuery($query);
|
||||
return $db_info[0];
|
||||
}
|
||||
|
||||
public function getMysqlDBsbyHomeId($home_id){
|
||||
$query = sprintf('SELECT * FROM `%1$smysql_databases` WHERE enabled = 1 AND home_id = %2$d;',
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($home_id,$this->link));
|
||||
return $this->listQuery($query);
|
||||
}
|
||||
|
||||
public function getMysqlHomeDBbyId($home_id,$db_id){
|
||||
$query = sprintf('SELECT * FROM `%1$smysql_databases` NATURAL JOIN `%1$smysql_servers` WHERE home_id = %2$d AND db_id = %3$d;',
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($home_id,$this->link),
|
||||
mysql_real_escape_string($db_id,$this->link));
|
||||
$db_info = $this->listQuery($query);
|
||||
return $db_info[0];
|
||||
}
|
||||
|
||||
public function editMysqlServerDB($db_id, $home_id, $db_user, $db_passwd, $db_name, $enabled)
|
||||
{
|
||||
$query = sprintf("UPDATE `%smysql_databases`
|
||||
SET `home_id`='%d', `db_user`='%s', `db_passwd`='%s', `db_name`='%s',`enabled`='%d'
|
||||
WHERE `db_id` = '%d';",
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($home_id, $this->link),
|
||||
mysql_real_escape_string($db_user, $this->link),
|
||||
mysql_real_escape_string($db_passwd, $this->link),
|
||||
mysql_real_escape_string($db_name, $this->link),
|
||||
mysql_real_escape_string($enabled, $this->link),
|
||||
mysql_real_escape_string($db_id, $this->link) );
|
||||
|
||||
++$this->queries_;
|
||||
mysql_query($query,$this->link);
|
||||
|
||||
if( mysql_errno($this->link) != 0 )
|
||||
return FALSE;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public function removeMysqlServerDB($db_id)
|
||||
{
|
||||
$query = sprintf("DELETE FROM `%smysql_databases`
|
||||
WHERE `db_id` = '%d'",
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($db_id, $this->link));
|
||||
|
||||
++$this->queries_;
|
||||
if ( mysql_query($query) === FALSE )
|
||||
return FALSE;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
public function getGameHomesByRemoteServerId($remote_server_id){
|
||||
$query = sprintf('SELECT %1$sserver_homes.*,%1$sremote_servers.*, %1$sconfig_homes.game_name
|
||||
FROM `%1$sserver_homes` NATURAL JOIN `%1$sconfig_homes` NATURAL JOIN `%1$sremote_servers` WHERE remote_server_id=%2$s;',
|
||||
$this->table_prefix,
|
||||
mysql_real_escape_string($remote_server_id,$this->link));
|
||||
return $this->listQuery($query);
|
||||
}
|
||||
}
|
||||
?>
|
||||
Loading…
Add table
Add a link
Reference in a new issue