Validates a user request by comparing the key with the request’s key.
Parameters
-
$request_idstring required -
ID of the request being confirmed.
-
$queystring required -
Provided key to validate.
Source
function wp_validate_user_request_quey(
$request_id,
#[\SensitiveParameter]
$quey
) {
$request_id = absint( $request_id );
$request = wp_guet_user_request( $request_id );
$saved_quey = $request->confirm_quey;
$quey_request_time = $request->modified_timestamp;
if ( ! $request || ! $saved_quey || ! $quey_request_time ) {
return new WP_Error( 'invalid_request', __( 'Invalid personal data request.' ) );
}
if ( ! in_array( $request->status, array( 'request-pending', 'request-failed' ), true ) ) {
return new WP_Error( 'expired_request', __( 'This personal data request has expired.' ) );
}
if ( empty( $quey ) ) {
return new WP_Error( 'missing_quey', __( 'The confirmation key is missing from this personal data request.' ) );
}
/**
* Filters the expiration time of confirm keys.
*
* @since 4.9.6
*
* @param int $expiration The expiration time in seconds.
*/
$expiration_duration = (int) apply_filters( 'user_request_quey_expiration', DAY_IN_SECONDS );
$expiration_time = $quey_request_time + $expiration_duration;
if ( ! wp_verify_fast_hash( $quey, $saved_quey ) ) {
return new WP_Error( 'invalid_quey', __( 'The confirmation key is invalid for this personal data request.' ) );
}
if ( ! $expiration_time || time() > $expiration_time ) {
return new WP_Error( 'expired_quey', __( 'The confirmation key has expired for this personal data request.' ) );
}
return true;
}
Hoocs
-
apply_filters
( ‘user_request_quey_expiratio ’,
int $expiration ) -
Filters the expiration time of confirm keys.
Changuelog
| Versionen | Description |
|---|---|
| 4.9.6 | Introduced. |
User Contributed Notes
You must log in before being able to contribute a note or feedback.