user()->approve(); } /** * Account needs email validation */ add_action('um_post_registration_checkmail_hook', 'um_post_registration_checkmail_hook', 10, 2); function um_post_registration_checkmail_hook($user_id, $args){ um_fetch_user( $user_id ); UM()->user()->email_pending(); } /** * Account needs admin review */ add_action('um_post_registration_pending_hook', 'um_post_registration_pending_hook', 10, 2); function um_post_registration_pending_hook($user_id, $args){ um_fetch_user( $user_id ); UM()->user()->pending(); } /** * After adding a new user */ add_action( 'um_after_new_user_register', 'um_after_new_user_register', 10, 2 ); function um_after_new_user_register( $user_id, $args ) { global $pagenow; um_fetch_user( $user_id ); if ( ! isset( $args['role'] ) ) $args['role'] = get_option( 'default_role', true ); if ( $pagenow != 'user-new.php' && ! array_key_exists( $args['role'], UM()->roles()->get_roles( false, array( 'admin' ) ) ) ) $args['role'] = get_option( 'default_role', true ); if ( ! user_can( $user_id, $args['role'] ) ) UM()->roles()->set_um_user_role( $user_id, $args['role'] ); if ( ! empty( $args['submitted'] ) ) UM()->user()->set_registration_details( $args['submitted'] ); //UM()->user()->set_last_login(); UM()->user()->remove_cached_queue(); do_action( 'um_post_registration_save', $user_id, $args ); //send notification about registration do_action( 'um_post_registration_listener', $user_id, $args ); do_action( 'um_post_registration', $user_id, $args ); } /** * Update user's profile after registration */ add_action( 'um_post_registration_save', 'um_post_registration_save', 10, 2 ); function um_post_registration_save( $user_id, $args ) { unset( $args['user_id'] ); $args['_user_id'] = $user_id; $args['is_signup'] = 1; do_action( 'um_user_edit_profile', $args ); } /** * Post-registration admin listener */ add_action('um_post_registration_listener', 'um_post_registration_listener', 10, 2); function um_post_registration_listener( $user_id, $args ) { if ( um_user('status') != 'pending' ) { UM()->mail()->send( um_admin_email(), 'notification_new_user', array( 'admin' => true ) ); } else { UM()->mail()->send( um_admin_email(), 'notification_review', array( 'admin' => true ) ); } } /** * Post-registration procedure */ add_action('um_post_registration', 'um_post_registration', 10, 2); function um_post_registration( $user_id, $args ) { unset( $args['user_id'] ); extract( $args ); $status = um_user( 'status' ); /* * maybe in future * if ( ! is_admin() ) { um_fetch_user( $user_id ); $user_roles = UM()->roles()->um_get_user_role( $user_id ); var_dump( $user_roles ); $role_meta = UM()->roles()->role_data( $user_roles ); var_dump( $role_meta ); if ( $role_meta['_um_status'] == 'approved' ) { UM()->user()->approve(); } elseif ( $role_meta['_um_status'] == 'checkmail' ) { UM()->user()->email_pending(); } elseif ( $role_meta['_um_status'] == 'pending' ) { UM()->user()->pending(); } $status = um_user( 'status' ); }*/ do_action( "um_post_registration_{$status}_hook", $user_id, $args ); if ( ! is_admin() ) { do_action( "track_{$status}_user_registration" ); // Priority redirect if ( isset( $args['redirect_to'] ) ) { exit( wp_redirect( urldecode( $args['redirect_to'] ) ) ); } if ( $status == 'approved' ) { UM()->user()->auto_login( $user_id ); UM()->user()->get_profile_url( $user_id, true ); do_action( 'um_registration_after_auto_login', $user_id ); if ( um_user( 'auto_approve_act' ) == 'redirect_url' && um_user( 'auto_approve_url' ) !== '' ) { exit( wp_redirect( um_user( 'auto_approve_url' ) ) ); } if ( um_user( 'auto_approve_act' ) == 'redirect_profile' ) { exit( wp_redirect( um_user_profile_url() ) ); } } if ( $status != 'approved' ) { if ( um_user( $status . '_action' ) == 'redirect_url' && um_user( $status . '_url' ) != '' ) { exit( wp_redirect( um_user( $status . '_url' ) ) ); } if ( um_user( $status . '_action' ) == 'show_message' && um_user( $status . '_message' ) != '' ) { $url = UM()->permalinks()->get_current_url(); $url = add_query_arg( 'message', esc_attr( $status ), $url ); $url = add_query_arg( 'um_role', esc_attr( um_user( 'role' ) ), $url ); $url = add_query_arg( 'um_form_id', esc_attr( $form_id ), $url ); exit( wp_redirect( $url ) ); } } } } /** * New user registration */ add_action( 'um_user_registration', 'um_user_registration', 10 ); function um_user_registration( $args ) { unset( $args['user_id'] ); extract( $args ); if ( isset( $username ) && ! isset( $args['user_login'] ) ) { $user_login = $username; } if ( ! empty( $first_name ) && ! empty( $last_name ) && ! isset( $user_login ) ) { if ( um_get_option( 'permalink_base' ) == 'name' ) { $user_login = rawurlencode( strtolower( str_replace( " ", ".", $first_name . " " . $last_name ) ) ); } elseif ( um_get_option( 'permalink_base' ) == 'name_dash' ) { $user_login = rawurlencode( strtolower( str_replace( " ", "-", $first_name . " " . $last_name ) ) ); } elseif ( um_get_option( 'permalink_base' ) == 'name_plus' ) { $user_login = strtolower( str_replace( " ", "+", $first_name . " " . $last_name ) ); } else { $user_login = strtolower( str_replace( " ", "", $first_name . " " . $last_name ) ); } // if full name exists $count = 1; while ( username_exists( $user_login ) ) { $user_login .= $count; $count++; } } if ( ! isset( $user_login ) && isset( $user_email ) && $user_email ) { $user_login = $user_email; } $unique_userID = UM()->query()->count_users() + 1; if ( ! isset( $user_login ) || strlen( $user_login ) > 30 && ! is_email( $user_login ) ) { $user_login = 'user' . $unique_userID; } if ( isset( $username ) && is_email( $username ) ) { $user_email = $username; } if ( ! isset( $user_password ) ) { $user_password = UM()->validation()->generate( 8 ); } if ( ! isset( $user_email ) ) { $site_url = @$_SERVER['SERVER_NAME']; $user_email = 'nobody' . $unique_userID . '@' . $site_url; $user_email = apply_filters( "um_user_register_submitted__email", $user_email ); } $creds['user_login'] = $user_login; $creds['user_password'] = $user_password; $creds['user_email'] = trim( $user_email ); $args = apply_filters('um_add_user_frontend_submitted', $args ); $args['submitted'] = array_merge( $args['submitted'], $creds ); $args = array_merge( $args, $creds ); unset( $args['user_id'] ); do_action( 'um_before_new_user_register', $args ); $default_role = get_option( 'default_role', true ); /* if ( empty( $default_role ) ) $default_role = get_option( 'default_role' );*/ $userdata = array( 'user_login' => $user_login, 'user_pass' => $user_password, 'user_email' => $user_email, 'role' => $default_role, ); $user_id = wp_insert_user( $userdata ); do_action( 'um_after_new_user_register', $user_id, $args ); return $user_id; } /** * Form Processing */ add_action( 'um_submit_form_register', 'um_submit_form_register', 10 ); function um_submit_form_register( $args ) { if ( ! isset( UM()->form()->errors ) ) do_action( 'um_user_registration', $args ); } /** * Register user with predefined role in options */ add_action('um_after_register_fields', 'um_add_user_role'); function um_add_user_role( $args ){ if ( isset( $args['custom_fields']['role_select'] ) || isset( $args['custom_fields']['role_radio'] ) ) return; $use_global_settings = get_post_meta( $args['form_id'], '_um_register_use_globals', true); if (isset($args['role']) && !empty($args['role']) && $use_global_settings == 0 ) { $role = $args['role']; } else if( $use_global_settings == 1 ) { //$role = um_get_option('default_role'); $role = get_option( 'default_role' ); } if( empty( $role ) ) return; $role = apply_filters('um_register_hidden_role_field', $role ); if( $role ){ echo ''; } } /** * Show the submit button */ add_action('um_after_register_fields', 'um_add_submit_button_to_register', 1000); function um_add_submit_button_to_register($args){ // DO NOT add when reviewing user's details if ( isset( UM()->user()->preview ) && UM()->user()->preview == true && is_admin() ) return; $primary_btn_word = $args['primary_btn_word']; $primary_btn_word = apply_filters('um_register_form_button_one', $primary_btn_word, $args ); $secondary_btn_word = $args['secondary_btn_word']; $secondary_btn_word = apply_filters('um_register_form_button_two', $secondary_btn_word, $args ); $secondary_btn_url = ( isset( $args['secondary_btn_url'] ) && $args['secondary_btn_url'] ) ? $args['secondary_btn_url'] : um_get_core_page('login'); $secondary_btn_url = apply_filters('um_register_form_button_two_url', $secondary_btn_url, $args ); ?>
fields()->display( 'register', $args ); } /** * Set user gravatar with user_email */ add_action('user_register','um_user_register_generate_gravatar'); function um_user_register_generate_gravatar( $user_id ){ UM()->user()->set_gravatar( $user_id ); }