/nukeviet/includes/core/stat.php
PHP | 84 lines | 65 code | 13 blank | 6 comment | 7 complexity | 418492746079802868613029ad83608c MD5 | raw file
Possible License(s): BSD-3-Clause, LGPL-2.1, GPL-2.0
- <?php
- /**
- * @Project NUKEVIET 3.x
- * @Author VINADES.,JSC (contact@vinades.vn)
- * @copyright 2009
- * @createdate 12/29/2009 20:7
- */
- if( ! defined( 'NV_MAINFILE' ) ) die( 'Stop!!!' );
- function nv_stat_update()
- {
- global $db, $client_info, $global_config;
- list( $last_update ) = $db->sql_fetchrow( $db->sql_query( "SELECT `c_count` FROM `" . NV_COUNTER_TABLE . "` WHERE `c_type` = 'c_time' AND `c_val`= 'last'" ) );
- if( NV_SITE_TIMEZONE_NAME == $global_config['statistics_timezone'] )
- {
- $last_year = date( "Y", $last_update );
- $last_month = date( "M", $last_update );
- $last_day = date( "d", $last_update );
- $current_year = date( 'Y', NV_CURRENTTIME );
- $current_month = date( 'M', NV_CURRENTTIME );
- $current_day = date( 'd', NV_CURRENTTIME );
- $current_hour = date( 'H', NV_CURRENTTIME );
- $current_week = date( 'l', NV_CURRENTTIME );
- }
- else
- {
- date_default_timezone_set( $global_config['statistics_timezone'] );
- $last_year = date( "Y", $last_update );
- $last_month = date( "M", $last_update );
- $last_day = date( "d", $last_update );
- $current_year = date( 'Y', NV_CURRENTTIME );
- $current_month = date( 'M', NV_CURRENTTIME );
- $current_day = date( 'd', NV_CURRENTTIME );
- $current_hour = date( 'H', NV_CURRENTTIME );
- $current_week = date( 'l', NV_CURRENTTIME );
- date_default_timezone_set( NV_SITE_TIMEZONE_NAME );
- }
- if( $last_year != $current_year )
- {
- $query = "UPDATE `" . NV_COUNTER_TABLE . "` SET `c_count`= 0 WHERE (`c_type`='month' OR `c_type`='day' OR `c_type`='hour')";
- $db->sql_query( $query );
- }
- elseif( $last_month != $current_month )
- {
- $query = "UPDATE `" . NV_COUNTER_TABLE . "` SET `c_count`= 0 WHERE (`c_type`='day' OR `c_type`='hour')";
- $db->sql_query( $query );
- }
- elseif( $last_day != $current_day )
- {
- $query = "UPDATE `" . NV_COUNTER_TABLE . "` SET `c_count`= 0 WHERE `c_type`='hour'";
- $db->sql_query( $query );
- }
- $bot_name = ( $client_info['is_bot'] and ! empty( $client_info['bot_info']['name'] ) ) ? $client_info['bot_info']['name'] : "Not_bot";
- $browser = ( $client_info['is_mobile'] ) ? "Mobile" : $client_info['browser']['key'];
- $query = "UPDATE `" . NV_COUNTER_TABLE . "` SET `c_count`= c_count + 1, `last_update`=" . NV_CURRENTTIME . " WHERE
- (`c_type`='total' AND `c_val`='hits') OR
- (`c_type`='year' AND `c_val`='" . $current_year . "') OR
- (`c_type`='month' AND `c_val`='" . $current_month . "') OR
- (`c_type`='day' AND `c_val`='" . $current_day . "') OR
- (`c_type`='dayofweek' AND `c_val`='" . $current_week . "') OR
- (`c_type`='hour' AND `c_val`='" . $current_hour . "') OR
- (`c_type`='bot' AND `c_val`=" . $db->dbescape( $bot_name ) . ") OR
- (`c_type`='browser' AND `c_val`=" . $db->dbescape( $browser ) . ") OR
- (`c_type`='os' AND `c_val`=" . $db->dbescape( $client_info['client_os']['key'] ) . ") OR
- (`c_type`='country' AND `c_val`=" . $db->dbescape( $client_info['country'] ) . ")";
- $db->sql_query( $query );
- $query = "UPDATE `" . NV_COUNTER_TABLE . "` SET `c_count`= " . NV_CURRENTTIME . " WHERE `c_type`='c_time' AND `c_val`= 'last'";
- $db->sql_query( $query );
- }
- nv_stat_update();
- $nv_Request->set_Session( 'statistic_' . NV_LANG_DATA, NV_CURRENTTIME );
- ?>