PageRenderTime 22ms CodeModel.GetById 21ms RepoModel.GetById 0ms app.codeStats 0ms

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

https://gitlab.com/code26/selah
PHP | 199 lines | 135 code | 39 blank | 25 comment | 25 complexity | 3a2f5aeefd36151a9af54129247291e9 MD5 | raw file
  1. <?php
  2. /**
  3. * Options handling
  4. */
  5. if (!defined('ABSPATH')) die('No direct access allowed');
  6. class UpdraftPlus_Options {
  7. public static function user_can_manage() {
  8. $user_can_manage = current_user_can(apply_filters('option_page_capability_updraft-options-group', 'manage_options'));
  9. // false: allows the filter to know that the request is not coming from the multisite add-on
  10. return apply_filters('updraft_user_can_manage', $user_can_manage, false);
  11. }
  12. public static function options_table() {
  13. return 'options';
  14. }
  15. public static function admin_page_url() {
  16. return admin_url('options-general.php');
  17. }
  18. public static function admin_page() {
  19. return 'options-general.php';
  20. }
  21. /**
  22. * Extracts the last logged message from updraftplus last process
  23. *
  24. * @return Mixed - Value set for the option or the default message
  25. */
  26. public static function get_updraft_lastmessage() {
  27. return UpdraftPlus_Options::get_updraft_option('updraft_lastmessage', __('(Nothing has been logged yet)', 'updraftplus'));
  28. }
  29. public static function get_updraft_option($option, $default = null) {
  30. $ret = get_option($option, $default);
  31. return apply_filters('updraftplus_get_option', $ret, $option, $default);
  32. }
  33. /**
  34. * The apparently unused parameter is used in the alternative class in the Multisite add-on
  35. *
  36. * @param String $option specify option name
  37. * @param String $value specify option value
  38. * @param Boolean $use_cache whether or not to use the WP options cache
  39. * @return Boolean - as from update_option()
  40. */
  41. public static function update_updraft_option($option, $value, $use_cache = true) {
  42. return update_option($option, apply_filters('updraftplus_update_option', $value, $option, $use_cache));
  43. }
  44. public static function delete_updraft_option($option) {
  45. delete_option($option);
  46. }
  47. public static function add_admin_pages() {
  48. global $updraftplus_admin;
  49. add_submenu_page('options-general.php', 'UpdraftPlus', __('UpdraftPlus Backups', 'updraftplus'), apply_filters('option_page_capability_updraft-options-group', 'manage_options'), "updraftplus", array($updraftplus_admin, "settings_output"));
  50. }
  51. public static function options_form_begin($settings_fields = 'updraft-options-group', $allow_autocomplete = true, $get_params = array()) {
  52. global $pagenow;
  53. echo '<form method="post"';
  54. $page = '';
  55. if ('options-general.php' == $pagenow) $page = "options.php";
  56. if (!empty($get_params)) {
  57. $page .= '?';
  58. $first_one = true;
  59. foreach ($get_params as $k => $v) {
  60. if ($first_one) {
  61. $first_one = false;
  62. } else {
  63. $page .= '&';
  64. }
  65. $page .= urlencode($k).'='.urlencode($v);
  66. }
  67. }
  68. if ($page) echo ' action="'.$page.'"';
  69. if (!$allow_autocomplete) echo ' autocomplete="off"';
  70. echo '>';
  71. if ($settings_fields) {
  72. // This is settings_fields('updraft-options-group'), but with the referer pruned
  73. echo "<input type='hidden' name='option_page' value='" . esc_attr('updraft-options-group') . "' />";
  74. echo '<input type="hidden" name="action" value="update" />';
  75. wp_nonce_field("updraft-options-group-options", '_wpnonce', false);
  76. $remove_query_args = array('state', 'action', 'oauth_verifier');
  77. // wp_unslash() does not exist until after WP 3.5
  78. if (function_exists('wp_unslash')) {
  79. $referer = wp_unslash(remove_query_arg($remove_query_args, $_SERVER['REQUEST_URI']));
  80. } else {
  81. $referer = stripslashes_deep(remove_query_arg($remove_query_args, $_SERVER['REQUEST_URI']));
  82. }
  83. // Add back the page parameter if it looks like we were on the settings page via an OAuth callback that has now had all parameters removed. This is likely unnecessarily conservative, but there's nothing requiring more than this at the current time.
  84. if (substr($referer, -19, 19) == 'options-general.php' && false !== strpos($_SERVER['REQUEST_URI'], '?')) $referer .= '?page=updraftplus';
  85. $referer_field = '<input type="hidden" name="_wp_http_referer" value="'. esc_attr($referer) . '" />';
  86. echo $referer_field;
  87. }
  88. }
  89. /**
  90. * Runs upon the WordPress action admin_init
  91. */
  92. public static function admin_init() {
  93. static $already_inited = false;
  94. if ($already_inited) return;
  95. $already_inited = true;
  96. // If being called outside of the admin context, this may not be loaded yet
  97. if (!function_exists('register_setting')) include_once(ABSPATH.'wp-admin/includes/plugin.php');
  98. global $updraftplus, $updraftplus_admin;
  99. register_setting('updraft-options-group', 'updraft_interval', array($updraftplus, 'schedule_backup'));
  100. register_setting('updraft-options-group', 'updraft_interval_database', array($updraftplus, 'schedule_backup_database'));
  101. register_setting('updraft-options-group', 'updraft_interval_increments');
  102. register_setting('updraft-options-group', 'updraft_retain', array($updraftplus, 'retain_range'));
  103. register_setting('updraft-options-group', 'updraft_retain_db', array($updraftplus, 'retain_range'));
  104. register_setting('updraft-options-group', 'updraft_retain_extrarules');
  105. register_setting('updraft-options-group', 'updraft_encryptionphrase');
  106. register_setting('updraft-options-group', 'updraft_service', array($updraftplus, 'just_one'));
  107. $services_to_register = array_keys($updraftplus->backup_methods);
  108. foreach ($services_to_register as $service) {
  109. register_setting('updraft-options-group', 'updraft_'.$service);
  110. // We have to add the filter manually in order to get the second parameter passed through (register_setting() only registers with one parameter)
  111. add_filter('sanitize_option_updraft_'.$service, array($updraftplus, 'storage_options_filter'), 10, 2);
  112. }
  113. register_setting('updraft-options-group', 'updraft_ssl_nossl', 'absint');
  114. register_setting('updraft-options-group', 'updraft_log_syslog', 'absint');
  115. register_setting('updraft-options-group', 'updraft_ssl_useservercerts', 'absint');
  116. register_setting('updraft-options-group', 'updraft_ssl_disableverify', 'absint');
  117. register_setting('updraft-options-group', 'updraft_split_every', array($updraftplus_admin, 'optionfilter_split_every'));
  118. register_setting('updraft-options-group', 'updraft_dir', array($updraftplus_admin, 'prune_updraft_dir_prefix'));
  119. register_setting('updraft-options-group', 'updraft_report_warningsonly', array($updraftplus_admin, 'return_array'));
  120. register_setting('updraft-options-group', 'updraft_report_wholebackup', array($updraftplus_admin, 'return_array'));
  121. register_setting('updraft-options-group', 'updraft_autobackup_default', 'absint');
  122. register_setting('updraft-options-group', 'updraft_delete_local', 'absint');
  123. register_setting('updraft-options-group', 'updraft_debug_mode', 'absint');
  124. register_setting('updraft-options-group', 'updraft_extradbs');
  125. register_setting('updraft-options-group', 'updraft_backupdb_nonwp', 'absint');
  126. register_setting('updraft-options-group', 'updraft_include_plugins', 'absint');
  127. register_setting('updraft-options-group', 'updraft_include_themes', 'absint');
  128. register_setting('updraft-options-group', 'updraft_include_uploads', 'absint');
  129. register_setting('updraft-options-group', 'updraft_include_others', 'absint');
  130. register_setting('updraft-options-group', 'updraft_include_wpcore', 'absint');
  131. register_setting('updraft-options-group', 'updraft_include_wpcore_exclude', array($updraftplus, 'strip_dirslash'));
  132. register_setting('updraft-options-group', 'updraft_include_more', 'absint');
  133. register_setting('updraft-options-group', 'updraft_include_more_path', array($updraftplus, 'remove_empties'));
  134. register_setting('updraft-options-group', 'updraft_include_uploads_exclude', array($updraftplus, 'strip_dirslash'));
  135. register_setting('updraft-options-group', 'updraft_include_others_exclude', array($updraftplus, 'strip_dirslash'));
  136. register_setting('updraft-options-group', 'updraft_starttime_files', array('UpdraftPlus_Options', 'hourminute'));
  137. register_setting('updraft-options-group', 'updraft_starttime_db', array('UpdraftPlus_Options', 'hourminute'));
  138. register_setting('updraft-options-group', 'updraft_startday_files', array('UpdraftPlus_Options', 'week_or_month_day'));
  139. register_setting('updraft-options-group', 'updraft_startday_db', array('UpdraftPlus_Options', 'week_or_month_day'));
  140. global $pagenow;
  141. if (is_multisite() && 'options-general.php' == $pagenow && isset($_REQUEST['page']) && 'updraftplus' == substr($_REQUEST['page'], 0, 11)) {
  142. add_action('all_admin_notices', array('UpdraftPlus_Options', 'show_admin_warning_multisite'));
  143. }
  144. }
  145. public static function hourminute($pot) {
  146. if (preg_match("/^([0-2]?[0-9]):([0-5][0-9])$/", $pot, $matches)) return sprintf("%02d:%s", $matches[1], $matches[2]);
  147. if ('' == $pot) return date('H:i', time()+300);
  148. return '00:00';
  149. }
  150. public static function week_or_month_day($pot) {
  151. $pot = absint($pot);
  152. return ($pot>28) ? 1 : $pot;
  153. }
  154. public static function show_admin_warning_multisite() {
  155. global $updraftplus_admin;
  156. $updraftplus_admin->show_admin_warning('<strong>'.__('UpdraftPlus warning:', 'updraftplus').'</strong> '.__('This is a WordPress multi-site (a.k.a. network) installation.', 'updraftplus').' <a href="https://updraftplus.com/shop/">'.__('WordPress Multisite is supported, with extra features, by UpdraftPlus Premium, or the Multisite add-on.', 'updraftplus').'</a> '.__('Without upgrading, UpdraftPlus allows <strong>every</strong> blog admin who can modify plugin settings to back up (and hence access the data, including passwords, from) and restore (including with customised modifications, e.g. changed passwords) <strong>the entire network</strong>.', 'updraftplus').' '.__('(This applies to all WordPress backup plugins unless they have been explicitly coded for multisite compatibility).', 'updraftplus'), 'error');
  157. }
  158. }
  159. add_action('admin_init', array('UpdraftPlus_Options', 'admin_init'));
  160. add_action('admin_menu', array('UpdraftPlus_Options', 'add_admin_pages'));