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-23 16:52:22 +03:00
* @param int $user_id
* @param array $args
2018-03-20 13:24:38 +02:00
*/
function um_post_registration_approved_hook ( $user_id , $args ) {
um_fetch_user ( $user_id );
UM () -> user () -> approve ();
}
add_action ( 'um_post_registration_approved_hook' , 'um_post_registration_approved_hook' , 10 , 2 );
/**
2023-06-23 16:52:22 +03:00
* Account needs email validation.
2018-03-20 13:24:38 +02:00
*
2023-06-23 16:52:22 +03:00
* @param int $user_id
* @param array $args
2018-03-20 13:24:38 +02:00
*/
function um_post_registration_checkmail_hook ( $user_id , $args ) {
um_fetch_user ( $user_id );
UM () -> user () -> email_pending ();
}
add_action ( 'um_post_registration_checkmail_hook' , 'um_post_registration_checkmail_hook' , 10 , 2 );
/**
2023-06-23 16:52:22 +03:00
* Account needs admin review.
2018-03-20 13:24:38 +02:00
*
2023-06-23 16:52:22 +03:00
* @param int $user_id
* @param array $args
2018-03-20 13:24:38 +02:00
*/
function um_post_registration_pending_hook ( $user_id , $args ) {
um_fetch_user ( $user_id );
UM () -> user () -> pending ();
}
2023-06-23 16:52:22 +03:00
add_action ( 'um_post_registration_pending_hook' , 'um_post_registration_pending_hook' , 10 , 2 );
2018-03-20 13:24:38 +02:00
/**
* After insert a new user
* run at frontend and backend
*
* @param $user_id
* @param $args
*/
function um_after_insert_user ( $user_id , $args ) {
2020-03-25 22:48:01 +02:00
if ( empty ( $user_id ) || ( is_object ( $user_id ) && is_a ( $user_id , 'WP_Error' ) ) ) {
return ;
}
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' ] ) ) {
2019-05-08 16:05:27 +03:00
UM () -> user () -> set_registration_details ( $args [ 'submitted' ], $args );
2017-07-26 14:57:52 +03:00
}
2020-05-25 18:00:39 +03:00
2020-12-22 17:04:18 +02:00
$status = um_user ( 'status' );
if ( empty ( $status ) ) {
um_fetch_user ( $user_id );
$status = um_user ( 'status' );
}
2020-05-25 18:00:39 +03:00
/* save user status */
2020-12-22 17:04:18 +02:00
UM () -> user () -> set_status ( $status );
2020-05-25 18:00:39 +03:00
/* create user uploads directory */
UM () -> uploader () -> get_upload_user_base_dir ( $user_id , true );
2017-07-26 14:57:52 +03:00
/**
2018-03-20 13:24:38 +02:00
* UM hook
*
* @type action
* @title um_registration_set_extra_data
* @description Hook that runs after insert user to DB and there you can set any extra details
* @input_vars
* [{"var":"$user_id","type":"int","desc":"User ID"},
* {"var":"$args","type":"array","desc":"Form data"}]
* @change_log
* ["Since: 2.0"]
* @usage add_action( 'um_registration_set_extra_data', 'function_name', 10, 2 );
* @example
* <?php
* add_action( 'um_registration_set_extra_data', 'my_registration_set_extra_data', 10, 2 );
* function my_registration_set_extra_data( $user_id, $args ) {
* // your code here
* }
* ?>
2017-07-26 14:57:52 +03:00
*/
2018-03-20 13:24:38 +02:00
do_action ( 'um_registration_set_extra_data' , $user_id , $args );
2017-07-26 14:57:52 +03:00
/**
2018-03-20 13:24:38 +02:00
* UM hook
*
* @type action
* @title um_registration_complete
* @description After complete UM user registration. Redirects handlers at 100 priority, you can add some info before redirects
* @input_vars
* [{"var":"$user_id","type":"int","desc":"User ID"},
* {"var":"$args","type":"array","desc":"Form data"}]
* @change_log
* ["Since: 2.0"]
* @usage add_action( 'um_registration_complete', 'function_name', 10, 2 );
* @example
* <?php
* add_action( 'um_registration_complete', 'my_registration_complete', 10, 2 );
* function my_registration_complete( $user_id, $args ) {
* // your code here
* }
* ?>
2017-07-26 14:57:52 +03:00
*/
2018-03-20 13:24:38 +02:00
do_action ( 'um_registration_complete' , $user_id , $args );
}
2018-05-11 15:08:06 +03:00
add_action ( 'um_user_register' , 'um_after_insert_user' , 1 , 2 );
2018-03-20 13:24:38 +02:00
/**
* Send notification about registration
*
* @param $user_id
* @param $args
*/
function um_send_registration_notification ( $user_id , $args ) {
um_fetch_user ( $user_id );
2018-04-02 23:04:39 +03:00
$emails = um_multi_admin_email ();
if ( ! empty ( $emails ) ) {
foreach ( $emails as $email ) {
2023-06-23 16:52:22 +03:00
if ( 'pending' !== um_user ( 'account_status' ) ) {
2018-04-02 23:04:39 +03:00
UM () -> mail () -> send ( $email , 'notification_new_user' , array ( 'admin' => true ) );
} else {
UM () -> mail () -> send ( $email , 'notification_review' , array ( 'admin' => true ) );
}
}
2017-07-26 14:57:52 +03:00
}
2018-03-20 13:24:38 +02:00
}
add_action ( 'um_registration_complete' , 'um_send_registration_notification' , 10 , 2 );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
/**
* Check user status and redirect it after registration
*
* @param $user_id
* @param $args
*/
function um_check_user_status ( $user_id , $args ) {
2018-05-11 10:53:29 +03:00
$status = um_user ( 'account_status' );
2018-03-20 13:24:38 +02:00
2017-07-26 14:57:52 +03:00
/**
2018-03-20 13:24:38 +02:00
* UM hook
2017-08-31 15:05:27 +03:00
*
2018-03-20 13:24:38 +02:00
* @type action
* @title um_post_registration_{$status}_hook
* @description After complete UM user registration.
* @input_vars
* [{"var":"$user_id","type":"int","desc":"User ID"},
* {"var":"$args","type":"array","desc":"Form data"}]
* @change_log
* ["Since: 2.0"]
* @usage add_action( 'um_post_registration_{$status}_hook', 'function_name', 10, 2 );
* @example
* <?php
* add_action( 'um_post_registration_{$status}_hook', 'my_post_registration', 10, 2 );
* function my_post_registration( $user_id, $args ) {
* // your code here
* }
* ?>
2017-07-26 14:57:52 +03:00
*/
2018-03-20 13:24:38 +02:00
do_action ( " um_post_registration_ { $status } _hook " , $user_id , $args );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
if ( ! is_admin () ) {
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
do_action ( " track_ { $status } _user_registration " );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
if ( $status == 'approved' ) {
2022-10-10 18:48:16 +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 );
}
2018-03-20 13:24:38 +02:00
UM () -> user () -> generate_profile_slug ( $user_id );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
/**
* UM hook
*
* @type action
* @title um_registration_after_auto_login
* @description After complete UM user registration and autologin.
* @input_vars
* [{"var":"$user_id","type":"int","desc":"User ID"}]
* @change_log
* ["Since: 2.0"]
* @usage add_action( 'um_registration_after_auto_login', 'function_name', 10, 1 );
* @example
* <?php
* add_action( 'um_registration_after_auto_login', 'my_registration_after_auto_login', 10, 1 );
* function my_registration_after_auto_login( $user_id ) {
* // your code here
* }
* ?>
*/
do_action ( 'um_registration_after_auto_login' , $user_id );
2017-07-26 14:57:52 +03:00
2020-08-31 23:08:54 +03:00
// Priority redirect
if ( isset ( $args [ 'redirect_to' ] ) ) {
exit ( wp_safe_redirect ( urldecode ( $args [ 'redirect_to' ] ) ) );
}
2020-10-02 15:48:59 +03:00
um_fetch_user ( $user_id );
2018-03-20 13:24:38 +02:00
if ( um_user ( 'auto_approve_act' ) == 'redirect_url' && um_user ( 'auto_approve_url' ) !== '' ) {
exit ( wp_redirect ( um_user ( 'auto_approve_url' ) ) );
2017-07-26 14:57:52 +03:00
}
2018-03-20 13:24:38 +02:00
if ( um_user ( 'auto_approve_act' ) == 'redirect_profile' ) {
exit ( wp_redirect ( um_user_profile_url () ) );
2017-07-26 14:57:52 +03:00
}
2020-08-31 23:08:54 +03:00
} else {
2018-03-20 13:24:38 +02:00
if ( um_user ( $status . '_action' ) == 'redirect_url' && um_user ( $status . '_url' ) != '' ) {
/**
* UM hook
*
* @type filter
* @title um_registration_pending_user_redirect
* @description Change redirect URL for pending user after registration
* @input_vars
* [{"var":"$url","type":"string","desc":"Redirect URL"},
* {"var":"$status","type":"string","desc":"User status"},
* {"var":"$user_id","type":"int","desc":"User ID"}]
* @change_log
* ["Since: 2.0"]
* @usage
* <?php add_filter( 'um_registration_pending_user_redirect', 'function_name', 10, 3 ); ?>
* @example
* <?php
* add_filter( 'um_registration_pending_user_redirect', 'my_registration_pending_user_redirect', 10, 3 );
* function my_registration_pending_user_redirect( $url, $status, $user_id ) {
* // your code here
* return $url;
* }
* ?>
*/
$redirect_url = apply_filters ( 'um_registration_pending_user_redirect' , um_user ( $status . '_url' ), $status , um_user ( 'ID' ) );
exit ( wp_redirect ( $redirect_url ) );
}
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
if ( um_user ( $status . '_action' ) == 'show_message' && um_user ( $status . '_message' ) != '' ) {
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
$url = UM () -> permalinks () -> get_current_url ();
$url = add_query_arg ( 'message' , esc_attr ( $status ), $url );
//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 ( $args [ 'form_id' ] ), $url );
2017-07-26 14:57:52 +03:00
2018-03-20 13:24:38 +02:00
exit ( wp_redirect ( $url ) );
2017-07-26 14:57:52 +03:00
}
}
}
2018-03-20 13:24:38 +02:00
}
add_action ( 'um_registration_complete' , 'um_check_user_status' , 100 , 2 );
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
2018-03-20 13:24:38 +02:00
*/
function um_submit_form_register ( $args ) {
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-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>
2018-03-20 13:24:38 +02:00
* function my_add_user_frontend_submitted( $submitted ) {
* // your code here
* return $submitted;
* }
2023-06-26 14:31:25 +03:00
* add_filter( 'um_add_user_frontend_submitted', 'my_add_user_frontend_submitted' );
2017-07-26 14:57:52 +03:00
*/
2018-03-20 13:24:38 +02:00
$args = apply_filters ( 'um_add_user_frontend_submitted' , $args );
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
2023-06-22 12:21:55 +03:00
if ( ! isset ( $args [ 'user_password' ] ) ) {
2018-03-20 13:24:38 +02:00
$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
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 );
2020-12-04 00:10:20 +02:00
2023-06-26 14:31:25 +03:00
// Set registration timestamp.
$timestamp = current_time ( 'timestamp' ); // @todo Working on timestamps.
2020-12-04 00:10:20 +02:00
$args [ 'submitted' ][ 'timestamp' ] = $timestamp ;
2023-06-22 12:21:55 +03:00
$args [ 'timestamp' ] = $timestamp ;
2020-12-04 00:10:20 +02:00
2018-03-20 13:24:38 +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-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>
* function my_registration_user_role( $user_role, $args ) {
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-22 12:21:55 +03:00
* add_filter( 'um_registration_user_role', 'my_registration_user_role', 10, 2 );
2018-03-20 13:24:38 +02:00
*/
2018-05-25 18:22:38 +03:00
$user_role = apply_filters ( 'um_registration_user_role' , $user_role , $args );
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 ,
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 );
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-22 12:21:55 +03:00
* @since 2.0
* @hook um_user_register
*
* @param {int} $user_id User ID.
2023-06-26 14:31:25 +03:00
* @param {array} $args Form data.
2023-06-22 12:21:55 +03:00
*
* @example <caption>Make any custom action after complete UM user registration.</caption>
2023-06-26 14:31:25 +03:00
* function my_um_user_register( $user_id, $args ) {
2018-03-20 13:24:38 +02:00
* // your code here
* }
2023-06-26 14:31:25 +03:00
* add_action( 'um_user_register', 'my_um_user_register', 10, 2 );
2017-07-26 14:57:52 +03:00
*/
2018-03-20 13:24:38 +02:00
do_action ( 'um_user_register' , $user_id , $args );
}
2023-06-26 14:31:25 +03:00
add_action ( 'um_submit_form_register' , 'um_submit_form_register' );
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 );
/**
* Saving files to register a new user, if there are fields with files
*
* @param $user_id
* @param $args
*/
function um_registration_save_files( $user_id, $args ) {
2017-11-17 11:18:46 +02:00
2019-05-08 16:05:27 +03:00
if ( empty( $args['custom_fields'] ) ) {
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
2018-03-20 13:24:38 +02:00
$fields = unserialize( $args['custom_fields'] );
2017-10-20 12:39:45 +03:00
2018-03-20 13:24:38 +02:00
// loop through fields
if ( isset( $fields ) && is_array( $fields ) ) {
2017-10-20 12:39:45 +03:00
2018-03-20 13:24:38 +02:00
foreach ( $fields as $key => $array ) {
2017-10-20 12:39:45 +03:00
2019-05-09 00:52:42 +03:00
if ( isset( $args['submitted'][ $key ] ) ) {
2017-10-20 12:39:45 +03:00
2019-05-08 16:05:27 +03:00
if ( isset( $fields[ $key ]['type'] ) && in_array( $fields[ $key ]['type'], array( 'image', 'file' ) ) &&
( um_is_temp_file( $args['submitted'][ $key ] ) || $args['submitted'][ $key ] == 'empty_file' )
2018-03-20 13:24:38 +02:00
) {
2017-10-20 12:39:45 +03: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
/**
* UM hook
*
* @type filter
* @title um_user_pre_updating_files_array
* @description Change submitted files before register new user
* @input_vars
* [{"var":"$files","type":"array","desc":"Profile data files"}]
* @change_log
* ["Since: 2.0"]
* @usage
* <?php add_filter( 'um_user_pre_updating_files_array', 'function_name', 10, 1 ); ?>
* @example
* <?php
* add_filter( 'um_user_pre_updating_files_array', 'my_user_pre_updating_files', 10, 1 );
* function my_user_pre_updating_files( $files ) {
* // your code here
* return $files;
* }
* ?>
*/
$files = apply_filters( 'um_user_pre_updating_files_array', $files );
2018-09-16 21:55:06 +03:00
if ( ! empty( $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
}
add_action( 'um_registration_set_extra_data', 'um_registration_save_files', 10, 2 );
/**
* Update user Full Name
*
* @profile name update
*
* @param $user_id
* @param $args
*/
function um_registration_set_profile_full_name( $user_id, $args ) {
/**
* UM hook
*
* @type action
* @title um_update_profile_full_name
* @description On update user profile change full name
* @input_vars
* [{"var":"$user_id","type":"int","desc":"User ID"},
* {"var":"$args","type":"array","desc":"Form data"}]
* @change_log
* ["Since: 2.0"]
* @usage add_action( 'um_update_profile_full_name', 'function_name', 10, 2 );
* @example
* <?php
* add_action( 'um_update_profile_full_name', 'my_update_profile_full_name', 10, 2 );
* function my_update_profile_full_name( $user_id, $args ) {
* // your code here
* }
* ?>
*/
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 );
/**
* Redirect from default registration to UM registration page
*/
function um_form_register_redirect() {
$page_id = UM()->options()->get( UM()->options()->get_core_page_id( 'register' ) );
$register_post = get_post( $page_id );
if ( ! empty( $register_post ) ) {
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 );