tbl_move_copy.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. /* vim: set expandtab sw=4 ts=4 sts=4: */
  3. /**
  4. *
  5. * @package PhpMyAdmin
  6. */
  7. /**
  8. * Gets some core libraries
  9. */
  10. require_once 'libraries/common.inc.php';
  11. // Check parameters
  12. PMA_Util::checkParameters(array('db', 'table'));
  13. /**
  14. * Defines the url to return to in case of error in a sql statement
  15. */
  16. $err_url = 'tbl_sql.php?' . PMA_generate_common_url($db, $table);
  17. /**
  18. * Selects the database to work with
  19. */
  20. PMA_DBI_select_db($db);
  21. $goto = $cfg['DefaultTabTable'];
  22. /**
  23. * $_REQUEST['target_db'] could be empty in case we came from an input field
  24. * (when there are many databases, no drop-down)
  25. */
  26. if (empty($_REQUEST['target_db'])) {
  27. $_REQUEST['target_db'] = $db;
  28. }
  29. /**
  30. * A target table name has been sent to this script -> do the work
  31. */
  32. if (PMA_isValid($_REQUEST['new_name'])) {
  33. if ($db == $_REQUEST['target_db'] && $table == $_REQUEST['new_name']) {
  34. if (isset($_REQUEST['submit_move'])) {
  35. $message = PMA_Message::error(__('Can\'t move table to same one!'));
  36. } else {
  37. $message = PMA_Message::error(__('Can\'t copy table to same one!'));
  38. }
  39. $result = false;
  40. } else {
  41. $result = PMA_Table::moveCopy(
  42. $db, $table, $_REQUEST['target_db'], $_REQUEST['new_name'],
  43. $_REQUEST['what'], isset($_REQUEST['submit_move']), 'one_table'
  44. );
  45. if (isset($_REQUEST['submit_move'])) {
  46. $message = PMA_Message::success(__('Table %s has been moved to %s.'));
  47. } else {
  48. $message = PMA_Message::success(__('Table %s has been copied to %s.'));
  49. }
  50. $old = PMA_Util::backquote($db) . '.'
  51. . PMA_Util::backquote($table);
  52. $message->addParam($old);
  53. $new = PMA_Util::backquote($_REQUEST['target_db']) . '.'
  54. . PMA_Util::backquote($_REQUEST['new_name']);
  55. $message->addParam($new);
  56. /* Check: Work on new table or on old table? */
  57. if (isset($_REQUEST['submit_move'])
  58. || PMA_isValid($_REQUEST['switch_to_new'])
  59. ) {
  60. $db = $_REQUEST['target_db'];
  61. $table = $_REQUEST['new_name'];
  62. }
  63. $reload = 1;
  64. }
  65. } else {
  66. /**
  67. * No new name for the table!
  68. */
  69. $message = PMA_Message::error(__('The table name is empty!'));
  70. $result = false;
  71. }
  72. if ($GLOBALS['is_ajax_request'] == true) {
  73. $response = PMA_Response::getInstance();
  74. $response->addJSON('message', $message);
  75. if ($message->isSuccess()) {
  76. $response->addJSON('db', $GLOBALS['db']);
  77. $response->addJSON(
  78. 'sql_query',
  79. PMA_Util::getMessage(null, $sql_query)
  80. );
  81. } else {
  82. $response->isSuccess(false);
  83. }
  84. exit;
  85. }
  86. /**
  87. * Back to the calling script
  88. */
  89. $_message = $message;
  90. unset($message);
  91. ?>