PageRenderTime 52ms CodeModel.GetById 19ms RepoModel.GetById 0ms app.codeStats 0ms

/wp-content/plugins/wp-dbmanager/wp-dbmanager.php

https://github.com/sharpmachine/wakeupmedia.com
PHP | 603 lines | 540 code | 22 blank | 41 comment | 51 complexity | 018c49d1ddbe175adb4796b983800294 MD5 | raw file
  1. <?php
  2. /*
  3. Plugin Name: WP-DBManager
  4. Plugin URI: http://lesterchan.net/portfolio/programming/php/
  5. Description: Manages your WordPress database. Allows you to optimize database, repair database, backup database, restore database, delete backup database , drop/empty tables and run selected queries. Supports automatic scheduling of backing up, optimizing and repairing of database.
  6. Version: 2.63
  7. Author: Lester 'GaMerZ' Chan
  8. Author URI: http://lesterchan.net
  9. */
  10. /*
  11. Copyright 2011 Lester Chan (email : lesterchan@gmail.com)
  12. This program is free software; you can redistribute it and/or modify
  13. it under the terms of the GNU General Public License as published by
  14. the Free Software Foundation; either version 2 of the License, or
  15. (at your option) any later version.
  16. This program is distributed in the hope that it will be useful,
  17. but WITHOUT ANY WARRANTY; without even the implied warranty of
  18. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  19. GNU General Public License for more details.
  20. You should have received a copy of the GNU General Public License
  21. along with this program; if not, write to the Free Software
  22. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  23. */
  24. ### Create Text Domain For Translations
  25. add_action('init', 'dbmanager_textdomain');
  26. function dbmanager_textdomain() {
  27. load_plugin_textdomain('wp-dbmanager', false, 'wp-dbmanager');
  28. }
  29. ### Function: Database Manager Menu
  30. add_action('admin_menu', 'dbmanager_menu');
  31. function dbmanager_menu() {
  32. if (function_exists('add_menu_page')) {
  33. add_menu_page(__('Database', 'wp-dbmanager'), __('Database', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-manager.php', '', plugins_url('wp-dbmanager/images/database.png'));
  34. }
  35. if (function_exists('add_submenu_page')) {
  36. add_submenu_page('wp-dbmanager/database-manager.php', __('Backup DB', 'wp-dbmanager'), __('Backup DB', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-backup.php');
  37. add_submenu_page('wp-dbmanager/database-manager.php', __('Manage Backup DB', 'wp-dbmanager'), __('Manage Backup DB', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-manage.php');
  38. add_submenu_page('wp-dbmanager/database-manager.php', __('Optimize DB', 'wp-dbmanager'), __('Optimize DB', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-optimize.php');
  39. add_submenu_page('wp-dbmanager/database-manager.php', __('Repair DB', 'wp-dbmanager'), __('Repair DB', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-repair.php');
  40. add_submenu_page('wp-dbmanager/database-manager.php', __('Empty/Drop Tables', 'wp-dbmanager'), __('Empty/Drop Tables', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-empty.php');
  41. add_submenu_page('wp-dbmanager/database-manager.php', __('Run SQL Query', 'wp-dbmanager'), __('Run SQL Query', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-run.php');
  42. add_submenu_page('wp-dbmanager/database-manager.php', __('DB Options', 'wp-dbmanager'), __('DB Options', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/wp-dbmanager.php', 'dbmanager_options');
  43. add_submenu_page('wp-dbmanager/database-manager.php', __('Uninstall WP-DBManager', 'wp-dbmanager'), __('Uninstall WP-DBManager', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-uninstall.php');
  44. }
  45. }
  46. ### Function: Displays DBManager Header In WP-Admin
  47. add_action('admin_enqueue_scripts', 'dbmanager_stylesheets_admin');
  48. function dbmanager_stylesheets_admin($hook_suffix) {
  49. $dbmanager_admin_pages = array('wp-dbmanager/database-manager.php', 'wp-dbmanager/database-backup.php', 'wp-dbmanager/database-manage.php', 'wp-dbmanager/database-optimize.php', 'wp-dbmanager/database-repair.php', 'wp-dbmanager/database-empty.php', 'wp-dbmanager/database-run.php', 'database_page_wp-dbmanager/wp-dbmanager', 'wp-dbmanager/database-uninstall.php');
  50. if(in_array($hook_suffix, $dbmanager_admin_pages)) {
  51. wp_enqueue_style('wp-dbmanager-admin', plugins_url('wp-dbmanager/database-admin-css.css'), false, '2.63', 'all');
  52. }
  53. }
  54. ### Funcion: Database Manager Cron
  55. add_filter('cron_schedules', 'cron_dbmanager_reccurences');
  56. add_action('dbmanager_cron_backup', 'cron_dbmanager_backup');
  57. add_action('dbmanager_cron_optimize', 'cron_dbmanager_optimize');
  58. add_action('dbmanager_cron_repair', 'cron_dbmanager_repair');
  59. function cron_dbmanager_backup() {
  60. global $wpdb;
  61. $backup_options = get_option('dbmanager_options');
  62. $backup_email = stripslashes($backup_options['backup_email']);
  63. if(intval($backup_options['backup_period']) > 0) {
  64. $current_date = mysql2date(sprintf(__('%s @ %s', 'wp-dbmanager'), get_option('date_format'), get_option('time_format')), gmdate('Y-m-d H:i:s', current_time('timestamp')));
  65. $backup = array();
  66. $backup['date'] = current_time('timestamp');
  67. $backup['mysqldumppath'] = $backup_options['mysqldumppath'];
  68. $backup['mysqlpath'] = $backup_options['mysqlpath'];
  69. $backup['path'] = $backup_options['path'];
  70. $backup['password'] = str_replace('$', '\$', DB_PASSWORD);
  71. $backup['host'] = DB_HOST;
  72. $backup['port'] = '';
  73. $backup['sock'] = '';
  74. if(strpos(DB_HOST, ':') !== false) {
  75. $db_host = explode(':', DB_HOST);
  76. $backup['host'] = $db_host[0];
  77. if(is_int($db_host[1])) {
  78. $backup['port'] = ' --port="'.intval($db_host[1]).'"';
  79. } else {
  80. $backup['sock'] = ' --socket="'.$db_host[1].'"';
  81. }
  82. }
  83. $backup['command'] = '';
  84. $brace = (substr(PHP_OS, 0, 3) == 'WIN') ? '"' : '';
  85. if(intval($backup_options['backup_gzip']) == 1) {
  86. $backup['filename'] = $backup['date'].'_-_'.DB_NAME.'.sql.gz';
  87. $backup['filepath'] = $backup['path'].'/'.$backup['filename'];
  88. $backup['command'] = $brace.$backup['mysqldumppath'].$brace.' --host="'.$backup['host'].'" --user="'.DB_USER.'" --password="'.$backup['password'].'"'.$backup['port'].$backup['sock'].' --add-drop-table --skip-lock-tables '.DB_NAME.' | gzip > '.$brace.$backup['filepath'].$brace;
  89. } else {
  90. $backup['filename'] = $backup['date'].'_-_'.DB_NAME.'.sql';
  91. $backup['filepath'] = $backup['path'].'/'.$backup['filename'];
  92. $backup['command'] = $brace.$backup['mysqldumppath'].$brace.' --host="'.$backup['host'].'" --user="'.DB_USER.'" --password="'.$backup['password'].'"'.$backup['port'].$backup['sock'].' --add-drop-table --skip-lock-tables '.DB_NAME.' > '.$brace.$backup['filepath'].$brace;
  93. }
  94. execute_backup($backup['command']);
  95. if(!empty($backup_email)) {
  96. // Get And Read The Database Backup File
  97. $file_path = $backup['filepath'];
  98. $file_size = format_size(filesize($file_path));
  99. $file_date = mysql2date(sprintf(__('%s @ %s', 'wp-dbmanager'), get_option('date_format'), get_option('time_format')), gmdate('Y-m-d H:i:s', substr($backup['filename'], 0, 10)));
  100. $file = fopen($file_path,'rb');
  101. $file_data = fread($file,filesize($file_path));
  102. fclose($file);
  103. $file_data = chunk_split(base64_encode($file_data));
  104. // Create Mail To, Mail Subject And Mail Header
  105. $mail_subject = sprintf(__('%s Database Backup File For %s', 'wp-dbmanager'), wp_specialchars_decode(get_option('blogname')), $file_date);
  106. $mail_header = 'From: '.wp_specialchars_decode(get_option('blogname')).' Administrator <'.get_option('admin_email').'>';
  107. // MIME Boundary
  108. $random_time = md5(time());
  109. $mime_boundary = "==WP-DBManager- $random_time";
  110. // Create Mail Header And Mail Message
  111. $mail_header .= "\nMIME-Version: 1.0\n" .
  112. "Content-Type: multipart/mixed;\n" .
  113. " boundary=\"{$mime_boundary}\"";
  114. $mail_message = __('Website Name:', 'wp-dbmanager').' '.wp_specialchars_decode(get_option('blogname'))."\n".
  115. __('Website URL:', 'wp-dbmanager').' '.get_bloginfo('siteurl')."\n".
  116. __('Backup File Name:', 'wp-dbmanager').' '.$backup['filename']."\n".
  117. __('Backup File Date:', 'wp-dbmanager').' '.$file_date."\n".
  118. __('Backup File Size:', 'wp-dbmanager').' '.$file_size."\n\n".
  119. __('With Regards,', 'wp-dbmanager')."\n".
  120. wp_specialchars_decode(get_option('blogname')).' '. __('Administrator', 'wp-dbmanager')."\n".
  121. get_bloginfo('siteurl');
  122. $mail_message = "This is a multi-part message in MIME format.\n\n" .
  123. "--{$mime_boundary}\n" .
  124. "Content-Type: text/plain; charset=\"utf-8\"\n" .
  125. "Content-Transfer-Encoding: 7bit\n\n".$mail_message."\n\n";
  126. $mail_message .= "--{$mime_boundary}\n" .
  127. "Content-Type: application/octet-stream;\n" .
  128. " name=\"{$backup['filename']}\"\n" .
  129. "Content-Disposition: attachment;\n" .
  130. " filename=\"{$backup['filename']}\"\n" .
  131. "Content-Transfer-Encoding: base64\n\n" .
  132. $file_data."\n\n--{$mime_boundary}--\n";
  133. mail($backup_email, $mail_subject, $mail_message, $mail_header);
  134. }
  135. }
  136. return;
  137. }
  138. function cron_dbmanager_optimize() {
  139. global $wpdb;
  140. $backup_options = get_option('dbmanager_options');
  141. $optimize = intval($backup_options['optimize']);
  142. $optimize_period = intval($backup_options['optimize_period']);
  143. if($optimize_period > 0) {
  144. $optimize_tables = array();
  145. $tables = $wpdb->get_col("SHOW TABLES");
  146. foreach($tables as $table_name) {
  147. $optimize_tables[] = '`'.$table_name.'`';
  148. }
  149. $wpdb->query('OPTIMIZE TABLE '.implode(',', $optimize_tables));
  150. }
  151. return;
  152. }
  153. function cron_dbmanager_repair() {
  154. global $wpdb;
  155. $backup_options = get_option('dbmanager_options');
  156. $repair = intval($backup_options['repair']);
  157. $repair_period = intval($backup_options['repair_period']);
  158. if($repair_period > 0) {
  159. $repair_tables = array();
  160. $tables = $wpdb->get_col("SHOW TABLES");
  161. foreach($tables as $table_name) {
  162. $repair_tables[] = '`'.$table_name.'`';
  163. }
  164. $wpdb->query('REPAIR TABLE '.implode(',', $repair_tables));
  165. }
  166. return;
  167. }
  168. function cron_dbmanager_reccurences($schedules) {
  169. $backup_options = get_option('dbmanager_options');
  170. $backup = intval($backup_options['backup'])*intval($backup_options['backup_period']);
  171. $optimize = intval($backup_options['optimize'])*intval($backup_options['optimize_period']);
  172. $repair = intval($backup_options['repair'])*intval($backup_options['repair_period']);
  173. if($backup == 0) {
  174. $backup = 31536000;
  175. }
  176. if($optimize == 0) {
  177. $optimize = 31536000;
  178. }
  179. if($repair == 0) {
  180. $repair = 31536000;
  181. }
  182. $schedules['dbmanager_backup'] = array('interval' => $backup, 'display' => __('WP-DBManager Backup Schedule', 'wp-dbmanager'));
  183. $schedules['dbmanager_optimize'] = array('interval' => $optimize, 'display' => __('WP-DBManager Optimize Schedule', 'wp-dbmanager'));
  184. $schedules['dbmanager_repair'] = array('interval' => $repair, 'display' => __('WP-DBManager Repair Schedule', 'wp-dbmanager'));
  185. return $schedules;
  186. }
  187. ### Function: Ensure .htaccess Is In The Backup Folder
  188. add_action('admin_notices', 'dbmanager_admin_notices');
  189. function dbmanager_admin_notices() {
  190. $backup_options = get_option('dbmanager_options');
  191. if(!@file_exists($backup_options['path'].'/.htaccess')) {
  192. echo '<div class="error" style="text-align: center;"><p style="color: red; font-size: 14px; font-weight: bold;">'.__('Your backup folder MIGHT be visible to the public', 'wp-postratings').'</p><p>'.sprintf(__('To correct this issue, move the <strong>.htaccess</strong> file from <strong>wp-content/plugins/wp-dbmanager</strong> to <strong>%s</strong>', 'wp-postratings'), $backup_options['path']).'</p></div>';
  193. }
  194. }
  195. ### Function: Auto Detect MYSQL and MYSQL Dump Paths
  196. function detect_mysql() {
  197. global $wpdb;
  198. $paths = array('mysq' => '', 'mysqldump' => '');
  199. if(substr(PHP_OS,0,3) == 'WIN') {
  200. $mysql_install = $wpdb->get_row("SHOW VARIABLES LIKE 'basedir'");
  201. if($mysql_install) {
  202. $install_path = str_replace('\\', '/', $mysql_install->Value);
  203. $paths['mysql'] = $install_path.'bin/mysql.exe';
  204. $paths['mysqldump'] = $install_path.'bin/mysqldump.exe';
  205. } else {
  206. $paths['mysql'] = 'mysql.exe';
  207. $paths['mysqldump'] = 'mysqldump.exe';
  208. }
  209. } else {
  210. if(function_exists('exec')) {
  211. $paths['mysql'] = @exec('which mysql');
  212. $paths['mysqldump'] = @exec('which mysqldump');
  213. } else {
  214. $paths['mysql'] = 'mysql';
  215. $paths['mysqldump'] = 'mysqldump';
  216. }
  217. }
  218. return $paths;
  219. }
  220. ### Executes OS-Dependent mysqldump Command (By: Vlad Sharanhovich)
  221. function execute_backup($command) {
  222. $backup_options = get_option('dbmanager_options');
  223. check_backup_files();
  224. if(substr(PHP_OS, 0, 3) == 'WIN') {
  225. $writable_dir = $backup_options['path'];
  226. $tmpnam = $writable_dir.'/wp-dbmanager.bat';
  227. $fp = fopen($tmpnam, 'w');
  228. fwrite($fp, $command);
  229. fclose($fp);
  230. system($tmpnam.' > NUL', $error);
  231. unlink($tmpnam);
  232. } else {
  233. passthru($command, $error);
  234. }
  235. return $error;
  236. }
  237. ### Function: Format Bytes Into KB/MB
  238. if(!function_exists('format_size')) {
  239. function format_size($rawSize) {
  240. if($rawSize / 1073741824 > 1)
  241. return number_format_i18n($rawSize/1048576, 1) . ' '.__('GiB', 'wp-dbmanager');
  242. else if ($rawSize / 1048576 > 1)
  243. return number_format_i18n($rawSize/1048576, 1) . ' '.__('MiB', 'wp-dbmanager');
  244. else if ($rawSize / 1024 > 1)
  245. return number_format_i18n($rawSize/1024, 1) . ' '.__('KiB', 'wp-dbmanager');
  246. else
  247. return number_format_i18n($rawSize, 0) . ' '.__('bytes', 'wp-dbmanager');
  248. }
  249. }
  250. ### Function: Get File Extension
  251. if(!function_exists('file_ext')) {
  252. function file_ext($file_name) {
  253. return substr(strrchr($file_name, '.'), 1);
  254. }
  255. }
  256. ### Function: Check Folder Whether There Is Any File Inside
  257. if(!function_exists('is_emtpy_folder')) {
  258. function is_emtpy_folder($folder){
  259. if(is_dir($folder) ){
  260. $handle = opendir($folder);
  261. while( (gettype( $name = readdir($handle)) != 'boolean')){
  262. if($name != '.htaccess') {
  263. $name_array[] = $name;
  264. }
  265. }
  266. foreach($name_array as $temp)
  267. $folder_content .= $temp;
  268. if($folder_content == '...')
  269. return true;
  270. else
  271. return false;
  272. closedir($handle);
  273. }
  274. else
  275. return true;
  276. }
  277. }
  278. ### Function: Make Sure Maximum Number Of Database Backup Files Does Not Exceed
  279. function check_backup_files() {
  280. $backup_options = get_option('dbmanager_options');
  281. $database_files = array();
  282. if(!is_emtpy_folder($backup_options['path'])) {
  283. if ($handle = opendir($backup_options['path'])) {
  284. while (false !== ($file = readdir($handle))) {
  285. if ($file != '.' && $file != '..' && (file_ext($file) == 'sql' || file_ext($file) == 'gz')) {
  286. $database_files[] = $file;
  287. }
  288. }
  289. closedir($handle);
  290. sort($database_files);
  291. }
  292. }
  293. if(sizeof($database_files) >= $backup_options['max_backup']) {
  294. @unlink($backup_options['path'].'/'.$database_files[0]);
  295. }
  296. }
  297. ### Function: Database Manager Role
  298. add_action('activate_wp-dbmanager/wp-dbmanager.php', 'dbmanager_init');
  299. function dbmanager_init() {
  300. global $wpdb;
  301. $auto = detect_mysql();
  302. // Add Options
  303. $backup_options = array();
  304. $backup_options['mysqldumppath'] = $auto['mysqldump'];
  305. $backup_options['mysqlpath'] = $auto['mysql'];
  306. $backup_options['path'] = str_replace('\\', '/', WP_CONTENT_DIR).'/backup-db';
  307. $backup_options['max_backup'] = 10;
  308. $backup_options['backup'] = 1;
  309. $backup_options['backup_gzip'] = 0;
  310. $backup_options['backup_period'] = 604800;
  311. $backup_options['backup_email'] = get_option('admin_email');
  312. $backup_options['optimize'] = 3;
  313. $backup_options['optimize_period'] = 86400;
  314. $backup_options['repair'] = 2;
  315. $backup_options['repair_period'] = 604800;
  316. add_option('dbmanager_options', $backup_options, 'WP-DBManager Options');
  317. // Create Backup Folder
  318. if(!is_dir(WP_CONTENT_DIR.'/backup-db')) {
  319. mkdir(WP_CONTENT_DIR.'/backup-db');
  320. chmod(WP_CONTENT_DIR.'/backup-db', 0750);
  321. }
  322. // Set 'manage_database' Capabilities To Administrator
  323. $role = get_role('administrator');
  324. if(!$role->has_cap('manage_database')) {
  325. $role->add_cap('manage_database');
  326. }
  327. }
  328. ### Function: Download Database
  329. add_action('init', 'download_database');
  330. function download_database() {
  331. if(isset($_POST['do']) && $_POST['do'] == __('Download', 'wp-dbmanager') && !empty($_POST['database_file'])) {
  332. if(strpos($_SERVER['HTTP_REFERER'], admin_url('admin.php?page=wp-dbmanager/database-manage.php')) !== false) {
  333. $database_file = trim($_POST['database_file']);
  334. if(substr($database_file, strlen($database_file) - 4, 4) == '.sql' || substr($database_file, strlen($database_file) - 7, 7) == '.sql.gz') {
  335. check_admin_referer('wp-dbmanager_manage');
  336. $backup_options = get_option('dbmanager_options');
  337. $clean_file_name = sanitize_file_name($database_file);
  338. $clean_file_name = str_replace('sql_.gz', 'sql.gz', $clean_file_name);
  339. $file_path = $backup_options['path'].'/'.$clean_file_name;
  340. header("Pragma: public");
  341. header("Expires: 0");
  342. header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
  343. header("Content-Type: application/force-download");
  344. header("Content-Type: application/octet-stream");
  345. header("Content-Type: application/download");
  346. header("Content-Disposition: attachment; filename=".basename($file_path).";");
  347. header("Content-Transfer-Encoding: binary");
  348. header("Content-Length: ".filesize($file_path));
  349. @readfile($file_path);
  350. }
  351. }
  352. exit();
  353. }
  354. }
  355. ### Function: Database Options
  356. function dbmanager_options() {
  357. global $wpdb;
  358. $text = '';
  359. $backup_options = array();
  360. $backup_options = get_option('dbmanager_options');
  361. if($_POST['Submit']) {
  362. check_admin_referer('wp-dbmanager_options');
  363. $backup_options['mysqldumppath'] = trim($_POST['db_mysqldumppath']);
  364. $backup_options['mysqlpath'] = trim($_POST['db_mysqlpath']);
  365. $backup_options['path'] = trim($_POST['db_path']);
  366. $backup_options['max_backup'] = intval($_POST['db_max_backup']);
  367. $backup_options['backup'] = intval($_POST['db_backup']);
  368. $backup_options['backup_gzip'] = intval($_POST['db_backup_gzip']);
  369. $backup_options['backup_period'] = intval($_POST['db_backup_period']);
  370. $backup_options['backup_email'] = trim(addslashes($_POST['db_backup_email']));
  371. $backup_options['optimize'] = intval($_POST['db_optimize']);
  372. $backup_options['optimize_period'] = intval($_POST['db_optimize_period']);
  373. $backup_options['repair'] = intval($_POST['db_repair']);
  374. $backup_options['repair_period'] = intval($_POST['db_repair_period']);
  375. $update_db_options = update_option('dbmanager_options', $backup_options);
  376. if($update_db_options) {
  377. $text = '<font color="green">'.__('Database Options Updated', 'wp-dbmanager').'</font>';
  378. }
  379. if(empty($text)) {
  380. $text = '<font color="red">'.__('No Database Option Updated', 'wp-dbmanager').'</font>';
  381. }
  382. wp_clear_scheduled_hook('dbmanager_cron_backup');
  383. if($backup_options['backup_period'] > 0) {
  384. if (!wp_next_scheduled('dbmanager_cron_backup')) {
  385. wp_schedule_event(time(), 'dbmanager_backup', 'dbmanager_cron_backup');
  386. }
  387. }
  388. wp_clear_scheduled_hook('dbmanager_cron_optimize');
  389. if($backup_options['optimize_period'] > 0) {
  390. if (!wp_next_scheduled('dbmanager_cron_optimize')) {
  391. wp_schedule_event(time(), 'dbmanager_optimize', 'dbmanager_cron_optimize');
  392. }
  393. }
  394. wp_clear_scheduled_hook('dbmanager_cron_repair');
  395. if($backup_options['repair_period'] > 0) {
  396. if (!wp_next_scheduled('dbmanager_cron_repair')) {
  397. wp_schedule_event(time(), 'dbmanager_repair', 'dbmanager_cron_repair');
  398. }
  399. }
  400. }
  401. $path = detect_mysql();
  402. ?>
  403. <script type="text/javascript">
  404. /* <![CDATA[*/
  405. function mysqlpath() {
  406. jQuery("#db_mysqlpath").val("<?php echo $path['mysql']; ?>");
  407. }
  408. function mysqldumppath() {
  409. jQuery("#db_mysqldumppath").val("<?php echo $path['mysqldump']; ?>");
  410. }
  411. /* ]]> */
  412. </script>
  413. <?php if(!empty($text)) { echo '<!-- Last Action --><div id="message" class="updated fade"><p>'.$text.'</p></div>'; } ?>
  414. <!-- Database Options -->
  415. <form method="post" action="<?php echo admin_url('admin.php?page='.plugin_basename(__FILE__)); ?>">
  416. <?php wp_nonce_field('wp-dbmanager_options'); ?>
  417. <div class="wrap">
  418. <div id="icon-wp-dbmanager" class="icon32"><br /></div>
  419. <h2><?php _e('Database Options', 'wp-dbmanager'); ?></h2>
  420. <h3><?php _e('Paths', 'wp-dbmanager'); ?></h3>
  421. <table class="form-table">
  422. <tr>
  423. <td width="20%" valign="top"><strong><?php _e('Path To mysqldump:', 'wp-dbmanager'); ?></strong></td>
  424. <td width="80%">
  425. <input type="text" id="db_mysqldumppath" name="db_mysqldumppath" size="60" maxlength="100" value="<?php echo stripslashes($backup_options['mysqldumppath']); ?>" dir="ltr" />&nbsp;&nbsp;<input type="button" value="<?php _e('Auto Detect', 'wp-dbmanager'); ?>" onclick="mysqldumppath();" />
  426. <p><?php _e('The absolute path to mysqldump without trailing slash. If unsure, please email your server administrator about this.', 'wp-dbmanager'); ?></p>
  427. </td>
  428. </tr>
  429. <tr>
  430. <td valign="top"><strong><?php _e('Path To mysql:', 'wp-dbmanager'); ?></strong></td>
  431. <td>
  432. <input type="text" id="db_mysqlpath" name="db_mysqlpath" size="60" maxlength="100" value="<?php echo stripslashes($backup_options['mysqlpath']); ?>" dir="ltr" />&nbsp;&nbsp;<input type="button" value="<?php _e('Auto Detect', 'wp-dbmanager'); ?>" onclick="mysqlpath();" />
  433. <p><?php _e('The absolute path to mysql without trailing slash. If unsure, please email your server administrator about this.', 'wp-dbmanager'); ?></p>
  434. </td>
  435. </tr>
  436. <tr>
  437. <td valign="top"><strong><?php _e('Path To Backup:', 'wp-dbmanager'); ?></strong></td>
  438. <td>
  439. <input type="text" name="db_path" size="60" maxlength="100" value="<?php echo stripslashes($backup_options['path']); ?>" dir="ltr" />
  440. <p><?php _e('The absolute path to your database backup folder without trailing slash. Make sure the folder is writable.', 'wp-dbmanager'); ?></p>
  441. </td>
  442. </tr>
  443. <tr>
  444. <td valign="top"><strong><?php _e('Maximum Backup Files:', 'wp-dbmanager'); ?></strong></td>
  445. <td>
  446. <input type="text" name="db_max_backup" size="5" maxlength="5" value="<?php echo stripslashes($backup_options['max_backup']); ?>" />
  447. <p><?php _e('The maximum number of database backup files that is allowed in the backup folder as stated above. The oldest database backup file is always deleted in order to maintain this value. This is to prevent the backup folder from getting too large.', 'wp-dbmanager'); ?></p>
  448. </td>
  449. </tr>
  450. </table>
  451. <h3><?php _e('Note', 'wp-dbmanager'); ?></h3>
  452. <table class="form-table">
  453. <tr>
  454. <td>
  455. <strong><?php _e('Windows Server', 'wp-dbmanager'); ?></strong><br />
  456. <?php _e('For mysqldump path, you can try \'<strong>mysqldump.exe</strong>\'.', 'wp-dbmanager'); ?><br />
  457. <?php _e('For mysql path, you can try \'<strong>mysql.exe</strong>\'.', 'wp-dbmanager'); ?>
  458. </td>
  459. </tr>
  460. <tr>
  461. <td>
  462. <strong><?php _e('Linux Server', 'wp-dbmanager'); ?></strong><br />
  463. <?php _e('For mysqldump path, normally is just \'<strong>mysqldump</strong>\'.', 'wp-dbmanager'); ?><br />
  464. <?php _e('For mysql path, normally is just \'<strong>mysql</strong>\'.', 'wp-dbmanager'); ?>
  465. </td>
  466. </tr>
  467. <tr>
  468. <td>
  469. <strong><?php _e('Note', 'wp-dbmanager'); ?></strong><br />
  470. <?php _e('The \'Auto Detect\' function does not work for some servers. If it does not work for you, please contact your server administrator for the MYSQL and MYSQL DUMP paths.', 'wp-dbmanager'); ?>
  471. </td>
  472. </tr>
  473. </table>
  474. <h3><?php _e('Automatic Scheduling', 'wp-dbmanager'); ?></h3>
  475. <table class="form-table">
  476. <tr>
  477. <td valign="top"><strong><?php _e('Automatic Backing Up Of DB:', 'wp-dbmanager'); ?></strong></td>
  478. <td>
  479. <?php
  480. _e('Next backup date: ', 'wp-dbmanager');
  481. if(wp_next_scheduled('dbmanager_cron_backup')) {
  482. echo '<strong>'.mysql2date(sprintf(__('%s @ %s', 'wp-dbmanager'), get_option('date_format'), get_option('time_format')), gmdate('Y-m-d H:i:s', (wp_next_scheduled('dbmanager_cron_backup') + (get_option('gmt_offset') * 3600)))).'</strong>';
  483. } else {
  484. _e('N/A', 'wp-dbmanager');
  485. }
  486. ?>
  487. <p>
  488. <?php _e('Every', 'wp-dbmanager'); ?>&nbsp;<input type="text" name="db_backup" size="3" maxlength="5" value="<?php echo intval($backup_options['backup']); ?>" />&nbsp;
  489. <select name="db_backup_period" size="1">
  490. <option value="0"<?php selected('0', $backup_options['backup_period']); ?>><?php _e('Disable', 'wp-dbmanager'); ?></option>
  491. <option value="60"<?php selected('60', $backup_options['backup_period']); ?>><?php _e('Minutes(s)', 'wp-dbmanager'); ?></option>
  492. <option value="3600"<?php selected('3600', $backup_options['backup_period']); ?>><?php _e('Hour(s)', 'wp-dbmanager'); ?></option>
  493. <option value="86400"<?php selected('86400', $backup_options['backup_period']); ?>><?php _e('Day(s)', 'wp-dbmanager'); ?></option>
  494. <option value="604800"<?php selected('604800', $backup_options['backup_period']); ?>><?php _e('Week(s)', 'wp-dbmanager'); ?></option>
  495. <option value="18144000"<?php selected('18144000', $backup_options['backup_period']); ?>><?php _e('Month(s)', 'wp-dbmanager'); ?></option>
  496. </select>&nbsp;&nbsp;&nbsp;
  497. <?php _e('Gzip', 'wp-dbmanager'); ?>
  498. <select name="db_backup_gzip" size="1">
  499. <option value="0"<?php selected('0', $backup_options['backup_gzip']); ?>><?php _e('No', 'wp-dbmanager'); ?></option>
  500. <option value="1"<?php selected('1', $backup_options['backup_gzip']); ?>><?php _e('Yes', 'wp-dbmanager'); ?></option>
  501. </select>
  502. </p>
  503. <p><?php _e('E-mail backup to:', 'wp-dbmanager'); ?> <input type="text" name="db_backup_email" size="30" maxlength="50" value="<?php echo stripslashes($backup_options['backup_email']) ?>" dir="ltr" />&nbsp;&nbsp;&nbsp;<?php _e('(Leave blank to disable this feature)', 'wp-dbmanager'); ?></p>
  504. <p><?php _e('WP-DBManager can automatically backup your database after a certain period.', 'wp-dbmanager'); ?></p>
  505. </td>
  506. </tr>
  507. <tr>
  508. <td valign="top"><strong><?php _e('Automatic Optimizing Of DB:', 'wp-dbmanager'); ?></strong></td>
  509. <td>
  510. <?php
  511. _e('Next optimize date: ', 'wp-dbmanager');
  512. if(wp_next_scheduled('dbmanager_cron_optimize')) {
  513. echo '<strong>'.mysql2date(sprintf(__('%s @ %s', 'wp-dbmanager'), get_option('date_format'), get_option('time_format')), gmdate('Y-m-d H:i:s', (wp_next_scheduled('dbmanager_cron_optimize') + (get_option('gmt_offset') * 3600)))).'</strong>';
  514. } else {
  515. _e('N/A', 'wp-dbmanager');
  516. }
  517. ?>
  518. <p>
  519. <?php _e('Every', 'wp-dbmanager'); ?>&nbsp;<input type="text" name="db_optimize" size="3" maxlength="5" value="<?php echo intval($backup_options['optimize']); ?>" />&nbsp;
  520. <select name="db_optimize_period" size="1">
  521. <option value="0"<?php selected('0', $backup_options['optimize_period']); ?>><?php _e('Disable', 'wp-dbmanager'); ?></option>
  522. <option value="60"<?php selected('60', $backup_options['optimize_period']); ?>><?php _e('Minutes(s)', 'wp-dbmanager'); ?></option>
  523. <option value="3600"<?php selected('3600', $backup_options['optimize_period']); ?>><?php _e('Hour(s)', 'wp-dbmanager'); ?></option>
  524. <option value="86400"<?php selected('86400', $backup_options['optimize_period']); ?>><?php _e('Day(s)', 'wp-dbmanager'); ?></option>
  525. <option value="604800"<?php selected('604800', $backup_options['optimize_period']); ?>><?php _e('Week(s)', 'wp-dbmanager'); ?></option>
  526. <option value="18144000"<?php selected('18144000', $backup_options['optimize_period']); ?>><?php _e('Month(s)', 'wp-dbmanager'); ?></option>
  527. </select>
  528. </p>
  529. <p><?php _e('WP-DBManager can automatically optimize your database after a certain period.', 'wp-dbmanager'); ?></p>
  530. </td>
  531. </tr>
  532. <tr>
  533. <td valign="top"><strong><?php _e('Automatic Repairing Of DB:', 'wp-dbmanager'); ?></strong></td>
  534. <td>
  535. <?php
  536. _e('Next repair date: ', 'wp-dbmanager');
  537. if(wp_next_scheduled('dbmanager_cron_repair')) {
  538. echo '<strong>'.mysql2date(sprintf(__('%s @ %s', 'wp-dbmanager'), get_option('date_format'), get_option('time_format')), gmdate('Y-m-d H:i:s', (wp_next_scheduled('dbmanager_cron_repair') + (get_option('gmt_offset') * 3600)))).'</strong>';
  539. } else {
  540. _e('N/A', 'wp-dbmanager');
  541. }
  542. ?>
  543. <p>
  544. <?php _e('Every', 'wp-dbmanager'); ?>&nbsp;<input type="text" name="db_repair" size="3" maxlength="5" value="<?php echo intval($backup_options['repair']); ?>" />&nbsp;
  545. <select name="db_repair_period" size="1">
  546. <option value="0"<?php selected('0', $backup_options['repair_period']); ?>><?php _e('Disable', 'wp-dbmanager'); ?></option>
  547. <option value="60"<?php selected('60', $backup_options['repair_period']); ?>><?php _e('Minutes(s)', 'wp-dbmanager'); ?></option>
  548. <option value="3600"<?php selected('3600', $backup_options['repair_period']); ?>><?php _e('Hour(s)', 'wp-dbmanager'); ?></option>
  549. <option value="86400"<?php selected('86400', $backup_options['repair_period']); ?>><?php _e('Day(s)', 'wp-dbmanager'); ?></option>
  550. <option value="604800"<?php selected('604800', $backup_options['repair_period']); ?>><?php _e('Week(s)', 'wp-dbmanager'); ?></option>
  551. <option value="18144000"<?php selected('18144000', $backup_options['repair_period']); ?>><?php _e('Month(s)', 'wp-dbmanager'); ?></option>
  552. </select>
  553. </p>
  554. <p><?php _e('WP-DBManager can automatically repair your database after a certain period.', 'wp-dbmanager'); ?></p>
  555. </td>
  556. </tr>
  557. </table>
  558. <p class="submit">
  559. <input type="submit" name="Submit" class="button" value="<?php _e('Save Changes', 'wp-dbmanager'); ?>" />
  560. </p>
  561. </div>
  562. </form>
  563. <?php
  564. }
  565. ?>