mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 02:13:15 +00:00

move code to services added "download" report change services to factory added excel lib added prod/report routes (download) cleanup api routes add : allow anonymized (user, fonction, societe... are "-") removed : xls support (memory eating lib) in favor of xlsx add : report download only on "document" and "preview" subdef classes cs : report factory add : restored "site" filter (see todos in src) remove debug, cs todo : doc
150 lines
5.3 KiB
PHP
150 lines
5.3 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.
|
|
*/
|
|
|
|
namespace Alchemy\Phrasea\Report;
|
|
|
|
use Alchemy\Phrasea\Application;
|
|
use Alchemy\Phrasea\Exception\InvalidArgumentException;
|
|
|
|
|
|
class ReportConnections extends Report
|
|
{
|
|
private $appKey;
|
|
|
|
/* those vars will be set once by computeVars() */
|
|
private $name = null;
|
|
private $sql = null;
|
|
private $columnTitles = [];
|
|
private $keyName = null;
|
|
|
|
|
|
public function getColumnTitles()
|
|
{
|
|
$this->computeVars();
|
|
return $this->columnTitles;
|
|
}
|
|
|
|
public function getKeyName()
|
|
{
|
|
$this->computeVars();
|
|
return $this->keyName;
|
|
}
|
|
|
|
public function getName()
|
|
{
|
|
$this->computeVars();
|
|
return $this->name;
|
|
}
|
|
|
|
public function setAppKey($appKey)
|
|
{
|
|
$this->appKey = $appKey;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function getAllRows($callback)
|
|
{
|
|
$this->computeVars();
|
|
$stmt = $this->databox->get_connection()->executeQuery($this->sql, []);
|
|
while (($row = $stmt->fetch())) {
|
|
$callback($row);
|
|
}
|
|
$stmt->closeCursor();
|
|
}
|
|
|
|
private function computeVars()
|
|
{
|
|
if(!is_null($this->name)) {
|
|
// vars already computed
|
|
return;
|
|
}
|
|
|
|
switch($this->parms['group']) {
|
|
case null:
|
|
$this->name = "Connections";
|
|
$this->columnTitles = ['id', 'date', 'usrid', 'user', 'fonction', 'societe', 'activite', 'pays', 'nav', 'version', 'os', 'res', 'ip', 'user_agent'];
|
|
if($this->parms['anonymize']) {
|
|
$sql = "SELECT `id`, `date`,\n"
|
|
. " `usrid`, '-' AS `user`, '-' AS `fonction`, '-' AS `societe`, '-' AS `activite`, '-' AS `pays`,\n"
|
|
. " `nav`, `version`, `os`, `res`, `ip`, `user_agent` FROM `log`\n"
|
|
. " WHERE {{GlobalFilter}}";
|
|
}
|
|
else {
|
|
$sql = "SELECT `id`, `date`,\n"
|
|
. " `usrid`, `user`, `fonction`, `societe`, `activite`, `pays`,\n"
|
|
. " `nav`, `version`, `os`, `res`, `ip`, `user_agent` FROM `log`\n"
|
|
. " WHERE {{GlobalFilter}}";
|
|
}
|
|
$this->keyName = null;
|
|
break;
|
|
case 'user':
|
|
$this->name = "Connections per user";
|
|
$this->columnTitles = ['user_id', 'user', 'fonction', 'societe', 'activite', 'pays', 'min_date', 'max_date', 'nb'];
|
|
if($this->parms['anonymize']) {
|
|
$sql = "SELECT `usrid`, '-' AS `user`, '-' AS `fonction`, '-' AS `societe`, '-' AS `activite`, '-' AS `pays`,\n"
|
|
. " MIN(`date`) AS `dmin`, MAX(`date`) AS `dmax`, SUM(1) AS `nb` FROM `log`\n"
|
|
. " WHERE {{GlobalFilter}}\n"
|
|
. " GROUP BY `usrid`\n"
|
|
. " ORDER BY `nb` DESC";
|
|
}
|
|
else {
|
|
$sql = "SELECT `usrid`, `user`, `fonction`, `societe`, `activite`, `pays`,\n"
|
|
. " MIN(`date`) AS `dmin`, MAX(`date`) AS `dmax`, SUM(1) AS `nb` FROM `log`\n"
|
|
. " WHERE {{GlobalFilter}}\n"
|
|
. " GROUP BY `usrid`\n"
|
|
. " ORDER BY `nb` DESC";
|
|
}
|
|
$this->keyName = 'usrid';
|
|
break;
|
|
case 'nav':
|
|
case 'nav,version':
|
|
case 'os':
|
|
case 'os,nav':
|
|
case 'os,nav,version':
|
|
case 'res':
|
|
$this->name = "Connections per " . $this->parms['group'];
|
|
$groups = explode(',', $this->parms['group']);
|
|
$qgroups = implode(
|
|
',',
|
|
array_map(function($g) {return '`'.$g.'`';}, $groups)
|
|
);
|
|
$this->columnTitles = $groups;
|
|
$this->columnTitles[] = 'nb';
|
|
$sql = "SELECT " . $qgroups . ", SUM(1) AS `nb` FROM `log`\n"
|
|
. " WHERE {{GlobalFilter}}\n"
|
|
. " GROUP BY " . $qgroups . "\n"
|
|
. " ORDER BY `nb` DESC"
|
|
;
|
|
$this->keyName = null;
|
|
break;
|
|
default:
|
|
throw new InvalidArgumentException('invalid "group" argument');
|
|
break;
|
|
}
|
|
|
|
$filter = "`usrid`>0";
|
|
// next line : comment to disable "site", to test on an imported dataset from another instance
|
|
$filter .= " AND `site` = " . $this->databox->get_connection()->quote($this->appKey);
|
|
|
|
if($this->parms['dmin']) {
|
|
$filter .= "\n AND `log`.`date` >= " . $this->databox->get_connection()->quote($this->parms['dmin']);
|
|
}
|
|
if($this->parms['dmax']) {
|
|
$filter .= "\n AND `log`.`date` <= " . $this->databox->get_connection()->quote($this->parms['dmax']);
|
|
}
|
|
|
|
$this->sql = str_replace('{{GlobalFilter}}', $filter, $sql);
|
|
|
|
// file_put_contents("/tmp/phraseanet-log.txt", sprintf("%s (%d) %s\n", __FILE__, __LINE__, var_export($this->sql, true)), FILE_APPEND);
|
|
}
|
|
|
|
}
|