servers.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. <script type="text/javascript">
  2. $(document).ready(function(){
  3. $( "#privilegies" ).change(function() {
  4. this.form.submit();
  5. });
  6. $( "#remote_server_id" ).change(function() {
  7. if( $(this).val() != "0" )
  8. {
  9. $( "input#mysql_ip" ).val('localhost').prop('readonly', true);
  10. }
  11. else
  12. {
  13. $( "input#mysql_ip" ).prop('readonly', false);
  14. }
  15. });
  16. });
  17. </script>
  18. <?php
  19. /*
  20. *
  21. * OGP - Open Game Panel
  22. * Copyright (C) 2008 - 2018 The OGP Development Team
  23. *
  24. * http://www.opengamepanel.org/
  25. *
  26. * This program is free software; you can redistribute it and/or
  27. * modify it under the terms of the GNU General Public License
  28. * as published by the Free Software Foundation; either version 2
  29. * of the License, or any later version.
  30. *
  31. * This program is distributed in the hope that it will be useful,
  32. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  33. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  34. * GNU General Public License for more details.
  35. *
  36. * You should have received a copy of the GNU General Public License
  37. * along with this program; if not, write to the Free Software
  38. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  39. *
  40. */
  41. require_once('includes/lib_remote.php');
  42. if ( function_exists('mysqli_connect') )
  43. require_once("modules/mysql/mysqli_database.php");
  44. else
  45. require_once("modules/mysql/mysql_database.php");
  46. function exec_ogp_module() {
  47. $modDb = new MySQLModuleDatabase();
  48. require("includes/config.inc.php");
  49. $modDb->connect($db_host,$db_user,$db_pass,$db_name,$table_prefix);
  50. global $view,$db;
  51. echo "<h2>".get_lang('add_new_mysql_host')."</h2>";
  52. if(isset($_GET['add_mysql_server']))
  53. {
  54. foreach ($_GET as $name => $value)
  55. {
  56. $get[$name] = trim($value);
  57. }
  58. if ( empty($get['mysql_ip']) ){
  59. print_failure(get_lang('enter_mysql_ip'));
  60. }
  61. if ( !isPortValid($get['mysql_port']) ){
  62. print_failure(get_lang('enter_valid_port'));
  63. }
  64. if ( empty($get['mysql_root_passwd']) ){
  65. print_failure(get_lang('enter_mysql_root_password'));
  66. }
  67. if ( empty($get['mysql_name']) ){
  68. print_failure(get_lang('enter_mysql_name'));
  69. }
  70. if ($get['privilegies'] == "custom")
  71. {
  72. $priv = $get;
  73. $privilegies_str = "";
  74. unset($priv['m'],$priv['p'],$priv['remote_server_id'],$priv['mysql_ip'],$priv['mysql_port'],$priv['mysql_root_passwd'],$priv['mysql_name'],$priv['privilegies'],$priv['add_mysql_server']);
  75. foreach($priv as $name => $value)
  76. {
  77. $privilegies_str .= str_replace("_"," ",$name).", ";
  78. }
  79. }
  80. else
  81. {
  82. $privilegies_str = "ALL";
  83. }
  84. $privilegies_str = rtrim( $privilegies_str , ', ' );
  85. $mysql_server_id = $modDb->addMysqlServer($get['remote_server_id'],$get['mysql_name'],$get['mysql_ip'],$get['mysql_port'],$get['mysql_root_passwd'],$privilegies_str);
  86. if ( !$mysql_server_id )
  87. {
  88. print_failure(get_lang('could_not_add_mysql_server'));
  89. $view->refresh("?m=mysql&p=mysql_admin");
  90. return;
  91. }
  92. print_success(get_lang('server_added'));
  93. $view->refresh("?m=mysql&p=mysql_admin");
  94. return;
  95. }
  96. echo "<p>".get_lang('note_mysql_host')."</p>";
  97. $servers = $db->getRemoteServers();
  98. $conn_method[0] = get_lang('direct_connection');
  99. foreach ( $servers as $server_row )
  100. {
  101. $id = $server_row['remote_server_id'];
  102. $name = get_lang_f('connection_through_remote_server_named',$server_row['remote_server_name']);
  103. $conn_method[$id] = $name;
  104. }
  105. require_once("includes/form_table_class.php");
  106. $ft = new FormTable();
  107. $ft->start_form("", "GET");
  108. $ft->start_table();
  109. $ft->add_field_hidden('m', 'mysql');
  110. $ft->add_field_hidden('p', 'mysql_admin');
  111. $ft->add_custom_field('connection_method',
  112. create_drop_box_from_array($conn_method,"remote_server_id","0",false));
  113. $ft->add_field('string','mysql_name',isset($_GET['mysql_name']) ? $_GET['mysql_name'] : "");
  114. $ft->add_field('string','mysql_ip',isset($_GET['mysql_ip']) ? $_GET['mysql_ip'] : "localhost");
  115. $ft->add_field('string','mysql_port',isset($_GET['mysql_port']) ? $_GET['mysql_port'] : "3306");
  116. $ft->add_field('string','mysql_root_passwd',isset($_GET['mysql_root_passwd']) ? $_GET['mysql_root_passwd'] : "");
  117. $ft->add_custom_field('privilegies',
  118. create_drop_box_from_array(array('all' => get_lang('all'), 'custom' => get_lang('custom')),"privilegies",isset($_GET['privilegies']) ? $_GET['privilegies'] : "all",false));
  119. if(isset($_GET['privilegies']) and $_GET['privilegies'] == "custom")
  120. {
  121. $ft->add_custom_field('sql_alter','<input type="checkbox" name="ALTER" checked="checked" >');
  122. $ft->add_custom_field('sql_create','<input type="checkbox" name="CREATE" checked="checked" >');
  123. $ft->add_custom_field('sql_create_temporary_tables','<input type="checkbox" name="CREATE TEMPORARY TABLES" checked="checked" >');
  124. $ft->add_custom_field('sql_delete','<input type="checkbox" name="DELETE" checked="checked" >');
  125. $ft->add_custom_field('sql_drop','<input type="checkbox" name="DROP" checked="checked" >');
  126. $ft->add_custom_field('sql_index','<input type="checkbox" name="INDEX" checked="checked" >');
  127. $ft->add_custom_field('sql_insert','<input type="checkbox" name="INSERT" checked="checked" >');
  128. $ft->add_custom_field('sql_lock_tables','<input type="checkbox" name="LOCK TABLES" checked="checked" >');
  129. $ft->add_custom_field('sql_select','<input type="checkbox" name="SELECT" checked="checked" >');
  130. $ft->add_custom_field('sql_update','<input type="checkbox" name="UPDATE" checked="checked" >');
  131. $ft->add_custom_field('sql_grant_option','<input type="checkbox" name="GRANT OPTION" checked="checked" >');
  132. }
  133. $ft->end_table();
  134. $ft->add_button("submit","add_mysql_server",get_lang('add_mysql_server'));
  135. $ft->end_form();
  136. $mysql_servers = $modDb->getMysqlServers();
  137. if ( $mysql_servers === FALSE )
  138. return;
  139. $tr = 0;
  140. ?><table id="servermonitor" class="tablesorter remote">
  141. <thead>
  142. <tr>
  143. <th colspan="4" class="sorter-false"><?php print_lang('configured_mysql_hosts'); ?></th>
  144. </tr>
  145. </thead>
  146. <tbody> <?php
  147. foreach ( $mysql_servers as $mysql_server )
  148. {
  149. if($mysql_server['remote_server_id'] != 0)
  150. {
  151. $remote_server = $db->getRemoteServer($mysql_server['remote_server_id']);
  152. $remote = new OGPRemoteLibrary($remote_server['agent_ip'],$remote_server['agent_port'],$remote_server['encryption_key'],$remote_server['timeout']);
  153. $host_stat = $remote->status_chk();
  154. if($host_stat === 0 )
  155. {
  156. $server_status = "<span class='failure'>".get_lang('offline')."</span> ";
  157. }
  158. elseif( $host_stat === 1)
  159. {
  160. $server_status = "<span class='success'>".get_lang('online')."</span>";
  161. $command = "mysql -h ".$mysql_server['mysql_ip']." -P ".$mysql_server['mysql_port']." -u root -p".$mysql_server['mysql_root_passwd'].' -e exit; echo $?';
  162. $test_mysql_conn = $remote->exec($command);
  163. if($test_mysql_conn == 0)
  164. {
  165. $server_status .= " / <span class='success'>".get_lang('mysql_online')."</span>";
  166. }
  167. else
  168. {
  169. $server_status .= "/<span class='failure'>".get_lang('mysql_offline')."</span>";
  170. }
  171. }
  172. elseif( $host_stat === -1 )
  173. {
  174. $server_status = "<span class='failure'>".get_lang('encryption_key_mismatch')."</span>\n";
  175. }
  176. else
  177. {
  178. $server_status = "<span class='failure'>".get_lang('unknown_error').": $host_stat</span>\n";
  179. }
  180. }
  181. else
  182. {
  183. if( function_exists('mysqli_connect') )
  184. {
  185. @$link = mysqli_connect($mysql_server['mysql_ip'], 'root', $mysql_server['mysql_root_passwd'], "", $mysql_server['mysql_port']);
  186. if ( $link === FALSE )
  187. {
  188. $server_status = "<span class='failure'>".get_lang('mysql_offline')."</span>";
  189. }
  190. else
  191. {
  192. $server_status = "<span class='success'>".get_lang('mysql_online')."</span>";
  193. mysqli_close($link);
  194. }
  195. }
  196. else
  197. {
  198. @$link = mysql_connect($mysql_server['mysql_ip'].':'.$mysql_server['mysql_port'], 'root', $mysql_server['mysql_root_passwd']);
  199. if ( $link === FALSE )
  200. {
  201. $server_status = "<span class='failure'>".get_lang('mysql_offline')."</span>";
  202. }
  203. else
  204. {
  205. $server_status = "<span class='success'>".get_lang('mysql_online')."</span>";
  206. mysql_close($link);
  207. }
  208. }
  209. }
  210. $databases = "";
  211. $mysql_server_dbs = $modDb->getMysqlServerDBs($mysql_server['mysql_server_id']);
  212. if ( !empty($mysql_server_dbs) )
  213. {
  214. foreach ( $mysql_server_dbs as $mysql_db )
  215. {
  216. $databases .= $mysql_db['db_name']."<a href='?m=mysql&p=edit&mysql_server_id=".$mysql_server['mysql_server_id'].
  217. "&assign=true&db_id=".$mysql_db['db_id']."&edit_db_settings'>[".get_lang('edit')."]</a>\n".
  218. "<a href='?m=mysql&p=edit&mysql_server_id=".$mysql_server['mysql_server_id'].
  219. "&assign=true&db_id=".$mysql_db['db_id']."&remove_db'>[".get_lang('remove')."]</a>\n".
  220. "<br>";
  221. }
  222. }
  223. $conection_type = $mysql_server['remote_server_id'] == 0 ?
  224. get_lang('direct_connection') :
  225. get_lang_f('connection_through_remote_server_named',$remote_server['remote_server_name']);
  226. $buttons = "<a href='?m=mysql&amp;p=edit&amp;mysql_server_id=".
  227. $mysql_server['mysql_server_id']."&amp;delete'>[".get_lang('remove')."]</a>\n".
  228. "<a href='?m=mysql&amp;p=edit&amp;mysql_server_id=".$mysql_server['mysql_server_id'].
  229. "&amp;edit'>[".get_lang('edit')."]</a>\n".
  230. "<a href='?m=mysql&amp;p=edit&amp;mysql_server_id=".$mysql_server['mysql_server_id'].
  231. "&amp;assign'>[".get_lang('assign_db')."]</a>\n";
  232. $tittle = "<b>ID#:</b> <b style='color:red;'>".$mysql_server['mysql_server_id']."</b></td>
  233. <td class='collapsible' ><b>".get_lang('mysql_server_name').":</b> ".$mysql_server['mysql_name']."</td>
  234. <td class='collapsible' ><b>".get_lang('server_status').": </b>$server_status</td>";
  235. $data = "<tr class='expand-child' >
  236. <td>
  237. <b>".get_lang('mysql_ip_port').":</b> ".$mysql_server['mysql_ip'].":".$mysql_server['mysql_port']."<br />
  238. <b>".get_lang('mysql_root_passwd').":</b> ".$mysql_server['mysql_root_passwd']."<br />
  239. <b>".get_lang('connection_method').":</b> ".$conection_type."<br />
  240. <b>".get_lang('user_privilegies').":</b> ".$mysql_server['privilegies_str']."<br />
  241. </td>
  242. <td>
  243. <b>".get_lang('current_dbs').":</b><br />".$databases.
  244. "</td>
  245. <td>
  246. $buttons
  247. </td>
  248. </tr>";
  249. // Template
  250. $first = "<tr class='maintr'><td class='collapsible' >$tittle</td></tr>";
  251. $second = $data;
  252. //Echo them all
  253. echo "$first$second";
  254. }
  255. echo "</tbody>";
  256. echo "</table>\n";
  257. ?>
  258. <script type="text/javascript">
  259. $(document).ready(function(){
  260. $("#servermonitor")
  261. .collapsible("td.collapsible", {collapse: true});
  262. });
  263. </script>
  264. <?php
  265. unset($modDb);
  266. }