Socket
Socket
Sign inDemoInstall

dmarc-report-parser

Package Overview
Dependencies
49
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    dmarc-report-parser

DMARC email report parser for Node.js


Version published
Weekly downloads
0
decreased by-100%
Maintainers
1
Install size
7.00 MB
Created
Weekly downloads
 

Readme

Source

DMARC Report Parser

This module provides a set of functions to parse DMARC reports contained within email attachments, as well as directly from XML strings or Buffers. The main functions are:

  • parseDmarcReportFromEmail(rawEmail: string)
  • parseDmarcReportsFromXml(xmlFiles: (string | Buffer)[])

Installation

npm install --save dmarc-report-parser
yarn add dmarc-report-parser

Usage

Parsing DMARC reports from an email

import { parseDmarcReportFromEmail } from "dmarc-report-parser";

const rawEmail = "..."; // The raw email source

try {
  const result = await parseDmarcReportFromEmail(rawEmail);
  console.log(result);
} catch (error) {
  console.error("Failed to parse DMARC report:", error.message);
}

Parsing DMARC reports from XML files

import { parseDmarcReportsFromXml } from "dmarc-report-parser";

const xmlFiles = ["..."]; // An array of XML strings or Buffers

try {
  const result = await parseDmarcReportsFromXml(xmlFiles);
  console.log(result);
} catch (error) {
  console.error("Failed to parse DMARC report:", error.message);
}

API

parseDmarcReportFromEmail(rawEmail: string)

Parses a DMARC report from a raw email message. The DMARC report can be contained in a .zip, .gz or .xml attachment.

  • rawEmail: The raw email string.

Returns a Promise that resolves with the parsed DMARC report, or rejects with an error if the email does not contain a DMARC report.

parseDmarcReportsFromXml(xmlFiles: (string | Buffer)[])

Parses DMARC reports from an array of XML strings or Buffers.

  • xmlFiles: An array of XML strings or Buffers.

Returns a Promise that resolves with an object containing the parsed DMARC reports and additional information, or rejects with an error if the XML is not valid or does not match the DMARC schema.

The returned object contains the following properties:

  • totalReports: The total number of DMARC reports parsed.
  • totalFailures: The total number of DMARC failures where disposition is not none
  • failures: An array of DMARC failures.
  • dkimFailures: An array of DKIM failures.
  • spfFailures: An array of SPF failures.
  • reports: The parsed DMARC reports.

License

MIT

FAQs

Last updated on 03 Feb 2024

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc