Seditio Source
Root |
./othercms/b2evolution_7.2.3/inc/cron/jobs/_inactive_account_reminder.job.php
<?php
/**
 * This file implements the inactive account email reminder cron job
 */
if( !defined('EVO_MAIN_INIT') ) die( 'Please, do not access this page directly.' );

global
$DB, $UserSettings, $Settings;

global
$servertimenow, $baseurl;

$inactive_account_threshold = intval( $Settings->get( 'inactive_account_reminder_threshold' ) );
if(
$inactive_account_threshold === 0 )
{
   
cron_log_append( 'Sending of inactive account reminders disabled.' );
    return
1;
}

if( empty(
$UserSettings ) )
{    
// initialize UserSettings, because in CLI mode is not initialized yet:
   
load_class( 'users/model/_usersettings.class.php', 'UserSettings' );
   
$UserSettings = new UserSettings();
}

// Only users with "activated", "manualactivated" OR "autoactivated" statuses may receive inactive account reminders
$status_condition = '( user_status = "activated" OR user_status = "manualactivated" OR user_status = "autoactivated" )';

$SQL = new SQL();
$SQL->SELECT( 'T_users.*' );
$SQL->FROM( 'T_users' );
$SQL->FROM_add( 'LEFT JOIN T_users__usersettings last_sent ON last_sent.uset_user_ID = user_ID AND last_sent.uset_name = "last_inactive_status_email"' );
$SQL->FROM_add( 'LEFT JOIN T_users__usersettings notif_setting ON notif_setting.uset_user_ID = user_ID AND notif_setting.uset_name = "send_inactive_reminder"' );

// check that user status is 'activated' or 'manualactivated' or 'autoactivated', and send reminders only for these users.
$SQL->WHERE( $status_condition );
// check if user has an email address
$SQL->WHERE_and( 'LENGTH(TRIM(user_email)) > 0' );
// check that user email is not blocked
$SQL->WHERE_and( 'user_email NOT IN ( SELECT emadr_address FROM T_email__address WHERE '.get_mail_blocked_condition().' )' );
// check if user wants to receive inactive reminder or not
$SQL->WHERE_and( 'notif_setting.uset_value IS NULL OR notif_setting.uset_value <> '.$DB->quote( '0' ) );
// check if user last seen timestamp exceeds threshold for inactive users
$SQL->WHERE_and( 'TIMESTAMPDIFF( SECOND, GREATEST( user_created_datetime, IFNULL( user_lastseen_ts, 0 ), IFNULL( last_sent.uset_value, 0 ) ), '.$DB->quote( date2mysql( $servertimenow ) ).' ) > '.$inactive_account_threshold );

$UserCache = & get_UserCache();
$UserCache->clear();
// load all users to reminded into the UserCache
$UserCache->load_by_sql( $SQL );

// Send inactive reminder to every user loaded into the UserCache ( there are only not activated users )
$reminder_sent = send_inactive_user_emails( $UserCache->get_ID_array(), NULL, 'cron_job' );

cron_log_append( ( empty( $result_message ) ? '' : "\n" ).sprintf( T_( '%d of %d account inactive reminder emails were sent!' ), $reminder_sent, count( $UserCache->get_ID_array() ) ) );
return
1; /* ok */
?>