2012-02-08 23:14:28 +01:00
< ? php
class ControllerHealthWorker extends Controller {
private $error = array ();
public function index (){
2013-02-16 12:33:25 +01:00
$archivesizeraw = $sqlsizeraw = $sphinxsizeraw = 0 ;
$averagemessagesweekraw = $averagemessagesmonthraw = $averagemessagesizeraw = $averagesizedayraw = $averagesqlsizeraw = $averagesphinxsizeraw = 0 ;
2013-04-30 15:59:04 +02:00
$averagemessagestotalraw = 0 ;
2012-02-08 23:14:28 +01:00
$this -> id = " content " ;
$this -> template = " health/worker.tpl " ;
$this -> layout = " common/layout-empty " ;
$db_history = Registry :: get ( 'db_history' );
$this -> load -> model ( 'health/health' );
$this -> load -> model ( 'stat/counter' );
2013-07-24 22:14:05 +02:00
if ( ENABLE_SAAS == 1 ) {
$this -> load -> model ( 'saas/customer' );
}
2012-02-08 23:14:28 +01:00
$request = Registry :: get ( 'request' );
$lang = Registry :: get ( 'language' );
$this -> data [ 'health' ] = array ();
if ( Registry :: get ( 'admin_user' ) != 1 && Registry :: get ( 'readonly_admin' ) != 1 ) {
die ( " go away " );
}
2013-04-08 20:46:19 +02:00
ini_set ( " default_socket_timeout " , 5 );
2012-02-08 23:14:28 +01:00
foreach ( Registry :: get ( 'health_smtp_servers' ) as $smtp ) {
$this -> data [ 'health' ][] = $this -> model_health_health -> checksmtp ( $smtp , $lang -> data [ 'text_error' ]);
}
2013-07-24 22:14:05 +02:00
if ( ENABLE_SAAS == 1 ) {
$this -> data [ 'num_of_online_users' ] = $this -> model_saas_customer -> count_online ();
}
2012-02-08 23:14:28 +01:00
$this -> data [ 'processed_emails' ] = $this -> model_health_health -> count_processed_emails ();
list ( $this -> data [ 'uptime' ], $this -> data [ 'cpuload' ]) = $this -> model_health_health -> uptime ();
$this -> data [ 'cpuinfo' ] = 100 - ( int ) file_get_contents ( CPUSTAT );
$this -> data [ 'quarantinereportinfo' ] = @ file_get_contents ( DAILY_QUARANTINE_REPORT_STAT );
list ( $this -> data [ 'totalmem' ], $this -> data [ 'meminfo' ], $this -> data [ 'totalswap' ], $this -> data [ 'swapinfo' ]) = $this -> model_health_health -> meminfo ();
$this -> data [ 'shortdiskinfo' ] = $this -> model_health_health -> diskinfo ();
/* counter related stuff */
2013-04-23 21:28:09 +02:00
2012-02-08 23:14:28 +01:00
$db = Registry :: get ( 'db' );
$db -> select_db ( $db -> database );
2013-02-16 12:33:25 +01:00
list ( $archivesizeraw , $this -> data [ 'counters' ]) = $this -> model_stat_counter -> get_counters ();
2013-04-23 21:28:09 +02:00
2013-04-22 23:03:40 +02:00
$oldest_record_timestamp = $this -> model_health_health -> get_oldest_record_ts ();
$total_number_days = round ( ( time () - $oldest_record_timestamp ) / 86400 );
2013-02-16 12:33:25 +01:00
$this -> data [ 'archive_size' ] = nice_size ( $archivesizeraw , ' ' );
2012-02-10 14:35:07 +01:00
2012-02-08 23:14:28 +01:00
$this -> data [ 'prefix' ] = '' ;
2012-02-10 14:35:07 +01:00
if ( isset ( $this -> data [ 'counters' ][ MEMCACHED_PREFIX . 'rcvd' ])) { $this -> data [ 'prefix' ] = MEMCACHED_PREFIX ; }
2012-02-08 23:14:28 +01:00
$this -> data [ 'sysinfo' ] = $this -> model_health_health -> sysinfo ();
2012-04-27 14:39:10 +02:00
$this -> data [ 'options' ] = $this -> model_health_health -> get_options ();
2013-04-23 21:28:09 +02:00
2013-02-16 12:33:25 +01:00
$sqlsizeraw = $this -> model_health_health -> get_database_size ();
2013-04-23 21:28:09 +02:00
2013-02-16 12:33:25 +01:00
$sphinxsizeraw = $this -> model_health_health -> get_sphinx_size ();
2013-04-30 15:59:04 +02:00
/*
* message count variables
*/
//average messages per day, computed over the past week
$averagemessagesweekraw = ( $this -> data [ 'processed_emails' ][ 1 ]) / 7 ;
//average messages per day, computed over the past month
$averagemessagesmonthraw = ( $this -> data [ 'processed_emails' ][ 2 ]) / 30 ;
//average messages per day, computed over the time period since the first email was archived
if ( $total_number_days > 0 ) { $averagemessagestotalraw = ( $this -> data [ 'counters' ][ 'rcvd' ]) / $total_number_days ; }
/*
* message size variables
*/
if ( $this -> data [ 'counters' ][ 'rcvd' ] > 0 ) {
//average message size, computed for total messages in database
$averagemessagesizeraw = $archivesizeraw / $this -> data [ 'counters' ][ 'rcvd' ];
//average message metadata size, computed for total messages in database
$averagesqlsizeraw = $sqlsizeraw / $this -> data [ 'counters' ][ 'rcvd' ];
//average message sphinx index size, computed for total messages in database
$averagesphinxsizeraw = $sphinxsizeraw / $this -> data [ 'counters' ][ 'rcvd' ];
}
//average total message size per day, computed over the time period since the first email was archived
$averagesizedayraw = ( $averagemessagesizeraw + $averagesqlsizeraw + $averagesphinxsizeraw ) * $averagemessagestotalraw ;
2013-02-16 12:33:25 +01:00
$datapart = 0 ;
foreach ( $this -> data [ 'shortdiskinfo' ] as $part ) {
2013-04-22 23:03:40 +02:00
if ( $part [ 'partition' ] == DATA_PARTITION ) { $datapart = $part [ 'freespace' ] * 1024 ; } // if the partition is the selected storage partition, record freespace on that partition
2013-02-16 12:33:25 +01:00
}
2013-04-23 21:28:09 +02:00
2013-04-22 23:03:40 +02:00
$this -> data [ 'oldestmessagets' ] = $oldest_record_timestamp ; // date of the oldest record in the db
$this -> data [ 'averagemessages' ] = round ( $averagemessagesweekraw ); // rounded average of messages over the past week
$this -> data [ 'averagemessagesize' ] = nice_size ( $averagemessagesizeraw , ' ' ); // formatted average message size on disk
$this -> data [ 'averagesqlsize' ] = nice_size ( $averagesqlsizeraw , ' ' ); // formatted average metadata size in sql
$this -> data [ 'averagesphinxsize' ] = nice_size ( $averagesphinxsizeraw , ' ' ); // formatted average sphinx index
$this -> data [ 'averagesizeday' ] = nice_size ( $averagesizedayraw , ' ' ); // formatted average size per day
2013-04-30 15:59:04 +02:00
// estimated number of days of free space left
$averagesizedayraw > 0 ? $this -> data [ 'daysleftatcurrentrate' ] = convert_days_ymd ( $datapart / $averagesizedayraw ) : $this -> data [ 'daysleftatcurrentrate' ] = 0 ;
/*
* determine if the trend of the last week compared to the last month is
* increasing , decreasing , or neutral
* ( only applies to message count , not size )
*/
if ( $averagemessagesweekraw > $averagemessagesmonthraw ) {
2013-02-16 12:33:25 +01:00
$this -> data [ 'usagetrend' ] = 1 ;
} elseif ( $averagemessagesweekraw < $averagemessagesmonthraw ) {
$this -> data [ 'usagetrend' ] = - 1 ;
} else {
$this -> data [ 'usagetrend' ] = 0 ;
}
2013-04-30 15:59:04 +02:00
2013-08-09 10:13:54 +02:00
$this -> data [ 'indexer_stat' ] = $this -> model_health_health -> indexer_stat ();
2012-02-08 23:14:28 +01:00
$this -> render ();
}
}
?>