warning('cron.php: can\'t determine running user. No cron user checks will occur.'); } elseif (array_key_exists('cron', $sugar_config) && array_key_exists('allowed_cron_users', $sugar_config['cron'])) { if (!in_array($cronUser, $sugar_config['cron']['allowed_cron_users'])) { $GLOBALS['log']->fatal("cron.php: running as $cronUser is not allowed in allowed_cron_users ". "in config.php. Exiting."); if ($cronUser == 'root') { // Additional advice so that people running as root aren't led to adding root as an allowed user: $GLOBALS['log']->fatal('cron.php: root\'s crontab should not be used for cron.php. ' . 'Use your web server user\'s crontab instead.'); } sugar_die('cron.php running with user that is not in allowed_cron_users in config.php'); } } else { $GLOBALS['log']->warning('cron.php: missing expected allowed_cron_users entry in config.php. ' . 'No cron user checks will occur.'); } } if (empty($current_language)) { $current_language = $sugar_config['default_language']; } $app_list_strings = return_app_list_strings_language($current_language); $app_strings = return_application_language($current_language); global $current_user; $current_user = BeanFactory::newBean('Users'); $current_user->getSystemUser(); $GLOBALS['log']->debug('--------------------------------------------> at cron.php <--------------------------------------------'); $cron_driver = !empty($sugar_config['cron_class'])?$sugar_config['cron_class']:'SugarCronJobs'; $GLOBALS['log']->debug("Using $cron_driver as CRON driver"); if (file_exists("custom/include/SugarQueue/$cron_driver.php")) { require_once "custom/include/SugarQueue/$cron_driver.php"; } else { require_once "include/SugarQueue/$cron_driver.php"; } $jobq = new $cron_driver(); $jobq->runCycle(); $exit_on_cleanup = true; sugar_cleanup(false); // some jobs have annoying habit of calling sugar_cleanup(), and it can be called only once // but job results can be written to DB after job is finished, so we have to disconnect here again // just in case we couldn't call cleanup if (class_exists('DBManagerFactory')) { $db = DBManagerFactory::getInstance(); $db->disconnect(); } // If we have a session left over, destroy it if (session_id()) { session_destroy(); } if ($exit_on_cleanup) { exit($jobq->runOk()?0:1); }