issue 2119. supporting php 5.4. counter module.

git-svn-id: http://xe-core.googlecode.com/svn/branches/maserati@12723 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
flyskyko 2013-02-07 08:09:15 +00:00
parent 687fe8683b
commit 2e8b49acce
4 changed files with 227 additions and 86 deletions

View file

@ -1,4 +1,5 @@
<?php
/**
* Model class of counter module
*
@ -6,6 +7,7 @@
*/
class counterModel extends counter
{
/**
* Initialization
*
@ -13,6 +15,7 @@ class counterModel extends counter
*/
function init()
{
}
/**
@ -21,25 +24,31 @@ class counterModel extends counter
* @param integer $site_srl Site_srl
* @return bool
*/
function isLogged($site_srl=0)
function isLogged($site_srl = 0)
{
$args = new stdClass;
$args = new stdClass();
$args->regdate = date('Ymd');
$args->ipaddress = $_SERVER['REMOTE_ADDR'];
$args->site_srl = $site_srl;
$oCacheHandler = &CacheHandler::getInstance('object');
$oCacheHandler = CacheHandler::getInstance('object');
if($oCacheHandler->isSupport())
{
$object_key = 'object:' . $site_srl . '_' . str_replace('.', '-', $args->ipaddress);
$cache_key = $oCacheHandler->getGroupKey('counterIpLogged_' . $args->regdate, $object_key);
if($oCacheHandler->isValid($cache_key)) return $oCacheHandler->get($cache_key);
if($oCacheHandler->isValid($cache_key))
{
return $oCacheHandler->get($cache_key);
}
}
$output = executeQuery('counter.getCounterLog', $args);
$result = $output->data->count ? TRUE : FALSE;
if($result && $oCacheHandler->isSupport()) $oCacheHandler->put($cache_key, $result);
if($result && $oCacheHandler->isSupport())
{
$oCacheHandler->put($cache_key, $result);
}
return $result;
}
@ -50,16 +59,19 @@ class counterModel extends counter
* @param integer $site_srl Site_srl
* @return bool
*/
function isInsertedTodayStatus($site_srl=0)
function isInsertedTodayStatus($site_srl = 0)
{
$args = new stdClass;
$args->regdate = date('Ymd');
$oCacheHandler = &CacheHandler::getInstance('object', NULL, TRUE);
$oCacheHandler = CacheHandler::getInstance('object', NULL, TRUE);
if($oCacheHandler->isSupport())
{
$cache_key = 'object:insertedTodayStatus:' . $site_srl . '_' . $args->regdate;
if($oCacheHandler->isValid($cache_key)) return $oCacheHandler->get($cache_key);
if($oCacheHandler->isValid($cache_key))
{
return $oCacheHandler->get($cache_key);
}
}
if($site_srl)
@ -67,8 +79,11 @@ class counterModel extends counter
$args->site_srl = $site_srl;
$output = executeQuery('counter.getSiteTodayStatus', $args);
}
else $output = executeQuery('counter.getTodayStatus', $args);
else
{
$output = executeQuery('counter.getTodayStatus', $args);
}
$result = $output->data->count ? TRUE : FALSE;
if($result && $oCacheHandler->isSupport())
{
@ -94,12 +109,15 @@ class counterModel extends counter
{
$date_count = count($selected_date);
$args = new stdClass();
$args->regdate = implode(',',$selected_date);
$args->regdate = implode(',', $selected_date);
// If a single date log is selected
}
else
{
if(strlen($selected_date) == 8) $selected_date = $selected_date;
if(strlen($selected_date) == 8)
{
$selected_date = $selected_date;
}
$args->regdate = $selected_date;
}
@ -112,17 +130,26 @@ class counterModel extends counter
{
$output = executeQuery('counter.getCounterStatusDays', $args);
}
$status = $output->data;
if(!is_array($selected_date)) return $status;
if(!is_array($selected_date))
{
return $status;
}
if(!is_array($status))
{
$status = array($status);
}
if(!is_array($status)) $status = array($status);
unset($output);
foreach($status as $key => $val)
{
$output[substr($val->regdate,0,8)] = $val;
$output[substr($val->regdate, 0, 8)] = $val;
}
return $output;
}
@ -134,16 +161,18 @@ class counterModel extends counter
* @param integer $site_srl Site_srl
* @return Object
*/
function getHourlyStatus($type='hour', $selected_date, $site_srl=0, $isPageView=false)
function getHourlyStatus($type = 'hour', $selected_date, $site_srl = 0, $isPageView = false)
{
$max = 0;
$sum = 0;
switch($type)
{
case 'year' :
// Get a date to start counting
if($site_srl)
{
$args = new stdClass();
$args->site_srl = $site_srl;
$output = executeQuery('counter.getSiteStartLogDate', $args);
}
@ -151,13 +180,20 @@ class counterModel extends counter
{
$output = executeQuery('counter.getStartLogDate');
}
$start_year = substr($output->data->regdate,0,4);
if(!$start_year) $start_year = date("Y");
for($i=$start_year;$i<=date("Y");$i++)
$start_year = substr($output->data->regdate, 0, 4);
if(!$start_year)
{
$start_year = date("Y");
}
for($i = $start_year; $i <= date("Y"); $i++)
{
$args = new stdClass();
$args->start_date = sprintf('%04d0000', $i);
$args->end_date = sprintf('%04d1231', $i);
if($site_srl)
{
$args->site_srl = $site_srl;
@ -170,37 +206,51 @@ class counterModel extends counter
if(!$isPageView)
{
$count = (int)$output->data->unique_visitor;
$count = (int) $output->data->unique_visitor;
}
else
{
$count = (int)$output->data->pageview;
$count = (int) $output->data->pageview;
}
$status->list[$i] = $count;
if($count>$max) $max = $count;
if($count > $max)
{
$max = $count;
}
$sum += $count;
}
break;
case 'week' :
$time = strtotime($selected_date);
$w = date("D");
while(date("D",$time) != "Sun")
while(date("D", $time) != "Sun")
{
$time += 60*60*24;
$time += 60 * 60 * 24;
}
$time -= 60*60*24;
while(date("D",$time)!="Sun")
$time -= 60 * 60 * 24;
while(date("D", $time) != "Sun")
{
$thisWeek[] = date("Ymd",$time);
$time -= 60*60*24;
$thisWeek[] = date("Ymd", $time);
$time -= 60 * 60 * 24;
}
$thisWeek[] = date("Ymd",$time);
$thisWeek[] = date("Ymd", $time);
asort($thisWeek);
foreach($thisWeek as $day)
{
$args = new stdClass();
$args->start_date = $day;
$args->end_date = $day;
if($site_srl)
{
$args->site_srl = $site_srl;
@ -213,24 +263,32 @@ class counterModel extends counter
if(!$isPageView)
{
$count = (int)$output->data->unique_visitor;
$count = (int) $output->data->unique_visitor;
}
else
{
$count = (int)$output->data->pageview;
$count = (int) $output->data->pageview;
}
$status->list[$day] = (int)$count;
if($count>$max) $max = $count;
$status->list[$day] = (int) $count;
if($count > $max)
{
$max = $count;
}
$sum += $count;
}
break;
case 'month' :
$year = substr($selected_date, 0, 4);
for($i=1;$i<=12;$i++)
for($i = 1; $i <= 12; $i++)
{
$args = new stdClass();
$args->start_date = sprintf('%04d%02d00', $year, $i);
$args->end_date = sprintf('%04d%02d31', $year, $i);
if($site_srl)
{
$args->site_srl = $site_srl;
@ -243,23 +301,31 @@ class counterModel extends counter
if(!$isPageView)
{
$count = (int)$output->data->unique_visitor;
$count = (int) $output->data->unique_visitor;
}
else
{
$count = (int)$output->data->pageview;
$count = (int) $output->data->pageview;
}
$status->list[$i] = (int)$count;
if($count>$max) $max = $count;
$status->list[$i] = (int) $count;
if($count > $max)
{
$max = $count;
}
$sum += $count;
}
break;
case 'hour' :
for($i=0;$i<24;$i++)
for($i = 0; $i < 24; $i++)
{
$args = new stdClass();
$args->start_date = sprintf('%08d%02d0000', $selected_date, $i);
$args->end_date = sprintf('%08d%02d5959', $selected_date, $i);
if($site_srl)
{
$args->site_srl = $site_srl;
@ -270,21 +336,30 @@ class counterModel extends counter
$args->site_srl = 0;
$output = executeQuery('counter.getCounterLogStatus', $args);
}
$count = (int)$output->data->count;
$count = (int) $output->data->count;
$status->list[$i] = $count;
if($count>$max) $max = $count;
if($count > $max)
{
$max = $count;
}
$sum += $count;
}
break;
default :
default :
$year = substr($selected_date, 0, 4);
$month = substr($selected_date, 4, 2);
$end_day = date('t', mktime(0,0,0,$month,1,$year));
for($i=1;$i<=$end_day;$i++)
$end_day = date('t', mktime(0, 0, 0, $month, 1, $year));
for($i = 1; $i <= $end_day; $i++)
{
$args = new stdClass();
$args->start_date = sprintf('%04d%02d%02d', $year, $month, $i);
$args->end_date = sprintf('%04d%02d%02d', $year, $month, $i);
if($site_srl)
{
$args->site_srl = $site_srl;
@ -297,14 +372,20 @@ class counterModel extends counter
if(!$isPageView)
{
$count = (int)$output->data->unique_visitor;
$count = (int) $output->data->unique_visitor;
}
else
{
$count = (int)$output->data->pageview;
$count = (int) $output->data->pageview;
}
$status->list[$i] = $count;
if($count>$max) $max = $count;
if($count > $max)
{
$max = $count;
}
$sum += $count;
}
break;
@ -312,6 +393,7 @@ class counterModel extends counter
$status->max = $max;
$status->sum = $sum;
return $status;
}
@ -322,9 +404,9 @@ class counterModel extends counter
$output1 = $this->getHourlyStatus('week', $date1);
$tmp = array();
foreach($output1->list AS $key=>$value)
foreach($output1->list AS $key => $value)
{
$tmp["'".$key."'"] = $value;
$tmp["'" . $key . "'"] = $value;
}
$output1->list = $tmp;
@ -333,9 +415,9 @@ class counterModel extends counter
$output2 = $this->getHourlyStatus('week', $date2);
$tmp = array();
foreach($output2->list AS $key=>$value)
foreach($output2->list AS $key => $value)
{
$tmp["'".$key."'"] = $value;
$tmp["'" . $key . "'"] = $value;
}
$output2->list = $tmp;
@ -347,29 +429,30 @@ class counterModel extends counter
{
//for last week
$date1 = date('Ymd', strtotime('-1 week'));
$output1 = $this->getHourlyStatus('week', $date1, 0, true);
$output1 = $this->getHourlyStatus('week', $date1, 0, TRUE);
$tmp = array();
foreach($output1->list AS $key=>$value)
foreach($output1->list AS $key => $value)
{
$tmp["'".$key."'"] = $value;
$tmp["'" . $key . "'"] = $value;
}
$output1->list = $tmp;
//for this week
$date2 = date('Ymd');
$output2 = $this->getHourlyStatus('week', $date2, 0, true);
$output2 = $this->getHourlyStatus('week', $date2, 0, TRUE);
$tmp = array();
foreach($output2->list AS $key=>$value)
foreach($output2->list AS $key => $value)
{
$tmp["'".$key."'"] = $value;
$tmp["'" . $key . "'"] = $value;
}
$output2->list = $tmp;
$this->add('last_week', $output1);
$this->add('this_week', $output2);
}
}
/* End of file counter.model.php */
/* Location: ./modules/counter/counter.model.php */