%PDF- %PDF-
| Direktori : /www/varak.net/dmarc.varak.net/public/ |
| Current File : /www/varak.net/dmarc.varak.net/public/summary.php |
<?php
/**
* dmarc-srg - A php parser, viewer and summary report generator for incoming DMARC reports.
* Copyright (C) 2022-2025 Aleksey Andreev (liuch)
*
* Available at:
* https://github.com/liuch/dmarc-srg
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the Free
* Software Foundation, either version 3 of the License.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*
* =========================
*
* This script is to get summary report via the web interface
*
* HTTP GET query:
* when the header 'Accept' is 'application/json':
* if parameter `mode` is `options`, it returs data for the report options dialog;
* if parameter `mode` is `report`, it returns report data for the specified domain and period
* otherwise:
* it returns the content of the template.html file
* Other HTTP methods:
* it returns an error
*
* All the data is in json format.
*
* @category Web
* @package DmarcSrg
* @author Aleksey Andreev (liuch)
* @license https://www.gnu.org/licenses/gpl-3.0.html GNU/GPLv3
*/
namespace Liuch\DmarcSrg;
use Liuch\DmarcSrg\Users\User;
use Liuch\DmarcSrg\Domains\Domain;
use Liuch\DmarcSrg\Domains\DomainList;
use Liuch\DmarcSrg\Report\SummaryReport;
use Liuch\DmarcSrg\Report\OverallReport;
use Liuch\DmarcSrg\Exception\SoftException;
use Liuch\DmarcSrg\Exception\RuntimeException;
require realpath(__DIR__ . '/..') . '/init.php';
if (Core::isJson() && isset($_GET['mode'])) {
try {
$core = Core::instance();
$core->auth()->isAllowed(User::LEVEL_USER);
$user = $core->getCurrentUser();
$mode = $_GET['mode'];
if ($mode === 'options') {
Core::sendJson(
[
'domains' => (new DomainList($user))->names()
]
);
return;
} elseif ($mode === 'report') {
if (empty($_GET['domain'])) {
throw new SoftException('Parameter "domain" is not specified');
}
if (empty($_GET['period'])) {
throw new SoftException('Parameter "period" is not specified');
}
$format = $_GET['format'] ?? '';
if (!in_array($format, [ 'raw', 'text', 'csv' ])) {
throw new SoftException('The `format` parameter can only be `raw`, `text` or `csv`');
}
$ovr = null;
$rep = new SummaryReport($_GET['period']);
if (true) { // TODO this optionally using GET paramenter
$ovr = new OverallReport();
$rep->bindSection($ovr);
}
$reports = [];
foreach (explode(',', $_GET['domain']) as $d) {
$dom = new Domain($d);
$dom->isAssigned($user, true);
$rep->setDomain($dom);
$r = [ 'domain' => $d ];
switch ($format) {
case 'raw':
$r['data'] = $rep->toArray();
break;
case 'text':
$r['text'] = $rep->text();
break;
case 'csv':
$r['csv'] = $rep->csv();
break;
}
$reports[] = $r;
}
$res['reports'] = $reports;
if ($ovr) {
$r = [];
switch ($format) {
case 'raw':
$r['data'] = $ovr->toArray();
break;
case 'text':
$r['text'] = $ovr->text();
break;
case 'csv':
$r['csv'] = $ovr->csv();
break;
}
$res['overall'] = $r;
}
Core::sendJson($res);
return;
} else {
throw new SoftException('The `mode` parameter can only be `options` or `report`');
}
} catch (RuntimeException $e) {
Core::sendJson(ErrorHandler::exceptionResult($e));
return;
}
} elseif (Core::requestMethod() == 'GET') {
Core::instance()->sendHtml();
return;
}
Core::sendBad();