dmarc-cat
is a small command-line utility to analyze and display in a usable manner the content of the DMARC XML reports sent by the various email providers around the globe. Should work properly on UNIX (FreeBSD, Linux, etc.) and now Windows systems.
As with many Go utilities, a simple
go get github.com/keltia/dmarc-cat
is enough to fetch, build and install. On some systems you may need to add some environment variables to enable the Go and C compilers to find the gpgme
include files and libraries.
CGO_CFLAGS="-I/usr/local/include" CGO_LDFLAGS="-L/usr/local/lib" go get ...
On Windows systems, GPG support is disabled in the archive
module so you don't need to compile any non-Go code and the above go get
command should work directly in a Powershell window.
Dmarc-cat is available on the AUR:
- dmarc-cat (release package)
- dmarc-cat-git (git package)
You can install it using your AUR helper of choice.
Example:
$ yay -Sy dmarc-cat
Aside from the standard library, I use github.com/intel/tfortools
to generate tables.
go get -u github.com/intel/tfortools
It also use my own module github.com/keltia/archive
to handle the various archive types.
If you use Go modules, it should all work automatically.
SYNOPSIS
dmarc-cat -hvDN [-j N] [-t type] [-S sort] [-version] <zipfile|xmlfile>
Usage of ./dmarc-cat:
-D Debug mode
-N Do not resolve IPs
-S string
Sort results (default "\"Count\" \"dsc\"")
-j int
Parallel jobs (default 8)
-t string
File type for stdin mode
-v Verbose mode
-version
Display version
Example:
$ dmarc-cat /tmp/yahoo.com\!keltia.net\!1518912000\!1518998399.xml
Reporting by: Yahoo! Inc. — postmaster@dmarc.yahoo.com
From 2018-02-18 01:00:00 +0100 CET to 2018-02-19 00:59:59 +0100 CET
Domain: keltia.net
Policy: p=none; dkim=r; spf=r
Reports(1):
IP Count From RFrom RDKIM RSPF
88.191.250.24 1 keltia.net keltia.net neutral pass
The full XML grammar is available here
The report has several columns:
IP
is matching IP addressCount
is the number of times this IP was presentFrom
is theFrom:
header valueRFrom
is the envelopeFrom
valueRDKIM
is the result from DKIM checkingRSPF
is the result from SPF checking
The file sent by MTAs can differ in format, some providers send zip files with both csv and XML files, some directly send compressed XML files. The archive
module should support all these, please open an issue if not.
Getting close to 90% coverage.
This is released under the BSD 2-Clause license. See LICENSE.md
.
I use Git Flow for this package so please use something similar or the usual github workflow.
- Fork it ( https://github.com/keltia/dmarc-cat/fork )
- Checkout the develop branch (
git checkout develop
) - Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request