PageRenderTime 34ms CodeModel.GetById 18ms RepoModel.GetById 0ms app.codeStats 0ms

/wp-content/plugins/updraftplus/updraftplus.php

https://gitlab.com/code26/selah
PHP | 215 lines | 116 code | 31 blank | 68 comment | 73 complexity | bc8282b8c86954f3828c4ba7b80181bf MD5 | raw file
  1. <?php
  2. // @codingStandardsIgnoreStart
  3. /*
  4. Plugin Name: UpdraftPlus - Backup/Restore
  5. Plugin URI: https://updraftplus.com
  6. Description: Backup and restore: take backups locally, or backup to Amazon S3, Dropbox, Google Drive, Rackspace, (S)FTP, WebDAV & email, on automatic schedules.
  7. Author: UpdraftPlus.Com, DavidAnderson
  8. Version: 1.14.3
  9. Donate link: https://david.dw-perspective.org.uk/donate
  10. License: GPLv3 or later
  11. Text Domain: updraftplus
  12. Domain Path: /languages
  13. Author URI: https://updraftplus.com
  14. */
  15. // @codingStandardsIgnoreEnd
  16. /*
  17. Portions copyright 2011-17 David Anderson
  18. Portions copyright 2010 Paul Kehrer
  19. Other portions copyright as indicated by authors in the relevant files
  20. This program is free software; you can redistribute it and/or modify
  21. it under the terms of the GNU General Public License as published by
  22. the Free Software Foundation; either version 3 of the License, or
  23. (at your option) any later version.
  24. This program is distributed in the hope that it will be useful,
  25. but WITHOUT ANY WARRANTY; without even the implied warranty of
  26. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  27. GNU General Public License for more details.
  28. You should have received a copy of the GNU General Public License
  29. along with this program; if not, write to the Free Software
  30. Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  31. */
  32. if (!defined('ABSPATH')) die('No direct access allowed');
  33. if ((isset($updraftplus) && is_object($updraftplus) && is_a($updraftplus, 'UpdraftPlus')) || function_exists('updraftplus_modify_cron_schedules')) return;
  34. define('UPDRAFTPLUS_DIR', dirname(__FILE__));
  35. define('UPDRAFTPLUS_URL', plugins_url('', __FILE__));
  36. define('UPDRAFT_DEFAULT_OTHERS_EXCLUDE', 'upgrade,cache,updraft,backup*,*backups,mysql.sql,debug.log');
  37. define('UPDRAFT_DEFAULT_UPLOADS_EXCLUDE', 'backup*,*backups,backwpup*,wp-clone,snapshots');
  38. // The following can go in your wp-config.php
  39. // Tables whose data can be skipped without significant loss, if (and only if) the attempt to back them up fails (e.g. bwps_log, from WordPress Better Security, is log data; but individual entries can be huge and cause out-of-memory fatal errors on low-resource environments). Comma-separate the table names (without the WordPress table prefix).
  40. if (!defined('UPDRAFTPLUS_DATA_OPTIONAL_TABLES')) define('UPDRAFTPLUS_DATA_OPTIONAL_TABLES', 'bwps_log,statpress,slim_stats,redirection_logs,Counterize,Counterize_Referers,Counterize_UserAgents,wbz404_logs,wbz404_redirects,tts_trafficstats,tts_referrer_stats,wponlinebackup_generations,svisitor_stat,simple_feed_stats,itsec_log,relevanssi_log,blc_instances,wysija_email_user_stat,woocommerce_sessions,et_bloom_stats,redirection_404,lbakut_activity_log');
  41. if (!defined('UPDRAFTPLUS_ZIP_EXECUTABLE')) define('UPDRAFTPLUS_ZIP_EXECUTABLE', "/usr/bin/zip,/bin/zip,/usr/local/bin/zip,/usr/sfw/bin/zip,/usr/xdg4/bin/zip,/opt/bin/zip");
  42. if (!defined('UPDRAFTPLUS_MYSQLDUMP_EXECUTABLE')) define('UPDRAFTPLUS_MYSQLDUMP_EXECUTABLE', updraftplus_build_mysqldump_list());
  43. // If any individual file size is greater than this, then a warning is given
  44. if (!defined('UPDRAFTPLUS_WARN_FILE_SIZE')) define('UPDRAFTPLUS_WARN_FILE_SIZE', 1024*1024*250);
  45. // On a test on a Pentium laptop, 100,000 rows needed ~ 1 minute to write out - so 150,000 is around the CPanel default of 90 seconds execution time.
  46. if (!defined('UPDRAFTPLUS_WARN_DB_ROWS')) define('UPDRAFTPLUS_WARN_DB_ROWS', 150000);
  47. // The smallest value (in megabytes) that the "split zip files at" setting is allowed to be set to
  48. if (!defined('UPDRAFTPLUS_SPLIT_MIN')) define('UPDRAFTPLUS_SPLIT_MIN', 25);
  49. // The maximum number of files to batch at one time when writing to the backup archive. You'd only be likely to want to raise (not lower) this.
  50. if (!defined('UPDRAFTPLUS_MAXBATCHFILES')) define('UPDRAFTPLUS_MAXBATCHFILES', 500);
  51. // If any individual email attachment is greater than this, then a warning is given (and then removed if the email actually succeeds)
  52. if (!defined('UPDRAFTPLUS_WARN_EMAIL_SIZE')) define('UPDRAFTPLUS_WARN_EMAIL_SIZE', 20*1048576);
  53. // Filetypes that should be stored inside the zip without any attempt at further compression. By default, we mark several extensions that refer to filetypes that are already compressed as not needing further compression - which saves time/resources. This option only applies to zip engines that support varying the compression method. Specify in lower-case, and upper-case variants (and for some zip engines, all variants) will automatically be included.
  54. if (!defined('UPDRAFTPLUS_ZIP_NOCOMPRESS')) define('UPDRAFTPLUS_ZIP_NOCOMPRESS', '.jpg,.jpeg,.png,.gif,.zip,.gz,.bz2,.xz,.rar,.mp3,.mp4,.mpeg,.avi,.mov');
  55. // This is passed to set_time_limit() at various points, to try to maximise run-time. (UD resumes if it gets killed, but more in one stretch always helps). The effect of this varies according to the hosting setup - it can't necessarily always be controlled.
  56. if (!defined('UPDRAFTPLUS_SET_TIME_LIMIT')) define('UPDRAFTPLUS_SET_TIME_LIMIT', 900);
  57. // Options to pass to the zip binary (if that method happens to be used). By default, we mark the extensions specified in UPDRAFTPLUS_ZIP_NOCOMPRESS for non-compression via the -n flag
  58. if (!defined('UPDRAFTPLUS_BINZIP_OPTS')) {
  59. $zip_nocompress = array_map('trim', explode(',', UPDRAFTPLUS_ZIP_NOCOMPRESS));
  60. $zip_binzip_opts = '';
  61. foreach ($zip_nocompress as $ext) {
  62. if (empty($zip_binzip_opts)) {
  63. $zip_binzip_opts = "-n $ext:".strtoupper($ext);
  64. } else {
  65. $zip_binzip_opts .= ':'.$ext.':'.strtoupper($ext);
  66. }
  67. }
  68. define('UPDRAFTPLUS_BINZIP_OPTS', $zip_binzip_opts);
  69. }
  70. // Load add-ons and files that may or may not be present, depending on where the plugin was distributed
  71. if (is_file(UPDRAFTPLUS_DIR.'/autoload.php')) require_once(UPDRAFTPLUS_DIR.'/autoload.php');
  72. if (!function_exists('updraftplus_modify_cron_schedules')) :
  73. /**
  74. * wp-cron only has hourly, daily and twicedaily, so we need to add some of our own
  75. *
  76. * @param array $schedules an array of schedule types
  77. * @return array
  78. */
  79. function updraftplus_modify_cron_schedules($schedules) {
  80. $schedules['weekly'] = array('interval' => 604800, 'display' => 'Once Weekly');
  81. $schedules['fortnightly'] = array('interval' => 1209600, 'display' => 'Once Each Fortnight');
  82. $schedules['monthly'] = array('interval' => 2592000, 'display' => 'Once Monthly');
  83. $schedules['every4hours'] = array('interval' => 14400, 'display' => sprintf(__('Every %s hours', 'updraftplus'), 4));
  84. $schedules['every8hours'] = array('interval' => 28800, 'display' => sprintf(__('Every %s hours', 'updraftplus'), 8));
  85. return $schedules;
  86. }
  87. endif;
  88. // http://codex.wordpress.org/Plugin_API/Filter_Reference/cron_schedules. Raised priority because some plugins wrongly over-write all prior schedule changes (including BackupBuddy!)
  89. add_filter('cron_schedules', 'updraftplus_modify_cron_schedules', 30);
  90. // The checks here before loading are for performance only - unless one of those conditions is met, then none of the hooks will ever be used
  91. if (!is_admin() && (!defined('DOING_CRON') || !DOING_CRON) && (!defined('XMLRPC_REQUEST') || !XMLRPC_REQUEST) && empty($_SERVER['SHELL']) && empty($_SERVER['USER']) && empty($_POST['udrpc_message']) && empty($_GET['udcentral_action']) && (empty($_SERVER['REQUEST_METHOD']) || 'OPTIONS' != $_SERVER['REQUEST_METHOD'])) {
  92. // There is no good way to work out if the cron event is likely to be called under the ALTERNATE_WP_CRON system, other than re-running the calculation
  93. // If ALTERNATE_WP_CRON is not active (and a few other things), then we are done
  94. if (!defined('ALTERNATE_WP_CRON') || !ALTERNATE_WP_CRON || !empty($_POST) || defined('DOING_AJAX') || isset($_GET['doing_wp_cron'])) return;
  95. // The check below is the one used by spawn_cron() to decide whether cron events should be run
  96. $gmt_time = microtime(true);
  97. $lock = get_transient('doing_cron');
  98. if ($lock > $gmt_time + 10 * 60) $lock = 0;
  99. if ((defined('WP_CRON_LOCK_TIMEOUT') && $lock + WP_CRON_LOCK_TIMEOUT > $gmt_time) || (!defined('WP_CRON_LOCK_TIMEOUT') && $lock + 60 > $gmt_time)) return;
  100. if (function_exists('_get_cron_array')) {
  101. $crons = _get_cron_array();
  102. } else {
  103. $crons = get_option('cron');
  104. }
  105. if (!is_array($crons)) return;
  106. $keys = array_keys($crons);
  107. if (isset($keys[0]) && $keys[0] > $gmt_time) return;
  108. // If we got this far, then cron is going to be fired, so we do want to load all our hooks
  109. }
  110. $updraftplus_have_addons = 0;
  111. if (is_dir(UPDRAFTPLUS_DIR.'/addons') && $dir_handle = opendir(UPDRAFTPLUS_DIR.'/addons')) {
  112. while (false !== ($e = readdir($dir_handle))) {
  113. if (is_file(UPDRAFTPLUS_DIR.'/addons/'.$e) && preg_match('/\.php$/', $e)) {
  114. // We used to have 1024 bytes here - but this meant that if someone's site was hacked and a lot of code added at the top, and if they were running a too-low PHP version, then they might just see the symptom rather than the cause - and raise the support request with us.
  115. $header = file_get_contents(UPDRAFTPLUS_DIR.'/addons/'.$e, false, null, -1, 16384);
  116. $phprequires = (preg_match("/RequiresPHP: (\d[\d\.]+)/", $header, $matches)) ? $matches[1] : false;
  117. $phpinclude = (preg_match("/IncludePHP: (\S+)/", $header, $matches)) ? $matches[1] : false;
  118. if (false === $phprequires || version_compare(PHP_VERSION, $phprequires, '>=')) {
  119. $updraftplus_have_addons++;
  120. if ($phpinclude) include_once(UPDRAFTPLUS_DIR.'/'.$phpinclude);
  121. include_once(UPDRAFTPLUS_DIR.'/addons/'.$e);
  122. }
  123. }
  124. }
  125. @closedir($dir_handle);
  126. }
  127. if (is_file(UPDRAFTPLUS_DIR.'/udaddons/updraftplus-addons.php')) require_once(UPDRAFTPLUS_DIR.'/udaddons/updraftplus-addons.php');
  128. if (!file_exists(UPDRAFTPLUS_DIR.'/class-updraftplus.php') || !file_exists(UPDRAFTPLUS_DIR.'/options.php')) {
  129. /**
  130. * Warn if they've not got the whole plugin - can happen if WP crashes (e.g. out of disk space) when upgrading the plugin
  131. */
  132. function updraftplus_incomplete_install_warning() {
  133. echo '<div class="updraftmessage error"><p><strong>'.__('Error', 'updraftplus').':</strong> '.__("You do not have UpdraftPlus completely installed - please de-install and install it again. Most likely, WordPress malfunctioned when copying the plugin files.", 'updraftplus').' <a href="https://updraftplus.com/faqs/wordpress-crashed-when-updating-updraftplus-what-can-i-do/">'.__('Go here for more information.', 'updraftplus').'</a></p></div>';
  134. }
  135. add_action('all_admin_notices', 'updraftplus_incomplete_install_warning');
  136. } else {
  137. include_once(UPDRAFTPLUS_DIR.'/class-updraftplus.php');
  138. $updraftplus = new UpdraftPlus();
  139. $GLOBALS['updraftplus'] = $updraftplus;
  140. $updraftplus->have_addons = $updraftplus_have_addons;
  141. if (!$updraftplus->memory_check(192)) {
  142. // Experience appears to show that the memory limit is only likely to be hit (unless it is very low) by single files that are larger than available memory (when compressed)
  143. // Add sanity checks - found someone who'd set WP_MAX_MEMORY_LIMIT to 256K !
  144. if (!$updraftplus->memory_check($updraftplus->memory_check_current(WP_MAX_MEMORY_LIMIT))) {
  145. $new = absint($updraftplus->memory_check_current(WP_MAX_MEMORY_LIMIT));
  146. if ($new>32 && $new<100000) {
  147. @ini_set('memory_limit', $new.'M');
  148. }
  149. }
  150. }
  151. }
  152. // Ubuntu bug - https://bugs.launchpad.net/ubuntu/+source/php5/+bug/1315888
  153. if (!function_exists('gzopen') && function_exists('gzopen64')) {
  154. function gzopen($filename, $mode, $use_include_path = 0) {
  155. return gzopen64($filename, $mode, $use_include_path);
  156. }
  157. }
  158. /**
  159. * For finding mysqldump. Added to include Windows locations
  160. */
  161. function updraftplus_build_mysqldump_list() {
  162. if ('win' == strtolower(substr(PHP_OS, 0, 3)) && function_exists('glob')) {
  163. $drives = array('C', 'D', 'E');
  164. if (!empty($_SERVER['DOCUMENT_ROOT'])) {
  165. // Get the drive that this is running on
  166. $current_drive = strtoupper(substr($_SERVER['DOCUMENT_ROOT'], 0, 1));
  167. if (!in_array($current_drive, $drives)) array_unshift($drives, $current_drive);
  168. }
  169. $directories = array();
  170. foreach ($drives as $drive_letter) {
  171. $dir = glob("$drive_letter:\\{Program Files\\MySQL\\{,MySQL*,etc}{,\\bin,\\?},mysqldump}\\mysqldump*", GLOB_BRACE);
  172. if (is_array($dir)) $directories = array_merge($directories, $dir);
  173. }
  174. $drive_string = implode(',', $directories);
  175. return $drive_string;
  176. } else {
  177. return "/usr/bin/mysqldump,/bin/mysqldump,/usr/local/bin/mysqldump,/usr/sfw/bin/mysqldump,/usr/xdg4/bin/mysqldump,/opt/bin/mysqldump";
  178. }
  179. }
  180. // Do this even if the missing files detection above fired, as the "missing files" detection above has a greater chance of showing the user useful info
  181. if (!class_exists('UpdraftPlus_Options')) require_once(UPDRAFTPLUS_DIR.'/options.php');