View Single Post
  #8  
Old 5th February 2012, 01:16
8omas 8omas is offline
Senior Member
 
Join Date: Jan 2011
Posts: 148
Thanks: 16
Thanked 35 Times in 26 Posts
Default

New code. Works good. Eliminates the problem of overwritten stats of previously month, the second day of the current month.

The logic, of the creation of awstats of the default cron, is that the second day of the month, the currently stats, are written in a new folder, repressenting the previously month.
This overwrites the stats already written in this folder by this script.
The new version corrects this.

One new addition, is the ability to recreate the stats from ANY month, as log as the data are in /var/lib/awstats or /var/cache/awstats.
Using this new feature
-first, you can correct any mistakes made by this script in the past and
-second, you can add ALL previously stats in the drop down menu.


Name it as:
/usr/local/ispconfig/server/mycron.php

Execute it:
Code:
/usr/bin/php /usr/local/ispconfig/server/mycron.php
Here is the script.
Code:
<?php

/*
Copyright (c) 2007, Till Brehm, projektfarm Gmbh
All rights reserved.

Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:

    * Redistributions of source code must retain the above copyright notice,
      this list of conditions and the following disclaimer.
    * Redistributions in binary form must reproduce the above copyright notice,
      this list of conditions and the following disclaimer in the documentation
      and/or other materials provided with the distribution.
    * Neither the name of ISPConfig nor the names of its contributors
      may be used to endorse or promote products derived from this software without
      specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

require('/usr/local/ispconfig/server/lib/config.inc.php');
require('/usr/local/ispconfig/server/lib/app.inc.php');

set_time_limit(0);

// make sure server_id is always an int
$conf['server_id'] = intval($conf['server_id']);


// Load required base-classes
$app->uses('ini_parser,file,services,getconf');


################################################################
######################### RECREATE STATS ##########################

$redo = 0; // set this to 1 if you want to recreate statistics for a specific month
$REMONTH = 11; // select the month
$REYEAR = 2011; //select the year
$LANG = 'en'; // set your language

# After setting the above rerun this script 
# e.g
# php /path/to
################################################################
################################################################



################################################################
// Create awstats statistics
################################################################

$sql = "SELECT domain_id, domain, document_root FROM web_domain WHERE stats_type = 'awstats' AND server_id = ".$conf['server_id'];
$records = $app->db->queryAllRecords($sql);

$web_config = $app->getconf->get_server_config($conf['server_id'], 'web');


foreach($records as $rec) {
        $logfile = escapeshellcmd($rec['document_root'].'/log/access.log');
        $domain = escapeshellcmd($rec['domain']);
        $statsdir = escapeshellcmd($rec['document_root'].'/web/stats');
        $awstats_pl = $web_config['awstats_pl'];
        $awstats_buildstaticpages_pl = $web_config['awstats_buildstaticpages_pl'];

        $awstats_conf_dir = $web_config['awstats_conf_dir'];
        $awstats_website_conf_file = $web_config['awstats_conf_dir'].'/awstats.'.$domain.'.conf';

        if(is_file($awstats_website_conf_file)) unlink($awstats_website_conf_file);

        $sql = "SELECT domain FROM web_domain WHERE (type = 'alias' OR AND type = 'subdomain') server_id = ".$conf['server_id'];
        $aliases = $app->db->queryAllRecords($sql);
        $aliasdomain = '';

        if(is_array($aliases)) {
                foreach ($aliases as $alias) {
                        $aliasdomain.= ' '.$alias['domain']. ' www.'.$alias['domain'];
                }
        }

        if(!is_file($awstats_website_conf_file)) {
                $awstats_conf_file_content = 'Include "'.$awstats_conf_dir.'/awstats.conf"
LogFile="/var/log/ispconfig/httpd/'.$domain.'/access.log"
SiteDomain="'.$domain.'"
HostAliases="www.'.$domain.' localhost 127.0.0.1"'.$aliasdomain;
                file_put_contents($awstats_website_conf_file,$awstats_conf_file_content);
        }

if(!@is_dir($statsdir)) mkdir($statsdir);



if ( $redo == 1 ) {

$awmonth = $REMONTH;
$awyear = $REYEAR;
        $statsdirold = $statsdir."/".$awyear."-".$awmonth."/";
        if (!is_dir($statsdirold)) {
                mkdir($statsdirold);
        }
        $command = "$awstats_buildstaticpages_pl -month='$awmonth' -year='$awyear' -update -config='$domain' -lang='$LANG' -dir='$statsdirold' -awstatsprog='$awstats_pl'";

        if($awstats_pl != '' && $awstats_buildstaticpages_pl != '' && fileowner($awstats_pl) == 0 && fileowner($awstats_buildstaticpages_pl) == 0) {
               exec($command);
               rename($statsdirold.'awstats.'.$domain.'.html',$statsdirold.'awsindex.html');
               $app->log('Created awstats statistics with command: '.$command,LOGLEVEL_DEBUG);
        } else {
               $app->log("No awstats statistics created. Either $awstats_pl or $awstats_buildstaticpages_pl is not owned by root user.",LOGLEVEL_WARN);
        }
}
else {
  if (date("d") == 1) {

      $awmonth = date("n")-1;
      $awyear = date("Y");


        if (date("n") == 0) {
                $awyear = date("Y")-1;
               $awmonth = "12";
        }

        $statsdirold = $statsdir."/".$awyear."-".$awmonth."/";

        if (!is_dir($statsdirold)) {
                mkdir($statsdirold);
                $command = "$awstats_buildstaticpages_pl -month='$awmonth' -year='$awyear' -update -config='$domain' -lang='$LANG' -dir='$statsdirold' -awstatsprog='$awstats_pl'";

                if($awstats_pl != '' && $awstats_buildstaticpages_pl != '' && fileowner($awstats_pl) == 0 && fileowner($awstats_buildstaticpages_pl) == 0) {
                        exec($command);
                        rename($statsdirold.'awstats.'.$domain.'.html',$statsdirold.'awsindex.html');
                        $app->log('Created awstats statistics with command: '.$command,LOGLEVEL_DEBUG);
                } else {
                        $app->log("No awstats statistics created. Either $awstats_pl or $awstats_buildstaticpages_pl is not owned by root user.",LOGLEVEL_WARN);
                }

        }
  }

// ispconfig, on the second day of month, overwrites the stats created before by this script
// to overwrite ispconfig default execution on 2nd day of month we must execute the below code
  if (date("d") == 2) {
      $awmonth = date("n")-1;
      $awyear = date("Y");
        if (date("n") == 0) {
                $awyear = date("Y")-1;
               $awmonth = "12";
        } 
        $statsdirold = $statsdir."/".$awyear."-".$awmonth."/";
                $command = "$awstats_buildstaticpages_pl -month='$awmonth' -year='$awyear' -update -config='$domain' -lang='$LANG' -dir='$statsdirold' -awstatsprog='$awstats_pl'";
                if($awstats_pl != '' && $awstats_buildstaticpages_pl != '' && fileowner($awstats_pl) == 0 && fileowner($awstats_buildstaticpages_pl) == 0) {
                        exec($command);
                        rename($statsdirold.'awstats.'.$domain.'.html',$statsdirold.'awsindex.html');
                        $app->log('Created awstats statistics with command: '.$command,LOGLEVEL_DEBUG);
                } else {
                        $app->log("No awstats statistics created. Either $awstats_pl or $awstats_buildstaticpages_pl is not owned by root user.",LOGLEVEL_WARN);
                }

  }
// end of overwrite
// unfortunately the above will execute many times (as many as you run this script by cron)


       $awmonth = date("n");
       $awyear = date("Y");
       $command = "$awstats_buildstaticpages_pl -month='$awmonth' -year='$awyear' -update -config='$domain' -lang='$LANG' -dir='$statsdir' -awstatsprog='$awstats_pl'";

       if($awstats_pl != '' && $awstats_buildstaticpages_pl != '' && fileowner($awstats_pl) == 0 && fileowner($awstats_buildstaticpages_pl) == 0) {
                exec($command);
                if(is_file($rec['document_root'].'/web/stats/index.html')) unlink($rec['document_root'].'/web/stats/index.html');
                rename($rec['document_root'].'/web/stats/awstats.'.$domain.'.html',$rec['document_root'].'/web/stats/awsindex.html');
                if(!is_file($rec['document_root']."/web/stats/index.php")) copy("/usr/local/ispconfig/server/conf/awstats_index.php.master",$rec['document_root']."/web/stats/index.php");

                $app->log('Created awstats statistics with command: '.$command,LOGLEVEL_DEBUG);
        } else {
                $app->log("No awstats statistics created. Either $awstats_pl or $awstats_buildstaticpages_pl is not owned by root user.",LOGLEVEL_WARN);
        }

} //end redo
} // end foreach


die("finished.\n");
?>
To run it for a specific month, edit the variables $redo, $REMONTH, $REYEAR, $LANG in the beggining of the script

If the $redo variable is 1, the script will ONLY recreate the month declared in $REMONTH, of the year $REYEAR, in you preffered language (declared in $LANG)

If the $redo variable is 0, the script will run normally. It will create the stats up to the time executed, for the current month, eliminating overwrites b ispconfig.

Last edited by 8omas; 5th February 2012 at 01:21.
Reply With Quote