0byt3m1n1
Path:
/
home1
/
aserty
/
www
/
ourhomebedroom.com
/
wp-content
/
plugins
/
wp-dbmanager
/
[
Home
]
File: wp-dbmanager.php
<?php /* Plugin Name: WP-DBManager Plugin URI: https://lesterchan.net/portfolio/programming/php/ 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. Version: 2.79.1 Author: Lester 'GaMerZ' Chan Author URI: https://lesterchan.net Text Domain: wp-dbmanager */ /* Copyright 2017 Lester Chan (email : lesterchan@gmail.com) 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 (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, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ ### Create Text Domain For Translations add_action( 'plugins_loaded', 'dbmanager_textdomain' ); function dbmanager_textdomain() { load_plugin_textdomain( 'wp-dbmanager', false, dirname( plugin_basename( __FILE__ ) ) ); } ### Function: Database Manager Menu add_action('admin_menu', 'dbmanager_menu'); function dbmanager_menu() { if (function_exists('add_menu_page')) { add_menu_page(__('Database', 'wp-dbmanager'), __('Database', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-manager.php', '', 'dashicons-archive'); } if (function_exists('add_submenu_page')) { add_submenu_page('wp-dbmanager/database-manager.php', __('Backup DB', 'wp-dbmanager'), __('Backup DB', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-backup.php'); 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'); add_submenu_page('wp-dbmanager/database-manager.php', __('Optimize DB', 'wp-dbmanager'), __('Optimize DB', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-optimize.php'); add_submenu_page('wp-dbmanager/database-manager.php', __('Repair DB', 'wp-dbmanager'), __('Repair DB', 'wp-dbmanager'), 'manage_database', 'wp-dbmanager/database-repair.php'); 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'); 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'); 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'); } } ### Funcion: Database Manager Cron add_filter('cron_schedules', 'cron_dbmanager_reccurences'); add_action('dbmanager_cron_backup', 'cron_dbmanager_backup'); add_action('dbmanager_cron_optimize', 'cron_dbmanager_optimize'); add_action('dbmanager_cron_repair', 'cron_dbmanager_repair'); function cron_dbmanager_backup() { $backup_options = get_option('dbmanager_options'); $backup_email = stripslashes($backup_options['backup_email']); if ( (int) $backup_options['backup_period'] > 0 ) { $backup = array(); $backup['date'] = current_time('timestamp'); $backup['mysqldumppath'] = $backup_options['mysqldumppath']; $backup['mysqlpath'] = $backup_options['mysqlpath']; $backup['path'] = $backup_options['path']; $backup['charset'] = ' --default-character-set="utf8"'; $backup['host'] = DB_HOST; $backup['port'] = ''; $backup['sock'] = ''; if ( strpos( DB_HOST, ':' ) !== false ) { $db_host = explode(':', DB_HOST); $backup['host'] = $db_host[0]; if ( (int) $db_host[1] !== 0 ) { $backup['port'] = ' --port=' . escapeshellarg( (int) $db_host[1] ); } else { $backup['sock'] = ' --socket=' . escapeshellarg( $db_host[1] ); } } $backup['command'] = ''; $brace = 0 === strpos( PHP_OS, 'WIN' ) ? '"' : ''; if ( (int) $backup_options['backup_gzip'] === 1 ) { $backup['filename'] = $backup['date'].'_-_'.DB_NAME.'.sql.gz'; $backup['filepath'] = $backup['path'].'/'.$backup['filename']; do_action( 'wp_dbmanager_before_escapeshellcmd' ); $backup['command'] = $brace . escapeshellcmd( $backup['mysqldumppath'] ) . $brace . ' --force --host=' . escapeshellarg( $backup['host'] ).' --user=' . escapeshellarg( DB_USER ) . ' --password=' . escapeshellarg( DB_PASSWORD ) . $backup['port'] . $backup['sock'] . $backup['charset'] . ' --add-drop-table --skip-lock-tables ' . DB_NAME . ' | gzip > '. $brace . escapeshellcmd( $backup['filepath'] ) . $brace; } else { $backup['filename'] = $backup['date'].'_-_'.DB_NAME.'.sql'; $backup['filepath'] = $backup['path'].'/'.$backup['filename']; do_action( 'wp_dbmanager_before_escapeshellcmd' ); $backup['command'] = $brace . escapeshellcmd( $backup['mysqldumppath'] ) . $brace . ' --force --host=' . escapeshellarg( $backup['host'] ).' --user=' . escapeshellarg( DB_USER ). ' --password=' . escapeshellarg( DB_PASSWORD ) . $backup['port'] . $backup['sock'] . $backup['charset'] . ' --add-drop-table --skip-lock-tables ' . DB_NAME . ' > ' . $brace . escapeshellcmd( $backup['filepath'] ) . $brace; } execute_backup($backup['command']); if( ! empty( $backup_email ) ) { dbmanager_email_backup( $backup_email, $backup['filepath'] ); } } return; } function cron_dbmanager_optimize() { global $wpdb; $backup_options = get_option('dbmanager_options'); $optimize_period = intval($backup_options['optimize_period']); if($optimize_period > 0) { $optimize_tables = array(); $tables = $wpdb->get_col("SHOW TABLES"); foreach($tables as $table_name) { $optimize_tables[] = '`'.$table_name.'`'; } $wpdb->query('OPTIMIZE TABLE '.implode(',', $optimize_tables)); } return; } function cron_dbmanager_repair() { global $wpdb; $backup_options = get_option('dbmanager_options'); $repair_period = intval($backup_options['repair_period']); if($repair_period > 0) { $repair_tables = array(); $tables = $wpdb->get_col("SHOW TABLES"); foreach($tables as $table_name) { $repair_tables[] = '`'.$table_name.'`'; } $wpdb->query('REPAIR TABLE '.implode(',', $repair_tables)); } return; } function cron_dbmanager_reccurences($schedules) { $backup_options = get_option( 'dbmanager_options' ); if( isset( $backup_options['backup'] ) && isset( $backup_options['backup_period'] ) ) { $backup = intval( $backup_options['backup'] ) * intval( $backup_options['backup_period'] ); } else { $backup = 0; } if( isset( $backup_options['optimize'] ) && isset( $backup_options['optimize_period'] ) ) { $optimize = intval( $backup_options['optimize'] ) * intval( $backup_options['optimize_period'] ); } else { $optimize = 0; } if( isset( $backup_options['repair'] ) && isset( $backup_options['repair_period'] ) ) { $repair = intval( $backup_options['repair'] ) * intval( $backup_options['repair_period'] ); } else { $repair = 0; } if( $backup === 0 ) { $backup = 31536000; } if( $optimize === 0 ) { $optimize = 31536000; } if( $repair === 0 ) { $repair = 31536000; } $schedules['dbmanager_backup'] = array( 'interval' => $backup, 'display' => __( 'WP-DBManager Backup Schedule', 'wp-dbmanager' ) ); $schedules['dbmanager_optimize'] = array( 'interval' => $optimize, 'display' => __( 'WP-DBManager Optimize Schedule', 'wp-dbmanager' ) ); $schedules['dbmanager_repair'] = array( 'interval' => $repair, 'display' => __( 'WP-DBManager Repair Schedule', 'wp-dbmanager' ) ); return $schedules; } ### Function: Ensure .htaccess Is In The Backup Folder add_action( 'admin_notices', 'dbmanager_admin_notices' ); function dbmanager_admin_notices() { $backup_options = get_option( 'dbmanager_options' ); $backup_folder_writable = ( is_dir( $backup_options['path'] ) && wp_is_writable( $backup_options['path'] ) ); $htaccess_exists = ( file_exists( $backup_options['path'] . '/.htaccess' ) ); $webconfig_exists = ( file_exists( $backup_options['path'] . '/Web.config' ) ); $index_exists = ( file_exists( $backup_options['path'] . '/index.php' ) ); if( ! isset( $backup_options['hide_admin_notices'] ) || intval( $backup_options['hide_admin_notices'] ) === 0 ) { if( ! $backup_folder_writable || ! $index_exists || ( is_iis() && ! $webconfig_exists ) || ( ! is_iis() && ! $htaccess_exists ) ) { echo '<div class="error">'; if( !$backup_folder_writable ) { echo '<p style="font-weight: bold;">' . __( 'Your backup folder is NOT writable', 'wp-postratings') . '</p>'; echo '<p>'.sprintf( __( 'To correct this issue, make the folder <strong>%s</strong> writable.', 'wp-dbmanager' ), $backup_options['path'] ).'</p>'; } if( ! $index_exists || ( is_iis() && ! $webconfig_exists ) || ( ! is_iis() && ! $htaccess_exists ) ) { echo '<p style="font-weight: bold;">'.__( 'Your backup folder MIGHT be visible to the public', 'wp-dbmanager' ).'</p>'; } if( is_iis() ) { if( ! $webconfig_exists ) { echo '<p>'.sprintf( __( 'To correct this issue, move the file from <strong>%s</strong> to <strong>%s</strong>', 'wp-dbmanager'), plugin_dir_path( __FILE__ ) . 'Web.config.txt', $backup_options['path'] .'/Web.config' ).'</p>'; } } else { if( ! $htaccess_exists ) { echo '<p>'.sprintf( __( 'To correct this issue, move the file from <strong>%s</strong> to <strong>%s</strong>', 'wp-dbmanager'), plugin_dir_path( __FILE__ ) . 'htaccess.txt', $backup_options['path'] .'/.htaccess' ).'</p>'; } } if( ! $index_exists ) { echo '<p>'.sprintf( __( 'To correct this issue, move the file from <strong>%s</strong> to <strong>%s</strong>', 'wp-dbmanager'), plugin_dir_path( __FILE__ ) . 'index.php', $backup_options['path'] .'/index.php' ).'</p>'; } echo '<p>' . sprintf( __( '<a href="%s">Click here</a> to let WP-DBManager try to fix it', 'wp-dbmanager' ), wp_nonce_url( admin_url( 'admin.php?page=wp-dbmanager/database-backup.php&try_fix=1' ), 'wp-dbmanager_fix' ) ) . '</a></p>'; echo '</div>'; } } } ### Function: Auto Detect MYSQL and MYSQL Dump Paths function detect_mysql() { global $wpdb; $paths = array('mysq' => '', 'mysqldump' => ''); if(substr(PHP_OS,0,3) == 'WIN') { $mysql_install = $wpdb->get_row("SHOW VARIABLES LIKE 'basedir'"); if($mysql_install) { $install_path = trailingslashit( str_replace('\\', '/', $mysql_install->Value) ); $paths['mysql'] = $install_path.'bin/mysql.exe'; $paths['mysqldump'] = $install_path.'bin/mysqldump.exe'; } else { $paths['mysql'] = 'mysql.exe'; $paths['mysqldump'] = 'mysqldump.exe'; } } else { if(function_exists('exec')) { $paths['mysql'] = @exec('which mysql'); $paths['mysqldump'] = @exec('which mysqldump'); } else { $paths['mysql'] = 'mysql'; $paths['mysqldump'] = 'mysqldump'; } } return $paths; } ### Function: Check if WordPress is installed on IIS function is_iis() { $server_software = strtolower( $_SERVER['SERVER_SOFTWARE'] ); if ( strpos( $server_software, 'microsoft-iis') !== false ) { return true; } return false; } ### Executes OS-Dependent mysqldump Command (By: Vlad Sharanhovich) function execute_backup($command) { $backup_options = get_option('dbmanager_options'); check_backup_files(); if( realpath( $backup_options['path'] ) === false ) { return sprintf( __( '%s is not a valid backup path', 'wp-dbmanager' ), stripslashes( $backup_options['path'] ) ); } else if( dbmanager_is_valid_path( $backup_options['mysqldumppath'] ) === 0 ) { return sprintf( __( '%s is not a valid mysqldump path', 'wp-dbmanager' ), stripslashes( $backup_options['mysqldumppath'] ) ); } else if( dbmanager_is_valid_path( $backup_options['mysqlpath'] ) === 0 ) { return sprintf( __( '%s is not a valid mysql path', 'wp-dbmanager' ), stripslashes( $backup_options['mysqlpath'] ) ); } if( substr( PHP_OS, 0, 3 ) === 'WIN' ) { $writable_dir = $backup_options['path']; $tmpnam = $writable_dir.'/wp-dbmanager.bat'; $fp = fopen( $tmpnam, 'w' ); fwrite ($fp, $command ); fclose( $fp ); system( $tmpnam.' > NUL', $error ); unlink( $tmpnam ); } else { passthru( $command, $error ); } return $error; } ### Function: Check for valid file path function dbmanager_is_valid_path( $path ) { return preg_match( '/^[^*?"<>|;]*$/', $path ); } ### Function: Email database backup function dbmanager_email_backup($to = '', $backup_file_path) { if( is_email( $to ) && file_exists( $backup_file_path ) ) { $backup_options = get_option( 'dbmanager_options' ); $file_name = basename( $backup_file_path ); $file_gmt_date = gmdate( 'Y-m-d H:i:s', substr( $file_name, 0, 10 ) ); $file_size = format_size( filesize( $backup_file_path) ); $file_date = mysql2date( sprintf( __( '%s @ %s', 'wp-dbmanager' ), get_option( 'date_format' ), get_option( 'time_format' ) ), $file_gmt_date ); $to = ( !empty( $to ) ? $to : get_option( 'admin_email' ) ); $subject = ( !empty( $backup_options['backup_email_subject'] ) ? $backup_options['backup_email_subject'] : dbmanager_default_options( 'backup_email_subject' ) ); $subject = str_replace( array( '%SITE_NAME%' , '%POST_DATE%' , '%POST_TIME%' ) , array( wp_specialchars_decode( get_bloginfo( 'name' ), ENT_QUOTES ) , mysql2date( get_option( 'date_format' ), $file_gmt_date ) , mysql2date( get_option( 'time_format' ), $file_gmt_date ) ) , $subject ); $message = __( 'Website Name:', 'wp-dbmanager').' '. wp_specialchars_decode( get_bloginfo( 'name' ), ENT_QUOTES ) . "\n". __( 'Website URL:', 'wp-dbmanager' ).' '.get_bloginfo( 'url' )."\n". __( 'Backup File Name:', 'wp-dbmanager' ).' '.$file_name."\n". __( 'Backup File Date:', 'wp-dbmanager' ).' '.$file_date."\n". __( 'Backup File Size:', 'wp-dbmanager' ).' '.$file_size."\n\n". __( 'With Regards,', 'wp-dbmanager' )."\n". wp_specialchars_decode( get_bloginfo( 'name' ), ENT_QUOTES ). ' ' . __('Administrator', 'wp-dbmanager' )."\n". get_bloginfo('url'); $from = ( !empty( $backup_options['backup_email_from'] ) ? $backup_options['backup_email_from'] : dbmanager_default_options( 'backup_email_from' ) ); $from_name = ( !empty( $backup_options['backup_email_from_name'] ) ? $backup_options['backup_email_from_name'] : dbmanager_default_options( 'backup_email_from_name' ) ); $headers[] = 'From: "' . wp_specialchars_decode( stripslashes_deep( $from_name ), ENT_QUOTES ) . '" <'.$from.'>'; return wp_mail( $to, $subject, $message, $headers, $backup_file_path ); } return false; } ### Function: Format Bytes Into KB/MB if(!function_exists('format_size')) { function format_size($rawSize) { if($rawSize / 1073741824 > 1) return number_format_i18n($rawSize/1048576, 1) . ' '.__('GiB', 'wp-dbmanager'); else if ($rawSize / 1048576 > 1) return number_format_i18n($rawSize/1048576, 1) . ' '.__('MiB', 'wp-dbmanager'); else if ($rawSize / 1024 > 1) return number_format_i18n($rawSize/1024, 1) . ' '.__('KiB', 'wp-dbmanager'); else return number_format_i18n($rawSize, 0) . ' '.__('bytes', 'wp-dbmanager'); } } ### Function: Get File Extension if(!function_exists('file_ext')) { function file_ext($file_name) { return substr(strrchr($file_name, '.'), 1); } } ### Function: Check Folder Whether There Is Any File Inside if(!function_exists('is_emtpy_folder')) { function is_emtpy_folder($folder){ if(is_dir($folder) ){ $folder_content = ''; $handle = opendir($folder); while( (gettype( $name = readdir($handle)) != 'boolean')){ if($name != '.htaccess') { $name_array[] = $name; } } foreach($name_array as $temp) $folder_content .= $temp; if($folder_content == '...') return true; else return false; closedir($handle); } else return true; } } ### Function: Make Sure Maximum Number Of Database Backup Files Does Not Exceed function check_backup_files() { $backup_options = get_option('dbmanager_options'); $database_files = array(); if(!is_emtpy_folder($backup_options['path'])) { if ($handle = opendir($backup_options['path'])) { while (false !== ($file = readdir($handle))) { if ($file != '.' && $file != '..' && (file_ext($file) == 'sql' || file_ext($file) == 'gz')) { $database_files[] = $file; } } closedir($handle); sort($database_files); } } if(sizeof($database_files) >= $backup_options['max_backup']) { @unlink($backup_options['path'].'/'.$database_files[0]); } } ### Function: DBManager Default Options function dbmanager_default_options( $option_name ) { switch( $option_name ) { case 'backup_email_from': return get_option( 'admin_email' ); break; case 'backup_email_from_name': return wp_specialchars_decode( get_bloginfo( 'name' ), ENT_QUOTES ) .' '.__( 'Administrator', 'wp-dbmanager' ); break; case 'backup_email_subject': return __( '%SITE_NAME% Database Backup File For %POST_DATE% @ %POST_TIME%', 'wp-dbmanager' ); break; case 'hide_admin_notices': return 0; break; } } ### Function: Acticate Plugin register_activation_hook( __FILE__, 'dbmanager_activation' ); function dbmanager_activation( $network_wide ) { $auto = detect_mysql(); // Add Options $option_name = 'dbmanager_options'; $option = array( 'mysqldumppath' => $auto['mysqldump'] , 'mysqlpath' => $auto['mysql'] , 'path' => str_replace( '\\', '/', WP_CONTENT_DIR ).'/backup-db' , 'max_backup' => 10 , 'backup' => 1 , 'backup_gzip' => 0 , 'backup_period' => 604800 , 'backup_email' => get_option( 'admin_email' ) , 'backup_email_from' => dbmanager_default_options( 'backup_email_from' ) , 'backup_email_from_name' => dbmanager_default_options( 'backup_email_from_name' ) , 'backup_email_subject' => dbmanager_default_options( 'backup_email_subject' ) , 'optimize' => 3 , 'optimize_period' => 86400 , 'repair' => 2 , 'repair_period' => 604800 , 'hide_admin_notices' => 0 ); if ( is_multisite() && $network_wide ) { $ms_sites = function_exists( 'get_sites' ) ? get_sites() : wp_get_sites(); if( 0 < sizeof( $ms_sites ) ) { foreach ( $ms_sites as $ms_site ) { $blog_id = class_exists( 'WP_Site' ) ? $ms_site->blog_id : $ms_site['blog_id']; switch_to_blog( $blog_id ); add_option( $option_name, $option ); dbmanager_activate(); } } restore_current_blog(); } else { add_option( $option_name, $option ); dbmanager_activate(); } } function dbmanager_activate() { dbmanager_create_backup_folder(); // Set 'manage_database' Capabilities To Administrator $role = get_role( 'administrator' ); if( ! $role->has_cap( 'manage_database') ) { $role->add_cap( 'manage_database' ); } } function dbmanager_create_backup_folder() { $plugin_path = plugin_dir_path( __FILE__ ); $backup_path = WP_CONTENT_DIR . '/backup-db'; $backup_options = get_option( 'dbmanager_options' ); if( ! empty( $backup_options['path'] ) ) { $backup_path = $backup_options['path']; } // Create Backup Folder wp_mkdir_p( $backup_path ); if( is_dir( $backup_path ) && wp_is_writable( $backup_path ) ) { if( is_iis() ) { if ( ! is_file( $backup_path . '/Web.config' ) ) { @copy( $plugin_path . 'Web.config.txt', $backup_path . '/Web.config' ); } } else { if( ! is_file( $backup_path . '/.htaccess' ) ) { @copy( $plugin_path . 'htaccess.txt', $backup_path . '/.htaccess' ); } } if( ! is_file( $backup_path . '/index.php' ) ) { @copy( $plugin_path . 'index.php', $backup_path . '/index.php' ); } @chmod( $backup_path, 0750 ); } } add_action( 'init', 'dbmanager_try_fix' ); function dbmanager_try_fix() { if ( ! empty( $_GET['try_fix'] ) ) { if ( intval( $_GET['try_fix'] ) === 1 ) { check_admin_referer( 'wp-dbmanager_fix' ); dbmanager_create_backup_folder(); } } } ### Function: Download Database add_action( 'init', 'download_database' ); function download_database() { if( isset( $_POST['do'] ) && $_POST['do'] === __( 'Download', 'wp-dbmanager' ) && ! empty( $_POST['database_file'] ) ) { check_admin_referer( 'wp-dbmanager_manage' ); $database_file = trim( $_POST['database_file'] ); if( substr( $database_file, strlen( $database_file ) -4, 4 ) === '.sql' || substr( $database_file, strlen( $database_file ) -7, 7 ) === '.sql.gz' ) { $backup_options = get_option( 'dbmanager_options' ); $clean_file_name = sanitize_file_name( $database_file ); $clean_file_name = str_replace( 'sql_.gz', 'sql.gz', $clean_file_name ); $file_path = $backup_options['path'].'/'.$clean_file_name; header( 'Pragma: public' ); header( 'Expires: 0' ); header( 'Cache-Control: must-revalidate, post-check=0, pre-check=0' ); header( 'Content-Type: application/force-download' ); header( 'Content-Type: application/octet-stream' ); header( 'Content-Type: application/download' ); header( 'Content-Disposition: attachment; filename=' . basename( $file_path ) . ';' ); header( 'Content-Transfer-Encoding: binary' ); header( 'Content-Length: '.filesize( $file_path ) ); @readfile( $file_path ); } exit(); } } ### Function: Check whether a function is disabled. function dbmanager_is_function_disabled( $function_name ) { return in_array( $function_name, array_map( 'trim', explode( ',', ini_get( 'disable_functions' ) ) ) ); } ### Function: Database Options function dbmanager_options() { $text = ''; $backup_options = get_option('dbmanager_options'); $old_backup_options = $backup_options; if(!empty($_POST['Submit'])) { check_admin_referer('wp-dbmanager_options'); $backup_options['mysqldumppath'] = sanitize_text_field( $_POST['db_mysqldumppath'] ); $backup_options['mysqlpath'] = sanitize_text_field( $_POST['db_mysqlpath'] ); $backup_options['path'] = sanitize_text_field( $_POST['db_path'] ); $backup_options['max_backup'] = intval( $_POST['db_max_backup'] ); $backup_options['backup'] = intval( $_POST['db_backup'] ); $backup_options['backup_gzip'] = intval( $_POST['db_backup_gzip'] ); $backup_options['backup_period'] = intval( $_POST['db_backup_period'] ); $backup_options['backup_email'] = sanitize_email( $_POST['db_backup_email'] ); $backup_options['backup_email_from'] = sanitize_email( $_POST['db_backup_email_from'] ); $backup_options['backup_email_from_name'] = sanitize_text_field( $_POST['db_backup_email_from_name'] ); $backup_options['backup_email_subject'] = sanitize_text_field( $_POST['db_backup_email_subject'] ); $backup_options['optimize'] = intval( $_POST['db_optimize'] ); $backup_options['optimize_period'] = intval( $_POST['db_optimize_period'] ); $backup_options['repair'] = intval( $_POST['db_repair'] ); $backup_options['repair_period'] = intval( $_POST['db_repair_period'] ); $backup_options['hide_admin_notices'] = intval( $_POST['db_hide_admin_notices'] ); if( realpath( $backup_options['path'] ) === false ) { $text = '<div id="message" class="error"><p>' . sprintf( __( '%s is not a valid backup path', 'wp-dbmanager' ), stripslashes( $backup_options['path'] ) ) . '</p></div>'; $backup_options['path'] = $old_backup_options['path']; } else if( dbmanager_is_valid_path( $backup_options['mysqldumppath'] ) === 0 ) { $text = '<div id="message" class="error"><p>' . sprintf( __( '%s is not a valid mysqldump path', 'wp-dbmanager' ), stripslashes( $backup_options['mysqldumppath'] ) ) . '</p></div>'; $backup_options['mysqldumppath'] = $old_backup_options['mysqldumppath']; } else if( dbmanager_is_valid_path( $backup_options['mysqlpath'] ) === 0 ) { $text = '<div id="message" class="error"><p>' . sprintf( __( '%s is not a valid mysql path', 'wp-dbmanager' ), stripslashes( $backup_options['mysqlpath'] ) ) . '</p></div>'; $backup_options['mysqlpath'] = $old_backup_options['mysqlpath']; } $update_db_options = update_option( 'dbmanager_options', $backup_options ); if( $update_db_options ) { $text = '<div id="message" class="updated"><p>' . __( 'Database Options Updated', 'wp-dbmanager' ) . '</p></div>'; } if( empty( $text ) ) { $text = '<div id="message" class="error"><p>' . __( 'No Database Option Updated', 'wp-dbmanager' ) . '</p></div>'; } wp_clear_scheduled_hook( 'dbmanager_cron_backup' ); if( $backup_options['backup_period'] > 0 ) { if ( ! wp_next_scheduled( 'dbmanager_cron_backup' ) ) { wp_schedule_event( time(), 'dbmanager_backup', 'dbmanager_cron_backup' ); } } wp_clear_scheduled_hook( 'dbmanager_cron_optimize' ); if( $backup_options['optimize_period'] > 0 ) { if ( ! wp_next_scheduled('dbmanager_cron_optimize' ) ) { wp_schedule_event( time(), 'dbmanager_optimize', 'dbmanager_cron_optimize' ); } } wp_clear_scheduled_hook( 'dbmanager_cron_repair' ); if( $backup_options['repair_period'] > 0 ) { if ( ! wp_next_scheduled( 'dbmanager_cron_repair' ) ) { wp_schedule_event( time(), 'dbmanager_repair', 'dbmanager_cron_repair' ); } } } $path = detect_mysql(); // Default Options if( !isset( $backup_options['backup_email_from'] ) ) { $backup_options['backup_email_from'] = dbmanager_default_options( 'backup_email_from' ); } if( !isset( $backup_options['backup_email_from_name'] ) ) { $backup_options['backup_email_from_name'] = dbmanager_default_options( 'backup_email_from_name' ); } if( !isset( $backup_options['backup_email_subject'] ) ) { $backup_options['backup_email_subject'] = dbmanager_default_options( 'backup_email_subject' ); } if( !isset( $backup_options['hide_admin_notices'] ) ) { $backup_options['hide_admin_notices'] = dbmanager_default_options( 'hide_admin_notices' ); } ?> <script type="text/javascript"> /* <![CDATA[*/ function mysqlpath() { jQuery("#db_mysqlpath").val("<?php echo $path['mysql']; ?>"); } function mysqldumppath() { jQuery("#db_mysqldumppath").val("<?php echo $path['mysqldump']; ?>"); } /* ]]> */ </script> <?php if( ! empty( $text ) ) { echo $text; } ?> <!-- Database Options --> <form method="post" action="<?php echo admin_url('admin.php?page='.plugin_basename(__FILE__)); ?>"> <?php wp_nonce_field('wp-dbmanager_options'); ?> <div class="wrap"> <h2><?php _e('Database Options', 'wp-dbmanager'); ?></h2> <h3><?php _e('Paths', 'wp-dbmanager'); ?></h3> <table class="form-table"> <tr> <td width="20%" valign="top"><strong><?php _e('Path To mysqldump:', 'wp-dbmanager'); ?></strong></td> <td width="80%"> <input type="text" id="db_mysqldumppath" name="db_mysqldumppath" size="60" maxlength="100" value="<?php echo stripslashes($backup_options['mysqldumppath']); ?>" dir="ltr" /> <input type="button" value="<?php _e('Auto Detect', 'wp-dbmanager'); ?>" onclick="mysqldumppath();" /> <p><?php _e('The absolute path to mysqldump without trailing slash. If unsure, please email your server administrator about this.', 'wp-dbmanager'); ?></p> </td> </tr> <tr> <td valign="top"><strong><?php _e('Path To mysql:', 'wp-dbmanager'); ?></strong></td> <td> <input type="text" id="db_mysqlpath" name="db_mysqlpath" size="60" maxlength="100" value="<?php echo stripslashes($backup_options['mysqlpath']); ?>" dir="ltr" /> <input type="button" value="<?php _e('Auto Detect', 'wp-dbmanager'); ?>" onclick="mysqlpath();" /> <p><?php _e('The absolute path to mysql without trailing slash. If unsure, please email your server administrator about this.', 'wp-dbmanager'); ?></p> </td> </tr> <tr> <td valign="top"><strong><?php _e('Path To Backup:', 'wp-dbmanager'); ?></strong></td> <td> <input type="text" name="db_path" size="60" maxlength="105" value="<?php echo stripslashes($backup_options['path']); ?>" dir="ltr" /> <p><?php _e('The absolute path to your database backup folder without trailing slash. Make sure the folder is writable.', 'wp-dbmanager'); ?></p> </td> </tr> <tr> <td valign="top"><strong><?php _e('Maximum Backup Files:', 'wp-dbmanager'); ?></strong></td> <td> <input type="text" name="db_max_backup" size="5" maxlength="5" value="<?php echo stripslashes($backup_options['max_backup']); ?>" /> <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> </td> </tr> </table> <h3><?php _e('Note', 'wp-dbmanager'); ?></h3> <table class="form-table"> <tr> <td> <strong><?php _e('Windows Server', 'wp-dbmanager'); ?></strong><br /> <?php _e('For mysqldump path, you can try \'<strong>mysqldump.exe</strong>\'.', 'wp-dbmanager'); ?><br /> <?php _e('For mysql path, you can try \'<strong>mysql.exe</strong>\'.', 'wp-dbmanager'); ?> </td> </tr> <tr> <td> <strong><?php _e('Linux Server', 'wp-dbmanager'); ?></strong><br /> <?php _e('For mysqldump path, normally is just \'<strong>mysqldump</strong>\'.', 'wp-dbmanager'); ?><br /> <?php _e('For mysql path, normally is just \'<strong>mysql</strong>\'.', 'wp-dbmanager'); ?> </td> </tr> <tr> <td> <strong><?php _e('Note', 'wp-dbmanager'); ?></strong><br /> <?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'); ?> </td> </tr> </table> <h3><?php _e('Automatic Scheduling', 'wp-dbmanager'); ?></h3> <table class="form-table"> <tr> <td valign="top"><strong><?php _e('Automatic Backing Up Of DB:', 'wp-dbmanager'); ?></strong></td> <td> <?php _e('Next backup date: ', 'wp-dbmanager'); if(wp_next_scheduled('dbmanager_cron_backup')) { 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>'; } else { _e('N/A', 'wp-dbmanager'); } ?> <p> <?php _e('Every', 'wp-dbmanager'); ?> <input type="text" name="db_backup" size="3" maxlength="5" value="<?php echo intval($backup_options['backup']); ?>" /> <select name="db_backup_period" size="1"> <option value="0"<?php selected('0', $backup_options['backup_period']); ?>><?php _e('Disable', 'wp-dbmanager'); ?></option> <option value="60"<?php selected('60', $backup_options['backup_period']); ?>><?php _e('Minutes(s)', 'wp-dbmanager'); ?></option> <option value="3600"<?php selected('3600', $backup_options['backup_period']); ?>><?php _e('Hour(s)', 'wp-dbmanager'); ?></option> <option value="86400"<?php selected('86400', $backup_options['backup_period']); ?>><?php _e('Day(s)', 'wp-dbmanager'); ?></option> <option value="604800"<?php selected('604800', $backup_options['backup_period']); ?>><?php _e('Week(s)', 'wp-dbmanager'); ?></option> <option value="2592000"<?php selected('2592000', $backup_options['backup_period']); ?>><?php _e('Month(s)', 'wp-dbmanager'); ?></option> </select> <?php _e('Gzip', 'wp-dbmanager'); ?> <select name="db_backup_gzip" size="1"> <option value="0"<?php selected('0', $backup_options['backup_gzip']); ?>><?php _e('No', 'wp-dbmanager'); ?></option> <option value="1"<?php selected('1', $backup_options['backup_gzip']); ?>><?php _e('Yes', 'wp-dbmanager'); ?></option> </select> </p> <p><?php _e('WP-DBManager can automatically backup your database after a certain period.', 'wp-dbmanager'); ?></p> </td> </tr> <tr> <td valign="top"><strong><?php _e('Automatic Optimizing Of DB:', 'wp-dbmanager'); ?></strong></td> <td> <?php _e('Next optimize date: ', 'wp-dbmanager'); if(wp_next_scheduled('dbmanager_cron_optimize')) { 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>'; } else { _e('N/A', 'wp-dbmanager'); } ?> <p> <?php _e('Every', 'wp-dbmanager'); ?> <input type="text" name="db_optimize" size="3" maxlength="5" value="<?php echo intval($backup_options['optimize']); ?>" /> <select name="db_optimize_period" size="1"> <option value="0"<?php selected('0', $backup_options['optimize_period']); ?>><?php _e('Disable', 'wp-dbmanager'); ?></option> <option value="60"<?php selected('60', $backup_options['optimize_period']); ?>><?php _e('Minutes(s)', 'wp-dbmanager'); ?></option> <option value="3600"<?php selected('3600', $backup_options['optimize_period']); ?>><?php _e('Hour(s)', 'wp-dbmanager'); ?></option> <option value="86400"<?php selected('86400', $backup_options['optimize_period']); ?>><?php _e('Day(s)', 'wp-dbmanager'); ?></option> <option value="604800"<?php selected('604800', $backup_options['optimize_period']); ?>><?php _e('Week(s)', 'wp-dbmanager'); ?></option> <option value="2592000"<?php selected('2592000', $backup_options['optimize_period']); ?>><?php _e('Month(s)', 'wp-dbmanager'); ?></option> </select> </p> <p><?php _e('WP-DBManager can automatically optimize your database after a certain period.', 'wp-dbmanager'); ?></p> </td> </tr> <tr> <td valign="top"><strong><?php _e('Automatic Repairing Of DB:', 'wp-dbmanager'); ?></strong></td> <td> <?php _e('Next repair date: ', 'wp-dbmanager'); if(wp_next_scheduled('dbmanager_cron_repair')) { 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>'; } else { _e('N/A', 'wp-dbmanager'); } ?> <p> <?php _e('Every', 'wp-dbmanager'); ?> <input type="text" name="db_repair" size="3" maxlength="5" value="<?php echo intval($backup_options['repair']); ?>" /> <select name="db_repair_period" size="1"> <option value="0"<?php selected('0', $backup_options['repair_period']); ?>><?php _e('Disable', 'wp-dbmanager'); ?></option> <option value="60"<?php selected('60', $backup_options['repair_period']); ?>><?php _e('Minutes(s)', 'wp-dbmanager'); ?></option> <option value="3600"<?php selected('3600', $backup_options['repair_period']); ?>><?php _e('Hour(s)', 'wp-dbmanager'); ?></option> <option value="86400"<?php selected('86400', $backup_options['repair_period']); ?>><?php _e('Day(s)', 'wp-dbmanager'); ?></option> <option value="604800"<?php selected('604800', $backup_options['repair_period']); ?>><?php _e('Week(s)', 'wp-dbmanager'); ?></option> <option value="2592000"<?php selected('2592000', $backup_options['repair_period']); ?>><?php _e('Month(s)', 'wp-dbmanager'); ?></option> </select> </p> <p><?php _e('WP-DBManager can automatically repair your database after a certain period.', 'wp-dbmanager'); ?></p> </td> </tr> </table> <h3><?php _e('Backup Email Options', 'wp-dbmanager'); ?></h3> <table class="form-table"> <tr> <td valign="top"><strong><?php _e('To', 'wp-dbmanager'); ?></strong></td> <td> <p> <input type="text" name="db_backup_email" size="30" maxlength="250" placeholder="<?php _e ( 'To E-mail', 'wp-dbmanager' ); ?>" value="<?php echo esc_attr( stripslashes( $backup_options['backup_email'] ) ) ?>" dir="ltr" /> </p> <p><?php _e('(Leave blank to disable this feature)', 'wp-dbmanager'); ?></p> </td> </tr> <tr> <td valign="top"><strong><?php _e('From', 'wp-dbmanager'); ?></strong></td> <td> <p> <input type="text" name="db_backup_email_from_name" size="60" maxlength="250" placeholder="<?php _e ( 'From Name', 'wp-dbmanager' ); ?>" value="<?php echo esc_attr( stripslashes( $backup_options['backup_email_from_name'] ) ) ?>" dir="ltr" /> <<input type="text" name="db_backup_email_from" size="30" maxlength="250" placeholder="<?php _e ( 'From E-mail', 'wp-dbmanager' ); ?>" value="<?php echo esc_attr( stripslashes( $backup_options['backup_email_from'] ) ) ?>" dir="ltr" />> </p> <p><?php _e('(Leave blank to use the default)', 'wp-dbmanager'); ?></p> </td> </tr> <tr> <td valign="top"><strong><?php _e('Subject:', 'wp-dbmanager'); ?></strong></td> <td> <p> <input type="text" name="db_backup_email_subject" size="90" maxlength="255" placeholder="<?php _e ( 'Subject', 'wp-dbmanager' ); ?>" value="<?php echo esc_attr( stripslashes( $backup_options['backup_email_subject'] ) ) ?>" dir="ltr" /> </p> <p><?php _e('(Leave blank to use the default)', 'wp-dbmanager'); ?></p> </td> </tr> </table> <h3><?php _e('Miscellaneous Options', 'wp-dbmanager'); ?></h3> <table class="form-table"> <tr> <td valign="top"><strong><?php _e('Hide Admin Notices', 'wp-dbmanager'); ?></strong></td> <td> <p> <input type="radio" name="db_hide_admin_notices" value="1"<?php echo (intval( $backup_options['hide_admin_notices'] ) === 1 ? ' checked="checked"' : '' ); ?> /> <?php _e('Yes', 'wp-dbmanager'); ?> <input type="radio" name="db_hide_admin_notices" value="0"<?php echo (intval( $backup_options['hide_admin_notices'] ) === 0 ? ' checked="checked"' : '' ); ?> /> <?php _e('No', 'wp-dbmanager'); ?> </p> </td> </tr> </table> <p class="submit"> <input type="submit" name="Submit" class="button" value="<?php _e('Save Changes', 'wp-dbmanager'); ?>" /> </p> </div> </form> <?php } ?>