]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - cron.php
Added SpellCheck Support to TinyMCE
[Github/sugarcrm.git] / cron.php
1 <?php
2  if(!defined('sugarEntry'))define('sugarEntry', true);
3 /*********************************************************************************
4  * SugarCRM Community Edition is a customer relationship management program developed by
5  * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
6  * 
7  * This program is free software; you can redistribute it and/or modify it under
8  * the terms of the GNU Affero General Public License version 3 as published by the
9  * Free Software Foundation with the addition of the following permission added
10  * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11  * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12  * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
13  * 
14  * This program is distributed in the hope that it will be useful, but WITHOUT
15  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  * FOR A PARTICULAR PURPOSE.  See the GNU Affero General Public License for more
17  * details.
18  * 
19  * You should have received a copy of the GNU Affero General Public License along with
20  * this program; if not, see http://www.gnu.org/licenses or write to the Free
21  * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22  * 02110-1301 USA.
23  * 
24  * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25  * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
26  * 
27  * The interactive user interfaces in modified source and object code versions
28  * of this program must display Appropriate Legal Notices, as required under
29  * Section 5 of the GNU Affero General Public License version 3.
30  * 
31  * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32  * these Appropriate Legal Notices must retain the display of the "Powered by
33  * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34  * technical reasons, the Appropriate Legal Notices must display the words
35  * "Powered by SugarCRM".
36  ********************************************************************************/
37
38 //change directories to where this file is located.
39 //this is to make sure it can find dce_config.php
40 chdir(realpath(dirname(__FILE__)));
41
42 require_once('include/entryPoint.php');
43
44 //Bug 27991 . Redirect to index.php if the request is not come from CLI.
45 $sapi_type = php_sapi_name();
46 if (substr($sapi_type, 0, 3) != 'cgi') {
47     global $sugar_config;
48         if(!empty($sugar_config['site_url'])){
49                 header("Location: ".$sugar_config['site_url'] . "/index.php");
50         }else{
51                 sugar_die("Didn't find site url in your sugarcrm config file");
52         }
53 }
54 //End of #27991
55
56 if(empty($current_language)) {
57         $current_language = $sugar_config['default_language'];
58 }
59
60 $app_list_strings = return_app_list_strings_language($current_language);
61 $app_strings = return_application_language($current_language);
62
63 global $current_user;
64 $current_user = new User();
65 $current_user->getSystemUser();
66
67 ///////////////////////////////////////////////////////////////////////////////
68 ////    PREP FOR SCHEDULER PID
69 $GLOBALS['log']->debug('--------------------------------------------> at cron.php <--------------------------------------------');
70
71 $cachePath = sugar_cached('modules/Schedulers');
72 $pid = 'pid.php';
73 if(!is_dir($cachePath)) {
74         mkdir_recursive($cachePath);
75 }
76 if(!is_file($cachePath.'/'.$pid)) {
77         if(is_writable($cachePath)) { // the "file" does not yet exist
78                 write_array_to_file('timestamp', array(strtotime(date('H:i'))) , $cachePath.'/'.$pid);
79                 require_once($cachePath.'/'.$pid);
80         } else {
81                 $GLOBALS['log']->fatal('Scheduler cannot write PID file.  Please check permissions on '.$cachePath);
82         }
83 } else {
84         if(is_writable($cachePath.'/'.$pid)) {
85                 require_once($cachePath.'/'.$pid);
86         } else {
87                 $GLOBALS['log']->fatal('Scheduler cannot read the PID file.  Please check permissions on '.$cachePath);
88         }
89 }
90 ////    END PREP FOR SCHEDULER PID
91 ///////////////////////////////////////////////////////////////////////////////
92
93 ///////////////////////////////////////////////////////////////////////////////
94 ////    EXECUTE IF VALID TIME (NOT DDOS)
95
96 // mjamil | bug # 45229 - schedulers not able to run due to current time being equal to
97 // $timestamp[0]
98 if($timestamp[0] <= strtotime(date('H:i'))) {
99         if(is_writable($cachePath.'/'.$pid)) {
100                 write_array_to_file('timestamp', array(strtotime(date('H:i'))) , $cachePath.'/'.$pid);
101                 require('modules/Schedulers/Scheduler.php');
102                 $s = new Scheduler();
103                 $s->flushDeadJobs();
104                 $s->checkPendingJobs();
105         } else {
106                 $GLOBALS['log']->fatal('Scheduler cannot write PID file.  Please check permissions on '.$cachePath);
107         }
108 } else {
109         $GLOBALS['log']->fatal('If you see a whole string of these, there is a chance someone is attacking your system.');
110 }
111 $exit_on_cleanup = true;
112
113 sugar_cleanup(false);
114 // some jobs have annoying habit of calling sugar_cleanup(), and it can be called only once
115 // but job results can be written to DB after job is finished, so we have to disconnect here again
116 // just in case we couldn't call cleanup
117 if(class_exists('DBManagerFactory')) {
118         $db = DBManagerFactory::getInstance();
119         $db->disconnect();
120 }
121
122 if($exit_on_cleanup) exit;