This project does not seem to handle request data directly as such no vulnerable execution paths were found.
include
, or for example
via PHP's auto-loading mechanism.
These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more
1 | <?php |
||
2 | /** |
||
3 | * Give Settings Page/Tab |
||
4 | * |
||
5 | * @package Give |
||
6 | * @subpackage Classes/Give_Settings_Advanced |
||
7 | * @copyright Copyright (c) 2016, GiveWP |
||
8 | * @license http://opensource.org/licenses/gpl-2.0.php GNU Public License |
||
9 | * @since 1.8 |
||
10 | */ |
||
11 | |||
12 | if ( ! defined( 'ABSPATH' ) ) { |
||
13 | exit; // Exit if accessed directly |
||
14 | } |
||
15 | |||
16 | if ( ! class_exists( 'Give_Settings_Advanced' ) ) : |
||
17 | |||
18 | /** |
||
19 | * Give_Settings_Advanced. |
||
20 | * |
||
21 | * @sine 1.8 |
||
22 | */ |
||
23 | class Give_Settings_Advanced extends Give_Settings_Page { |
||
24 | |||
25 | /** |
||
26 | * Constructor. |
||
27 | */ |
||
28 | View Code Duplication | public function __construct() { |
|
0 ignored issues
–
show
|
|||
29 | $this->id = 'advanced'; |
||
30 | $this->label = __( 'Advanced', 'give' ); |
||
31 | |||
32 | $this->default_tab = 'advanced-options'; |
||
33 | |||
34 | if ( $this->id === give_get_current_setting_tab() ) { |
||
35 | add_action( 'give_admin_field_remove_cache_button', array( $this, 'render_remove_cache_button' ), 10, 1 ); |
||
36 | add_action( 'give_save_settings_give_settings', array( $this, 'validate_settngs' ) ); |
||
37 | } |
||
38 | |||
39 | parent::__construct(); |
||
40 | } |
||
41 | |||
42 | /** |
||
43 | * Get settings array. |
||
44 | * |
||
45 | * @since 1.8 |
||
46 | * @return array |
||
47 | */ |
||
48 | public function get_settings() { |
||
49 | $settings = array(); |
||
50 | |||
51 | $current_section = give_get_current_setting_section(); |
||
52 | |||
53 | switch ( $current_section ) { |
||
54 | case 'advanced-options': |
||
55 | $settings = array( |
||
56 | array( |
||
57 | 'id' => 'give_title_data_control_2', |
||
58 | 'type' => 'title', |
||
59 | ), |
||
60 | array( |
||
61 | 'name' => __( 'Remove Data on Uninstall', 'give' ), |
||
62 | 'desc' => __( 'When the plugin is deleted, completely remove all Give data. This includes all Give settings, forms, form meta, donor, donor data, donations. Everything.', 'give' ), |
||
63 | 'id' => 'uninstall_on_delete', |
||
64 | 'type' => 'radio_inline', |
||
65 | 'default' => 'disabled', |
||
66 | 'options' => array( |
||
67 | 'enabled' => __( 'Yes, Remove all data', 'give' ), |
||
68 | 'disabled' => __( 'No, keep my Give settings and donation data', 'give' ), |
||
69 | ), |
||
70 | ), |
||
71 | array( |
||
72 | 'name' => __( 'Default User Role', 'give' ), |
||
73 | 'desc' => __( 'Assign default user roles for donors when donors opt to register as a WP User.', 'give' ), |
||
74 | 'id' => 'donor_default_user_role', |
||
75 | 'type' => 'select', |
||
76 | 'default' => 'give_donor', |
||
77 | 'options' => give_get_user_roles(), |
||
78 | ), |
||
79 | array( |
||
80 | /* translators: %s: the_content */ |
||
81 | 'name' => sprintf( __( '%s filter', 'give' ), '<code>the_content</code>' ), |
||
82 | /* translators: 1: https://codex.wordpress.org/Plugin_API/Filter_Reference/the_content 2: the_content */ |
||
83 | 'desc' => sprintf( __( 'If you are seeing extra social buttons, related posts, or other unwanted elements appearing within your forms then you can disable WordPress\' content filter. <a href="%1$s" target="_blank">Learn more</a> about %2$s filter.', 'give' ), esc_url( 'https://codex.wordpress.org/Plugin_API/Filter_Reference/the_content' ), '<code>the_content</code>' ), |
||
84 | 'id' => 'the_content_filter', |
||
85 | 'default' => 'enabled', |
||
86 | 'type' => 'radio_inline', |
||
87 | 'options' => array( |
||
88 | 'enabled' => __( 'Enabled', 'give' ), |
||
89 | 'disabled' => __( 'Disabled', 'give' ), |
||
90 | ), |
||
91 | ), |
||
92 | array( |
||
93 | 'name' => __( 'Script Loading Location', 'give' ), |
||
94 | 'desc' => __( 'This allows you to load your Give scripts either in the <code><head></code> or footer of your website.', 'give' ), |
||
95 | 'id' => 'scripts_footer', |
||
96 | 'type' => 'radio_inline', |
||
97 | 'default' => 'disabled', |
||
98 | 'options' => array( |
||
99 | 'disabled' => __( 'Head', 'give' ), |
||
100 | 'enabled' => __( 'Footer', 'give' ), |
||
101 | ), |
||
102 | ), |
||
103 | array( |
||
104 | 'name' => __( 'Babel Polyfill Script', 'give' ), |
||
105 | 'desc' => __( 'Decide whether to load the Babel polyfill, which provides backwards compatibility for older browsers such as IE 11. The polyfill may be disabled to avoid conflicts with other themes or plugins that load the same script.', 'give' ), |
||
106 | 'id' => 'babel_polyfill_script', |
||
107 | 'type' => 'radio_inline', |
||
108 | 'default' => 'enabled', |
||
109 | 'options' => array( |
||
110 | 'enabled' => __( 'Enabled', 'give' ), |
||
111 | 'disabled' => __( 'Disabled', 'give' ), |
||
112 | ), |
||
113 | ), |
||
114 | array( |
||
115 | 'name' => __( 'Akismet SPAM Protection', 'give' ), |
||
116 | 'desc' => __( 'Add a layer of SPAM protection to your donation submissions with Akismet. When enabled, donation submissions will be first sent to Akismet\'s API if you have the plugin activated and configured.', 'give' ), |
||
117 | 'id' => 'akismet_spam_protection', |
||
118 | 'type' => 'radio_inline', |
||
119 | 'default' => ( give_check_akismet_key() ) ? 'enabled' : 'disabled', |
||
120 | 'options' => array( |
||
121 | 'enabled' => __( 'Enabled', 'give' ), |
||
122 | 'disabled' => __( 'Disabled', 'give' ), |
||
123 | ), |
||
124 | ), |
||
125 | array( |
||
126 | 'name' => 'Give Cache', |
||
127 | 'id' => 'give-clear-cache', |
||
128 | 'buttonTitle' => __( 'Clear Cache', 'give' ), |
||
129 | 'desc' => __( 'Click this button if you want to clear Give\'s cache. The plugin stores common settings and queries in cache to optimize performance. Clearing cache will remove and begin rebuilding these saved queries.', 'give' ), |
||
130 | 'type' => 'remove_cache_button' |
||
131 | ), |
||
132 | array( |
||
133 | 'name' => __( 'Advanced Settings Docs Link', 'give' ), |
||
134 | 'id' => 'advanced_settings_docs_link', |
||
135 | 'url' => esc_url( 'http://docs.givewp.com/settings-advanced' ), |
||
136 | 'title' => __( 'Advanced Settings', 'give' ), |
||
137 | 'type' => 'give_docs_link', |
||
138 | ), |
||
139 | array( |
||
140 | 'id' => 'give_title_data_control_2', |
||
141 | 'type' => 'sectionend', |
||
142 | ), |
||
143 | ); |
||
144 | break; |
||
145 | } |
||
146 | |||
147 | /** |
||
148 | * Hide caching setting by default. |
||
149 | * |
||
150 | * @since 2.0 |
||
151 | */ |
||
152 | if ( apply_filters( 'give_settings_advanced_show_cache_setting', false ) ) { |
||
153 | array_splice( $settings, 1, 0, array( |
||
154 | array( |
||
155 | 'name' => __( 'Cache', 'give' ), |
||
156 | 'desc' => __( 'If caching is enabled the plugin will start caching custom post type related queries and reduce the overall load time.', 'give' ), |
||
157 | 'id' => 'cache', |
||
158 | 'type' => 'radio_inline', |
||
159 | 'default' => 'enabled', |
||
160 | 'options' => array( |
||
161 | 'enabled' => __( 'Enabled', 'give' ), |
||
162 | 'disabled' => __( 'Disabled', 'give' ), |
||
163 | ), |
||
164 | ) |
||
165 | ) ); |
||
166 | } |
||
167 | |||
0 ignored issues
–
show
|
|||
168 | |||
169 | /** |
||
170 | * Filter the advanced settings. |
||
171 | * Backward compatibility: Please do not use this filter. This filter is deprecated in 1.8 |
||
172 | */ |
||
173 | $settings = apply_filters( 'give_settings_advanced', $settings ); |
||
174 | |||
175 | /** |
||
176 | * Filter the settings. |
||
177 | * |
||
178 | * @since 1.8 |
||
179 | * |
||
180 | * @param array $settings |
||
181 | */ |
||
182 | $settings = apply_filters( 'give_get_settings_' . $this->id, $settings ); |
||
183 | |||
184 | // Output. |
||
185 | return $settings; |
||
186 | } |
||
187 | |||
188 | /** |
||
189 | * Get sections. |
||
190 | * |
||
191 | * @since 1.8 |
||
192 | * @return array |
||
193 | */ |
||
194 | public function get_sections() { |
||
195 | $sections = array( |
||
196 | 'advanced-options' => __( 'Advanced Options', 'give' ), |
||
197 | ); |
||
198 | |||
199 | return apply_filters( 'give_get_sections_' . $this->id, $sections ); |
||
200 | } |
||
201 | |||
202 | |||
203 | /** |
||
204 | * Render remove_cache_button field type |
||
205 | * |
||
206 | * @since 2.1 |
||
207 | * @access public |
||
208 | * |
||
209 | * @param array $field |
||
210 | */ |
||
211 | View Code Duplication | public function render_remove_cache_button( $field ) { |
|
0 ignored issues
–
show
This method seems to be duplicated in your project.
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation. You can also find more detailed suggestions in the “Code” section of your repository. ![]() |
|||
212 | ?> |
||
213 | <tr valign="top" <?php echo ! empty( $field['wrapper_class'] ) ? 'class="' . $field['wrapper_class'] . '"' : '' ?>> |
||
0 ignored issues
–
show
|
|||
214 | <th scope="row" class="titledesc"> |
||
215 | <label |
||
216 | for="<?php echo esc_attr( $field['id'] ); ?>"><?php echo esc_html( $field['name'] ) ?></label> |
||
217 | </th> |
||
218 | <td class="give-forminp"> |
||
219 | <button type="button" id="<?php echo esc_attr( $field['id'] ); ?>" |
||
220 | class="button button-secondary"><?php echo esc_html( $field['buttonTitle'] ) ?></button> |
||
221 | <?php echo Give_Admin_Settings::get_field_description( $field ); ?> |
||
0 ignored issues
–
show
|
|||
222 | </td> |
||
223 | </tr> |
||
224 | <?php |
||
225 | } |
||
226 | |||
227 | |||
228 | /** |
||
229 | * Validate setting |
||
230 | * |
||
231 | * @since 2.2.0 |
||
232 | * @access public |
||
233 | * |
||
234 | * @param array $options |
||
235 | */ |
||
236 | public function validate_settngs( $options ) { |
||
237 | // Sanitize data. |
||
238 | $akismet_spam_protection = isset( $options['akismet_spam_protection'] ) |
||
239 | ? $options['akismet_spam_protection'] |
||
240 | : ( give_check_akismet_key() ? 'enabled' : 'disabled' ); |
||
241 | |||
242 | // Show error message if Akismet not configured and Admin try to save 'enabled' option. |
||
243 | if ( |
||
244 | give_is_setting_enabled( $akismet_spam_protection ) |
||
245 | && ! give_check_akismet_key() |
||
246 | ) { |
||
247 | Give_Admin_Settings::add_error( |
||
248 | 'give-akismet-protection', |
||
249 | __( 'Please properly configure Akismet to enable SPAM protection.', 'give' ) |
||
250 | ); |
||
251 | |||
252 | give_update_option( 'akismet_spam_protection', 'disabled' ); |
||
253 | } |
||
254 | } |
||
255 | } |
||
256 | |||
257 | endif; |
||
258 | |||
259 | return new Give_Settings_Advanced(); |
||
260 |
Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.
You can also find more detailed suggestions in the “Code” section of your repository.