' . __( 'ERROR:', 'user-registration' ) . '' . __( 'The password you entered for username %1$1s is incorrect. %2$2s', 'user-registration' ), sanitize_text_field( wp_unslash( $_POST['username'] ) ), "" . __( 'Lost Your Password?', 'user-registration' ) . '' ); // phpcs:ignore WordPress.Security.NonceVerification } elseif ( is_int( $pos2 ) && isset( $_POST['username'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification /* translators: %s - Lost password URL */ $error = sprintf( '' . __( 'ERROR:', 'user-registration' ) . '' . __( 'Invalid username. %1s', 'user-registration' ), "" . __( 'Lost Your Password?', 'user-registration' ) . '' ); // phpcs:ignore WordPress.Security.NonceVerification } return $error; } /** * Returns the url to the lost password endpoint url. * * @param string $default_url Default lost password URL. * * @return string */ function ur_lostpassword_url( $default_url = '' ) { // Don't redirect to the user registration endpoint on global network admin lost passwords. if ( is_multisite() && isset( $_GET['redirect_to'] ) && false !== strpos( wp_unslash( $_GET['redirect_to'] ), network_admin_url() ) ) { // phpcs:ignore WordPress.Security.NonceVerification, WordPress.Security.ValidatedSanitizedInput.InputNotSanitized return $default_url; } // Don't change default url if admin side login form. if ( 'wp-login.php' === $GLOBALS['pagenow'] ) { return $default_url; } $lost_password_page = get_option( 'user_registration_lost_password_page_id', false ); if ( $lost_password_page && ! empty( get_post( $lost_password_page ) ) ) { return get_permalink( $lost_password_page ); } else { $ur_account_page_url = ur_get_page_permalink( 'myaccount' ); $ur_account_page_exists = ur_get_page_id( 'myaccount' ) > 0; $lost_password_endpoint = get_option( 'user_registration_myaccount_lost_password_endpoint', 'lost-password' ); $lost_password_page = get_option( 'user_registration_general_setting_lost_password_page', '' ); $ur_login_page_exists = ur_get_page_id( 'login' ) > 0; if ( ! $ur_account_page_exists && $ur_login_page_exists ) { update_option( 'user_registration_login_page_id', ur_get_page_id( 'login' ) ); } if ( $ur_account_page_exists && ! empty( $lost_password_endpoint ) ) { return ur_get_endpoint_url( $lost_password_endpoint, '', $ur_account_page_url ); } elseif ( $ur_login_page_exists && ! empty( $lost_password_endpoint ) ) { return ur_get_endpoint_url( $lost_password_endpoint, '', get_permalink( ur_get_page_id( 'login' ) ) ); } elseif ( ! empty( $lost_password_endpoint ) && 'lost-password' !== $lost_password_endpoint ) { return str_replace( 'lost-password', $lost_password_endpoint, $default_url ); } else { return $default_url; } } } add_filter( 'lostpassword_url', 'ur_lostpassword_url', 20, 1 ); /** * Get My Account menu items. * * @return array */ function ur_get_account_menu_items() { $endpoints = array( 'edit-profile' => get_option( 'user_registration_myaccount_edit_profile_endpoint', 'edit-profile' ), 'edit-password' => get_option( 'user_registration_myaccount_change_password_endpoint', 'edit-password' ), 'user-logout' => get_option( 'user_registration_logout_endpoint', 'user-logout' ), ); $items = array( 'dashboard' => __( 'Dashboard', 'user-registration' ), 'edit-profile' => __( 'Profile Details', 'user-registration' ), 'edit-password' => __( 'Change Password', 'user-registration' ), 'user-logout' => __( 'Logout', 'user-registration' ), ); $user_id = get_current_user_id(); $form_id = ur_get_form_id_by_userid( $user_id ); $profile = user_registration_form_data( $user_id, $form_id ); if ( count( $profile ) < 1 ) { unset( $items['edit-profile'] ); } // Remove missing endpoints. foreach ( $endpoints as $endpoint_id => $endpoint ) { if ( empty( $endpoint ) ) { unset( $items[ $endpoint_id ] ); } } /** * Applies a filter to modify the account menu items. * * The 'user_registration_account_menu_items' filter allows developers to modify * the account menu items in User Registration. * * @param array $items Default array of account menu items. */ return apply_filters( 'user_registration_account_menu_items', $items ); } /** * Get account menu item classes. * * @param string $endpoint Endpoint. * * @return string */ function ur_get_account_menu_item_classes( $endpoint ) { global $wp; $classes = array( 'user-registration-MyAccount-navigation-link', 'user-registration-MyAccount-navigation-link--' . $endpoint, ); // Set current item class. $current = isset( $wp->query_vars[ $endpoint ] ); if ( 'dashboard' === $endpoint && ( isset( $wp->query_vars['page'] ) || empty( $wp->query_vars ) ) ) { $current = true; // Dashboard is not an endpoint, so needs a custom check. } if ( $current ) { $classes[] = 'is-active'; } /** * Applies a filter to modify the classes for an account menu item. * * The 'user_registration_account_menu_item_classes' filter allows developers to modify * the classes for an account menu item. * * @param array $classes Default array of classes for the account menu item. * @param string $endpoint The endpoint for the account menu item. */ $classes = apply_filters( 'user_registration_account_menu_item_classes', $classes, $endpoint ); return implode( ' ', array_map( 'sanitize_html_class', $classes ) ); } /** * Get account endpoint URL. * * @since 2.6.0 * * @param string $endpoint Endpoint. * * @return string */ function ur_get_account_endpoint_url( $endpoint ) { if ( 'dashboard' === $endpoint ) { return ur_get_page_permalink( 'myaccount' ); } if ( 'user-logout' === $endpoint ) { return ur_logout_url( ur_get_page_permalink( 'myaccount' ) ); } return ur_get_endpoint_url( $endpoint, '', ur_get_page_permalink( 'myaccount' ) ); } /** * Custom function to override get_gavatar function. * * @param [type] $avatar Avatar of user. * @param [type] $id_or_email ID or email of user. * @param [type] $size Size of avatar. * @param [type] $default Default avatar. * @param [type] $alt Alt. * @param array $args Args. */ function ur_replace_gravatar_image( $avatar, $id_or_email, $size, $default, $alt, $args = array() ) { global $wp_filter; remove_all_filters( 'get_avatar' ); add_filter( 'get_avatar', 'ur_replace_gravatar_image', 100, 6 ); // Process the user identifier. $user = false; if ( is_numeric( $id_or_email ) ) { $user = get_user_by( 'id', absint( $id_or_email ) ); } elseif ( is_string( $id_or_email ) ) { $user = get_user_by( 'email', $id_or_email ); } elseif ( $id_or_email instanceof WP_User ) { // User Object. $user = $id_or_email; } elseif ( $id_or_email instanceof WP_Post ) { // Post Object. $user = get_user_by( 'id', (int) $id_or_email->post_author ); } elseif ( $id_or_email instanceof WP_Comment ) { if ( ! empty( $id_or_email->user_id ) ) { $user = get_user_by( 'id', (int) $id_or_email->user_id ); } } if ( ! $user || is_wp_error( $user ) ) { return $avatar; } $profile_picture_url = get_user_meta( $user->ID, 'user_registration_profile_pic_url', true ); if ( is_numeric( $profile_picture_url ) ) { $profile_picture_url = wp_get_attachment_url( $profile_picture_url ); } $profile_picture_url = apply_filters( 'user_registration_profile_picture_url', $profile_picture_url, $user->ID ); $class = array( 'avatar', 'avatar-' . (int) $args['size'], 'photo' ); if ( ( isset( $args['found_avatar'] ) && ! $args['found_avatar'] ) || ( isset( $args['force_default'] ) && $args['force_default'] ) ) { $class[] = 'avatar-default'; } if ( $args['class'] ) { if ( is_array( $args['class'] ) ) { $class = array_merge( $class, $args['class'] ); } else { $class[] = $args['class']; } } if ( $profile_picture_url && ur_check_url_is_image( $profile_picture_url ) ) { $avatar = sprintf( "%s", esc_attr( $args['alt'] ), esc_url( $profile_picture_url ), esc_url( $profile_picture_url ) . ' 2x', esc_attr( join( ' ', $class ) ), (int) $args['height'], (int) $args['width'], $args['extra_attr'] ); } return $avatar; } if ( ! function_exists( 'ur_get_user_login_option' ) ) { /** * Returns user login option set in 'ur_login_option' meta. * If the meta is not set ( old users ), login option from form is returned. * * @param integer $user_id User Id. * @return string */ function ur_get_user_login_option( $user_id = 0 ) { $user_id = (int) $user_id; if ( 1 > $user_id ) { return ''; } $login_option = get_user_meta( $user_id, 'ur_login_option', true ); if ( empty( $login_option ) ) { $form_id = ur_get_form_id_by_userid( $user_id ); // Handle backwards compatibility. $login_option = get_option( 'user_registration_general_setting_login_options', 'default' ); $login_option = ur_get_single_post_meta( $form_id, 'user_registration_form_setting_login_options', $login_option ); } return $login_option; } }