Я пытаюсь изменить эту функцию :
// automatically delete users after 7 days in wordpress
function wcs_auto_delete_users() {
global $wpdb;
$query = $wpdb->prepare( "SELECT ID FROM $wpdb->users WHERE datediff( now(), user_registered ) > 7" );
if ( $oldUsers = $wpdb->get_results( $query, ARRAY_N ) ) {
foreach ( $oldUsers as $user_id ) {
wp_delete_user( $user_id[0] );
}
}
}
add_action( 'wcs_daily_clean_database', 'wcs_auto_delete_users' );
wp_schedule_event( time(), 'daily', 'wcs_daily_clean_database' );
вместо этого работать по-другому - я хочу, чтобы он автоматически удалял пользователей, которые не были активны, скажем, в течение 2 месяцев. У меня есть плагин, который отслеживает активность пользователя и сохраняет данные в wp_usermeta. Пример:
user_id = 2; meta_key = wp_wp_kc_last_active_time; meta_value = 1422796627
Это запрос, который я придумал:
SELECT user_id FROM wp_usermeta WHERE meta_key = 'wp_wp_kc_last_active_time' AND TIMESTAMPDIFF( second, now(), TIMESTAMP(SELECT meta_value) ) > 5184000
Но это не выбор правильных идентификаторов. Что я должен изменить, чтобы это работало?
источник