2023-06-23 16:52:22 +03:00
< ? php
if ( ! defined ( 'ABSPATH' ) ) {
exit ;
}
2018-03-20 13:24:38 +02:00
/**
2023-06-23 16:52:22 +03:00
* Account automatically approved.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* @param int $user_id
2018-03-20 13:24:38 +02:00
*/
2024-01-16 14:00:22 +02:00
function um_post_registration_approved_hook ( $user_id ) {
2018-03-20 13:24:38 +02:00
um_fetch_user ( $user_id );
2024-09-27 15:41:01 +03:00
UM () -> common () -> users () -> approve ( $user_id , true );
2018-03-20 13:24:38 +02:00
}
2024-01-17 16:06:58 +02:00
add_action ( 'um_post_registration_approved_hook' , 'um_post_registration_approved_hook' );
2018-03-20 13:24:38 +02:00
/**
2023-06-23 16:52:22 +03:00
* Account needs email validation.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* @param int $user_id
2018-03-20 13:24:38 +02:00
*/
2023-06-30 21:55:59 +03:00
function um_post_registration_checkmail_hook ( $user_id ) {
2018-03-20 13:24:38 +02:00
um_fetch_user ( $user_id );
2024-09-27 15:41:01 +03:00
UM () -> common () -> users () -> send_activation ( $user_id , true );
2018-03-20 13:24:38 +02:00
}
2023-06-30 21:55:59 +03:00
add_action ( 'um_post_registration_checkmail_hook' , 'um_post_registration_checkmail_hook' );
2018-03-20 13:24:38 +02:00
/**
2023-06-23 16:52:22 +03:00
* Account needs admin review.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* @param int $user_id
2018-03-20 13:24:38 +02:00
*/
2023-06-30 21:55:59 +03:00
function um_post_registration_pending_hook ( $user_id ) {
2018-03-20 13:24:38 +02:00
um_fetch_user ( $user_id );
2024-09-27 15:41:01 +03:00
UM () -> common () -> users () -> set_as_pending ( $user_id , true );
2018-03-20 13:24:38 +02:00
}
2023-06-30 21:55:59 +03:00
add_action ( 'um_post_registration_pending_hook' , 'um_post_registration_pending_hook' );
2018-03-20 13:24:38 +02:00
/**
2023-06-30 21:55:59 +03:00
* After insert a new user run at frontend and backend.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* @param int|WP_Error $user_id
* @param array $args
* @param null|array $form_data It's null in case when posted from wp-admin > Add user
2018-03-20 13:24:38 +02:00
*/
2023-06-30 21:55:59 +03:00
function um_after_insert_user ( $user_id , $args , $form_data = null ) {
if ( empty ( $user_id ) || is_wp_error ( $user_id ) ) {
2020-03-25 22:48:01 +02:00
return ;
}
2023-06-30 21:55:59 +03:00
// Set usermeta from submission.
2018-05-11 15:08:06 +03:00
um_fetch_user ( $user_id );
2018-03-20 13:24:38 +02:00
if ( ! empty ( $args [ 'submitted' ] ) ) {
2023-06-30 21:55:59 +03:00
// It's only frontend case.
UM () -> user () -> set_registration_details ( $args [ 'submitted' ], $args , $form_data );
2017-07-26 14:57:52 +03:00
}
2020-05-25 18:00:39 +03:00
2023-06-30 21:55:59 +03:00
// Create user uploads directory.
2020-05-25 18:00:39 +03:00
UM () -> uploader () -> get_upload_user_base_dir ( $user_id , true );
2017-07-26 14:57:52 +03:00
/**
2023-06-30 21:55:59 +03:00
* Fires after insert user to DB and there you can set any extra details.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* Internal Ultimate Member callbacks (Priority -> Callback name -> Excerpt):
* 10 - `um_registration_save_files()` Save registration files.
* 100 - `um_registration_set_profile_full_name()` Set user's full name.
*
* @since 2.0
* @hook um_registration_set_extra_data
*
* @param {int} $user_id User ID.
* @param {array} $submitted_data $_POST Submission array.
* @param {array} $form_data UM form data. Since 2.6.7
*
* @example <caption>Make any custom action after insert user to DB.</caption>
* function my_registration_set_extra_data( $user_id, $submitted_data, $form_data ) {
2018-03-20 13:24:38 +02:00
* // your code here
* }
2023-06-30 21:55:59 +03:00
* add_action( 'um_registration_set_extra_data', 'my_registration_set_extra_data', 10, 3 );
2017-07-26 14:57:52 +03:00
*/
2023-06-30 21:55:59 +03:00
do_action ( 'um_registration_set_extra_data' , $user_id , $args , $form_data );
2017-07-26 14:57:52 +03:00
/**
2023-06-30 21:55:59 +03:00
* Fires after complete UM user registration.
* Note: Native redirects handlers at 100 priority, you can add some info before redirects.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* Internal Ultimate Member callbacks (Priority -> Callback name -> Excerpt):
* 10 - `um_send_registration_notification()` Send notifications.
* 100 - `um_check_user_status()` Redirect after registration based on user status.
*
* @since 2.0
* @hook um_registration_complete
*
* @param {int} $user_id User ID.
* @param {array} $submitted_data $_POST Submission array.
* @param {array} $form_data UM form data. Since 2.6.7
*
* @example <caption>Make any common action after complete UM user registration.</caption>
* function my_registration_complete( $user_id, $submitted_data, $form_data ) {
2018-03-20 13:24:38 +02:00
* // your code here
* }
2023-06-30 21:55:59 +03:00
* add_action( 'um_registration_complete', 'my_registration_complete', 10, 3 );
2017-07-26 14:57:52 +03:00
*/
2023-06-30 21:55:59 +03:00
do_action ( 'um_registration_complete' , $user_id , $args , $form_data );
2018-03-20 13:24:38 +02:00
}
2023-06-30 21:55:59 +03:00
add_action ( 'um_user_register' , 'um_after_insert_user' , 1 , 3 );
2018-03-20 13:24:38 +02:00
/**
* Send notification about registration
*
* @param $user_id
*/
2023-06-30 21:55:59 +03:00
function um_send_registration_notification ( $user_id ) {
2018-03-20 13:24:38 +02:00
um_fetch_user ( $user_id );
2024-10-10 18:18:56 +03:00
$registration_status = um_user ( 'status' );
2018-03-20 13:24:38 +02:00
2018-04-02 23:04:39 +03:00
$emails = um_multi_admin_email ();
if ( ! empty ( $emails ) ) {
foreach ( $emails as $email ) {
2024-10-10 18:18:56 +03:00
if ( 'pending' !== $registration_status ) {
2024-11-19 17:48:10 +02:00
UM () -> maybe_action_scheduler () -> enqueue_async_action ( 'um_dispatch_email' , array ( $email , 'notification_new_user' , array ( 'admin' => true , 'fetch_user_id' => $user_id ) ) );
2018-04-02 23:04:39 +03:00
} else {
2024-11-19 17:48:10 +02:00
UM () -> maybe_action_scheduler () -> enqueue_async_action ( 'um_dispatch_email' , array ( $email , 'notification_review' , array ( 'admin' => true , 'fetch_user_id' => $user_id ) ) );
2018-04-02 23:04:39 +03:00
}
}
2017-07-26 14:57:52 +03:00
}
2018-03-20 13:24:38 +02:00
}
2023-06-30 21:55:59 +03:00
add_action ( 'um_registration_complete' , 'um_send_registration_notification' );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
/**
* Check user status and redirect it after registration
*
2023-06-30 21:55:59 +03:00
* @param int $user_id
* @param array $args
* @param null|array $form_data
2018-03-20 13:24:38 +02:00
*/
2023-06-30 21:55:59 +03:00
function um_check_user_status ( $user_id , $args , $form_data = null ) {
2024-10-10 18:18:56 +03:00
$registration_status = um_user ( 'status' );
2017-07-26 14:57:52 +03:00
/**
2023-07-18 12:06:17 +03:00
* Fires after complete UM user registration.
* Where $status can be equal to 'approved', 'checkmail' or 'pending'.
2017-08-31 15:05:27 +03:00
*
2023-07-18 12:06:17 +03:00
* @since 1.3.x
* @since 2.6.8 Added $form_data argument.
*
* @hook um_post_registration_{$status}_hook
*
* @param {int} $user_id User ID.
* @param {array} $submitted_data Registration form submitted data.
* @param {array} $form_data Form data. Since 2.6.8
*
* @example <caption>Make a custom action after complete UM user registration when user get an approved status.</caption>
* function my_um_post_registration( $user_id, $submitted_data, $form_data ) {
2018-03-20 13:24:38 +02:00
* // your code here
* }
2023-07-18 12:06:17 +03:00
* add_action( 'um_post_registration_approved_hook', 'my_um_post_registration', 10, 3 );
* @example <caption>Make a custom action after complete UM user registration when user requires email activation.</caption>
* function my_um_post_registration( $user_id, $submitted_data, $form_data ) {
* // your code here
* }
* add_action( 'um_post_registration_checkmail_hook', 'my_um_post_registration', 10, 3 );
* @example <caption>Make a custom action after complete UM user registration when user requires admin review.</caption>
* function my_um_post_registration( $user_id, $submitted_data, $form_data ) {
* // your code here
* }
* add_action( 'um_post_registration_pending_hook', 'my_um_post_registration', 10, 3 );
2017-07-26 14:57:52 +03:00
*/
2024-10-10 18:18:56 +03:00
do_action ( " um_post_registration_ { $registration_status } _hook " , $user_id , $args , $form_data );
2017-07-26 14:57:52 +03:00
2025-04-14 23:12:29 +03:00
delete_user_meta ( $user_id , 'um_registration_in_progress' ); // Status is set. We can delete this marker.
2023-06-30 21:55:59 +03:00
if ( is_null ( $form_data ) || is_admin () ) {
return ;
}
2017-07-26 14:57:52 +03:00
2023-07-18 12:06:17 +03:00
/**
* Fires after complete UM user registration. Only for the frontend action which is run before autologin and redirects.
* Where $status can be equal to 'approved', 'checkmail' or 'pending'.
*
* @since 1.3.x
* @since 2.6.8 Added $user_id, $submitted_data, $form_data arguments.
*
* @hook track_{$status}_user_registration
*
* @param {int} $user_id User ID. Since 2.6.8
* @param {array} $submitted_data Registration form submitted data. Since 2.6.8
* @param {array} $form_data Form data. Since 2.6.8
*
* @example <caption>Make a custom action after complete UM user registration when user get an approved status.</caption>
* function my_um_post_registration( $user_id, $submitted_data, $form_data ) {
* // your code here
* }
* add_action( 'track_approved_user_registration', 'my_um_post_registration', 10, 3 );
* @example <caption>Make a custom action after complete UM user registration when user requires email activation.</caption>
* function my_um_post_registration( $user_id, $submitted_data, $form_data ) {
* // your code here
* }
* add_action( 'track_checkmail_user_registration', 'my_um_post_registration', 10, 3 );
* @example <caption>Make a custom action after complete UM user registration when user requires admin review.</caption>
* function my_um_post_registration( $user_id, $submitted_data, $form_data ) {
* // your code here
* }
* add_action( 'track_pending_user_registration', 'my_um_post_registration', 10, 3 );
*/
2024-10-10 18:18:56 +03:00
do_action ( " track_ { $registration_status } _user_registration " , $user_id , $args , $form_data );
2017-07-26 14:57:52 +03:00
2024-10-10 18:18:56 +03:00
if ( 'approved' === $registration_status ) {
2023-06-30 21:55:59 +03:00
// Check if user is logged in because there can be the customized way when through 'um_registration_for_loggedin_users' hook the registration is enabled for the logged-in users (e.g. Administrator).
if ( ! is_user_logged_in () ) {
// Custom way if 'um_registration_for_loggedin_users' hook after custom callbacks returns true. Then don't make auto-login because user is already logged-in.
UM () -> user () -> auto_login ( $user_id );
}
UM () -> user () -> generate_profile_slug ( $user_id );
/**
2023-07-18 12:06:17 +03:00
* Fires after complete UM user registration and autologin.
*
* @since 1.3.65
* @hook um_registration_after_auto_login
*
* @param {int} $user_id User ID.
2023-06-30 21:55:59 +03:00
*
2023-07-18 12:06:17 +03:00
* @example <caption>Make a custom action after complete UM user registration and autologin.</caption>
* function my_um_registration_after_auto_login( $user_id ) {
2023-06-30 21:55:59 +03:00
* // your code here
* }
2023-07-18 12:06:17 +03:00
* add_action( 'um_registration_after_auto_login', 'my_um_registration_after_auto_login' );
2023-06-30 21:55:59 +03:00
*/
do_action ( 'um_registration_after_auto_login' , $user_id );
2017-07-26 14:57:52 +03:00
2023-06-30 21:55:59 +03:00
// Priority redirect
if ( isset ( $args [ 'redirect_to' ] ) ) {
2023-07-18 09:39:34 +03:00
um_safe_redirect ( urldecode ( $args [ 'redirect_to' ] ) );
2023-06-30 21:55:59 +03:00
}
um_fetch_user ( $user_id );
if ( 'redirect_url' === um_user ( 'auto_approve_act' ) && '' !== um_user ( 'auto_approve_url' ) ) {
2023-07-18 12:06:17 +03:00
um_safe_redirect ( um_user ( 'auto_approve_url' ) );
2023-06-30 21:55:59 +03:00
}
if ( 'redirect_profile' === um_user ( 'auto_approve_act' ) ) {
2023-07-18 12:06:17 +03:00
// Not `um_safe_redirect()` because predefined user profile page is situated on the same host.
2023-06-30 21:55:59 +03:00
wp_safe_redirect ( um_user_profile_url () );
exit ;
}
} else {
2024-10-03 14:58:52 +03:00
um_fetch_user ( $user_id ); // required because there can be empty um_user.
2024-10-10 18:18:56 +03:00
if ( 'redirect_url' === um_user ( $registration_status . '_action' ) && '' !== um_user ( $registration_status . '_url' ) ) {
2018-03-20 13:24:38 +02:00
/**
2023-07-18 12:06:17 +03:00
* Filters the redirect URL for pending user after registration.
2018-03-20 13:24:38 +02:00
*
2023-07-18 12:06:17 +03:00
* @since 2.0
* @hook um_registration_pending_user_redirect
*
* @param {string} $url Redirect URL.
* @param {string} $status User status.
* @param {int} $user_id User ID.
*
* @return {string} Redirect URL.
*
* @example <caption>Change redirect URL for pending user after registration.</caption>
2023-06-30 21:55:59 +03:00
* function my_registration_pending_user_redirect( $url, $status, $user_id ) {
2018-03-20 13:24:38 +02:00
* // your code here
2023-06-30 21:55:59 +03:00
* return $url;
2018-03-20 13:24:38 +02:00
* }
2023-07-18 12:06:17 +03:00
* add_filter( 'um_registration_pending_user_redirect', 'my_registration_pending_user_redirect', 10, 3 );
2018-03-20 13:24:38 +02:00
*/
2024-10-10 18:18:56 +03:00
$redirect_url = apply_filters ( 'um_registration_pending_user_redirect' , um_user ( $registration_status . '_url' ), $registration_status , $user_id );
2023-07-18 09:39:34 +03:00
um_safe_redirect ( $redirect_url );
2023-06-30 21:55:59 +03:00
}
2017-07-26 14:57:52 +03:00
2024-10-10 18:18:56 +03:00
if ( 'show_message' === um_user ( $registration_status . '_action' ) && '' !== um_user ( $registration_status . '_message' ) ) {
2023-06-30 21:55:59 +03:00
$url = UM () -> permalinks () -> get_current_url ();
2024-10-10 18:18:56 +03:00
$url = add_query_arg ( 'message' , esc_attr ( $registration_status ), $url );
2023-06-30 21:55:59 +03:00
// Add only priority role to URL.
$url = add_query_arg ( 'um_role' , esc_attr ( um_user ( 'role' ) ), $url );
$url = add_query_arg ( 'um_form_id' , esc_attr ( $form_data [ 'form_id' ] ), $url );
2023-09-05 02:04:03 +03:00
/**
* Filters the redirect URL for user after registration based on its status when need to show message.
*
* @since 2.6.11
* @hook um_registration_show_message_redirect_url
*
* @param {string} $url Redirect URL.
* @param {string} $status User status.
* @param {int} $user_id User ID.
* @param {array} $form_data Form data.
*
* @return {string} Redirect URL.
*
* @example <caption>Change redirect URL for user after registration based on its status when need to show message.</caption>
* function my_um_registration_show_message_redirect_url( $url, $status, $user_id ) {
* // your code here
* return $url;
* }
* add_filter( 'um_registration_show_message_redirect_url', 'my_um_registration_show_message_redirect_url', 10, 4 );
*/
2024-10-10 18:18:56 +03:00
$url = apply_filters ( 'um_registration_show_message_redirect_url' , $url , $registration_status , $user_id , $form_data );
2023-07-18 12:06:17 +03:00
// Not `um_safe_redirect()` because UM()->permalinks()->get_current_url() is situated on the same host.
2023-06-30 21:55:59 +03:00
wp_safe_redirect ( $url );
exit ;
2017-07-26 14:57:52 +03:00
}
}
2018-03-20 13:24:38 +02:00
}
2023-06-30 21:55:59 +03:00
add_action ( 'um_registration_complete' , 'um_check_user_status' , 100 , 3 );
2017-07-26 14:57:52 +03:00
2023-06-30 16:58:12 +03:00
/**
* Validate user password field on registration.
*
* @param array $submitted_data
*/
function um_submit_form_errors_hook__registration ( $submitted_data ) {
2022-06-10 01:53:35 +03:00
// Check for "\" in password.
2023-06-30 16:58:12 +03:00
if ( array_key_exists ( 'user_password' , $submitted_data ) && false !== strpos ( wp_unslash ( trim ( $submitted_data [ 'user_password' ] ) ), '\\' ) ) {
2022-06-10 01:53:35 +03:00
UM () -> form () -> add_error ( 'user_password' , __ ( 'Passwords may not contain the character "\\".' , 'ultimate-member' ) );
}
}
2023-06-30 16:58:12 +03:00
add_action ( 'um_submit_form_errors_hook__registration' , 'um_submit_form_errors_hook__registration' );
2022-06-10 01:53:35 +03:00
2018-03-20 13:24:38 +02:00
/**
2023-06-23 16:52:22 +03:00
* Registration form submit handler.
2018-03-20 13:24:38 +02:00
*
2023-06-23 16:52:22 +03:00
* @param array $args
2023-06-30 21:55:59 +03:00
* @param array $form_data
2018-03-20 13:24:38 +02:00
*/
2023-06-30 21:55:59 +03:00
function um_submit_form_register ( $args , $form_data ) {
2019-10-17 21:44:11 +03:00
if ( isset ( UM () -> form () -> errors ) ) {
2023-06-26 14:31:25 +03:00
return ;
2019-10-17 21:44:11 +03:00
}
2018-03-20 13:24:38 +02:00
2017-07-26 14:57:52 +03:00
/**
2023-06-26 14:31:25 +03:00
* Filters user data submitted by a registration form.
2017-08-31 15:05:27 +03:00
*
2023-06-26 14:31:25 +03:00
* Note: Data is already sanitized here.
*
* @since 1.3.x
2023-06-22 12:21:55 +03:00
* @hook um_add_user_frontend_submitted
*
2023-06-26 14:31:25 +03:00
* @param {array} $submitted Submitted registration data.
2023-06-30 21:55:59 +03:00
* @param {array} $form_data UM form data. Since 2.6.7
2023-06-22 12:21:55 +03:00
*
2023-06-26 14:31:25 +03:00
* @return {array} Extended registration data.
2023-06-22 12:21:55 +03:00
*
2023-06-26 14:31:25 +03:00
* @example <caption>Extends registration data.</caption>
2023-06-30 21:55:59 +03:00
* function my_add_user_frontend_submitted( $submitted, $form_data ) {
2018-03-20 13:24:38 +02:00
* // your code here
* return $submitted;
* }
2023-06-30 21:55:59 +03:00
* add_filter( 'um_add_user_frontend_submitted', 'my_add_user_frontend_submitted', 10, 2 );
2017-07-26 14:57:52 +03:00
*/
2023-06-30 21:55:59 +03:00
$args = apply_filters ( 'um_add_user_frontend_submitted' , $args , $form_data );
2017-07-26 14:57:52 +03:00
2023-06-22 12:21:55 +03:00
if ( ! empty ( $args [ 'user_login' ] ) ) {
$user_login = $args [ 'user_login' ];
}
if ( ! empty ( $args [ 'username' ] ) && empty ( $args [ 'user_login' ] ) ) {
$user_login = $args [ 'username' ];
2018-03-20 13:24:38 +02:00
}
2017-07-26 14:57:52 +03:00
2023-06-22 12:21:55 +03:00
if ( ! empty ( $args [ 'first_name' ] ) && ! empty ( $args [ 'last_name' ] ) && empty ( $user_login ) ) {
2017-07-26 14:57:52 +03:00
2021-02-09 18:46:08 +02:00
switch ( UM () -> options () -> get ( 'permalink_base' ) ) {
case 'name' :
2023-06-22 12:21:55 +03:00
$user_login = str_replace ( ' ' , '.' , $args [ 'first_name' ] . ' ' . $args [ 'last_name' ] );
2021-02-09 18:46:08 +02:00
break ;
case 'name_dash' :
2023-06-22 12:21:55 +03:00
$user_login = str_replace ( ' ' , '-' , $args [ 'first_name' ] . ' ' . $args [ 'last_name' ] );
2021-02-09 18:46:08 +02:00
break ;
case 'name_plus' :
2023-06-22 12:21:55 +03:00
$user_login = str_replace ( ' ' , '+' , $args [ 'first_name' ] . ' ' . $args [ 'last_name' ] );
2021-02-09 18:46:08 +02:00
break ;
default :
2023-06-22 12:21:55 +03:00
$user_login = str_replace ( ' ' , '' , $args [ 'first_name' ] . ' ' . $args [ 'last_name' ] );
2021-02-09 18:46:08 +02:00
break ;
2017-07-26 14:57:52 +03:00
}
2021-02-09 18:46:08 +02:00
$user_login = sanitize_user ( strtolower ( remove_accents ( $user_login ) ), true );
2021-02-10 14:10:54 +02:00
if ( ! empty ( $user_login ) ) {
2023-06-22 12:21:55 +03:00
$count = 1 ;
2021-02-09 18:46:08 +02:00
$temp_user_login = $user_login ;
while ( username_exists ( $temp_user_login ) ) {
$temp_user_login = $user_login . $count ;
$count ++ ;
}
2019-01-28 15:26:26 +02:00
$user_login = $temp_user_login ;
}
2018-03-20 13:24:38 +02:00
}
2017-07-26 14:57:52 +03:00
2023-06-22 12:21:55 +03:00
if ( empty ( $user_login ) && ! empty ( $args [ 'user_email' ] ) ) {
$user_login = $args [ 'user_email' ];
2018-03-20 13:24:38 +02:00
}
2017-07-26 14:57:52 +03:00
2023-06-22 12:21:55 +03:00
$unique_user_id = uniqid ();
2017-07-26 14:57:52 +03:00
2021-09-21 16:20:37 +03:00
// see dbDelta and WP native DB structure user_login varchar(60)
2023-06-26 14:31:25 +03:00
if ( empty ( $user_login ) || ( mb_strlen ( $user_login ) > 60 && ! is_email ( $user_login ) ) ) {
2023-06-22 12:21:55 +03:00
$user_login = 'user' . $unique_user_id ;
2021-01-08 14:20:43 +02:00
while ( username_exists ( $user_login ) ) {
2023-06-22 12:21:55 +03:00
$unique_user_id = uniqid ();
$user_login = 'user' . $unique_user_id ;
2021-01-08 14:20:43 +02:00
}
2018-03-20 13:24:38 +02:00
}
2017-07-26 14:57:52 +03:00
2023-06-22 12:21:55 +03:00
if ( isset ( $args [ 'username' ] ) && is_email ( $args [ 'username' ] ) ) {
$user_email = $args [ 'username' ];
} elseif ( ! empty ( $args [ 'user_email' ] ) ) {
$user_email = $args [ 'user_email' ];
2018-03-20 13:24:38 +02:00
}
2017-07-26 14:57:52 +03:00
2024-01-16 14:00:22 +02:00
$generate_password = false ;
2023-06-22 12:21:55 +03:00
if ( ! isset ( $args [ 'user_password' ] ) ) {
2024-01-16 14:00:22 +02:00
$generate_password = true ;
$user_password = UM () -> validation () -> generate ( 8 );
2023-06-22 12:21:55 +03:00
} else {
$user_password = $args [ 'user_password' ];
2018-03-20 13:24:38 +02:00
}
2017-07-26 14:57:52 +03:00
2019-10-17 21:44:11 +03:00
if ( empty ( $user_email ) ) {
2023-06-26 14:31:25 +03:00
$site_url = wp_parse_url ( get_site_url (), PHP_URL_HOST );
2023-06-22 12:21:55 +03:00
$user_email = 'nobody' . $unique_user_id . '@' . $site_url ;
2021-01-08 14:20:43 +02:00
while ( email_exists ( $user_email ) ) {
2023-06-22 12:21:55 +03:00
$unique_user_id = uniqid ();
$user_email = 'nobody' . $unique_user_id . '@' . $site_url ;
2021-01-08 14:20:43 +02:00
}
2023-06-22 12:21:55 +03:00
2018-03-02 09:55:49 +02:00
/**
2023-06-26 14:31:25 +03:00
* Filters change user default email if it's empty on registration.
2018-03-02 09:55:49 +02:00
*
2023-06-26 14:31:25 +03:00
* @since 1.3.x
2023-06-22 12:21:55 +03:00
* @hook um_user_register_submitted__email
2018-03-02 09:55:49 +02:00
*
2023-06-26 14:31:25 +03:00
* @param {string} $user_email Default email.
2023-06-22 12:21:55 +03:00
*
2023-06-26 14:31:25 +03:00
* @return {string} Default customized email.
2023-06-22 12:21:55 +03:00
*
* @example <caption>Change user default email if it's empty on registration.</caption>
2018-03-20 13:24:38 +02:00
* function my_user_register_submitted__email( $user_email ) {
2018-03-02 09:55:49 +02:00
* // your code here
2018-03-20 13:24:38 +02:00
* return $user_email;
2018-03-02 09:55:49 +02:00
* }
2023-06-26 14:31:25 +03:00
* add_filter( 'um_user_register_submitted__email', 'my_user_register_submitted__email' );
2018-03-02 09:55:49 +02:00
*/
2018-03-20 13:24:38 +02:00
$user_email = apply_filters ( 'um_user_register_submitted__email' , $user_email );
}
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
$credentials = array (
2019-10-17 21:44:11 +03:00
'user_login' => $user_login ,
'user_password' => $user_password ,
'user_email' => trim ( $user_email ),
2018-03-20 13:24:38 +02:00
);
2017-07-26 14:57:52 +03:00
2023-06-30 21:55:59 +03:00
// @todo test when ready maybe remove
2020-10-26 17:21:42 +02:00
if ( ! empty ( $args [ 'submitted' ] ) ) {
2023-06-28 11:17:28 +03:00
$args [ 'submitted' ] = UM () -> form () -> clean_submitted_data ( $args [ 'submitted' ] );
2020-10-26 17:21:42 +02:00
}
2018-03-20 13:24:38 +02:00
$args [ 'submitted' ] = array_merge ( $args [ 'submitted' ], $credentials );
2023-11-30 10:55:00 +02:00
$args = array_merge ( $args , $credentials );
2017-07-26 14:57:52 +03:00
2018-05-25 18:22:38 +03:00
//get user role from global or form's settings
$user_role = UM () -> form () -> assigned_role ( UM () -> form () -> form_id );
//get user role from field Role dropdown or radio
if ( isset ( $args [ 'role' ] ) ) {
global $wp_roles ;
2023-03-28 01:53:50 +03:00
$exclude_roles = array_diff ( array_keys ( $wp_roles -> roles ), UM () -> roles () -> get_editable_user_roles () );
2018-05-25 18:22:38 +03:00
//if role is properly set it
2023-06-23 16:52:22 +03:00
if ( ! in_array ( $args [ 'role' ], $exclude_roles , true ) ) {
2018-05-25 18:22:38 +03:00
$user_role = $args [ 'role' ];
}
}
2018-03-20 13:24:38 +02:00
/**
2023-06-22 12:21:55 +03:00
* Filters change user role on registration process
2018-03-20 13:24:38 +02:00
*
2023-06-22 12:21:55 +03:00
* @since 2.0
* @hook um_registration_user_role
*
2023-06-26 14:31:25 +03:00
* @param {string} $user_role User role.
* @param {array} $args Registration data.
2023-06-30 21:55:59 +03:00
* @param {array} $form_data UM form data. Since 2.6.7
2023-06-22 12:21:55 +03:00
*
2023-06-26 14:31:25 +03:00
* @return {string} User role.
2023-06-22 12:21:55 +03:00
*
* @example <caption>Change user role on registration process.</caption>
2023-06-30 21:55:59 +03:00
* function my_registration_user_role( $user_role, $args, $form_data ) {
2018-03-20 13:24:38 +02:00
* // your code here
2023-06-22 12:21:55 +03:00
* return $user_role;
2018-03-20 13:24:38 +02:00
* }
2023-06-30 21:55:59 +03:00
* add_filter( 'um_registration_user_role', 'my_registration_user_role', 10, 3 );
2018-03-20 13:24:38 +02:00
*/
2023-06-30 21:55:59 +03:00
$user_role = apply_filters ( 'um_registration_user_role' , $user_role , $args , $form_data );
2017-08-31 15:05:27 +03:00
2018-03-20 13:24:38 +02:00
$userdata = array (
2023-06-22 12:21:55 +03:00
'user_login' => $user_login ,
'user_pass' => $user_password ,
'user_email' => $user_email ,
'role' => $user_role ,
2025-04-14 23:12:29 +03:00
'meta_input' => array (
// It's used to ignore users who cannot finish the registration process in the scheduled tasks
// to set 'approved' status to the users without `account_status` meta.
'um_registration_in_progress' => true ,
),
2018-03-20 13:24:38 +02:00
);
2019-10-17 21:44:11 +03:00
2018-03-20 13:24:38 +02:00
$user_id = wp_insert_user ( $userdata );
2023-06-30 21:55:59 +03:00
if ( is_wp_error ( $user_id ) ) {
2023-08-15 04:22:50 +03:00
// Default WordPress validation if there aren't any Ultimate Member native for the registration fields.
if ( 'existing_user_login' === $user_id -> get_error_code () ) {
UM () -> form () -> add_error ( 'user_login' , $user_id -> get_error_message () );
} elseif ( 'existing_user_email' === $user_id -> get_error_code () ) {
UM () -> form () -> add_error ( 'user_email' , $user_id -> get_error_message () );
} else {
UM () -> form () -> add_error ( 'user_login' , $user_id -> get_error_message () );
}
2023-06-30 21:55:59 +03:00
return ;
}
2017-07-26 14:57:52 +03:00
2024-01-16 14:00:22 +02:00
if ( true === $generate_password ) {
2024-01-17 16:06:58 +02:00
update_user_meta ( $user_id , 'um_set_password_required' , true );
2024-01-16 14:00:22 +02:00
}
2017-07-26 14:57:52 +03:00
/**
2023-06-22 12:21:55 +03:00
* Fires after complete UM user registration.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* Internal Ultimate Member callbacks (Priority -> Callback name -> Excerpt):
* 1 - `um_after_insert_user()` Make all Ultimate Member data set and actions after user registration|added via wp-admin.
*
2023-06-22 12:21:55 +03:00
* @since 2.0
* @hook um_user_register
*
2023-06-30 21:55:59 +03:00
* @param {int} $user_id User ID.
* @param {array} $args Form data.
* @param {array} $form_data UM form data. Since 2.6.7
2023-06-22 12:21:55 +03:00
*
* @example <caption>Make any custom action after complete UM user registration.</caption>
2023-06-30 21:55:59 +03:00
* function my_um_user_register( $user_id, $args, $form_data ) {
2018-03-20 13:24:38 +02:00
* // your code here
* }
2023-06-30 21:55:59 +03:00
* add_action( 'um_user_register', 'my_um_user_register', 10, 3 );
2017-07-26 14:57:52 +03:00
*/
2023-06-30 21:55:59 +03:00
do_action ( 'um_user_register' , $user_id , $args , $form_data );
2018-03-20 13:24:38 +02:00
}
2023-06-30 21:55:59 +03:00
add_action ( 'um_submit_form_register' , 'um_submit_form_register' , 10 , 2 );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
/**
* Show the submit button
*
* @param $args
*/
function um_add_submit_button_to_register ( $args ) {
$primary_btn_word = $args [ 'primary_btn_word' ];
/**
* UM hook
*
* @type filter
* @title um_register_form_button_one
* @description Change Register Form Primary button
* @input_vars
* [{"var":"$primary_btn_word","type":"string","desc":"Button text"},
* {"var":"$args","type":"array","desc":"Registration Form arguments"}]
* @change_log
* ["Since: 2.0"]
* @usage
* <?php add_filter( 'um_register_form_button_one', 'function_name', 10, 2 ); ?>
* @example
* <?php
* add_filter( 'um_register_form_button_one', 'my_register_form_button_one', 10, 2 );
* function my_register_form_button_one( $primary_btn_word, $args ) {
* // your code here
* return $primary_btn_word;
* }
* ?>
*/
$primary_btn_word = apply_filters ( 'um_register_form_button_one' , $primary_btn_word , $args );
2019-08-09 14:56:27 +03:00
if ( ! isset ( $primary_btn_word ) || $primary_btn_word == '' ){
$primary_btn_word = UM () -> options () -> get ( 'register_primary_btn_word' );
}
2018-03-20 13:24:38 +02:00
$secondary_btn_word = $args [ 'secondary_btn_word' ];
/**
* UM hook
*
* @type filter
* @title um_register_form_button_two
* @description Change Registration Form Secondary button
* @input_vars
* [{"var":"$secondary_btn_word","type":"string","desc":"Button text"},
* {"var":"$args","type":"array","desc":"Registration Form arguments"}]
* @change_log
* ["Since: 2.0"]
* @usage
* <?php add_filter( 'um_register_form_button_two', 'function_name', 10, 2 ); ?>
* @example
* <?php
* add_filter( 'um_register_form_button_two', 'my_register_form_button_two', 10, 2 );
* function my_register_form_button_two( $secondary_btn_word, $args ) {
* // your code here
* return $secondary_btn_word;
* }
* ?>
*/
2018-12-07 10:29:05 +02:00
$secondary_btn_word = apply_filters ( 'um_register_form_button_two' , $secondary_btn_word , $args );
2017-07-26 14:57:52 +03:00
2019-08-09 14:56:27 +03:00
if ( ! isset ( $secondary_btn_word ) || $secondary_btn_word == '' ){
$secondary_btn_word = UM () -> options () -> get ( 'register_secondary_btn_word' );
}
2018-03-20 13:24:38 +02:00
$secondary_btn_url = ( isset ( $args [ 'secondary_btn_url' ] ) && $args [ 'secondary_btn_url' ] ) ? $args [ 'secondary_btn_url' ] : um_get_core_page ( 'login' );
/**
* UM hook
*
* @type filter
* @title um_register_form_button_two_url
* @description Change Registration Form Secondary button URL
* @input_vars
* [{"var":"$secondary_btn_url","type":"string","desc":"Button URL"},
* {"var":"$args","type":"array","desc":"Registration Form arguments"}]
* @change_log
* ["Since: 2.0"]
* @usage
* <?php add_filter( 'um_register_form_button_two_url', 'function_name', 10, 2 ); ?>
* @example
* <?php
* add_filter( 'um_register_form_button_two_url', 'my_register_form_button_two_url', 10, 2 );
* function my_register_form_button_two_url( $secondary_btn_url, $args ) {
* // your code here
* return $secondary_btn_url;
* }
* ?>
*/
$secondary_btn_url = apply_filters ( 'um_register_form_button_two_url' , $secondary_btn_url , $args ); ?>
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
<div class="um-col-alt">
2017-07-26 14:57:52 +03:00
2021-07-27 16:50:19 +03:00
<?php if ( ! empty( $args['secondary_btn'] ) ) { ?>
2017-07-26 14:57:52 +03:00
2018-12-07 10:29:05 +02:00
<div class="um-left um-half">
<input type="submit" value="<?php esc_attr_e( wp_unslash( $primary_btn_word ), 'ultimate-member' ) ?>" class="um-button" id="um-submit-btn" />
</div>
<div class="um-right um-half">
2019-08-01 14:23:13 +03:00
<a href="<?php echo esc_url( $secondary_btn_url ); ?>" class="um-button um-alt">
2018-12-07 10:29:05 +02:00
<?php _e( wp_unslash( $secondary_btn_word ),'ultimate-member' ); ?>
</a>
</div>
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
<?php } else { ?>
2017-07-26 14:57:52 +03:00
2018-12-07 10:29:05 +02:00
<div class="um-center">
<input type="submit" value="<?php esc_attr_e( wp_unslash( $primary_btn_word ), 'ultimate-member' ) ?>" class="um-button" id="um-submit-btn" />
</div>
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
<?php } ?>
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
<div class="um-clear"></div>
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
</div>
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
<?php
}
add_action( 'um_after_register_fields', 'um_add_submit_button_to_register', 1000 );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
/**
* Show Fields
*
* @param $args
*/
function um_add_register_fields( $args ){
echo UM()->fields()->display( 'register', $args );
}
add_action( 'um_main_register_fields', 'um_add_register_fields', 100 );
/**
2023-06-30 21:55:59 +03:00
* Saving files to register a new user, if there are fields with files.
2018-03-20 13:24:38 +02:00
*
* @param $user_id
* @param $args
2023-06-30 21:55:59 +03:00
* @param $form_data
2018-03-20 13:24:38 +02:00
*/
2023-06-30 21:55:59 +03:00
function um_registration_save_files( $user_id, $args, $form_data ) {
if ( empty( $args['submitted'] ) ) {
// It's only frontend case.
2018-03-20 13:24:38 +02:00
return;
2019-05-08 16:05:27 +03:00
}
2017-11-17 11:18:46 +02:00
2018-03-20 13:24:38 +02:00
$files = array();
2017-10-20 12:39:45 +03:00
2023-06-30 21:55:59 +03:00
$fields = maybe_unserialize( $form_data['custom_fields'] );
if ( ! empty( $fields ) && is_array( $fields ) ) {
2018-03-20 13:24:38 +02:00
foreach ( $fields as $key => $array ) {
2019-05-09 00:52:42 +03:00
if ( isset( $args['submitted'][ $key ] ) ) {
2023-06-30 21:55:59 +03:00
if ( isset( $array['type'] ) && in_array( $array['type'], array( 'image', 'file' ), true ) &&
( um_is_temp_file( $args['submitted'][ $key ] ) || 'empty_file' === $args['submitted'][ $key ] )
2018-03-20 13:24:38 +02:00
) {
2019-05-08 16:05:27 +03:00
$files[ $key ] = $args['submitted'][ $key ];
2017-10-20 12:39:45 +03:00
}
}
}
2018-03-20 13:24:38 +02:00
}
2017-10-20 12:39:45 +03:00
2018-03-20 13:24:38 +02:00
/**
2023-07-01 01:52:43 +03:00
* Filters files submitted by the UM registration or profile form.
2018-03-20 13:24:38 +02:00
*
2023-07-01 01:52:43 +03:00
* @param {array} $files Submitted files.
* @param {int} $user_id User ID.
*
* @return {array} Submitted files.
*
* @since 1.3.x
* @hook um_user_pre_updating_files_array
*
* @example <caption>Extends submitted files.</caption>
* function my_user_pre_updating_files( $files, $user_id ) {
* $files[] = 'some file';
2018-03-20 13:24:38 +02:00
* return $files;
* }
2023-07-01 01:52:43 +03:00
* add_filter( 'um_user_pre_updating_files_array', 'my_user_pre_updating_files', 10, 2 );
2018-03-20 13:24:38 +02:00
*/
2023-07-01 01:52:43 +03:00
$files = apply_filters( 'um_user_pre_updating_files_array', $files, $user_id );
if ( ! empty( $files ) && is_array( $files ) ) {
2019-02-08 11:43:01 +02:00
UM()->uploader()->replace_upload_dir = true;
2018-08-07 18:05:13 +03:00
UM()->uploader()->move_temporary_files( $user_id, $files );
2019-02-08 11:43:01 +02:00
UM()->uploader()->replace_upload_dir = false;
2017-11-30 16:27:30 +02:00
}
2018-03-20 13:24:38 +02:00
}
2023-06-30 21:55:59 +03:00
add_action( 'um_registration_set_extra_data', 'um_registration_save_files', 10, 3 );
2018-03-20 13:24:38 +02:00
/**
* Update user Full Name
*
* @profile name update
*
* @param $user_id
* @param $args
*/
function um_registration_set_profile_full_name( $user_id, $args ) {
/**
2023-06-30 21:55:59 +03:00
* Fires for updating user profile full name.
2018-03-20 13:24:38 +02:00
*
2023-06-30 21:55:59 +03:00
* @since 1.3.x
* @hook um_registration_set_extra_data
*
* @param {int} $user_id User ID.
* @param {array} $submitted_data $_POST Submission array.
*
* @example <caption>Make any custom action when updating user profile full name.</caption>
* function my_registration_set_extra_data( $user_id, $submitted_data ) {
2018-03-20 13:24:38 +02:00
* // your code here
* }
2023-06-30 21:55:59 +03:00
* add_action( 'um_update_profile_full_name', 'my_update_profile_full_name', 10, 2 );
2018-03-20 13:24:38 +02:00
*/
do_action( 'um_update_profile_full_name', $user_id, $args );
}
2018-05-25 15:05:14 +03:00
add_action( 'um_registration_set_extra_data', 'um_registration_set_profile_full_name', 10, 2 );
/**
2023-08-27 21:29:36 +03:00
* Redirect from default registration to UM registration page
2018-05-25 15:05:14 +03:00
*/
function um_form_register_redirect() {
2024-03-07 14:56:55 +02:00
$page_id = UM()->options()->get( UM()->options()->get_predefined_page_option_key( 'register' ) );
2023-08-27 21:29:36 +03:00
// Do not redirect if the registration page is not published.
if ( ! empty( $page_id ) && 'publish' === get_post_status( $page_id ) ) {
2023-07-18 12:06:17 +03:00
// Not `um_safe_redirect()` because predefined register page is situated on the same host.
2018-05-25 15:05:14 +03:00
wp_safe_redirect( get_permalink( $page_id ) );
exit();
}
}
2021-07-27 16:50:19 +03:00
add_action( 'login_form_register', 'um_form_register_redirect', 10 );