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 | * Login / Register Functions |
||
4 | * |
||
5 | * @package Give |
||
6 | * @subpackage Functions/Login |
||
7 | * @copyright Copyright (c) 2016, GiveWP |
||
8 | * @license https://opensource.org/licenses/gpl-license GNU Public License |
||
9 | * @since 1.0 |
||
10 | */ |
||
11 | |||
12 | // Exit if accessed directly. |
||
13 | if ( ! defined( 'ABSPATH' ) ) { |
||
14 | exit; |
||
15 | } |
||
16 | |||
17 | /** |
||
18 | * Login Form |
||
19 | * |
||
20 | * @since 1.0 |
||
21 | * @global $give_login_redirect |
||
22 | * @global $give_logout_redirect |
||
23 | * |
||
24 | * @param string $login_redirect Login redirect page URL |
||
25 | * @param string $logout_redirect Logout redirect page URL |
||
26 | * |
||
27 | * @return string Login form |
||
28 | */ |
||
29 | function give_login_form( $login_redirect = '', $logout_redirect = '' ) { |
||
30 | |||
31 | if ( empty( $login_redirect ) ) { |
||
32 | $login_redirect = add_query_arg( 'give-login-success', 'true', give_get_history_page_uri() ); |
||
33 | } |
||
34 | |||
35 | if ( empty( $logout_redirect ) ) { |
||
36 | $logout_redirect = add_query_arg( 'give-logout-success', 'true', give_get_current_page_url() ); |
||
37 | } |
||
38 | |||
39 | // Add user_logout action to logout url. |
||
40 | $logout_redirect = add_query_arg( |
||
41 | array( |
||
42 | 'give_action' => 'user_logout', |
||
43 | 'give_logout_nonce' => wp_create_nonce( 'give-logout-nonce' ), |
||
44 | 'give_logout_redirect' => urlencode( $logout_redirect ), |
||
45 | ), |
||
46 | home_url( '/' ) |
||
47 | ); |
||
48 | |||
49 | ob_start(); |
||
50 | |||
51 | give_get_template( |
||
52 | 'shortcode-login', |
||
53 | array( |
||
54 | 'give_login_redirect' => $login_redirect, |
||
55 | 'give_logout_redirect' => $logout_redirect, |
||
56 | ) |
||
57 | ); |
||
58 | |||
59 | return apply_filters( 'give_login_form', ob_get_clean() ); |
||
60 | } |
||
61 | |||
62 | /** |
||
63 | * Registration Form |
||
64 | * |
||
65 | * @since 2.0 |
||
66 | * @global $give_register_redirect |
||
67 | * |
||
68 | * @param string $redirect Redirect page URL |
||
69 | * |
||
70 | * @return string Register form |
||
71 | */ |
||
72 | function give_register_form( $redirect = '' ) { |
||
73 | if ( empty( $redirect ) ) { |
||
74 | $redirect = give_get_current_page_url(); |
||
75 | } |
||
76 | |||
77 | ob_start(); |
||
78 | |||
79 | if ( ! is_user_logged_in() ) { |
||
80 | give_get_template( |
||
81 | 'shortcode-register', |
||
82 | array( |
||
83 | 'give_register_redirect' => $redirect, |
||
84 | ) |
||
85 | ); |
||
86 | } |
||
87 | |||
88 | return apply_filters( 'give_register_form', ob_get_clean() ); |
||
89 | } |
||
90 | |||
91 | /** |
||
92 | * Process Login Form |
||
93 | * |
||
94 | * @since 1.0 |
||
95 | * |
||
96 | * @param array $data Data sent from the login form |
||
97 | * |
||
98 | * @return void |
||
99 | */ |
||
100 | function give_process_login_form( $data ) { |
||
101 | |||
102 | if ( wp_verify_nonce( $data['give_login_nonce'], 'give-login-nonce' ) ) { |
||
103 | |||
104 | // Set Receipt Access Session. |
||
105 | if ( ! empty( $_GET['donation_id'] ) ) { |
||
0 ignored issues
–
show
introduced
by
![]() |
|||
106 | Give()->session->set( 'receipt_access', true ); |
||
107 | } |
||
108 | |||
109 | $user_data = get_user_by( 'login', $data['give_user_login'] ); |
||
110 | |||
111 | if ( ! $user_data ) { |
||
112 | $user_data = get_user_by( 'email', $data['give_user_login'] ); |
||
113 | } |
||
114 | |||
115 | if ( $user_data ) { |
||
116 | |||
117 | $user_id = $user_data->ID; |
||
118 | |||
119 | if ( wp_check_password( $data['give_user_pass'], $user_data->user_pass, $user_id ) ) { |
||
120 | give_log_user_in( $user_data->ID, $data['give_user_login'], $data['give_user_pass'] ); |
||
121 | } else { |
||
122 | give_set_error( 'password_incorrect', __( 'The password you entered is incorrect.', 'give' ) ); |
||
123 | } |
||
124 | } else { |
||
125 | give_set_error( 'username_incorrect', __( 'The username you entered does not exist.', 'give' ) ); |
||
126 | } |
||
127 | |||
128 | // Check for errors and redirect if none present. |
||
129 | $errors = give_get_errors(); |
||
130 | |||
131 | if ( ! $errors ) { |
||
132 | $redirect = apply_filters( 'give_login_redirect', $data['give_login_redirect'], $user_id ); |
||
133 | wp_redirect( $redirect ); |
||
134 | give_die(); |
||
135 | } |
||
136 | } |
||
137 | } |
||
138 | |||
139 | add_action( 'give_user_login', 'give_process_login_form' ); |
||
140 | |||
141 | |||
142 | /** |
||
143 | * Process User Logout |
||
144 | * |
||
145 | * @since 1.0 |
||
146 | * |
||
147 | * @param array $data Data sent from the give login form page |
||
148 | * |
||
149 | * @return void |
||
150 | */ |
||
151 | function give_process_user_logout( $data ) { |
||
152 | if ( wp_verify_nonce( $data['give_logout_nonce'], 'give-logout-nonce' ) && is_user_logged_in() ) { |
||
153 | |||
154 | // Prevent occurring of any custom action on wp_logout. |
||
155 | remove_all_actions( 'wp_logout' ); |
||
156 | |||
157 | /** |
||
158 | * Fires before processing user logout. |
||
159 | * |
||
160 | * @since 1.0 |
||
161 | */ |
||
162 | do_action( 'give_before_user_logout' ); |
||
163 | |||
164 | // Logout user. |
||
165 | wp_logout(); |
||
166 | |||
167 | /** |
||
168 | * Fires after processing user logout. |
||
169 | * |
||
170 | * @since 1.0 |
||
171 | */ |
||
172 | do_action( 'give_after_user_logout' ); |
||
173 | |||
174 | wp_redirect( $data['give_logout_redirect'] ); |
||
175 | give_die(); |
||
176 | } |
||
177 | } |
||
178 | |||
179 | add_action( 'give_user_logout', 'give_process_user_logout' ); |
||
180 | |||
181 | /** |
||
182 | * Log User In |
||
183 | * |
||
184 | * @since 1.0 |
||
185 | * |
||
186 | * @param int $user_id User ID |
||
187 | * @param string $user_login Username |
||
188 | * @param string $user_pass Password |
||
189 | * |
||
190 | * @return bool |
||
191 | */ |
||
192 | function give_log_user_in( $user_id, $user_login, $user_pass ) { |
||
193 | |||
194 | if ( $user_id < 1 ) { |
||
195 | return false; |
||
196 | } |
||
197 | |||
198 | wp_set_auth_cookie( $user_id ); |
||
199 | wp_set_current_user( $user_id, $user_login ); |
||
200 | |||
201 | /** |
||
202 | * Fires after the user has successfully logged in. |
||
203 | * |
||
204 | * @since 1.0 |
||
205 | * |
||
206 | * @param string $user_login Username. |
||
207 | * @param WP_User $$user WP_User object of the logged-in user. |
||
208 | */ |
||
209 | do_action( 'wp_login', $user_login, get_userdata( $user_id ) ); |
||
210 | |||
211 | /** |
||
212 | * Fires after give user has successfully logged in. |
||
213 | * |
||
214 | * @since 1.0 |
||
215 | * |
||
216 | * @param int $$user_id User id. |
||
217 | * @param string $user_login Username. |
||
218 | * @param string $user_pass User password. |
||
219 | */ |
||
220 | do_action( 'give_log_user_in', $user_id, $user_login, $user_pass ); |
||
221 | } |
||
222 | |||
223 | |||
224 | /** |
||
225 | * Process Register Form |
||
226 | * |
||
227 | * @since 2.0 |
||
228 | * |
||
229 | * @param array $data Data sent from the register form |
||
230 | * |
||
231 | * @return bool |
||
232 | */ |
||
233 | function give_process_register_form( $data ) { |
||
234 | |||
235 | if ( is_user_logged_in() ) { |
||
236 | return false; |
||
237 | } |
||
238 | |||
239 | if ( empty( $_POST['give_register_submit'] ) ) { |
||
0 ignored issues
–
show
|
|||
240 | return false; |
||
241 | } |
||
242 | |||
243 | /** |
||
244 | * Fires before processing user registration. |
||
245 | * |
||
246 | * @since 1.0 |
||
247 | */ |
||
248 | do_action( 'give_pre_process_register_form' ); |
||
249 | |||
250 | if ( empty( $data['give_user_login'] ) ) { |
||
251 | give_set_error( 'empty_username', esc_html__( 'Invalid username.', 'give' ) ); |
||
252 | } |
||
253 | |||
254 | if ( username_exists( $data['give_user_login'] ) ) { |
||
255 | give_set_error( 'username_unavailable', esc_html__( 'Username already taken.', 'give' ) ); |
||
256 | } |
||
257 | |||
258 | if ( ! validate_username( $data['give_user_login'] ) ) { |
||
259 | give_set_error( 'username_invalid', esc_html__( 'Invalid username.', 'give' ) ); |
||
260 | } |
||
261 | |||
262 | if ( email_exists( $data['give_user_email'] ) ) { |
||
263 | give_set_error( 'email_unavailable', esc_html__( 'Email address already taken.', 'give' ) ); |
||
264 | } |
||
265 | |||
266 | if ( empty( $data['give_user_email'] ) || ! is_email( $data['give_user_email'] ) ) { |
||
267 | give_set_error( 'email_invalid', esc_html__( 'Invalid email.', 'give' ) ); |
||
268 | } |
||
269 | |||
270 | if ( ! empty( $data['give_payment_email'] ) && $data['give_payment_email'] != $data['give_user_email'] && ! is_email( $data['give_payment_email'] ) ) { |
||
271 | give_set_error( 'payment_email_invalid', esc_html__( 'Invalid payment email.', 'give' ) ); |
||
272 | } |
||
273 | |||
274 | if ( empty( $_POST['give_user_pass'] ) ) { |
||
0 ignored issues
–
show
|
|||
275 | give_set_error( 'empty_password', esc_html__( 'Please enter a password.', 'give' ) ); |
||
276 | } |
||
277 | |||
278 | if ( ( ! empty( $_POST['give_user_pass'] ) && empty( $_POST['give_user_pass2'] ) ) || ( $_POST['give_user_pass'] !== $_POST['give_user_pass2'] ) ) { |
||
0 ignored issues
–
show
|
|||
279 | give_set_error( 'password_mismatch', esc_html__( 'Passwords don\'t match.', 'give' ) ); |
||
280 | } |
||
281 | |||
282 | /** |
||
283 | * Fires while processing user registration. |
||
284 | * |
||
285 | * @since 1.0 |
||
286 | */ |
||
287 | do_action( 'give_process_register_form' ); |
||
288 | |||
289 | // Check for errors and redirect if none present |
||
290 | $errors = give_get_errors(); |
||
291 | |||
292 | if ( empty( $errors ) ) { |
||
293 | |||
294 | $redirect = apply_filters( 'give_register_redirect', $data['give_redirect'] ); |
||
295 | |||
296 | give_register_and_login_new_user( array( |
||
297 | 'user_login' => $data['give_user_login'], |
||
298 | 'user_pass' => $data['give_user_pass'], |
||
299 | 'user_email' => $data['give_user_email'], |
||
300 | 'user_registered' => date( 'Y-m-d H:i:s' ), |
||
301 | 'role' => get_option( 'default_role' ), |
||
302 | ) ); |
||
303 | |||
304 | wp_redirect( $redirect ); |
||
305 | give_die(); |
||
306 | } |
||
307 | } |
||
308 | |||
309 | add_action( 'give_user_register', 'give_process_register_form' ); |
||
310 | |||
311 | |||
312 | /** |
||
313 | * Email access login form. |
||
314 | * |
||
315 | * @since 1.8.17 |
||
316 | * |
||
317 | * @return bool |
||
318 | */ |
||
319 | function give_email_access_login() { |
||
320 | |||
321 | // Verify nonce. |
||
322 | if ( ! isset( $_POST['_wpnonce'] ) || ! wp_verify_nonce( $_POST['_wpnonce'], 'give' ) ) { |
||
0 ignored issues
–
show
|
|||
323 | return false; |
||
324 | } |
||
325 | |||
326 | // Need email to proceed. |
||
327 | $email = isset( $_POST['give_email'] ) ? give_clean( $_POST['give_email'] ) : ''; |
||
0 ignored issues
–
show
|
|||
328 | if ( empty( $email ) ) { |
||
329 | give_set_error( 'give_empty_email', __( 'Please enter the email address you used for your donation.', 'give' ) ); |
||
330 | } |
||
331 | |||
332 | $recaptcha_key = give_get_option( 'recaptcha_key' ); |
||
333 | $recaptcha_secret = give_get_option( 'recaptcha_secret' ); |
||
334 | $enable_recaptcha = ( give_is_setting_enabled( give_get_option( 'enable_recaptcha' ) ) ) && ! empty( $recaptcha_key ) && ! empty( $recaptcha_secret ) ? true : false; |
||
335 | |||
336 | // Use reCAPTCHA. |
||
337 | if ( $enable_recaptcha ) { |
||
338 | |||
339 | $args = array( |
||
340 | 'secret' => $recaptcha_secret, |
||
341 | 'response' => $_POST['g-recaptcha-response'], |
||
0 ignored issues
–
show
|
|||
342 | 'remoteip' => $_POST['give_ip'], |
||
0 ignored issues
–
show
|
|||
343 | ); |
||
344 | |||
345 | if ( ! empty( $args['response'] ) ) { |
||
346 | $request = wp_remote_post( 'https://www.google.com/recaptcha/api/siteverify', array( |
||
347 | 'body' => $args, |
||
348 | ) ); |
||
349 | if ( ! is_wp_error( $request ) || 200 == wp_remote_retrieve_response_code( $request ) ) { |
||
350 | |||
351 | $response = json_decode( $request['body'], true ); |
||
352 | |||
353 | // reCAPTCHA fail. |
||
354 | if ( ! $response['success'] ) { |
||
355 | give_set_error( 'give_recaptcha_test_failed', apply_filters( 'give_recaptcha_test_failed_message', __( 'reCAPTCHA test failed.', 'give' ) ) ); |
||
356 | } |
||
357 | } else { |
||
358 | |||
359 | // Connection issue. |
||
360 | give_set_error( 'give_recaptcha_connection_issue', apply_filters( 'give_recaptcha_connection_issue_message', __( 'Unable to connect to reCAPTCHA server.', 'give' ) ) ); |
||
361 | |||
362 | } // End if(). |
||
363 | } else { |
||
364 | |||
365 | give_set_error( 'give_recaptcha_failed', apply_filters( 'give_recaptcha_failed_message', __( 'It looks like the reCAPTCHA test has failed.', 'give' ) ) ); |
||
366 | |||
367 | } // End if(). |
||
368 | } // End if(). |
||
369 | |||
370 | // If no errors or only expired token key error - then send email. |
||
371 | if ( ! give_get_errors() ) { |
||
372 | |||
373 | $donor = Give()->donors->get_donor_by( 'email', $email ); |
||
0 ignored issues
–
show
$email is of type string|array , but the function expects a integer .
It seems like the type of the argument is not accepted by the function/method which you are calling. In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug. We suggest to add an explicit type cast like in the following example: function acceptsInteger($int) { }
$x = '123'; // string "123"
// Instead of
acceptsInteger($x);
// we recommend to use
acceptsInteger((integer) $x);
![]() |
|||
374 | Give()->email_access->init(); |
||
375 | |||
376 | // Verify that donor object is present and donor is connected with its user profile or not. |
||
377 | if ( is_object( $donor ) ) { |
||
378 | |||
379 | // Verify that email can be sent. |
||
380 | if ( ! Give()->email_access->can_send_email( $donor->id ) ) { |
||
381 | |||
382 | $_POST['email-access-exhausted'] = true; |
||
383 | |||
384 | return false; |
||
385 | |||
386 | } else { |
||
387 | // Send the email. Requests not |
||
388 | $email_sent = Give()->email_access->send_email( $donor->id, $donor->email ); |
||
389 | |||
390 | if ( ! $email_sent ) { |
||
391 | give_set_error( 'give_email_access_send_issue', __( 'Unable to send email. Please try again.', 'give' ) ); |
||
392 | return false; |
||
393 | } |
||
394 | |||
395 | $_POST['email-access-sent'] = true; |
||
396 | |||
397 | return true; |
||
398 | } |
||
399 | } else { |
||
400 | |||
401 | give_set_error( 'give-no-donations', __( 'We were unable to find any donations associated with the email address provided. Please try again using another email.', 'give' ) ); |
||
402 | |||
403 | } |
||
404 | } // End if(). |
||
405 | |||
406 | } |
||
407 | |||
408 | add_action( 'give_email_access_form_login', 'give_email_access_login' ); |
||
409 |