Auto Scheduled Tasks #23586 » cac-save-initial-email-address-for-existing-users.php
| 1 |
<?php
|
|---|---|
| 2 |
|
| 3 |
global $wpdb; |
| 4 |
|
| 5 |
$user_ids = $wpdb->get_col( "SELECT ID FROM $wpdb->users LIMIT 20" ); |
| 6 |
|
| 7 |
$progress = WP_CLI\Utils\make_progress_bar( 'Saving initial email address for existing users', count( $user_ids ) ); |
| 8 |
|
| 9 |
foreach ( $user_ids as $user_id ) { |
| 10 |
$progress->tick(); |
| 11 |
|
| 12 |
$user = get_user_by( 'ID', $user_id ); |
| 13 |
if ( ! $user ) { |
| 14 |
continue; |
| 15 |
}
|
| 16 |
|
| 17 |
$signup = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM {$wpdb->signups} WHERE user_login = %s", $user->user_login ) ); |
| 18 |
if ( ! $signup ) { |
| 19 |
WP_CLI::log( "No signup record found for user ID {$user_id} ({$user->user_login}), skipping." ); |
| 20 |
continue; |
| 21 |
}
|
| 22 |
|
| 23 |
update_user_meta( $user_id, 'cac_initial_email_address', $signup->user_email ); |
| 24 |
|
| 25 |
WP_CLI::log( "Saved initial email address for user ID {$user_id}: {$signup->user_email}" ); |
| 26 |
};
|
| 27 |
|
| 28 |
$progress->finish(); |