Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

80 wp user avatar #85

Merged
merged 25 commits into from
Feb 22, 2022
Merged
Show file tree
Hide file tree
Changes from 19 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
573bcfa
Create wp-cli command to migrate avatars from WP User Avatars plugin
claytoncollie Sep 11, 2021
45ecb2f
Clean up the migrations option if the plugin is deactivated
claytoncollie Sep 11, 2021
4e4d4be
Make compatible with WP Multisite
claytoncollie Sep 11, 2021
26413b8
Rename cli method name
claytoncollie Oct 19, 2021
8fb01fd
Add button to settings fields
claytoncollie Oct 19, 2021
f3f468e
Add migration with wp ajax from dashboard
claytoncollie Oct 19, 2021
681f17d
Switch admin enqueue scripts guard clause to in-array and allow filte…
claytoncollie Oct 22, 2021
a29c240
Change plural and singlar names
claytoncollie Oct 22, 2021
8514dc9
Fix nonce verification by using get_query_var
claytoncollie Oct 22, 2021
77f743a
Update class names to be singular or plural
claytoncollie Oct 22, 2021
5a306c5
Refactor to DRY out code
claytoncollie Oct 22, 2021
44ffa4d
Add acceptance test for new settings fields
claytoncollie Nov 5, 2021
8949b2a
Simplify CLI command. Add --yes flag to skip confirmation for automat…
claytoncollie Nov 5, 2021
f6fe4ea
Error out and stop execution on WP CLI migration script
claytoncollie Nov 6, 2021
c3ca822
Refactor admin button to use paragraphs
claytoncollie Nov 6, 2021
6df622a
Add dynamic messaging to AJAX version of migration script
claytoncollie Nov 6, 2021
3c537c6
Merge develop into 80-wp-user-avatar
claytoncollie Nov 6, 2021
7a765ef
Change admin table heading to be more descriptive
claytoncollie Dec 1, 2021
0c21332
Change wording on success message to be single string
claytoncollie Dec 1, 2021
0213020
Remove extra spaces in array
claytoncollie Dec 10, 2021
b6cc21d
Do not set default parameter values
claytoncollie Dec 10, 2021
d3768cd
Sanitize data
claytoncollie Dec 10, 2021
a2dc546
Add support for single site and multisite installs
claytoncollie Dec 17, 2021
3235c37
revert change to how we get user ID on user-edit screen
claytoncollie Dec 23, 2021
8b23cee
Merge branch 'develop' into 80-wp-user-avatar
faisal-alvi Feb 16, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
206 changes: 199 additions & 7 deletions includes/class-simple-local-avatars.php
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,12 @@ public function add_hooks() {
add_action( 'user_edit_form_tag', array( $this, 'user_edit_form_tag' ) );

add_action( 'rest_api_init', array( $this, 'register_rest_fields' ) );

add_action( 'wp_ajax_migrate_from_wp_user_avatar', array( $this, 'ajax_migrate_from_wp_user_avatar' ) );

if ( defined( 'WP_CLI' ) && WP_CLI ) {
WP_CLI::add_command( 'simple-local-avatars migrate wp-user-avatar', array( $this, 'wp_cli_migrate_from_wp_user_avatar' ) );
}
}

/**
Expand Down Expand Up @@ -251,6 +257,13 @@ public function admin_init() {
'desc' => __( 'Only allow users with file upload capabilities to upload local avatars (Authors and above)', 'simple-local-avatars' ),
)
);
add_settings_field(
'simple-local-avatars-migration',
__( 'Migrate Other Local Avatars', 'simple-local-avatars' ),
array( $this, 'migrate_from_wp_user_avatar_settings_field' ),
'discussion',
'avatars'
);
}

/**
Expand All @@ -259,15 +272,25 @@ public function admin_init() {
* @param string $hook_suffix Page hook
*/
public function admin_enqueue_scripts( $hook_suffix ) {
if ( 'profile.php' !== $hook_suffix && 'user-edit.php' !== $hook_suffix ) {

/**
* Filter the admin screens where we enqueue our scripts.
*
* @param array $screens Array of admin screens.
* @param string $hook_suffix Page hook.
* @return array
*/
$screens = apply_filters( 'simple_local_avatars_admin_enqueue_scripts', array( 'profile.php', 'user-edit.php', 'options-discussion.php' ), $hook_suffix );

if ( ! in_array( $hook_suffix, $screens, true ) ) {
return;
}

if ( current_user_can( 'upload_files' ) ) {
wp_enqueue_media();
}

$user_id = ( 'profile.php' === $hook_suffix ) ? get_current_user_id() : (int) $_GET['user_id'];
$user_id = ( 'profile.php' === $hook_suffix ) ? get_current_user_id() : (int) get_query_var( 'user_id' );

$this->remove_nonce = wp_create_nonce( 'remove_simple_local_avatar_nonce' );

Expand All @@ -277,11 +300,15 @@ public function admin_enqueue_scripts( $hook_suffix ) {
'simple-local-avatars',
'i10n_SimpleLocalAvatars',
array(
'user_id' => $user_id,
'insertMediaTitle' => __( 'Choose an Avatar', 'simple-local-avatars' ),
'insertIntoPost' => __( 'Set as avatar', 'simple-local-avatars' ),
'deleteNonce' => $this->remove_nonce,
'mediaNonce' => wp_create_nonce( 'assign_simple_local_avatar_nonce' ),
'user_id' => $user_id,
'insertMediaTitle' => __( 'Choose an Avatar', 'simple-local-avatars' ),
'insertIntoPost' => __( 'Set as avatar', 'simple-local-avatars' ),
'deleteNonce' => $this->remove_nonce,
'mediaNonce' => wp_create_nonce( 'assign_simple_local_avatar_nonce' ),
'migrateFromWpUserAvatarNonce' => wp_create_nonce( 'migrate_from_wp_user_avatar_nonce' ),
'migrateFromWpUserAvatarSuccess' => __( 'Number of avatars successfully migrated from WP User Avatar', 'simple-local-avatars' ),
'migrateFromWpUserAvatarFailure' => __( 'No avatars were migrated from WP User Avatar.', 'simple-local-avatars' ),
'migrateFromWpUserAvatarProgress' => __( 'Migration in progress.', 'simple-local-avatars' ),
claytoncollie marked this conversation as resolved.
Show resolved Hide resolved
)
);
}
Expand Down Expand Up @@ -324,6 +351,17 @@ public function avatar_settings_field( $args ) {
';
}

/**
* Settings field for migrating avatars away from WP User Avatar
*/
public function migrate_from_wp_user_avatar_settings_field() {
printf(
'<p><button type="button" name="%1$s" id="%1$s" class="button button-secondary">%2$s</button></p><p class="%1$s-progress"></p>',
esc_attr( 'simple-local-avatars-migrate-from-wp-user-avatar' ),
esc_html__( 'Migrate avatars from WP User Avatar to Simple Local Avatars', 'simple-local-avatars' )
);
}

/**
* Output new Avatar fields to user editing / profile screen
*
Expand Down Expand Up @@ -678,4 +716,158 @@ public function get_avatar_rest( $user ) {
public function set_avatar_rest( $input, $user ) {
$this->assign_new_user_avatar( $input['media_id'], $user->ID );
}

/**
* Migrate the user's avatar data from WP User Avatar/ProfilePress
*
* This function creates a new option in the wp_options table to store the processed user IDs
* so that we can run this command multiple times without processing the same user over and over again.
*
* Credit to Philip John for the Gist
*
* @see https://gist.github.com/philipjohn/822d3521a95481f6ad7e118a7106fbc7
*
* @return int
*/
public function migrate_from_wp_user_avatar() {

global $wpdb;

$count = 0;
$sites = get_sites();

// Bail early if we don't find sites.
if ( empty( $sites ) ) {
claytoncollie marked this conversation as resolved.
Show resolved Hide resolved
return $count;
}

foreach ( $sites as $site ) {
// Get the blog ID to use in the meta key and user query.
$blog_id = isset( $site->blog_id ) ? $site->blog_id : 1;
claytoncollie marked this conversation as resolved.
Show resolved Hide resolved

// Get the name of the meta key for WP User Avatar.
$meta_key = $wpdb->get_blog_prefix( $blog_id ) . 'user_avatar';

// Get processed users from database.
$migrations = get_option( 'simple_local_avatars_migrations', array() );
$processed_users = isset( $migrations['wp_user_avatar'] ) ? $migrations['wp_user_avatar'] : array();
claytoncollie marked this conversation as resolved.
Show resolved Hide resolved

// Get all users that have a local avatar.
$users = get_users(
array(
'blog_id' => $blog_id,
'exclude' => $processed_users,
'meta_key' => $meta_key,
'meta_compare' => 'EXISTS',
)
);

// Bail early if we don't find users.
if ( empty( $users ) ) {
continue;
}

foreach ( $users as $user ) {
// Get the existing avatar media ID.
$avatar_id = get_user_meta( $user->ID, $meta_key, true );

// Attach the user and media to Simple Local Avatars.
$sla = new Simple_Local_Avatars();
$sla->assign_new_user_avatar( (int) $avatar_id, $user->ID );

// Check that it worked.
$is_migrated = get_user_meta( $user->ID, 'simple_local_avatar', true );

if ( ! empty( $is_migrated ) ) {
// Build array of user IDs.
$migrations['wp_user_avatar'][] = $user->ID;

// Record the user IDs so we don't process a second time.
$is_saved = update_option( 'simple_local_avatars_migrations', $migrations );

// Record how many avatars we migrate to be used in our messaging.
if ( $is_saved ) {
$count++;
}
}
}
}

return $count;

}

/**
* Migrate the user's avatar data away from WP User Avatar/ProfilePress via the dashboard.
*
* Sends the number of avatars processed back to the AJAX response before stopping execution.
*
* @return void
*/
public function ajax_migrate_from_wp_user_avatar() {
// Bail early if nonce is not available.
if ( empty( $_POST['migrateFromWpUserAvatarNonce'] ) ) {
die;
}

// Bail early if nonce is invalid.
if ( ! wp_verify_nonce( $_POST['migrateFromWpUserAvatarNonce'], 'migrate_from_wp_user_avatar_nonce' ) ) {
claytoncollie marked this conversation as resolved.
Show resolved Hide resolved
die();
}

// Run the migration script and store the number of avatars processed.
$count = $this->migrate_from_wp_user_avatar();

// Create the array we send back to javascript here.
$array_we_send_back = array( 'count' => $count );

// Make sure to json encode the output because that's what it is expecting.
echo wp_json_encode( $array_we_send_back );

// Make sure you die when finished doing ajax output.
wp_die();

}

/**
* Migrate the user's avatar data from WP User Avatar/ProfilePress via the command line.
*
* ## OPTIONS
*
* [--yes]
* : Skips the confirmations (for automated systems).
*
* ## EXAMPLES
*
* $ wp simple-local-avatars migrate wp-user-avatar
* Success: Number of avatars successfully migrated from WP User Avatar: 5
*
* @param array|null $args The arguments.
* @param array|null $assoc_args The associative arguments.
*
* @return void
*/
public function wp_cli_migrate_from_wp_user_avatar( $args = null, $assoc_args = null ) {
claytoncollie marked this conversation as resolved.
Show resolved Hide resolved

// Argument --yes to prevent confirmation (for automated systems).
if ( ! isset( $assoc_args['yes'] ) ) {
WP_CLI::confirm( esc_html__( 'Do you want to migrate avatars from WP User Avatar?', 'simple-local-avatars' ) );
}

// Run the migration script and store the number of avatars processed.
$count = $this->migrate_from_wp_user_avatar();

// Error out if we don't process any avatars.
if ( 0 === absint( $count ) ) {
WP_CLI::error( esc_html__( 'No avatars were migrated from WP User Avatar.', 'simple-local-avatars' ) );
}

WP_CLI::success(
sprintf(
'%s: %s',
esc_html__( 'Number of avatars successfully migrated from WP User Avatar', 'simple-local-avatars' ),
esc_html( $count )
)
);
}
}
27 changes: 27 additions & 0 deletions simple-local-avatars.dev.js
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,33 @@ jQuery(document).ready(function($){
avatar_preview.attr( 'src', current_avatar );
}
} );

$( document.getElementById('simple-local-avatars-migrate-from-wp-user-avatar') ).on( 'click', function(event) {
event.preventDefault();
jQuery.post( ajaxurl, { action: 'migrate_from_wp_user_avatar', migrateFromWpUserAvatarNonce: i10n_SimpleLocalAvatars.migrateFromWpUserAvatarNonce } )
claytoncollie marked this conversation as resolved.
Show resolved Hide resolved
.always( function() {
$('.simple-local-avatars-migrate-from-wp-user-avatar-progress').empty();
$('.simple-local-avatars-migrate-from-wp-user-avatar-progress').text(i10n_SimpleLocalAvatars.migrateFromWpUserAvatarProgress);
})
.done( function( response ) {
$('.simple-local-avatars-migrate-from-wp-user-avatar-progress').empty();
const data = $.parseJSON(response);
const count = data.count;
if ( 0 === count ) {
$('.simple-local-avatars-migrate-from-wp-user-avatar-progress').text(
i10n_SimpleLocalAvatars.migrateFromWpUserAvatarFailure
);
}
if ( count > 0 ) {
$('.simple-local-avatars-migrate-from-wp-user-avatar-progress').text(
i10n_SimpleLocalAvatars.migrateFromWpUserAvatarSuccess + ': ' + count
);
}
setTimeout(function() {
$('.simple-local-avatars-migrate-from-wp-user-avatar-progress').empty();
}, 5000);
});
});
});

function avatar_lock( lock_or_unlock ) {
Expand Down
1 change: 1 addition & 0 deletions simple-local-avatars.php
Original file line number Diff line number Diff line change
Expand Up @@ -57,4 +57,5 @@ function simple_local_avatars_uninstall() {
endforeach;

delete_option( 'simple_local_avatars' );
delete_option( 'simple_local_avatars_migrations' );
}
4 changes: 4 additions & 0 deletions tests/wpa/BasicTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,10 @@ public function testAdminSettingShows() {

$I->seeText( 'Local Avatars Only' );

$I->seeText( 'Local Upload Permissions' );

$I->seeText( 'Migrate Other Local Avatars' );

$I->moveTo( 'wp-admin/profile.php' );

$I->seeText( 'Upload Avatar' );
Expand Down