mirror of
				https://github.com/alchemy-fr/Phraseanet.git
				synced 2025-10-26 11:23:13 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			95 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of Phraseanet
 | |
|  *
 | |
|  * (c) 2005-2016 Alchemy
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| use Alchemy\Phrasea\Application;
 | |
| 
 | |
| class module_report_sqlconnexion extends module_report_sql implements module_report_sqlReportInterface
 | |
| {
 | |
| 
 | |
|     public function __construct(Application $app, module_report $report)
 | |
|     {
 | |
|         parent::__construct($app, $report);
 | |
|     }
 | |
| 
 | |
|     public function buildSql()
 | |
|     {
 | |
|         $filter = $this->filter->getReportFilter() ? : ['params' => [], 'sql' => false];
 | |
|         $this->params = array_merge([], $filter['params']);
 | |
| 
 | |
|         if ($this->groupby == false) {
 | |
|             $this->sql = "
 | |
|                 SELECT
 | |
|                  log.id,
 | |
|                  log.user,
 | |
|                  log.usrid,
 | |
|                  log.date as ddate,
 | |
|                  log.societe,
 | |
|                  log.pays,
 | |
|                  log.activite,
 | |
|                  log.fonction,
 | |
|                  log.site,
 | |
|                  log.sit_session,
 | |
|                  log.appli,
 | |
|                  log.ip
 | |
|                 FROM log FORCE INDEX (date_site)
 | |
|                 WHERE (" . $filter['sql'] .") AND !ISNULL(log.usrid)";
 | |
| 
 | |
| // no_file_put_contents("/tmp/report.txt", sprintf("%s (%s)\n%s\n\n", __FILE__, __LINE__, $this->sql), FILE_APPEND);
 | |
| 
 | |
|             $stmt = $this->connbas->prepare($this->sql);
 | |
|             $stmt->execute($this->params);
 | |
|             $this->total_row = $stmt->rowCount();
 | |
|             $stmt->closeCursor();
 | |
| 
 | |
|             $this->sql .= $this->filter->getOrderFilter() ? : '';
 | |
| 
 | |
|             if ($this->enable_limit) {
 | |
|                 $this->sql .= $this->filter->getLimitFilter() ? : '';
 | |
|             }
 | |
|         } else {
 | |
|             $this->sql = "
 | |
|                 SELECT " . $this->groupby . ", SUM(1) as nb
 | |
|                 FROM (
 | |
|                     SELECT DISTINCT(log.id),  TRIM(" . $this->getTransQuery($this->groupby) . ") AS " . $this->groupby . "
 | |
|                     FROM  log FORCE INDEX (date_site)
 | |
|                     WHERE (" . $filter['sql'] .")
 | |
|                 ) AS tt
 | |
|                 GROUP BY " . $this->groupby. "
 | |
|                 ORDER BY nb DESC";
 | |
| 
 | |
| // no_file_put_contents("/tmp/report.txt", sprintf("%s (%s)\n%s\n\n", __FILE__, __LINE__, $this->sql), FILE_APPEND);
 | |
| 
 | |
|             $stmt = $this->connbas->prepare($this->sql);
 | |
|             $stmt->execute($this->params);
 | |
|             $this->total_row = $stmt->rowCount();
 | |
|             $stmt->closeCursor();
 | |
|         }
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function sqlDistinctValByField($field)
 | |
|     {
 | |
|         $filter = $this->filter->getReportFilter() ? : ['params' => [], 'sql' => false];
 | |
|         $this->params = array_merge([], $filter['params']);
 | |
| 
 | |
|         $this->sql = '
 | |
|             SELECT DISTINCT(val)
 | |
|             FROM (
 | |
|                 SELECT DISTINCT(log.id), ' . $this->getTransQuery($field) . ' AS val
 | |
|                 FROM log FORCE INDEX (date_site)
 | |
|                 WHERE (' . $filter['sql'] . ')
 | |
|             ) AS tt ORDER BY val ASC';
 | |
| 
 | |
|         return ['sql' => $this->sql, 'params' => $this->params];
 | |
|     }
 | |
| }
 | 
