Project

General

Profile

Auto Scheduled Tasks #23586 » cac-save-initial-email-address-for-existing-users.php

Boone Gorges, 2026-03-19 07:46 AM

 
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();
    (1-1/1)