0){ if(isset($_SERVER['SERVER_ADDR'])) $info['ip_address'] = $_SERVER['SERVER_ADDR']; else $info['ip_address'] = '127.0.0.1'; } $info['application_key']=$sugar_config['unique_key']; $info['php_version']=phpversion(); if(isset($_SERVER['SERVER_SOFTWARE'])) { $info['server_software'] = $_SERVER['SERVER_SOFTWARE']; } // if //get user count. $user_list = get_user_array(false, "Active", "", false, null, " AND is_group=0 AND portal_only=0 ", false); $info['users']=count($user_list); if(empty($administration)){ $administration = new Administration(); } $administration->retrieveSettings('system'); $info['system_name'] = (!empty($administration->settings['system_name']))?substr($administration->settings['system_name'], 0 ,255):''; $result=$db->getOne("select count(*) count from users where status='Active' and deleted=0 and is_admin='1'", false, 'fetching admin count'); if($result !== false) { $info['admin_users'] = $result; } if(empty($authLevel)){ $authLevel = 0; } $result=$db->getOne("select count(*) count from users", false, 'fetching all users count'); if($result !== false) { $info['registered_users'] = $result; } $lastMonth = $db->convert("'". $timedate->getNow()->modify("-30 days")->asDb(false) . "'", 'datetime'); if( !$send_usage_info) { $info['users_active_30_days'] = -1; } else { $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'); } if(!$send_usage_info){ $info['latest_tracker_id'] = -1; }else{ $id=$db->getOne("select id from tracker order by date_modified desc", false, 'fetching most recent tracker entry'); if ( $id !== false ) $info['latest_tracker_id'] = $id; } $info['db_type']=$sugar_config['dbconfig']['db_type']; $info['db_version']=$db->version(); } if(file_exists('distro.php')){ include('distro.php'); if(!empty($distro_name))$info['distro_name'] = $distro_name; } $info['auth_level'] = $authLevel; $info['os'] = php_uname('s'); $info['os_version'] = php_uname('r'); $info['timezone_u'] = $GLOBALS['current_user']->getPreference('timezone'); $info['timezone'] = date('e'); if($info['timezone'] == 'e'){ $info['timezone'] = date('T'); } return $info; } function getBaseSystemInfo($send_usage_info=true){ global $authLevel; include('sugar_version.php'); $info=array(); if($send_usage_info){ $info['sugar_db_version']=$sugar_db_version; } $info['sugar_version']=$sugar_version; $info['sugar_flavor']=$sugar_flavor; $info['auth_level'] = $authLevel; return $info; } function check_now($send_usage_info=true, $get_request_data=false, $response_data = false, $from_install=false ) { global $sugar_config, $timedate; global $db, $license; $return_array=array(); if(!$from_install && empty($license))loadLicense(true); if(!$response_data){ if($from_install){ $info = getBaseSystemInfo(false); }else{ $info = getSystemInfo($send_usage_info); } require_once('include/nusoap/nusoap.php'); $GLOBALS['log']->debug('USING HTTPS TO CONNECT TO HEARTBEAT'); $sclient = new nusoapclient('https://updates.sugarcrm.com/heartbeat/soap.php', false, false, false, false, false, 15, 15); $ping = $sclient->call('sugarPing', array()); if(empty($ping) || $sclient->getError()){ $sclient = ''; } if(empty($sclient)){ $GLOBALS['log']->debug('USING HTTP TO CONNECT TO HEARTBEAT'); $sclient = new nusoapclient('http://updates.sugarcrm.com/heartbeat/soap.php', false, false, false, false, false, 15, 15); } $key = '4829482749329'; $encoded = sugarEncode($key, serialize($info)); if($get_request_data){ $request_data = array('key'=>$key, 'data'=>$encoded); return serialize($request_data); } $encodedResult = $sclient->call('sugarHome', array('key'=>$key, 'data'=>$encoded)); }else{ $encodedResult = $response_data['data']; $key = $response_data['key']; } if($response_data || !$sclient->getError()){ $serializedResultData = sugarDecode($key,$encodedResult); $resultData = unserialize($serializedResultData); if($response_data && empty($resultData)) { $resultData = array(); $resultData['validation'] = 'invalid validation key'; } }else { $resultData = array(); $resultData['versions'] = array(); } if($response_data || !$sclient->getError() ) { if(!empty($resultData['msg'])){ if(!empty($resultData['msg']['admin'])){ $license->saveSetting('license', 'msg_admin', base64_encode($resultData['msg']['admin'])); }else{ $license->saveSetting('license', 'msg_admin',''); } if(!empty($resultData['msg']['all'])){ $license->saveSetting('license', 'msg_all', base64_encode($resultData['msg']['all'])); }else{ $license->saveSetting('license', 'msg_all',''); } }else{ $license->saveSetting('license', 'msg_admin',''); $license->saveSetting('license', 'msg_all',''); } $license->saveSetting('license', 'last_validation', 'success'); unset($_SESSION['COULD_NOT_CONNECT']); } else { $resultData = array(); $resultData['versions'] = array(); $license->saveSetting('license', 'last_connection_fail', TimeDate::getInstance()->nowDb()); $license->saveSetting('license', 'last_validation', 'no_connection'); if( empty($license->settings['license_last_validation_success']) && empty($license->settings['license_last_validation_fail']) && empty($license->settings['license_vk_end_date'])){ $license->saveSetting('license', 'vk_end_date', TimeDate::getInstance()->nowDb()); $license->saveSetting('license', 'validation_key', base64_encode(serialize(array('verified'=>false)))); } $_SESSION['COULD_NOT_CONNECT'] =TimeDate::getInstance()->nowDb(); } if(!empty($resultData['versions'])){ $license->saveSetting('license', 'latest_versions',base64_encode(serialize($resultData['versions']))); }else{ $resultData['versions'] = array(); $license->saveSetting('license', 'latest_versions','') ; } include('sugar_version.php'); if(sizeof($resultData) == 1 && !empty($resultData['versions'][0]['version']) && compareVersions($sugar_version, $resultData['versions'][0]['version'])) { $resultData['versions'][0]['version'] = $sugar_version; $resultData['versions'][0]['description'] = "You have the latest version."; } return $resultData['versions']; } /* * returns true if $ver1 > $ver2 */ function compareVersions($ver1, $ver2) { if(!preg_match_all("/[0-9]/", $ver1, $matches1)) { return false; } if(!preg_match_all("/[0-9]/", $ver2, $matches2)) { return true; } //Now recreate string with only numbers $ver1 = implode('', $matches1[0]); $ver2 = implode('', $matches2[0]); $len1 = strlen($ver1); $len2 = strlen($ver2); //Now apply padding if($len1 > $len2) { $ver2 = str_pad($ver2, $len1, '0'); } else if($len2 > $len1) { $ver1 = str_pad($ver1, $len2, '0'); } //Return result return (int)$ver1 > (int)$ver2; } function set_CheckUpdates_config_setting($value) { $admin=new Administration(); $admin->saveSetting('Update','CheckUpdates',$value); } /* return's value for the 'CheckUpdates' config setting * if the setting does not exist one gets created with a default value of automatic. */ function get_CheckUpdates_config_setting() { $checkupdates='automatic'; $admin=new Administration(); $admin=$admin->retrieveSettings('Update',true); if (empty($admin->settings) or empty($admin->settings['Update_CheckUpdates'])) { $admin->saveSetting('Update','CheckUpdates','automatic'); } else { $checkupdates=$admin->settings['Update_CheckUpdates']; } return $checkupdates; } function set_last_check_version_config_setting($value) { $admin=new Administration(); $admin->saveSetting('Update','last_check_version',$value); } function get_last_check_version_config_setting() { $admin=new Administration(); $admin=$admin->retrieveSettings('Update'); if (empty($admin->settings) or empty($admin->settings['Update_last_check_version'])) { return null; } else { return $admin->settings['Update_last_check_version']; } } function set_last_check_date_config_setting($value) { $admin=new Administration(); $admin->saveSetting('Update','last_check_date',$value); } function get_last_check_date_config_setting() { $admin=new Administration(); $admin=$admin->retrieveSettings('Update'); if (empty($admin->settings) or empty($admin->settings['Update_last_check_date'])) { return 0; } else { return $admin->settings['Update_last_check_date']; } } function set_sugarbeat($value) { global $sugar_config; $_SUGARBEAT="sugarbeet"; $sugar_config[$_SUGARBEAT] = $value; write_array_to_file( "sugar_config", $sugar_config, "config.php" ); } function get_sugarbeat() { global $sugar_config; $_SUGARBEAT="sugarbeet"; if (isset($sugar_config[$_SUGARBEAT]) && $sugar_config[$_SUGARBEAT] == false) { return false; } return true; } function shouldCheckSugar(){ global $license, $timedate; if( get_CheckUpdates_config_setting() == 'automatic' ){ return true; } return false; } function loadLicense($firstLogin=false){ $GLOBALS['license']=new Administration(); $GLOBALS['license']=$GLOBALS['license']->retrieveSettings('license', $firstLogin); } function loginLicense(){ global $current_user, $license, $authLevel; loadLicense(true); $authLevel = 0; if (shouldCheckSugar()) { $last_check_date=get_last_check_date_config_setting(); $current_date_time=time(); $time_period=3*23*3600 ; if (($current_date_time - $last_check_date) > $time_period ) { $version = check_now(get_sugarbeat()); unset($_SESSION['license_seats_needed']); loadLicense(); set_last_check_date_config_setting("$current_date_time"); include('sugar_version.php'); if(!empty($version)&& count($version) == 1 && $version[0]['version'] > $sugar_version && is_admin($current_user)) { //set session variables. $_SESSION['available_version']=$version[0]['version']; $_SESSION['available_version_description']=$version[0]['description']; set_last_check_version_config_setting($version[0]['version']); } } } } ?>