DMARC Report Parser is designed to simplify the analysis of DMARC (Domain-based Message Authentication, Reporting & Conformance) reports:
- Parse the XML-based report into fully typed classes
- Read reports from GZip files without decompressing first (coming soon)
You can install the package via composer:
composer require avvertix/dmarc-report-parser
Require PHP 8.3 with xsl
and sodium
extensions.
It is possible to parse reports from XML files or strings. The output is fully typed instance of DmarcReport
.
from file
$dmarc = new Avvertix\DmarcReportParser\DmarcReportParser();
/**
* @var Avvertix\DmarcReportParser\Data\DmarcReport
*/
$report = $dmarc->fromFile('path/to/report.xml');
from string
$dmarc = new Avvertix\DmarcReportParser\DmarcReportParser();
$xml = <<<'DMARC'
<?xml version="1.0"?>
<feedback xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<version>1.0</version>
<!-- content omitted for brevity -->
</feedback>
DMARC;
/**
* @var Avvertix\DmarcReportParser\Data\DmarcReport
*/
$report = $dmarc->fromString($xml);
DmarcReport class
The DmarcReport
class represent the report in a fully typed manner.
A few differences with respect to the spec:
- Report generator metadata are directly accessible from the
DmarcReport
class and not encapsulated in an object - Records are exposed using the
records
(array) property - In AuthResult both dkim and spf properties are represented as arrays
- In general when the spec report an element to be available multiple times we represent it as an array property
DMARC Report Parser is covered in unit test. The PestPHP framework is used. To run the whole test suite execute the test
script.
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.