summaryrefslogtreecommitdiffstats
path: root/modules-available/statistics_reporting
diff options
context:
space:
mode:
authorSimon Rettberg2017-02-06 15:45:30 +0100
committerSimon Rettberg2017-02-06 15:45:30 +0100
commitf3c37dd0c499f3b66e794701921c09ca2f71f8ed (patch)
tree6fb425d745d8c89329201c0edcb6785584ed81f5 /modules-available/statistics_reporting
parent[statistics_reporting] Move logic js -> php (for export feature) (diff)
downloadslx-admin-f3c37dd0c499f3b66e794701921c09ca2f71f8ed.tar.gz
slx-admin-f3c37dd0c499f3b66e794701921c09ca2f71f8ed.tar.xz
slx-admin-f3c37dd0c499f3b66e794701921c09ca2f71f8ed.zip
[statistics_reporting] Add export functionality for json, csv, xml - GUI still missing
Diffstat (limited to 'modules-available/statistics_reporting')
-rw-r--r--modules-available/statistics_reporting/page.inc.php89
1 files changed, 83 insertions, 6 deletions
diff --git a/modules-available/statistics_reporting/page.inc.php b/modules-available/statistics_reporting/page.inc.php
index 235cebb7..9d19f95a 100644
--- a/modules-available/statistics_reporting/page.inc.php
+++ b/modules-available/statistics_reporting/page.inc.php
@@ -43,6 +43,18 @@ class Page_Statistics_Reporting extends Page
Message::addError('invalid-table-type', $this->type);
$this->type = 'total';
}
+
+ // timespan you want to see. default = last 7 days
+ GetData::$from = strtotime("- " . ($this->days - 1) . " days 00:00:00");
+ GetData::$to = time();
+ GetData::$lowerTimeBound = $this->lower;
+ GetData::$upperTimeBound = $this->upper;
+
+ // Export - handle in doPreprocess so we don't render the menu etc.
+ if ($this->action === 'export') {
+ $this->doExport();
+ // Does not return
+ }
}
/**
@@ -104,12 +116,6 @@ class Page_Statistics_Reporting extends Page
Render::addTemplate('columnChooser', $data);
- // timespan you want to see. default = last 7 days
- GetData::$from = strtotime("- " . ($this->days - 1) . " days 00:00:00");
- GetData::$to = time();
- GetData::$lowerTimeBound = $this->lower;
- GetData::$upperTimeBound = $this->upper;
-
$data['data'] = $this->fetchData(GETDATA_PRINTABLE);
Render::addTemplate('table-' . $this->type, $data);
}
@@ -134,6 +140,77 @@ class Page_Statistics_Reporting extends Page
}
}
+ private function doExport()
+ {
+ $format = Request::get('format', 'json', 'string');
+ $printable = (bool)Request::get('printable', 0, 'int');
+ $flags = 0;
+ if ($printable) {
+ $flags |= GETDATA_PRINTABLE;
+ }
+ $res = $this->fetchData($flags);
+ // TODO: Filter unwanted columns
+ switch ($format) {
+ case 'json':
+ Header('Content-Type: application/json; charset=utf-8');
+ $output = json_encode(array('data' => $res));
+ break;
+ case 'csv':
+ if (!is_array($res)) {
+ die('Error fetching data.');
+ }
+ Header('Content-Type: text/csv; charset=utf-8');
+ $fh = fopen('php://output', 'w');
+ // Output UTF-8 BOM - Excel needs this to automatically decode as UTF-8
+ // (and since Excel is the only sane reason to export as csv, just always do it)
+ fputs($fh, chr(239) . chr(187) . chr(191));
+ // Output
+ if (isset($res[0]) && is_array($res[0])) {
+ // List of rows
+ fputcsv($fh, array_keys($res[0]));
+ foreach ($res as $row) {
+ fputcsv($fh, $row);
+ }
+ } else {
+ // Single assoc array
+ fputcsv($fh, array_keys($res));
+ fputcsv($fh, $res);
+ }
+ fclose($fh);
+ exit();
+ break;
+ case 'xml':
+ $xml_data = new SimpleXMLElement('<?xml version="1.0" encoding="utf-8" ?><data></data>');
+ $this->array_to_xml($res, $xml_data, 'row');
+ $output = $xml_data->asXML();
+ Header('Content-Type: text/xml; charset=utf-8');
+ break;
+ default:
+ Header('Content-Type: text/plain');
+ $output = 'Invalid format: ' . $format;
+ }
+ die($output);
+ }
+
+ /**
+ * @param $data array Data to encode
+ * @param $xml_data \SimpleXMLElement XML Object to append to
+ */
+ private function array_to_xml($data, $xml_data, $parentName = 'row')
+ {
+ foreach ($data as $key => $value) {
+ if (is_numeric($key)) {
+ $key = $parentName;
+ }
+ if (is_array($value)) {
+ $subnode = $xml_data->addChild($key);
+ $this->array_to_xml($value, $subnode, $key);
+ } else {
+ $xml_data->addChild($key, htmlspecialchars($value));
+ }
+ }
+ }
+
private function fetchData($flags)
{
switch ($this->type) {