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
158 lines
3.9 KiB
PHP
158 lines
3.9 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\Out\Module\Excel;
|
|
|
|
|
|
abstract class Report
|
|
{
|
|
const FORMAT_CSV = 'format_csv';
|
|
const FORMAT_ODS = 'format_ods';
|
|
// const FORMAT_XLS = 'format_xls';
|
|
const FORMAT_XLSX = 'format_xlsx';
|
|
|
|
private $format = self::FORMAT_CSV;
|
|
|
|
/** @var \databox */
|
|
protected $databox;
|
|
protected $parms;
|
|
|
|
public function __construct(\databox $databox, $parms)
|
|
{
|
|
$this->databox = $databox;
|
|
$this->parms = $parms;
|
|
|
|
$this->databox->get_connection()->getWrappedConnection()->setAttribute(\PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, FALSE);
|
|
}
|
|
|
|
abstract function getName();
|
|
|
|
abstract function getColumnTitles();
|
|
|
|
abstract function getKeyName();
|
|
|
|
abstract function getAllRows($callback);
|
|
|
|
protected function getDatabox()
|
|
{
|
|
return $this->databox;
|
|
}
|
|
|
|
public function getContent()
|
|
{
|
|
$ret = [];
|
|
$this->getAllRows(
|
|
function($row) use($ret) {
|
|
$ret[] = $row;
|
|
}
|
|
);
|
|
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* get quoted coll id's granted for report, possibly filtered by
|
|
* baseIds : only from this list of bases
|
|
*
|
|
* @param \ACL $acl
|
|
* @param int[]|null $baseIds
|
|
* @return array
|
|
*/
|
|
protected function getCollIds(\ACL $acl, $baseIds)
|
|
{
|
|
$ret = [];
|
|
/** @var \collection $collection */
|
|
foreach($acl->get_granted_base([\ACL::CANREPORT]) as $collection) {
|
|
if($collection->get_sbas_id() != $this->databox->get_sbas_id()) {
|
|
continue;
|
|
}
|
|
if(!is_null($baseIds) && !in_array($collection->get_base_id(), $baseIds)) {
|
|
continue;
|
|
}
|
|
$ret[] = $this->databox->get_connection()->quote($collection->get_coll_id());
|
|
}
|
|
|
|
return $ret;
|
|
}
|
|
|
|
public function setFormat($format)
|
|
{
|
|
if(!in_array($format, [
|
|
//self::FORMAT_XLS,
|
|
self::FORMAT_CSV,
|
|
self::FORMAT_ODS,
|
|
self::FORMAT_XLSX,
|
|
])) {
|
|
throw new \InvalidArgumentException(sprintf("bad format \"%s\" for report", $format));
|
|
}
|
|
$this->format = $format;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function getFormat()
|
|
{
|
|
return $this->format;
|
|
}
|
|
|
|
public function render()
|
|
{
|
|
switch($this->format) {
|
|
//case self::FORMAT_XLS:
|
|
case self::FORMAT_CSV:
|
|
case self::FORMAT_ODS:
|
|
case self::FORMAT_XLSX:
|
|
$this->renderAsExcel();
|
|
break;
|
|
default:
|
|
// should not happen since format is checked before
|
|
break;
|
|
}
|
|
}
|
|
|
|
private function renderAsExcel()
|
|
{
|
|
switch($this->format) {
|
|
//case self::FORMAT_XLS:
|
|
// $excel = new Excel(Excel::FORMAT_XLS);
|
|
// header('Content-Type: application/vnd.ms-excel');
|
|
// break;
|
|
case self::FORMAT_XLSX:
|
|
$excel = new Excel(Excel::FORMAT_XLSX, $this->getName() . ".xlsx");
|
|
break;
|
|
case self::FORMAT_ODS:
|
|
$excel = new Excel(Excel::FORMAT_ODS, $this->getName() . ".ods");
|
|
break;
|
|
case self::FORMAT_CSV:
|
|
default:
|
|
$excel = new Excel(Excel::FORMAT_CSV, $this->getName() . ".csv");
|
|
break;
|
|
}
|
|
|
|
$excel->addRow($this->getColumnTitles());
|
|
|
|
$n = 0;
|
|
$this->getAllRows(
|
|
function($row) use($excel, $n) {
|
|
$excel->addRow($row);
|
|
if($n++ % 10000 === 0) {
|
|
flush();
|
|
}
|
|
}
|
|
);
|
|
|
|
$excel->render();
|
|
}
|
|
|
|
}
|