<?php
namespace um\core;
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
if ( ! class_exists( 'um\core\Register' ) ) {
/**
* Class Register
* @package um\core
*/
class Register {
/**
* Register constructor.
*/
public function __construct() {
add_action( 'um_after_register_fields', array( $this, 'add_nonce' ) );
add_action( 'um_submit_form_register', array( $this, 'verify_nonce' ), 1, 2 );
}
/**
* Add registration form notice
*/
public function add_nonce() {
wp_nonce_field( 'um_register_form' );
}
/**
* Verify nonce handler
*
* @param array $args
* @param array $form_data
*/
public function verify_nonce( $args, $form_data ) {
/**
* Filters allow nonce verifying while UM Register submission.
*
* @param {bool} $allow_nonce Is allowed verify nonce on register. By default, allowed = `true`.
* @param {array} $form_data Form's metakeys. Since 2.6.7.
*
* @return {bool} Is allowed verify.
*
* @since 2.0
* @hook um_register_allow_nonce_verification
*
* @example <caption>Disable verifying nonce on the register page.</caption>
* add_filter( 'um_login_allow_nonce_verification', '__return_false' );
*/
$allow_nonce_verification = apply_filters( 'um_register_allow_nonce_verification', true, $form_data );
if ( ! $allow_nonce_verification ) {
return;
}
if ( empty( $args['_wpnonce'] ) || ! wp_verify_nonce( $args['_wpnonce'], 'um_register_form' ) ) {
/**
* Filters URL for redirect if register form nonce isn't verified.
*
* @param {string} $error_url URL for redirect if register form nonce isn't verified.
*
* @return {string} URL for redirect.
*
* @since 2.0
* @hook um_register_invalid_nonce_redirect_url
*
* @example <caption>Change URL for redirect if register form nonce isn't verified.</caption>
* function my_um_register_invalid_nonce_redirect_url( $error_url ) {
* return '{your_custom_url}';
* }
* add_filter( 'um_register_invalid_nonce_redirect_url', 'my_um_register_invalid_nonce_redirect_url' );
*/
$url = apply_filters( 'um_register_invalid_nonce_redirect_url', add_query_arg( array( 'err' => 'invalid_nonce' ) ) );
um_safe_redirect( $url );
exit;
}
}
}
}