A WordPress-centric search engine for devs and theme authors



wp_privacy_process_personal_data_erasure_page ›

Since4.9.6
Deprecatedn/a
wp_privacy_process_personal_data_erasure_page ( $response, $eraser_index, $email_address, $page, $request_id )
Parameters: (5)
  • (array) $response The response from the personal data eraser for the given page.
    Required: Yes
  • (int) $eraser_index The index of the personal data eraser. Begins at 1.
    Required: Yes
  • (string) $email_address The email address of the user whose personal data this is.
    Required: Yes
  • (int) $page The page of personal data for this eraser. Begins at 1.
    Required: Yes
  • (int) $request_id The request ID for this personal data erasure.
    Required: Yes
See:
  • wp_privacy_personal_data_erasure_page
Returns:
  • (array) The filtered response.
Defined at:
Codex:

Mark erasure requests as completed after processing is finished.

This intercepts the Ajax responses to personal data eraser page requests, and monitors the status of a request. Once all of the processing has finished, the request is marked as completed.



Source

function wp_privacy_process_personal_data_erasure_page( $response, $eraser_index, $email_address, $page, $request_id ) {
	/*
	 * If the eraser response is malformed, don't attempt to consume it; let it
	 * pass through, so that the default Ajax processing will generate a warning
	 * to the user.
	 */
	if ( ! is_array( $response ) ) {
		return $response;
	}

	if ( ! array_key_exists( 'done', $response ) ) {
		return $response;
	}

	if ( ! array_key_exists( 'items_removed', $response ) ) {
		return $response;
	}

	if ( ! array_key_exists( 'items_retained', $response ) ) {
		return $response;
	}

	if ( ! array_key_exists( 'messages', $response ) ) {
		return $response;
	}

	$request = wp_get_user_request_data( $request_id );

	if ( ! $request || 'remove_personal_data' !== $request->action_name ) {
		wp_send_json_error( __( 'Invalid request ID when processing eraser data.' ) );
	}

	/** This filter is documented in wp-admin/includes/ajax-actions.php */
	$erasers        = apply_filters( 'wp_privacy_personal_data_erasers', array() );
	$is_last_eraser = count( $erasers ) === $eraser_index;
	$eraser_done    = $response['done'];

	if ( ! $is_last_eraser || ! $eraser_done ) {
		return $response;
	}

	_wp_privacy_completed_request( $request_id );

	/**
	 * Fires immediately after a personal data erasure request has been marked completed.
	 *
	 * @since 4.9.6
	 *
	 * @param int $request_id The privacy request post ID associated with this request.
	 */
	do_action( 'wp_privacy_personal_data_erased', $request_id );

	return $response;
}