diff -r 000000000000 -r d970ebf37754 wp/wp-content/plugins/wp-db-backup/wp-db-backup.php
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/wp/wp-content/plugins/wp-db-backup/wp-db-backup.php Wed Nov 06 03:21:17 2013 +0000
@@ -0,0 +1,1524 @@
+Tools → Backup to get started.
+Author: Austin Matzko
+Author URI: http://austinmatzko.com/
+Version: 2.2.4
+
+Copyright 2013 Austin Matzko (email : austin at pressedcode.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., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
+*/
+
+/**
+ * Change WP_BACKUP_DIR if you want to
+ * use a different backup location
+ */
+
+if ( ! defined('ABSPATH') ) {
+ die('Please do not load this file directly.');
+}
+
+$rand = substr( md5( md5( DB_PASSWORD ) ), -5 );
+global $wpdbb_content_dir, $wpdbb_content_url, $wpdbb_plugin_dir;
+$wpdbb_content_dir = ( defined('WP_CONTENT_DIR') ) ? WP_CONTENT_DIR : ABSPATH . 'wp-content';
+$wpdbb_content_url = ( defined('WP_CONTENT_URL') ) ? WP_CONTENT_URL : get_option('siteurl') . '/wp-content';
+$wpdbb_plugin_dir = ( defined('WP_PLUGIN_DIR') ) ? WP_PLUGIN_DIR : $wpdbb_content_dir . '/plugins';
+
+if ( ! defined('WP_BACKUP_DIR') ) {
+ define('WP_BACKUP_DIR', $wpdbb_content_dir . '/backup-' . $rand . '/');
+}
+
+if ( ! defined('WP_BACKUP_URL') ) {
+ define('WP_BACKUP_URL', $wpdbb_content_url . '/backup-' . $rand . '/');
+}
+
+if ( ! defined('ROWS_PER_SEGMENT') ) {
+ define('ROWS_PER_SEGMENT', 100);
+}
+
+/**
+ * Set MOD_EVASIVE_OVERRIDE to true
+ * and increase MOD_EVASIVE_DELAY
+ * if the backup stops prematurely.
+ */
+// define('MOD_EVASIVE_OVERRIDE', false);
+if ( ! defined('MOD_EVASIVE_DELAY') ) {
+ define('MOD_EVASIVE_DELAY', '500');
+}
+
+class wpdbBackup {
+
+ var $backup_complete = false;
+ var $backup_file = '';
+ var $backup_filename;
+ var $core_table_names = array();
+ var $errors = array();
+ var $basename;
+ var $page_url;
+ var $referer_check_key;
+ var $version = '2.1.5-alpha';
+
+ function module_check() {
+ $mod_evasive = false;
+ if ( defined( 'MOD_EVASIVE_OVERRIDE' ) && true === MOD_EVASIVE_OVERRIDE ) return true;
+ if ( ! defined( 'MOD_EVASIVE_OVERRIDE' ) || false === MOD_EVASIVE_OVERRIDE ) return false;
+ if ( function_exists('apache_get_modules') )
+ foreach( (array) apache_get_modules() as $mod )
+ if ( false !== strpos($mod,'mod_evasive') || false !== strpos($mod,'mod_dosevasive') )
+ return true;
+ return false;
+ }
+
+ function wpdbBackup() {
+ global $table_prefix, $wpdb;
+ add_action('wp_ajax_save_backup_time', array(&$this, 'save_backup_time'));
+ add_action('init', array(&$this, 'init_textdomain'));
+ add_action('init', array(&$this, 'set_page_url'));
+ add_action('load-update-core.php', array(&$this, 'update_notice_action'));
+ add_action('wp_db_backup_cron', array(&$this, 'cron_backup'));
+ add_action('wp_cron_daily', array(&$this, 'wp_cron_daily'));
+ add_filter('cron_schedules', array(&$this, 'add_sched_options'));
+ add_filter('wp_db_b_schedule_choices', array(&$this, 'schedule_choices'));
+
+ $table_prefix = ( isset( $table_prefix ) ) ? $table_prefix : $wpdb->prefix;
+ $datum = date("Ymd_B");
+ $this->backup_filename = DB_NAME . "_$table_prefix$datum.sql";
+
+ $possible_names = array(
+ 'categories',
+ 'commentmeta',
+ 'comments',
+ 'link2cat',
+ 'linkcategories',
+ 'links',
+ 'options',
+ 'post2cat',
+ 'postmeta',
+ 'posts',
+ 'terms',
+ 'term_taxonomy',
+ 'term_relationships',
+ 'users',
+ 'usermeta',
+ );
+
+ foreach( $possible_names as $name ) {
+ if ( isset( $wpdb->{$name} ) ) {
+ $this->core_table_names[] = $wpdb->{$name};
+ }
+ }
+
+ $this->backup_dir = trailingslashit(apply_filters('wp_db_b_backup_dir', WP_BACKUP_DIR));
+ $this->basename = 'wp-db-backup';
+
+ $this->referer_check_key = $this->basename . '-download_' . DB_NAME;
+ if (isset($_POST['do_backup'])) {
+ $this->wp_secure('fatal');
+ check_admin_referer($this->referer_check_key);
+ $this->can_user_backup('main');
+ // save exclude prefs
+
+ $exc_revisions = isset( $_POST['exclude-revisions'] ) ? (array) $_POST['exclude-revisions'] : array();
+ $exc_spam = isset( $_POST['exclude-spam'] ) ? (array) $_POST['exclude-spam'] : array();
+ update_option('wp_db_backup_excs', array('revisions' => $exc_revisions, 'spam' => $exc_spam));
+ switch($_POST['do_backup']) {
+ case 'backup':
+ add_action('init', array(&$this, 'perform_backup'));
+ break;
+ case 'fragments':
+ add_action('admin_menu', array(&$this, 'fragment_menu'));
+ break;
+ }
+ } elseif (isset($_GET['fragment'] )) {
+ $this->can_user_backup('frame');
+ add_action('init', array(&$this, 'init'));
+ } elseif (isset($_GET['backup'] )) {
+ $this->can_user_backup();
+ add_action('init', array(&$this, 'init'));
+ } else {
+ add_action('admin_menu', array(&$this, 'admin_menu'));
+ }
+ }
+
+ function init() {
+ $this->can_user_backup();
+ if (isset($_GET['backup'])) {
+ $via = isset($_GET['via']) ? $_GET['via'] : 'http';
+
+ $this->backup_file = $_GET['backup'];
+ $this->validate_file($this->backup_file);
+
+ switch($via) {
+ case 'smtp':
+ case 'email':
+ $success = $this->deliver_backup($this->backup_file, 'smtp', $_GET['recipient'], 'frame');
+ $this->error_display( 'frame' );
+ if ( $success ) {
+ echo '
+
+
+ ';
+ }
+ break;
+ default:
+ $success = $this->deliver_backup($this->backup_file, $via);
+ echo $this->error_display( 'frame', false );
+
+ if ( $success ) {
+ echo '
+
+ ';
+ }
+ }
+ exit;
+ }
+ if (isset($_GET['fragment'] )) {
+ list($table, $segment, $filename) = explode(':', $_GET['fragment']);
+ $this->validate_file($filename);
+ $this->backup_fragment($table, $segment, $filename);
+ }
+
+ die();
+ }
+
+ function init_textdomain() {
+ load_plugin_textdomain('wp-db-backup', str_replace(ABSPATH, '', dirname(__FILE__)), dirname(plugin_basename(__FILE__)));
+ }
+
+ function set_page_url() {
+ $query_args = array( 'page' => $this->basename );
+ if ( function_exists('wp_create_nonce') )
+ $query_args = array_merge( $query_args, array('_wpnonce' => wp_create_nonce($this->referer_check_key)) );
+ $base = ( function_exists('site_url') ) ? site_url('', 'admin') : get_option('siteurl');
+ $this->page_url = add_query_arg( $query_args, $base . '/wp-admin/edit.php');
+ }
+
+ /*
+ * Add a link to back up your database when doing a core upgrade
+ */
+ function update_notice_action() {
+ if ( 'upgrade-core' == $_REQUEST['action'] ) :
+ ob_start(array(&$this, 'update_notice'));
+ add_action('admin_footer', create_function('', 'ob_end_flush();'));
+ endif;
+ }
+ function update_notice($text = '') {
+ $pattern = '#(.*?
)#';
+ $replace = '$1' . "\n" . sprintf(__('Click here to back up your database using the WordPress Database Backup plugin. Note: WordPress Database Backup does not back up your files, just your database.', 'wp-db-backup'), 'tools.php?page=wp-db-backup') . "
\n";
+ $text = preg_replace($pattern, $replace, $text);
+ return $text;
+ }
+
+ function build_backup_script() {
+ global $table_prefix, $wpdb;
+
+ echo "";
+ echo '
' . __('Progress','wp-db-backup') . '
+ ' .
+ __('DO NOT DO THE FOLLOWING AS IT WILL CAUSE YOUR BACKUP TO FAIL:','wp-db-backup').
+ '
+
+ '.__('Close this browser','wp-db-backup').'
+ '.__('Reload this page','wp-db-backup').'
+ '.__('Click the Stop or Back buttons in your browser','wp-db-backup').'
+
+ ' . __('Progress:','wp-db-backup') . '
+
+
+
+
+
+
+
+ ';
+ $this->backup_menu();
+ }
+
+ function backup_fragment($table, $segment, $filename) {
+ global $table_prefix, $wpdb;
+
+ echo "$table:$segment:$filename";
+
+ if($table == '') {
+ $msg = __('Creating backup file...','wp-db-backup');
+ } else {
+ if($segment == -1) {
+ $msg = sprintf(__('Finished backing up table \\"%s\\".','wp-db-backup'), $table);
+ } else {
+ $msg = sprintf(__('Backing up table \\"%s\\"...','wp-db-backup'), $table);
+ }
+ }
+
+ if (is_writable($this->backup_dir)) {
+ $this->fp = $this->open($this->backup_dir . $filename, 'a');
+ if(!$this->fp) {
+ $this->error(__('Could not open the backup file for writing!','wp-db-backup'));
+ $this->error(array('loc' => 'frame', 'kind' => 'fatal', 'msg' => __('The backup file could not be saved. Please check the permissions for writing to your backup directory and try again.','wp-db-backup')));
+ }
+ else {
+ if($table == '') {
+ //Begin new backup of MySql
+ $this->stow("# " . __('WordPress MySQL database backup','wp-db-backup') . "\n");
+ $this->stow("#\n");
+ $this->stow("# " . sprintf(__('Generated: %s','wp-db-backup'),date("l j. F Y H:i T")) . "\n");
+ $this->stow("# " . sprintf(__('Hostname: %s','wp-db-backup'),DB_HOST) . "\n");
+ $this->stow("# " . sprintf(__('Database: %s','wp-db-backup'),$this->backquote(DB_NAME)) . "\n");
+ $this->stow("# --------------------------------------------------------\n");
+ } else {
+ if($segment == 0) {
+ // Increase script execution time-limit to 15 min for every table.
+ if ( !ini_get('safe_mode')) @set_time_limit(15*60);
+ // Create the SQL statements
+ $this->stow("# --------------------------------------------------------\n");
+ $this->stow("# " . sprintf(__('Table: %s','wp-db-backup'),$this->backquote($table)) . "\n");
+ $this->stow("# --------------------------------------------------------\n");
+ }
+ $this->backup_table($table, $segment);
+ }
+ }
+ } else {
+ $this->error(array('kind' => 'fatal', 'loc' => 'frame', 'msg' => __('The backup directory is not writeable! Please check the permissions for writing to your backup directory and try again.','wp-db-backup')));
+ }
+
+ if($this->fp) $this->close($this->fp);
+
+ $this->error_display('frame');
+
+ echo '
+ ';
+ die();
+ }
+
+ function perform_backup() {
+ // are we backing up any other tables?
+ $also_backup = array();
+ if (isset($_POST['other_tables']))
+ $also_backup = $_POST['other_tables'];
+ $core_tables = $_POST['core_tables'];
+ $this->backup_file = $this->db_backup($core_tables, $also_backup);
+ if (false !== $this->backup_file) {
+ if ('smtp' == $_POST['deliver']) {
+ $this->deliver_backup($this->backup_file, $_POST['deliver'], $_POST['backup_recipient'], 'main');
+ if ( get_option('wpdb_backup_recip') != $_POST['backup_recipient'] ) {
+ update_option('wpdb_backup_recip', $_POST['backup_recipient'] );
+ }
+ wp_redirect($this->page_url);
+ } elseif ('http' == $_POST['deliver']) {
+ $download_uri = add_query_arg('backup',$this->backup_file,$this->page_url);
+ wp_redirect($download_uri);
+ exit;
+ }
+ // we do this to say we're done.
+ $this->backup_complete = true;
+ }
+ }
+
+ function admin_header() {
+ ?>
+
+
+ basename, array(&$this, 'backup_menu'));
+ add_action('load-' . $_page_hook, array(&$this, 'admin_load'));
+ if (function_exists('get_current_screen')) {
+ $screen = convert_to_screen($_page_hook);
+ if (method_exists($screen,'add_help_tab')) {
+ $screen->add_help_tab(array(
+ 'title' => __('Backup','wp-db-backup'),
+ 'id' => $_page_hook,
+ 'content' => $this->help_menu(),
+ ));
+ }
+ } elseif ( function_exists('add_contextual_help') ) {
+ $text = $this->help_menu();
+ add_contextual_help($_page_hook, $text);
+ }
+ }
+
+ function fragment_menu() {
+ $page_hook = add_management_page(__('Backup','wp-db-backup'), __('Backup','wp-db-backup'), 'import', $this->basename, array(&$this, 'build_backup_script'));
+ add_action('load-' . $page_hook, array(&$this, 'admin_load'));
+ }
+
+ /**
+ * Add WP-DB-Backup-specific help options to the 2.7 =< WP contextual help menu
+ * @return string The text of the help menu.
+ */
+ function help_menu() {
+ $text = "\n" . __('FAQ', 'wp-db-backup') . ' ';
+ return $text;
+ }
+
+ function save_backup_time() {
+ if ( $this->can_user_backup() ) {
+ // try to get a time from the input string
+ $time = strtotime(strval($_POST['backup-time']));
+ if ( ! empty( $time ) && time() < $time ) {
+ wp_clear_scheduled_hook( 'wp_db_backup_cron' ); // unschedule previous
+ $scheds = (array) wp_get_schedules();
+ $name = get_option('wp_cron_backup_schedule');
+ if ( 0 != $time ) {
+ wp_schedule_event($time, $name, 'wp_db_backup_cron');
+ echo gmdate(get_option('date_format') . ' ' . get_option('time_format'), $time + (get_option('gmt_offset') * 3600));
+ exit;
+ }
+ }
+ } else {
+ die(0);
+ }
+ }
+
+ /**
+ * Better addslashes for SQL queries.
+ * Taken from phpMyAdmin.
+ */
+ function sql_addslashes($a_string = '', $is_like = false) {
+ if ($is_like) $a_string = str_replace('\\', '\\\\\\\\', $a_string);
+ else $a_string = str_replace('\\', '\\\\', $a_string);
+ return str_replace('\'', '\\\'', $a_string);
+ }
+
+ /**
+ * Add backquotes to tables and db-names in
+ * SQL queries. Taken from phpMyAdmin.
+ */
+ function backquote($a_name) {
+ if (!empty($a_name) && $a_name != '*') {
+ if (is_array($a_name)) {
+ $result = array();
+ reset($a_name);
+ while(list($key, $val) = each($a_name))
+ $result[$key] = '`' . $val . '`';
+ return $result;
+ } else {
+ return '`' . $a_name . '`';
+ }
+ } else {
+ return $a_name;
+ }
+ }
+
+ function open($filename = '', $mode = 'w') {
+ if ('' == $filename) return false;
+ $fp = @fopen($filename, $mode);
+ return $fp;
+ }
+
+ function close($fp) {
+ fclose($fp);
+ }
+
+ /**
+ * Write to the backup file
+ * @param string $query_line the line to write
+ * @return null
+ */
+ function stow($query_line) {
+ if(false === @fwrite($this->fp, $query_line))
+ $this->error(__('There was an error writing a line to the backup script:','wp-db-backup') . ' ' . $query_line . ' ' . $php_errormsg);
+ }
+
+ /**
+ * Logs any error messages
+ * @param array $args
+ * @return bool
+ */
+ function error($args = array()) {
+ if ( is_string( $args ) )
+ $args = array('msg' => $args);
+ $args = array_merge( array('loc' => 'main', 'kind' => 'warn', 'msg' => ''), $args);
+ $this->errors[$args['kind']][] = $args['msg'];
+ if ( 'fatal' == $args['kind'] || 'frame' == $args['loc'])
+ $this->error_display($args['loc']);
+ return true;
+ }
+
+ /**
+ * Displays error messages
+ * @param array $errs
+ * @param string $loc
+ * @return string
+ */
+ function error_display($loc = 'main', $echo = true) {
+ $errs = $this->errors;
+ unset( $this->errors );
+ if ( ! count($errs) ) return;
+ $msg = '';
+ $errs['fatal'] = isset( $errs['fatal'] ) ? (array) $errs['fatal'] : array();
+ $errs['warn'] = isset( $errs['warn'] ) ? (array) $errs['warn'] : array();
+ $err_list = array_slice( array_merge( $errs['fatal'], $errs['warn'] ), 0, 10);
+ if ( 10 == count( $err_list ) )
+ $err_list[9] = __('Subsequent errors have been omitted from this log.','wp-db-backup');
+ $wrap = ( 'frame' == $loc ) ? "" : '%1$s';
+ $line = ( 'frame' == $loc ) ?
+ "try{ window.parent.addError('%1\$s'); } catch(e) { msgList += ' %1\$s';}\n" :
+ "%1\$s \n";
+ foreach( (array) $err_list as $err )
+ $msg .= sprintf($line,str_replace(array("\n","\r"), '', addslashes($err)));
+ $msg = sprintf($wrap,$msg);
+ if ( count($errs['fatal'] ) ) {
+ if ( function_exists('wp_die') && 'frame' != $loc ) wp_die(stripslashes($msg));
+ else die($msg);
+ }
+ else {
+ if ( $echo ) echo $msg;
+ else return $msg;
+ }
+ }
+
+ /**
+ * Taken partially from phpMyAdmin and partially from
+ * Alain Wolf, Zurich - Switzerland
+ * Website: http://restkultur.ch/personal/wolf/scripts/db_backup/
+
+ * Modified by Scott Merrill (http://www.skippy.net/)
+ * to use the WordPress $wpdb object
+ * @param string $table
+ * @param string $segment
+ * @return void
+ */
+ function backup_table($table, $segment = 'none') {
+ global $wpdb;
+
+ $table_structure = $wpdb->get_results("DESCRIBE $table");
+ if (! $table_structure) {
+ $this->error(__('Error getting table details','wp-db-backup') . ": $table");
+ return false;
+ }
+
+ if(($segment == 'none') || ($segment == 0)) {
+ // Add SQL statement to drop existing table
+ $this->stow("\n\n");
+ $this->stow("#\n");
+ $this->stow("# " . sprintf(__('Delete any existing table %s','wp-db-backup'),$this->backquote($table)) . "\n");
+ $this->stow("#\n");
+ $this->stow("\n");
+ $this->stow("DROP TABLE IF EXISTS " . $this->backquote($table) . ";\n");
+
+ // Table structure
+ // Comment in SQL-file
+ $this->stow("\n\n");
+ $this->stow("#\n");
+ $this->stow("# " . sprintf(__('Table structure of table %s','wp-db-backup'),$this->backquote($table)) . "\n");
+ $this->stow("#\n");
+ $this->stow("\n");
+
+ $create_table = $wpdb->get_results("SHOW CREATE TABLE $table", ARRAY_N);
+ if (false === $create_table) {
+ $err_msg = sprintf(__('Error with SHOW CREATE TABLE for %s.','wp-db-backup'), $table);
+ $this->error($err_msg);
+ $this->stow("#\n# $err_msg\n#\n");
+ }
+ $this->stow($create_table[0][1] . ' ;');
+
+ if (false === $table_structure) {
+ $err_msg = sprintf(__('Error getting table structure of %s','wp-db-backup'), $table);
+ $this->error($err_msg);
+ $this->stow("#\n# $err_msg\n#\n");
+ }
+
+ // Comment in SQL-file
+ $this->stow("\n\n");
+ $this->stow("#\n");
+ $this->stow('# ' . sprintf(__('Data contents of table %s','wp-db-backup'),$this->backquote($table)) . "\n");
+ $this->stow("#\n");
+ }
+
+ if(($segment == 'none') || ($segment >= 0)) {
+ $defs = array();
+ $ints = array();
+ foreach ($table_structure as $struct) {
+ if ( (0 === strpos($struct->Type, 'tinyint')) ||
+ (0 === strpos(strtolower($struct->Type), 'smallint')) ||
+ (0 === strpos(strtolower($struct->Type), 'mediumint')) ||
+ (0 === strpos(strtolower($struct->Type), 'int')) ||
+ (0 === strpos(strtolower($struct->Type), 'bigint')) ) {
+ $defs[strtolower($struct->Field)] = ( null === $struct->Default ) ? 'NULL' : $struct->Default;
+ $ints[strtolower($struct->Field)] = "1";
+ }
+ }
+
+
+ // Batch by $row_inc
+
+ if($segment == 'none') {
+ $row_start = 0;
+ $row_inc = ROWS_PER_SEGMENT;
+ } else {
+ $row_start = $segment * ROWS_PER_SEGMENT;
+ $row_inc = ROWS_PER_SEGMENT;
+ }
+
+ do {
+ // don't include extra stuff, if so requested
+ $excs = (array) get_option('wp_db_backup_excs');
+ $where = '';
+ if ( is_array($excs['spam'] ) && in_array($table, $excs['spam']) ) {
+ $where = ' WHERE comment_approved != "spam"';
+ } elseif ( is_array($excs['revisions'] ) && in_array($table, $excs['revisions']) ) {
+ $where = ' WHERE post_type != "revision"';
+ }
+
+ if ( !ini_get('safe_mode')) @set_time_limit(15*60);
+ $table_data = $wpdb->get_results("SELECT * FROM $table $where LIMIT {$row_start}, {$row_inc}", ARRAY_A);
+
+ $entries = 'INSERT INTO ' . $this->backquote($table) . ' VALUES (';
+ // \x08\\x09, not required
+ $search = array("\x00", "\x0a", "\x0d", "\x1a");
+ $replace = array('\0', '\n', '\r', '\Z');
+ if($table_data) {
+ foreach ($table_data as $row) {
+ $values = array();
+ foreach ($row as $key => $value) {
+ if ($ints[strtolower($key)]) {
+ // make sure there are no blank spots in the insert syntax,
+ // yet try to avoid quotation marks around integers
+ $value = ( null === $value || '' === $value) ? $defs[strtolower($key)] : $value;
+ $values[] = ( '' === $value ) ? "''" : $value;
+ } else {
+ $values[] = "'" . str_replace($search, $replace, $this->sql_addslashes($value)) . "'";
+ }
+ }
+ $this->stow(" \n" . $entries . implode(', ', $values) . ');');
+ }
+ $row_start += $row_inc;
+ }
+ } while((count($table_data) > 0) and ($segment=='none'));
+ }
+
+ if(($segment == 'none') || ($segment < 0)) {
+ // Create footer/closing comment in SQL-file
+ $this->stow("\n");
+ $this->stow("#\n");
+ $this->stow("# " . sprintf(__('End of data contents of table %s','wp-db-backup'),$this->backquote($table)) . "\n");
+ $this->stow("# --------------------------------------------------------\n");
+ $this->stow("\n");
+ }
+ } // end backup_table()
+
+ function db_backup($core_tables, $other_tables) {
+ global $table_prefix, $wpdb;
+
+ if (is_writable($this->backup_dir)) {
+ $this->fp = $this->open($this->backup_dir . $this->backup_filename);
+ if(!$this->fp) {
+ $this->error(__('Could not open the backup file for writing!','wp-db-backup'));
+ return false;
+ }
+ } else {
+ $this->error(__('The backup directory is not writeable!','wp-db-backup'));
+ return false;
+ }
+
+ //Begin new backup of MySql
+ $this->stow("# " . __('WordPress MySQL database backup','wp-db-backup') . "\n");
+ $this->stow("#\n");
+ $this->stow("# " . sprintf(__('Generated: %s','wp-db-backup'),date("l j. F Y H:i T")) . "\n");
+ $this->stow("# " . sprintf(__('Hostname: %s','wp-db-backup'),DB_HOST) . "\n");
+ $this->stow("# " . sprintf(__('Database: %s','wp-db-backup'),$this->backquote(DB_NAME)) . "\n");
+ $this->stow("# --------------------------------------------------------\n");
+
+ if ( (is_array($other_tables)) && (count($other_tables) > 0) )
+ $tables = array_merge($core_tables, $other_tables);
+ else
+ $tables = $core_tables;
+
+ foreach ($tables as $table) {
+ // Increase script execution time-limit to 15 min for every table.
+ if ( !ini_get('safe_mode')) @set_time_limit(15*60);
+ // Create the SQL statements
+ $this->stow("# --------------------------------------------------------\n");
+ $this->stow("# " . sprintf(__('Table: %s','wp-db-backup'),$this->backquote($table)) . "\n");
+ $this->stow("# --------------------------------------------------------\n");
+ $this->backup_table($table);
+ }
+
+ $this->close($this->fp);
+
+ if (count($this->errors)) {
+ return false;
+ } else {
+ return $this->backup_filename;
+ }
+
+ } //wp_db_backup
+
+ /**
+ * Sends the backed-up file via email
+ * @param string $to
+ * @param string $subject
+ * @param string $message
+ * @return bool
+ */
+ function send_mail( $to, $subject, $message, $diskfile) {
+ global $phpmailer;
+
+ $filename = basename($diskfile);
+
+ extract( apply_filters( 'wp_mail', compact( 'to', 'subject', 'message' ) ) );
+
+ if ( !is_object( $phpmailer ) || ( strtolower(get_class( $phpmailer )) != 'phpmailer' ) ) {
+ if ( file_exists( ABSPATH . WPINC . '/class-phpmailer.php' ) )
+ require_once ABSPATH . WPINC . '/class-phpmailer.php';
+ if ( file_exists( ABSPATH . WPINC . '/class-smtp.php' ) )
+ require_once ABSPATH . WPINC . '/class-smtp.php';
+ if ( class_exists( 'PHPMailer') )
+ $phpmailer = new PHPMailer();
+ }
+
+ // try to use phpmailer directly (WP 2.2+)
+ if ( is_object( $phpmailer ) && ( strtolower(get_class( $phpmailer )) == 'phpmailer' ) ) {
+
+ // Get the site domain and get rid of www.
+ $sitename = strtolower( $_SERVER['SERVER_NAME'] );
+ if ( substr( $sitename, 0, 4 ) == 'www.' ) {
+ $sitename = substr( $sitename, 4 );
+ }
+ $from_email = 'wordpress@' . $sitename;
+ $from_name = 'WordPress';
+
+ // Empty out the values that may be set
+ $phpmailer->ClearAddresses();
+ $phpmailer->ClearAllRecipients();
+ $phpmailer->ClearAttachments();
+ $phpmailer->ClearBCCs();
+ $phpmailer->ClearCCs();
+ $phpmailer->ClearCustomHeaders();
+ $phpmailer->ClearReplyTos();
+
+ $phpmailer->AddAddress( $to );
+ $phpmailer->AddAttachment($diskfile, $filename);
+ $phpmailer->Body = $message;
+ $phpmailer->CharSet = apply_filters( 'wp_mail_charset', get_bloginfo('charset') );
+ $phpmailer->From = apply_filters( 'wp_mail_from', $from_email );
+ $phpmailer->FromName = apply_filters( 'wp_mail_from_name', $from_name );
+ $phpmailer->IsMail();
+ $phpmailer->Subject = $subject;
+
+ do_action_ref_array( 'phpmailer_init', array( &$phpmailer ) );
+
+ $result = @$phpmailer->Send();
+
+ // old-style: build the headers directly
+ } else {
+ $randomish = md5(time());
+ $boundary = "==WPBACKUP-$randomish";
+ $fp = fopen($diskfile,"rb");
+ $file = fread($fp,filesize($diskfile));
+ $this->close($fp);
+
+ $data = chunk_split(base64_encode($file));
+
+ $headers .= "MIME-Version: 1.0\n";
+ $headers = 'From: wordpress@' . preg_replace('#^www\.#', '', strtolower($_SERVER['SERVER_NAME'])) . "\n";
+ $headers .= "Content-Type: multipart/mixed; boundary=\"$boundary\"\n";
+
+ // Add a multipart boundary above the plain message
+ $message = "This is a multi-part message in MIME format.\n\n" .
+ "--{$boundary}\n" .
+ "Content-Type: text/plain; charset=\"" . get_bloginfo('charset') . "\"\n" .
+ "Content-Transfer-Encoding: 7bit\n\n" .
+ $message . "\n\n";
+
+ // Add file attachment to the message
+ $message .= "--{$boundary}\n" .
+ "Content-Type: application/octet-stream;\n" .
+ " name=\"{$filename}\"\n" .
+ "Content-Disposition: attachment;\n" .
+ " filename=\"{$filename}\"\n" .
+ "Content-Transfer-Encoding: base64\n\n" .
+ $data . "\n\n" .
+ "--{$boundary}--\n";
+
+ $result = @wp_mail($to, $subject, $message, $headers);
+ }
+ return $result;
+
+ }
+
+ function deliver_backup($filename = '', $delivery = 'http', $recipient = '', $location = 'main') {
+ if ('' == $filename) { return false; }
+
+ $diskfile = $this->backup_dir . $filename;
+ $gz_diskfile = "{$diskfile}.gz";
+
+ /**
+ * Try upping the memory limit before gzipping
+ */
+ if ( function_exists('memory_get_usage') && ( (int) @ini_get('memory_limit') < 64 ) ) {
+ @ini_set('memory_limit', '64M' );
+ }
+
+ if ( file_exists( $diskfile ) && empty( $_GET['download-retry'] ) ) {
+ /**
+ * Try gzipping with an external application
+ */
+ if ( file_exists( $diskfile ) && ! file_exists( $gz_diskfile ) ) {
+ @exec( "gzip $diskfile" );
+ }
+
+ if ( file_exists( $gz_diskfile ) ) {
+ if ( file_exists( $diskfile ) ) {
+ unlink($diskfile);
+ }
+ $diskfile = $gz_diskfile;
+ $filename = "{$filename}.gz";
+
+ /**
+ * Try to compress to gzip, if available
+ */
+ } else {
+ if ( function_exists('gzencode') ) {
+ if ( function_exists('file_get_contents') ) {
+ $text = file_get_contents($diskfile);
+ } else {
+ $text = implode("", file($diskfile));
+ }
+ $gz_text = gzencode($text, 9);
+ $fp = fopen($gz_diskfile, "w");
+ fwrite($fp, $gz_text);
+ if ( fclose($fp) ) {
+ unlink($diskfile);
+ $diskfile = $gz_diskfile;
+ $filename = "{$filename}.gz";
+ }
+ }
+ }
+ /*
+ *
+ */
+ } elseif ( file_exists( $gz_diskfile ) && empty( $_GET['download-retry'] ) ) {
+ $diskfile = $gz_diskfile;
+ $filename = "{$filename}.gz";
+ }
+
+ if ('http' == $delivery) {
+ if ( ! file_exists( $diskfile ) ) {
+ if ( empty( $_GET['download-retry'] ) ) {
+ $this->error(array('kind' => 'fatal', 'msg' => sprintf(__('File not found:%s','wp-db-backup'), " $filename ") . '' . __('Return to Backup','wp-db-backup') . ' '));
+ } else {
+ return true;
+ }
+ } elseif ( file_exists( $diskfile ) ) {
+ header('Content-Description: File Transfer');
+ header('Content-Type: application/octet-stream');
+ header('Content-Length: ' . filesize($diskfile));
+ header("Content-Disposition: attachment; filename=$filename");
+ $success = readfile($diskfile);
+ if ( $success ) {
+ unlink($diskfile);
+ }
+ }
+ } elseif ('smtp' == $delivery) {
+ if (! file_exists($diskfile)) {
+ $msg = sprintf(__('File %s does not exist!','wp-db-backup'), $diskfile);
+ $this->error($msg);
+ return false;
+ }
+ if (! is_email($recipient)) {
+ $recipient = get_option('admin_email');
+ }
+ $message = sprintf(__("Attached to this email is\n %1s\n Size:%2s kilobytes\n",'wp-db-backup'), $filename, round(filesize($diskfile)/1024));
+ $success = $this->send_mail($recipient, get_bloginfo('name') . ' ' . __('Database Backup','wp-db-backup'), $message, $diskfile);
+
+ if ( false === $success ) {
+ $msg = __('The following errors were reported:','wp-db-backup') . "\n ";
+ if ( function_exists('error_get_last') ) {
+ $err = error_get_last();
+ $msg .= $err['message'];
+ } else {
+ $msg .= __('ERROR: The mail application has failed to deliver the backup.','wp-db-backup');
+ }
+ $this->error(array('kind' => 'fatal', 'loc' => $location, 'msg' => $msg));
+ } else {
+ if ( file_exists( $diskfile ) ) {
+ unlink($diskfile);
+ }
+ }
+ }
+ return $success;
+ }
+
+ function backup_menu() {
+ global $table_prefix, $wpdb;
+ $feedback = '';
+ $whoops = false;
+
+ // did we just do a backup? If so, let's report the status
+ if ( $this->backup_complete ) {
+ $feedback = '' . __('Backup Successful','wp-db-backup') . '!';
+ $file = $this->backup_file;
+ switch($_POST['deliver']) {
+ case 'http':
+ $feedback .= ' ' . sprintf(__('Your backup file: %2s should begin downloading shortly.','wp-db-backup'), WP_BACKUP_URL . "{$this->backup_file}", $this->backup_file);
+ break;
+ case 'smtp':
+ if (! is_email($_POST['backup_recipient'])) {
+ $feedback .= get_option('admin_email');
+ } else {
+ $feedback .= $_POST['backup_recipient'];
+ }
+ $feedback = ' ' . sprintf(__('Your backup has been emailed to %s','wp-db-backup'), $feedback);
+ break;
+ case 'none':
+ $feedback .= ' ' . __('Your backup file has been saved on the server. If you would like to download it now, right click and select "Save As"','wp-db-backup');
+ $feedback .= ': $file : " . sprintf(__('%s bytes','wp-db-backup'), filesize($this->backup_dir . $file));
+ }
+ $feedback .= '
';
+ }
+
+ // security check
+ $this->wp_secure();
+
+ if (count($this->errors)) {
+ $feedback .= '' . __('The following errors were reported:','wp-db-backup') . '
';
+ $feedback .= '
' . $this->error_display( 'main', false ) . '
';
+ $feedback .= "
";
+ }
+
+ // did we just save options for wp-cron?
+ if ( (function_exists('wp_schedule_event') || function_exists('wp_cron_init'))
+ && isset($_POST['wp_cron_backup_options']) ) :
+ do_action('wp_db_b_update_cron_options');
+ if ( function_exists('wp_schedule_event') ) {
+ wp_clear_scheduled_hook( 'wp_db_backup_cron' ); // unschedule previous
+ $scheds = (array) wp_get_schedules();
+ $name = strval($_POST['wp_cron_schedule']);
+ $interval = ( isset($scheds[$name]['interval']) ) ?
+ (int) $scheds[$name]['interval'] : 0;
+ update_option('wp_cron_backup_schedule', $name, false);
+ if ( 0 !== $interval ) {
+ wp_schedule_event(time() + $interval, $name, 'wp_db_backup_cron');
+ }
+ }
+ else {
+ update_option('wp_cron_backup_schedule', intval($_POST['cron_schedule']), false);
+ }
+ update_option('wp_cron_backup_tables', isset( $_POST['wp_cron_backup_tables'] ) ? $_POST['wp_cron_backup_tables'] : array() );
+ if (is_email($_POST['cron_backup_recipient'])) {
+ update_option('wp_cron_backup_recipient', $_POST['cron_backup_recipient'], false);
+ }
+ $feedback .= '' . __('Scheduled Backup Options Saved!','wp-db-backup') . '
';
+ endif;
+
+ $other_tables = array();
+ $also_backup = array();
+
+ // Get complete db table list
+ $all_tables = $wpdb->get_results("SHOW TABLES", ARRAY_N);
+ $all_tables = array_map(create_function('$a', 'return $a[0];'), $all_tables);
+ // Get list of WP tables that actually exist in this DB (for 1.6 compat!)
+ $wp_backup_default_tables = array_intersect($all_tables, $this->core_table_names);
+ // Get list of non-WP tables
+ $other_tables = array_diff($all_tables, $wp_backup_default_tables);
+
+ if ('' != $feedback)
+ echo $feedback;
+
+ if ( ! $this->wp_secure() )
+ return;
+
+ // Give the new dirs the same perms as wp-content.
+// $stat = stat( ABSPATH . 'wp-content' );
+// $dir_perms = $stat['mode'] & 0000777; // Get the permission bits.
+ $dir_perms = '0777';
+
+ // the file doesn't exist and can't create it
+ if ( ! file_exists($this->backup_dir) && ! @mkdir($this->backup_dir) ) {
+ ?>NOT exist, and we cannot create it.','wp-db-backup'); ?>
+
' . $this->backup_dir . ''); ?>
backup_dir) && ! @chmod($this->backup_dir, $dir_perms) ) {
+ ?>NOT writable! We cannot create the backup files.','wp-db-backup'); ?>
+
777', 'a+w
', '' . $this->backup_dir . '
'); ?>
+
fp = $this->open($this->backup_dir . 'test' );
+ if( $this->fp ) {
+ $this->close($this->fp);
+ @unlink($this->backup_dir . 'test' );
+ // the directory is not writable probably due to safe mode
+ } else {
+ ?>NOT writable! We cannot create the backup files.','wp-db-backup'); ?>
safe_mode file ownership restrictions, which limit what files web applications like WordPress can create.', 'wp-db-backup'); ?>
' . $this->backup_dir . '');
+ ?>
backup_dir . 'index.php') )
+ @ touch($this->backup_dir . 'index.php');
+ ?>
+
+
+
+
' . __('Scheduled Backup','wp-db-backup') . ' ';
+ $datetime = get_option('date_format') . ' ' . get_option('time_format');
+ if ( $cron ) :
+ $next_cron = wp_next_scheduled('wp_db_backup_cron');
+ if ( ! empty( $next_cron ) ) :
+ ?>
+
+ ' . gmdate($datetime, $next_cron + (get_option('gmt_offset') * 3600)) . ''); ?>
+
+
';
+ echo '';
+ endif; // end of wp_cron (legacy) section
+
+ echo '
';
+
+ } // end wp_backup_menu()
+
+ function get_sched() {
+ $options = array_keys( (array) wp_get_schedules() );
+ $freq = get_option('wp_cron_backup_schedule');
+ $freq = ( in_array( $freq , $options ) ) ? $freq : 'never';
+ return $freq;
+ }
+
+ function schedule_choices($schedule) { // create the cron menu based on the schedule
+ $wp_cron_backup_schedule = $this->get_sched();
+ $next_cron = wp_next_scheduled('wp_db_backup_cron');
+ $wp_cron_backup_schedule = ( empty( $next_cron ) ) ? 'never' : $wp_cron_backup_schedule;
+ $sort = array();
+ foreach ( (array) $schedule as $key => $value ) $sort[$key] = $value['interval'];
+ asort( $sort );
+ $schedule_sorted = array();
+ foreach ( (array) $sort as $key => $value ) $schedule_sorted[$key] = $schedule[$key];
+ $menu = '';
+ $schedule = array_merge( array( 'never' => array( 'interval' => 0, 'display' => __('Never','wp-db-backup') ) ),
+ (array) $schedule_sorted );
+ foreach ( $schedule as $name => $settings) {
+ $interval = (int) $settings['interval'];
+ if ( 0 == $interval && ! 'never' == $name ) continue;
+ $display = ( ! '' == $settings['display'] ) ? $settings['display'] : sprintf(__('%s seconds','wp-db-backup'),$interval);
+ $menu .= " cron_backup();
+ }
+
+ function cron_backup() {
+ global $table_prefix, $wpdb;
+ $all_tables = $wpdb->get_results("SHOW TABLES", ARRAY_N);
+ $all_tables = array_map(create_function('$a', 'return $a[0];'), $all_tables);
+ $core_tables = array_intersect($all_tables, $this->core_table_names);
+ $other_tables = get_option('wp_cron_backup_tables');
+ $recipient = get_option('wp_cron_backup_recipient');
+ $backup_file = $this->db_backup($core_tables, $other_tables);
+ if (false !== $backup_file)
+ return $this->deliver_backup($backup_file, 'smtp', $recipient, 'main');
+ else return false;
+ }
+
+ function add_sched_options($sched) {
+ $sched['weekly'] = array('interval' => 604800, 'display' => __('Once Weekly','wp-db-backup'));
+ return $sched;
+ }
+
+ /**
+ * Checks that WordPress has sufficient security measures
+ * @param string $kind
+ * @return bool
+ */
+ function wp_secure($kind = 'warn', $loc = 'main') {
+ global $wp_version;
+ if ( function_exists('wp_verify_nonce') ) return true;
+ else {
+ $this->error(array('kind' => $kind, 'loc' => $loc, 'msg' => sprintf(__('Your WordPress version, %1s, lacks important security features without which it is unsafe to use the WP-DB-Backup plugin. Hence, this plugin is automatically disabled. Please consider upgrading WordPress to a more recent version.','wp-db-backup'),$wp_version,'http://wordpress.org/download/')));
+ return false;
+ }
+ }
+
+ /**
+ * Checks that the user has sufficient permission to backup
+ * @param string $loc
+ * @return bool
+ */
+ function can_user_backup($loc = 'main') {
+ $can = false;
+ // make sure WPMU users are site admins, not ordinary admins
+ if ( function_exists('is_site_admin') && ! is_site_admin() )
+ return false;
+ if ( ( $this->wp_secure('fatal', $loc) ) && current_user_can('import') )
+ $can = $this->verify_nonce($_REQUEST['_wpnonce'], $this->referer_check_key, $loc);
+ if ( false == $can )
+ $this->error(array('loc' => $loc, 'kind' => 'fatal', 'msg' => __('You are not allowed to perform backups.','wp-db-backup')));
+ return $can;
+ }
+
+ /**
+ * Verify that the nonce is legitimate
+ * @param string $rec the nonce received
+ * @param string $nonce what the nonce should be
+ * @param string $loc the location of the check
+ * @return bool
+ */
+ function verify_nonce($rec = '', $nonce = 'X', $loc = 'main') {
+ if ( wp_verify_nonce($rec, $nonce) )
+ return true;
+ else
+ $this->error(array('loc' => $loc, 'kind' => 'fatal', 'msg' => sprintf(__('There appears to be an unauthorized attempt from this site to access your database located at %1s. The attempt has been halted.','wp-db-backup'),get_option('home'))));
+ }
+
+ /**
+ * Check whether a file to be downloaded is
+ * surreptitiously trying to download a non-backup file
+ * @param string $file
+ * @return null
+ */
+ function validate_file($file) {
+ if ( (false !== strpos($file, '..')) || (false !== strpos($file, './')) || (':' == substr($file, 1, 1)) )
+ $this->error(array('kind' => 'fatal', 'loc' => 'frame', 'msg' => __("Cheatin' uh ?",'wp-db-backup')));
+ }
+
+}
+
+function wpdbBackup_init() {
+ global $mywpdbbackup;
+ $mywpdbbackup = new wpdbBackup();
+}
+
+add_action('plugins_loaded', 'wpdbBackup_init');
+?>