npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

haraka-plugin-messagesniffer

v1.0.0

Published

Haraka plugin that filters messages with messagesniffer

Downloads

2,199

Readme

CI Test Status Code Climate

NPM

haraka-plugin-messagesniffer

This plugin provides integration with the commerical Anti-Spam product MessageSniffer by Arm Research Labs using its XML Client interface XCI over TCP.

Installation

Install the SNF Client/Server package for your platform as per the instructions on the MessageSniffer website.

Modify your SNFServer.xml file and under the 'xheaders' section set:

  • output mode='api'

This prevents MessageSniffer from adding additional headers to the temporary file used to send it the message data which is unnecessary as Haraka reads the headers from the XCI response.

  • rulebase on-off='on'
  • result on-off='on'
  • black on-off='on'
  • while on-off='on'
  • clean on-off='on'
  • all symbol on-off='on'

These cause SNFServer to send Haraka additional headers that are inserted into all messages scanned by MessageSniffer and will aid debugging and troubleshooting.

Once this is done start/restart the SNF server.

Configuration

This plugin uses messagesniffer.ini for configuration. The [main] section is for global configuration, the [gbudb] section is used to specify the action that should be taken based on the GBUdb result which is checked at the start of the connection and the [message] section is used to specify the action to be taken based on the main scan result.

cp node_modules/haraka-plugin-messagesniffer/config/messagesniffer.ini config/messagesniffer.ini
$EDITOR config/messagesniffer.ini

[main]

  • port

    Default: 9001 TCP port to use when communicating to the SNFServer daemon. This needs to match the <xci on-off='on' port='9001'/> value in the SNFServer.xml file.

  • tmpdir

    Default: /tmp Temporary directory used to write temporary message files to that are read by the SNFServer daemon. This directory and the files within need to be readable by the user that SNFServer is running as.

  • gbudb_report_deny = [ true | false | 0 | 1 ]

    Default: false This is an experimental option that will record a GBUdb 'bad' encounter for a connected IP address when a client disconnects with no message having been sent or seen by MessageSniffer but Haraka has recorded a hard rejection at some point during the session. The idea behind this option is that it allows other Haraka plugins rejections influence GBUdb IP reputation where MessageSniffer isn't seeing the actual message because it is being rejected pre-DATA.

  • tag_string

    Default: [SPAM] String to prepend to the Subject line if the 'tag' action is applied.

[gbudb]

  • white = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: accept Action to take when GBUdb reports a 'white' result.

  • caution = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: continue Action to take when GBUdb reports a 'caution' result.

  • black = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: continue Action to take when GBUdb reports a 'black' result.

  • truncate = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ] Default: reject Action to take when GBUdb reports a 'truncate' result.

[message]

  • white = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: continue Action to take when MessageSniffer reports a 'white' result (result code: 0).

  • local_white = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: accept Action to take when MessageSniffer reports a local whitelist result (result code: 1). NOTE: You will not see this result unless you Arm support have customized your rulebase and added white rules for you.

  • truncate = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: reject Action to take when MessageSniffer reports a GBUdb result of 'truncate' (result code: 20). NOTE: GBUdb IP lookups during the data phase can be different than the connecting IP address if you have configured Source and DrillDown options in the Training section of SNFServer.xml.

  • caution = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: continue Action to take when MessageSniffer reports a GBUdb result of 'caution' (result code: 40). NOTE: GBUdb IP lookups during the data phase can be different than the connecting IP address if you have configured Source and DrillDown options in the Training section of SNFServer.xml.

  • black = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Default: continue Action to take when MessageSniffer reports a GBUdb result of 'black' (result code: 63). NOTE: GBUdb IP lookups during the data phase can be different than the connecting IP address if you have configured Source and DrillDown options in the Training section of SNFServer.xml.

  • code_NN = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    NOTE: replace NN with the numeric MessageSniffer result code Action to take when MessageSniffer reports a result code other than those explicitly defined above.

  • nonzero = [ accept | allow | continue | retry | tempfail | reject | quarantine | tag ]

    Defalt: reject Action to take for any non-zero result code other than those explicity defined above. This is a catch-all result that is checked last after all other settings have been checked so you can define a code_NN value to prevent this action from being taken.

Actions

  • accept

    Accept the message and skip further plugins (whitelist).

  • allow | continute

    Continue to the next plugin.

  • retry | tempfail

    Reject the message with a temporary failure message (DENYSOFT).

  • reject

    Reject the message with a permanent failure message (DENY).

  • quarantine

    Continue to the next plugin. If the message isn't rejected by another plugin - it will cause the message to be quarantined and the message will not be delivered to the recipient(s).

    NOTE: this option requires the queue/quarantine plugin in your config/plugins files and it must be listed before any other queue plugins.

  • tag

    Tag the subject with the default 'tag_string' defined in the main section above, this will also set X-Spam-Flag: YES in the message headers. Once tagged, processing will continue to the next plugin.