2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4 * SugarCRM Community Edition is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
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.
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
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
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.
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.
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 ********************************************************************************/
38 /*********************************************************************************
40 ********************************************************************************/
41 require_once('include/utils/encryption_utils.php');
43 function getSystemInfo($send_usage_info=true){
45 global $db, $authLevel, $administration, $timedate;
47 $info = getBaseSystemInfo($send_usage_info);
50 if(isset($_SERVER['SERVER_ADDR']))
51 $info['ip_address'] = $_SERVER['SERVER_ADDR'];
53 $info['ip_address'] = '127.0.0.1';
55 $info['application_key']=$sugar_config['unique_key'];
56 $info['php_version']=phpversion();
57 if(isset($_SERVER['SERVER_SOFTWARE'])) {
58 $info['server_software'] = $_SERVER['SERVER_SOFTWARE'];
63 $user_list = get_user_array(false, "Active", "", false, null, " AND is_group=0 AND portal_only=0 ", false);
67 $info['users']=count($user_list);
68 if(empty($administration)){
70 $administration = new Administration();
72 $administration->retrieveSettings('system');
73 $info['system_name'] = (!empty($administration->settings['system_name']))?substr($administration->settings['system_name'], 0 ,255):'';
76 $result=$db->getOne("select count(*) count from users where status='Active' and deleted=0 and is_admin='1'", false, 'fetching admin count');
77 if($result !== false) {
78 $info['admin_users'] = $result;
81 if(empty($authLevel)){
85 $result=$db->getOne("select count(*) count from users", false, 'fetching all users count');
86 if($result !== false) {
87 $info['registered_users'] = $result;
90 $lastMonth = $db->convert("'". $timedate->getNow()->modify("-30 days")->asDb(false) . "'", 'datetime');
91 if( !$send_usage_info) {
92 $info['users_active_30_days'] = -1;
94 $info['users_active_30_days'] = $db->getOne("SELECT count( DISTINCT users.id ) user_count FROM tracker, users WHERE users.id = tracker.user_id AND tracker.date_modified >= $lastMonth", false, 'fetching last 30 users count');
100 if(!$send_usage_info){
101 $info['latest_tracker_id'] = -1;
103 $id=$db->getOne("select id from tracker order by date_modified desc", false, 'fetching most recent tracker entry');
105 $info['latest_tracker_id'] = $id;
108 $info['db_type']=$sugar_config['dbconfig']['db_type'];
109 $info['db_version']=$db->version();
111 if(file_exists('distro.php')){
112 include('distro.php');
113 if(!empty($distro_name))$info['distro_name'] = $distro_name;
115 $info['auth_level'] = $authLevel;
116 $info['os'] = php_uname('s');
117 $info['os_version'] = php_uname('r');
118 $info['timezone_u'] = $GLOBALS['current_user']->getPreference('timezone');
119 $info['timezone'] = date('e');
120 if($info['timezone'] == 'e'){
121 $info['timezone'] = date('T');
127 function getBaseSystemInfo($send_usage_info=true){
129 include('sugar_version.php');
132 if($send_usage_info){
133 $info['sugar_db_version']=$sugar_db_version;
135 $info['sugar_version']=$sugar_version;
136 $info['sugar_flavor']=$sugar_flavor;
137 $info['auth_level'] = $authLevel;
146 function check_now($send_usage_info=true, $get_request_data=false, $response_data = false, $from_install=false ) {
147 global $sugar_config, $timedate;
148 global $db, $license;
151 $return_array=array();
152 if(!$from_install && empty($license))loadLicense(true);
157 $info = getBaseSystemInfo(false);
160 $info = getSystemInfo($send_usage_info);
163 require_once('include/nusoap/nusoap.php');
165 $GLOBALS['log']->debug('USING HTTPS TO CONNECT TO HEARTBEAT');
166 $sclient = new nusoapclient('https://updates.sugarcrm.com/heartbeat/soap.php', false, false, false, false, false, 15, 15);
167 $ping = $sclient->call('sugarPing', array());
168 if(empty($ping) || $sclient->getError()){
173 $GLOBALS['log']->debug('USING HTTP TO CONNECT TO HEARTBEAT');
174 $sclient = new nusoapclient('http://updates.sugarcrm.com/heartbeat/soap.php', false, false, false, false, false, 15, 15);
182 $key = '4829482749329';
186 $encoded = sugarEncode($key, serialize($info));
188 if($get_request_data){
189 $request_data = array('key'=>$key, 'data'=>$encoded);
190 return serialize($request_data);
192 $encodedResult = $sclient->call('sugarHome', array('key'=>$key, 'data'=>$encoded));
195 $encodedResult = $response_data['data'];
196 $key = $response_data['key'];
200 if($response_data || !$sclient->getError()){
201 $serializedResultData = sugarDecode($key,$encodedResult);
202 $resultData = unserialize($serializedResultData);
203 if($response_data && empty($resultData))
205 $resultData = array();
206 $resultData['validation'] = 'invalid validation key';
210 $resultData = array();
211 $resultData['versions'] = array();
215 if($response_data || !$sclient->getError() )
217 if(!empty($resultData['msg'])){
218 if(!empty($resultData['msg']['admin'])){
219 $license->saveSetting('license', 'msg_admin', base64_encode($resultData['msg']['admin']));
221 $license->saveSetting('license', 'msg_admin','');
223 if(!empty($resultData['msg']['all'])){
224 $license->saveSetting('license', 'msg_all', base64_encode($resultData['msg']['all']));
226 $license->saveSetting('license', 'msg_all','');
229 $license->saveSetting('license', 'msg_admin','');
230 $license->saveSetting('license', 'msg_all','');
232 $license->saveSetting('license', 'last_validation', 'success');
233 unset($_SESSION['COULD_NOT_CONNECT']);
237 $resultData = array();
238 $resultData['versions'] = array();
240 $license->saveSetting('license', 'last_connection_fail', TimeDate::getInstance()->nowDb());
241 $license->saveSetting('license', 'last_validation', 'no_connection');
243 if( empty($license->settings['license_last_validation_success']) && empty($license->settings['license_last_validation_fail']) && empty($license->settings['license_vk_end_date'])){
244 $license->saveSetting('license', 'vk_end_date', TimeDate::getInstance()->nowDb());
246 $license->saveSetting('license', 'validation_key', base64_encode(serialize(array('verified'=>false))));
248 $_SESSION['COULD_NOT_CONNECT'] =TimeDate::getInstance()->nowDb();
251 if(!empty($resultData['versions'])){
253 $license->saveSetting('license', 'latest_versions',base64_encode(serialize($resultData['versions'])));
255 $resultData['versions'] = array();
256 $license->saveSetting('license', 'latest_versions','') ;
262 include('sugar_version.php');
264 if(sizeof($resultData) == 1 && !empty($resultData['versions'][0]['version'])
265 && compareVersions($sugar_version, $resultData['versions'][0]['version']))
267 $resultData['versions'][0]['version'] = $sugar_version;
268 $resultData['versions'][0]['description'] = "You have the latest version.";
272 return $resultData['versions'];
275 * returns true if $ver1 > $ver2
277 function compareVersions($ver1, $ver2)
279 if(!preg_match_all("/[0-9]/", $ver1, $matches1))
284 if(!preg_match_all("/[0-9]/", $ver2, $matches2))
289 //Now recreate string with only numbers
290 $ver1 = implode('', $matches1[0]);
291 $ver2 = implode('', $matches2[0]);
293 $len1 = strlen($ver1);
294 $len2 = strlen($ver2);
298 $ver2 = str_pad($ver2, $len1, '0');
299 } else if($len2 > $len1) {
300 $ver1 = str_pad($ver1, $len2, '0');
304 return (int)$ver1 > (int)$ver2;
306 function set_CheckUpdates_config_setting($value) {
309 $admin=new Administration();
310 $admin->saveSetting('Update','CheckUpdates',$value);
312 /* return's value for the 'CheckUpdates' config setting
313 * if the setting does not exist one gets created with a default value of automatic.
315 function get_CheckUpdates_config_setting() {
317 $checkupdates='automatic';
320 $admin=new Administration();
321 $admin=$admin->retrieveSettings('Update',true);
322 if (empty($admin->settings) or empty($admin->settings['Update_CheckUpdates'])) {
323 $admin->saveSetting('Update','CheckUpdates','automatic');
325 $checkupdates=$admin->settings['Update_CheckUpdates'];
327 return $checkupdates;
330 function set_last_check_version_config_setting($value) {
333 $admin=new Administration();
334 $admin->saveSetting('Update','last_check_version',$value);
336 function get_last_check_version_config_setting() {
340 $admin=new Administration();
341 $admin=$admin->retrieveSettings('Update');
342 if (empty($admin->settings) or empty($admin->settings['Update_last_check_version'])) {
345 return $admin->settings['Update_last_check_version'];
350 function set_last_check_date_config_setting($value) {
353 $admin=new Administration();
354 $admin->saveSetting('Update','last_check_date',$value);
356 function get_last_check_date_config_setting() {
360 $admin=new Administration();
361 $admin=$admin->retrieveSettings('Update');
362 if (empty($admin->settings) or empty($admin->settings['Update_last_check_date'])) {
365 return $admin->settings['Update_last_check_date'];
369 function set_sugarbeat($value) {
370 global $sugar_config;
371 $_SUGARBEAT="sugarbeet";
372 $sugar_config[$_SUGARBEAT] = $value;
373 write_array_to_file( "sugar_config", $sugar_config, "config.php" );
375 function get_sugarbeat() {
378 global $sugar_config;
379 $_SUGARBEAT="sugarbeet";
381 if (isset($sugar_config[$_SUGARBEAT]) && $sugar_config[$_SUGARBEAT] == false) {
390 function shouldCheckSugar(){
391 global $license, $timedate;
394 get_CheckUpdates_config_setting() == 'automatic' ){
403 function loadLicense($firstLogin=false){
405 $GLOBALS['license']=new Administration();
406 $GLOBALS['license']=$GLOBALS['license']->retrieveSettings('license', $firstLogin);
410 function loginLicense(){
411 global $current_user, $license, $authLevel;
416 if (shouldCheckSugar()) {
419 $last_check_date=get_last_check_date_config_setting();
420 $current_date_time=time();
421 $time_period=3*23*3600 ;
422 if (($current_date_time - $last_check_date) > $time_period
424 $version = check_now(get_sugarbeat());
426 unset($_SESSION['license_seats_needed']);
428 set_last_check_date_config_setting("$current_date_time");
429 include('sugar_version.php');
431 if(!empty($version)&& count($version) == 1 && $version[0]['version'] > $sugar_version && is_admin($current_user))
433 //set session variables.
434 $_SESSION['available_version']=$version[0]['version'];
435 $_SESSION['available_version_description']=$version[0]['description'];
436 set_last_check_version_config_setting($version[0]['version']);