This commit introduces a more reliable and consistent approach to setting up the development environment using backups: - Add setup-from-backup.sh script for environment setup from existing backups - Standardize script naming and organization - Move obsolete scripts to bin/obsolete directory - Update documentation with new workflow instructions - Create migration guide for transitioning to new workflow - Update Memory Bank with workflow improvements The new workflow provides: - More reliable environment setup - Faster setup process - Offline development capability - Consistent development environments across team members Breaking changes: - setup-dev.sh is replaced by setup-from-backup.sh - sync-and-setup.sh is replaced by separate scripts - verify-with-wpcli.sh is no longer used Migration path is documented in MIGRATION_GUIDE.md
		
			
				
	
	
		
			321 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			321 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * UserRegistration Account Functions
 | |
|  *
 | |
|  * Functions for account specific things.
 | |
|  *
 | |
|  * @package  UserRegistration/Functions
 | |
|  * @version  1.0.0
 | |
|  */
 | |
| 
 | |
| if ( ! defined( 'ABSPATH' ) ) {
 | |
| 	exit;
 | |
| }
 | |
| 
 | |
| add_filter( 'login_errors', 'ur_login_error_message' );
 | |
| add_filter( 'get_avatar', 'ur_replace_gravatar_image', 99, 6 );
 | |
| add_filter( 'ajax_query_attachments_args', 'ur_show_current_user_attachments' );
 | |
| 
 | |
| /**
 | |
|  * Limit media library access to own uploads.
 | |
|  *
 | |
|  * @since 1.5.8
 | |
|  *
 | |
|  * @param  array $query User Queries.
 | |
|  *
 | |
|  * @return array
 | |
|  */
 | |
| function ur_show_current_user_attachments( $query ) {
 | |
| 	$user_id = get_current_user_id();
 | |
| 
 | |
| 	if ( $user_id && ! current_user_can( 'edit_others_posts' ) ) {
 | |
| 		$query['author'] = $user_id;
 | |
| 	}
 | |
| 
 | |
| 	return $query;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Modify error message on invalid username or password.
 | |
|  *
 | |
|  * @param string $error Error Message.
 | |
|  */
 | |
| function ur_login_error_message( $error ) {
 | |
| 	// Don't change login error messages on admin site .
 | |
| 	if ( isset( $_POST['redirect_to'] ) && false !== strpos( wp_unslash( $_POST['redirect_to'] ), network_admin_url() ) ) {  // phpcs:ignore WordPress.Security.NonceVerification, WordPress.Security.ValidatedSanitizedInput.InputNotSanitized
 | |
| 		return $error;
 | |
| 	}
 | |
| 
 | |
| 	$pos  = strpos( $error, 'incorrect' );     // Check if the error contains incorrect string.
 | |
| 	$pos2 = strpos( $error, 'Invalid' );       // Check if the error contains Invalid string.
 | |
| 
 | |
| 	// Its the correct username with incorrect password.
 | |
| 	if ( is_int( $pos ) && isset( $_POST['username'] ) ) {  // phpcs:ignore WordPress.Security.NonceVerification
 | |
| 		/* translators: %s - Username */
 | |
| 		$error = sprintf( '<strong>' . __( 'ERROR:', 'user-registration' ) . '</strong>' . __( 'The password you entered for username %1$1s is incorrect. %2$2s', 'user-registration' ), sanitize_text_field( wp_unslash( $_POST['username'] ) ), "<a href='" . esc_url( wp_lostpassword_url() ) . "'>" . __( 'Lost Your Password?', 'user-registration' ) . '</a>' ); // phpcs:ignore WordPress.Security.NonceVerification
 | |
| 	} elseif ( is_int( $pos2 ) && isset( $_POST['username'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification
 | |
| 		/* translators: %s - Lost password URL */
 | |
| 		$error = sprintf( '<strong>' . __( 'ERROR:', 'user-registration' ) . '</strong>' . __( 'Invalid username. %1s', 'user-registration' ), "<a href='" . esc_url( wp_lostpassword_url() ) . "'>" . __( 'Lost Your Password?', 'user-registration' ) . '</a>' ); // 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(
 | |
| 			"<img alt='%s' src='%s' srcset='%s' class='%s' height='%d' width='%d' %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;
 | |
| 	}
 | |
| }
 |