HEX
Server: Apache
System: Linux 4485441ca2e2 6.8.0-1039-aws #41~22.04.1-Ubuntu SMP Thu Sep 11 11:03:07 UTC 2025 aarch64
User: (1000)
PHP: 8.2.24
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/wp-members/inc/register.php
<?php
/**
 * WP-Members Registration Functions
 *
 * Handles new user registration and existing user updates.
 * 
 * This file is part of the WP-Members plugin by Chad Butler
 * You can find out more about this plugin at http://rocketgeek.com
 * Copyright (c) 2006-2016 Chad Butler
 * WP-Members(tm) is a trademark of butlerblog.com
 *
 * @package WP-Members
 * @subpackage WP-Members Registration Functions
 * @author Chad Butler
 * @copyright 2006-2016
 *
 * Functions Included:
 * - wpmem_registration
 * - wpmem_get_captcha_err
 */


if ( ! function_exists( 'wpmem_registration' ) ):
/**
 * Register function.
 *
 * Handles registering new users and updating existing users.
 *
 * @since 2.2.1
 * @since 2.7.2 Added pre/post process actions.
 * @since 2.8.2 Added validation and data filters.
 * @since 2.9.3 Added validation for multisite.
 * @since 3.0.0 Moved from wp-members-register.php to /inc/register.php.
 *
 * @param  string $tag           Identifies 'register' or 'update'.
 * @global int    $user_ID
 * @global string $wpmem_themsg
 * @global array  $userdata
 * @return string $wpmem_themsg|success|editsuccess
 */
function wpmem_registration( $tag ) {

	// Get the globals.
	global $user_ID, $wpmem, $wpmem_themsg, $userdata; 
	
	// Check the nonce.
	if ( defined( 'WPMEM_USE_NONCE' ) ) {
		if ( empty( $_POST ) || ! wp_verify_nonce( $_POST['wpmem-form-submit'], 'wpmem-validate-submit' ) ) {
			$wpmem_themsg = __( 'There was an error processing the form.', 'wp-members' );
			return;
		}
	}

	// Is this a registration or a user profile update?
	if ( $tag == 'register' ) { 
		$fields['username'] = ( isset( $_POST['user_login'] ) ) ? sanitize_user( $_POST['user_login'] ) : '';
	}
	
	// Add the user email to the $fields array for _data hooks.
	$fields['user_email'] = ( isset( $_POST['user_email'] ) ) ? $_POST['user_email'] : '';

	/** This filter defined in inc/class-wp-members-forms.php */
	$wpmem_fields = apply_filters( 'wpmem_register_fields_arr', $wpmem->fields, $tag );
	
	// Build the $fields array from $_POST data.
	$wpmem_fields = $wpmem->fields; // get_option( 'wpmembers_fields' );
	foreach ( $wpmem_fields as $meta ) {
		if ( $meta[4] == 'y' ) {
			if ( $meta[2] != 'password' || $meta[2] != 'confirm_password' ) {
				if ( isset( $_POST[ $meta[2] ] ) ) {
					switch ( $meta[3] ) {
					case 'checkbox':
						$fields[ $meta[2] ] = $_POST[ $meta[2] ];
						break;
					case 'multiselect':
					case 'multicheckbox':
						$delimiter = ( isset( $meta[8] ) ) ? $meta[8] : '|';
						$fields[ $meta[2] ] = ( isset( $_POST[ $meta[2] ] ) ) ? implode( $delimiter, $_POST[ $meta[2] ] ) : '';
						break;
					case 'textarea':
						$fields[ $meta[2] ] = $_POST[ $meta[2] ];
						break;
					default:
						$fields[ $meta[2] ] = sanitize_text_field( $_POST[ $meta[2] ] );
						break;
					}
				} else {
					$fields[ $meta[2] ] = '';
				}
			} else {
				// We do have password as part of the registration form.
				if ( isset( $_POST['password'] ) ) {
					$fields['password'] = $_POST['password'];
				}
				if ( isset( $_POST['confirm_password'] ) ) {
					$fields['confirm_password'] = $_POST['confirm_password'];
				}
			}
		}
	}
	
	/**
	 * Filter the submitted form fields prior to validation.
	 *
	 * @since 2.8.2
	 *
	 * @param array $fields An array of the posted form field data.
	 */
	$fields = apply_filters( 'wpmem_pre_validate_form', $fields );

	// Check for required fields, reverse the array for logical error message order.
	$wpmem_fields_rev = array_reverse( $wpmem_fields );

	foreach ( $wpmem_fields_rev as $meta ) {
		$pass_arr = array( 'password', 'confirm_password', 'password_confirm' );
		$pass_chk = ( $tag == 'update' && in_array( $meta[2], $pass_arr ) ) ? true : false;
		// Validation if the field is required.
		if ( $meta[5] == 'y' && $pass_chk == false ) {
			if ( 'file' == $meta[3] || 'image' == $meta[3] ) {
				// If this is a new registration.
				if ( 'register' == $tag ) {
					// If the required field is a file type.
					if ( empty( $_FILES[ $meta[2] ]['name'] ) ) {
						$wpmem_themsg = sprintf( $wpmem->get_text( 'reg_empty_field' ), __( $meta[1], 'wp-members' ) );
					}
				}
			} else {
				// If the required field is any other field type.
				if ( ! $fields[ $meta[2] ] ) { 
					$wpmem_themsg = sprintf( $wpmem->get_text( 'reg_empty_field' ), __( $meta[1], 'wp-members' ) );
				}
			}
		}
	}

	switch ( $tag ) {

	case "register":
		
		if ( is_multisite() ) {
			// Multisite has different requirements.
			$result = wpmu_validate_user_signup( $fields['username'], $fields['user_email'] ); 
			$errors = $result['errors'];
			if ( $errors->errors ) {
				$wpmem_themsg = $errors->get_error_message(); return $wpmem_themsg; exit;
			}

		} else {
			// Validate username and email fields.
			$wpmem_themsg = ( email_exists( $fields['user_email'] ) ) ? "email" : $wpmem_themsg;
			$wpmem_themsg = ( username_exists( $fields['username'] ) ) ? "user" : $wpmem_themsg;
			$wpmem_themsg = ( ! is_email( $fields['user_email']) ) ? $wpmem->get_text( 'reg_valid_email' ) : $wpmem_themsg;
			$wpmem_themsg = ( ! validate_username( $fields['username'] ) ) ? $wpmem->get_text( 'reg_non_alphanumeric' ) : $wpmem_themsg;
			$wpmem_themsg = ( ! $fields['username'] ) ? $wpmem->get_text( 'reg_empty_username' ) : $wpmem_themsg;
			
			// If there is an error from username, email, or required field validation, stop registration and return the error.
			if ( $wpmem_themsg ) {
				return $wpmem_themsg;
				exit();
			}
		}

		// If form contains password and email confirmation, validate that they match.
		if ( array_key_exists( 'confirm_password', $fields ) && $fields['confirm_password'] != $fields ['password'] ) { 
			$wpmem_themsg = $wpmem->get_text( 'reg_password_match' );
		}
		if ( array_key_exists( 'confirm_email', $fields ) && $fields['confirm_email'] != $fields ['user_email'] ) { 
			$wpmem_themsg = $wpmem->get_text( 'reg_email_match' ); 
		}
		
		// Get the captcha settings (api keys).
		$wpmem_captcha = get_option( 'wpmembers_captcha' );
		
		// If captcha is on, check the captcha.
		if ( $wpmem->captcha == 1 && $wpmem_captcha['recaptcha'] ) { 
			
			// If there is no api key, the captcha never displayed to the end user.
			if ( $wpmem_captcha['recaptcha']['public'] && $wpmem_captcha['recaptcha']['private'] ) {   
				if ( ! $_POST["recaptcha_response_field"] ) { // validate for empty captcha field
					$wpmem_themsg = $wpmem->get_text( 'reg_empty_captcha' );
					return "empty"; exit();
				}
			}

			// Check to see if the recaptcha library has already been loaded by another plugin.
			if ( ! function_exists( '_recaptcha_qsencode' ) ) { 
				require_once( WPMEM_PATH . 'lib/recaptchalib.php' ); 
			}

			$publickey  = $wpmem_captcha['recaptcha']['public'];
			$privatekey = $wpmem_captcha['recaptcha']['private'];

			// The response from reCAPTCHA.
			$resp = null;
			// The error code from reCAPTCHA, if any.
			$error = null;

			if ( $_POST["recaptcha_response_field"] ) {

				$resp = recaptcha_check_answer (
					$privatekey,
					$_SERVER["REMOTE_ADDR"],
					$_POST["recaptcha_challenge_field"],
					$_POST["recaptcha_response_field"]
				);

				if ( ! $resp->is_valid ) {

					// Set the error code so that we can display it.
					global $wpmem_captcha_err;
					$wpmem_captcha_err = $resp->error;
					$wpmem_captcha_err = wpmem_get_captcha_err( $wpmem_captcha_err );

					return "captcha";
					exit();

				}
			} // End check recaptcha.
		} elseif ( $wpmem->captcha == 2 ) {
			if ( defined( 'REALLYSIMPLECAPTCHA_VERSION' ) ) {
				// Validate Really Simple Captcha.
				$wpmem_captcha = new ReallySimpleCaptcha();
				// This variable holds the CAPTCHA image prefix, which corresponds to the correct answer.
				$wpmem_captcha_prefix = ( isset( $_POST['captcha_prefix'] ) ) ? $_POST['captcha_prefix'] : '';
				// This variable holds the CAPTCHA response, entered by the user.
				$wpmem_captcha_code = ( isset( $_POST['captcha_code'] ) ) ? $_POST['captcha_code'] : '';
				// Check CAPTCHA validity.
				$wpmem_captcha_correct = ( $wpmem_captcha->check( $wpmem_captcha_prefix, $wpmem_captcha_code ) ) ? true : false;
				// Clean up the tmp directory.
				$wpmem_captcha->remove( $wpmem_captcha_prefix );
				$wpmem_captcha->cleanup();
				// If CAPTCHA validation fails (incorrect value entered in CAPTCHA field), return an error.
				if ( ! $wpmem_captcha_correct ) {
					$wpmem_themsg = wpmem_get_captcha_err( 'really-simple' );
					return "empty"; exit();
				}
			}
		} elseif ( $wpmem->captcha == 3 && $wpmem_captcha['recaptcha'] ) {
			// Get the captcha response.
			if ( isset( $_POST['g-recaptcha-response'] ) ) {
				$captcha = $_POST['g-recaptcha-response'];
			}
			
			// If there is no captcha value, return error.
			if ( ! $captcha ) {
				$wpmem_themsg = $wpmem->get_text( 'reg_empty_captcha' );
				return "empty"; exit();
			}
			
			// We need the private key for validation.
			$privatekey = $wpmem_captcha['recaptcha']['private'];
			
			// Validate the captcha.
			$response = wp_remote_fopen( "https://www.google.com/recaptcha/api/siteverify?secret=" . $privatekey . "&response=" . $captcha . "&remoteip=" . $_SERVER['REMOTE_ADDR'] );
			
			// Decode the json response.
			$response = json_decode( $response, true );
			
			// If captcha validation was unsuccessful.
			if ( $response['success'] == false ) {
				$wpmem_themsg = $wpmem->get_text( 'reg_invalid_captcha' );
				if ( WP_DEBUG && isset( $response['error-codes'] ) ) {
					$wpmem_themsg.= '<br /><br />';
					foreach( $response['error-codes'] as $code ) {
						$wpmem_themsg.= "Error code: " . $code . "<br />";
					}
				}
				return "empty"; exit();
			}
		}

		// Check for user defined password.
		$fields['password'] = ( ! isset( $_POST['password'] ) ) ? wp_generate_password() : $_POST['password'];

		// Add for _data hooks
		$fields['user_registered'] = current_time( 'mysql', 1 );
		$fields['user_role']       = get_option( 'default_role' );
		$fields['wpmem_reg_ip']    = $_SERVER['REMOTE_ADDR'];
		$fields['wpmem_reg_url']   = ( isset( $_REQUEST['wpmem_reg_page'] ) ) ? $_REQUEST['wpmem_reg_page'] : $_REQUEST['redirect_to'];

		/*
		 * These native fields are not installed by default, but if they
		 * are added, use the $_POST value - otherwise, default to username.
		 * Value can be filtered with wpmem_register_data.
	 	 */
		$fields['user_nicename']   = ( isset( $_POST['user_nicename'] ) ) ? sanitize_title( $_POST['user_nicename'] ) : $fields['username'];
		$fields['display_name']    = ( isset( $_POST['display_name'] ) )  ? sanitize_user ( $_POST['display_name']  ) : $fields['username'];
		$fields['nickname']        = ( isset( $_POST['nickname'] ) )      ? sanitize_user ( $_POST['nickname']      ) : $fields['username'];

		/**
		 * Filter registration data after validation before data insertion.
		 *
		 * @since 2.8.2
		 *
		 * @param array  $fields An array of the registration field data.
		 * @param string $tag    A switch to indicate the action (new|edit).
		 */
		$fields = apply_filters( 'wpmem_register_data', $fields, 'new' ); 

		/**
		 * Fires before any insertion/emails.
		 *
		 * This action is the final step in pre registering a user. This
		 * can be used for attaching custom validation to the registration
		 * process. It cannot be used for changing any user registration
		 * data. Use the wpmem_register_data filter for that.
		 *
		 * @since 2.7.2
		 *
		 * @param array $fields The user's submitted registration data.
		 */
		do_action( 'wpmem_pre_register_data', $fields );

		// If the _pre_register_data hook sends back an error message.
		if ( $wpmem_themsg ) { 
			return $wpmem_themsg;
		}

		// Main new user fields are ready.
		$new_user_fields = array (
			'user_pass'       => $fields['password'], 
			'user_login'      => $fields['username'],
			'user_nicename'   => $fields['user_nicename'],
			'user_email'      => $fields['user_email'],
			'display_name'    => $fields['display_name'],
			'nickname'        => $fields['nickname'],
			'user_registered' => $fields['user_registered'],
			'role'            => $fields['user_role']
		);

		// Get any excluded meta fields.
		$excluded_meta = wpmem_get_excluded_meta( 'register' );

		// Fields for wp_insert_user: user_url, first_name, last_name, description, jabber, aim, yim.
		$new_user_fields_meta = array( 'user_url', 'first_name', 'last_name', 'description', 'jabber', 'aim', 'yim' );
		foreach ( $wpmem_fields as $meta ) {
			if ( in_array( $meta[2], $new_user_fields_meta ) ) {
				if ( $meta[4] == 'y' && ! in_array( $meta[2], $excluded_meta ) ) {
					$new_user_fields[ $meta[2] ] = $fields[ $meta[2] ];
				}
			}
		}

		// Inserts to wp_users table.
		$fields['ID'] = wp_insert_user( $new_user_fields );

		// Set remaining fields to wp_usermeta table.
		foreach ( $wpmem_fields as $meta ) {
			// If the field is not excluded, update accordingly.
			if ( ! in_array( $meta[2], $excluded_meta ) && ! in_array( $meta[2], $new_user_fields_meta ) ) {
				if ( $meta[4] == 'y' && $meta[2] != 'user_email' ) {
					update_user_meta( $fields['ID'], $meta[2], $fields[ $meta[2] ] );
				}
			}
		}

		// Capture IP address of user at registration.
		update_user_meta( $fields['ID'], 'wpmem_reg_ip', $fields['wpmem_reg_ip'] );

		// Store the registration url.
		update_user_meta( $fields['ID'], 'wpmem_reg_url', $fields['wpmem_reg_url'] );

		// Set user expiration, if used.
		if ( $wpmem->use_exp == 1 && $wpmem->mod_reg != 1 ) {
			if ( function_exists( 'wpmem_set_exp' ) ) {
				wpmem_set_exp( $fields['ID'] );
			}
		}
		
		// Handle file uploads, if any.
		if ( ! empty( $_FILES ) ) {
	
			foreach ( $wpmem->fields as $file_field ) {
	
				if ( ( 'file' == $file_field[3] || 'image' == $file_field[3] ) && is_array( $_FILES[ $file_field[2] ] ) ) {
	
					// Upload the file and save it as an attachment.
					$file_post_id = $wpmem->forms->do_file_upload( $_FILES[ $file_field[2] ], $fields['ID'] );
	
					// Save the attachment ID as user meta.
					update_user_meta( $fields['ID'], $file_field[2], $file_post_id );
				}
			}
		}

		/**
		 * Fires after user insertion but before email.
		 *
		 * @since 2.7.2
		 *
		 * @param array $fields The user's submitted registration data.
		 */
		do_action( 'wpmem_post_register_data', $fields );

		require_once( WPMEM_PATH . 'inc/email.php' );

		/*
		 * If this was successful, and you have email properly
		 * configured, send a notification email to the user.
		 */
		wpmem_inc_regemail( $fields['ID'], $fields['password'], $wpmem->mod_reg, $wpmem_fields, $fields );

		// Notify admin of new reg, if needed.
		if ( $wpmem->notify == 1 ) { 
			wpmem_notify_admin( $fields['ID'], $wpmem_fields, $fields );
		}
		
		if ( isset( $_POST['redirect_to'] ) ) {
			$nonce_url = wp_nonce_url( $_POST['redirect_to'], 'register_redirect', 'nonce' );
			$url = add_query_arg( 'reg', 'success', $nonce_url );
			wp_redirect( $url );
			exit();
		}

		/**
		 * Fires after registration is complete.
		 *
		 * @since 2.7.1
		 * @since 3.1.0 Added $fields
		 */
		do_action( 'wpmem_register_redirect', $fields );

		// successful registration message
		return "success"; exit();
		break;

	case "update":

		if ( $wpmem_themsg ) { 
			return "updaterr";
			exit();
		}

		/*
		 * Doing a check for existing email is not the same as a new reg. check first to 
		 * see if it's different, then check if it is a valid address and it exists.
		 */
		global $current_user; wp_get_current_user();
		if ( $fields['user_email'] !=  $current_user->user_email ) {
			if ( email_exists( $fields['user_email'] ) ) { 
				return "email";
				exit();
			} 
			if ( !is_email( $fields['user_email']) ) { 
				$wpmem_themsg = $wpmem->get_text( 'reg_valid_email' );
				return "updaterr";
				exit();
			}
		}

		// If form includes email confirmation, validate that they match.
		if ( array_key_exists( 'confirm_email', $fields ) && $fields['confirm_email'] != $fields ['user_email'] ) { 
			$wpmem_themsg = $wpmem->get_text( 'reg_email_match' );
			return "updaterr";
			exit();
		}
		
		// Add the user_ID to the fields array.
		$fields['ID'] = $user_ID;
		
		/** This filter is documented in register.php */
		$fields = apply_filters( 'wpmem_register_data', $fields, 'edit' ); 
		
		/**
		 * Fires before data insertion.
		 *
		 * This action is the final step in pre updating a user. This
		 * can be used for attaching custom validation to the update
		 * process. It cannot be used for changing any user update
		 * data. Use the wpmem_register_data filter for that.
		 *
		 * @since 2.7.2
		 *
		 * @param array $fields The user's submitted update data.
		 */
		do_action( 'wpmem_pre_update_data', $fields );
		
		// If the _pre_update_data hook sends back an error message.
		if ( $wpmem_themsg ){ 
			return "updaterr";
		}

		// A list of fields that can be updated by wp_update_user.
		$native_fields = array( 
			'user_nicename',
			'user_url',
			'user_email',
			'display_name',
			'nickname',
			'first_name',
			'last_name',
			'description',
			'role',
			'jabber',
			'aim',
			'yim' 
		);
		$native_update = array( 'ID' => $user_ID );

		foreach ( $wpmem_fields as $meta ) {
			// If the field is not excluded, update accordingly.
			if ( ! in_array( $meta[2], wpmem_get_excluded_meta( 'update' ) ) ) {
				if ( 'file' != $meta[3] && 'image' != $meta[3] ) {
					switch ( $meta[2] ) {
	
					// If the field can be updated by wp_update_user.
					case( in_array( $meta[2], $native_fields ) ):
						$fields[ $meta[2] ] = ( isset( $fields[ $meta[2] ] ) ) ? $fields[ $meta[2] ] : '';
						$native_update[ $meta[2] ] = $fields[ $meta[2] ];
						break;
	
					// If the field is password.
					case( 'password' ):
						// Do nothing.
						break;
	
					// Everything else goes into wp_usermeta.
					default:
						if ( $meta[4] == 'y' ) {
							update_user_meta( $user_ID, $meta[2], $fields[ $meta[2] ] );
						}
						break;
					}
				}
			}
		}
		
		// Handle file uploads, if any.
		if ( ! empty( $_FILES ) ) {
	
			foreach ( $wpmem->fields as $file_field ) {
	
				if ( ( 'file' == $file_field[3] || 'image' == $file_field[3] ) && is_array( $_FILES[ $file_field[2] ] ) ) {
					if ( ! empty( $_FILES[ $file_field[2] ]['name'] ) ) {
						// Upload the file and save it as an attachment.
						$file_post_id = $wpmem->forms->do_file_upload( $_FILES[ $file_field[2] ], $fields['ID'] );
	
						// Save the attachment ID as user meta.
						update_user_meta( $fields['ID'], $file_field[2], $file_post_id );
					}
				}
			}
		}

		// Update wp_update_user fields.
		wp_update_user( $native_update );

		/**
		 * Fires at the end of user update data insertion.
		 *
		 * @since 2.7.2
		 *
		 * @param array $fields The user's submitted registration data.
		 */
		do_action( 'wpmem_post_update_data', $fields );

		return "editsuccess"; exit();
		break;
	}
} // End registration function.
endif;


if ( ! function_exists( 'wpmem_get_captcha_err' ) ):
/**
 * Generate reCAPTCHA error messages.
 *
 * @since 2.4
 *
 * @param  string $wpmem_captcha_err The response from the reCAPTCHA API.
 * @return string $wpmem_captcha_err The appropriate error message.
 */
function wpmem_get_captcha_err( $wpmem_captcha_err ) {

	switch ( $wpmem_captcha_err ) {

	case "invalid-site-public-key":
		$wpmem_captcha_err = __( 'We were unable to validate the public key.', 'wp-members' );
		break;

	case "invalid-site-public-key":
		$wpmem_captcha_err = __( 'We were unable to validate the private key.', 'wp-members' );
		break;

	case "invalid-request-cookie":
		$wpmem_captcha_err = __( 'The challenge parameter of the verify script was incorrect.', 'wp-members' );
		break;

	case "incorrect-captcha-sol":
		$wpmem_captcha_err = __( 'The CAPTCHA solution was incorrect.', 'wp-members' );
		break;

	case "verify-params-incorrect":
		$wpmem_captcha_err = __( 'The parameters to verify were incorrect', 'wp-members' );
		break;

	case "invalid-referrer":
		$wpmem_captcha_err = __( 'reCAPTCHA API keys are tied to a specific domain name for security reasons.', 'wp-members' );
		break;

	case "recaptcha-not-reachable":
		$wpmem_captcha_err = __( 'The reCAPTCHA server was not reached.  Please try to resubmit.', 'wp-members' );
		break;

	case 'really-simple':
		$wpmem_captcha_err = __( 'You have entered an incorrect code value. Please try again.', 'wp-members' );
		break;
	}

	return $wpmem_captcha_err;
}
endif;

// End of file.