Skip to main content

A pymilter based sendmail/postfix pre-queue filter.

Project description

pyquarantine-milter

A pymilter based sendmail/postfix pre-queue filter with the ability to quarantine e-mails, sending notifications to recipients and respond with a milter-action (ACCEPT, DISCARD or REJECT).

It is useful in many cases because of its felxible configuration and the ability to handle any number of quarantines. The MTA can check e-mail headers using regular expressions to determine if and which quarantine to use. Each quarantine can be configured with a quarantine type, notification type, whitelist and an action to respond with.

Addionally, pyquarantine-milter provides a sanitized, harmless version of the text parts of e-mails, which can be embedded in e-mail notifications. This makes it easier for users to decide, if a match is a false-positive or not. If a matching quarantine provides a quarantine ID of the original e-mail, it is also available as a template variable. This is useful if you want to add links to a webservice to notification e-mails, to give your users the ability to release e-mails or whitelist the from-address for example. The webservice then releases the e-mail from the quarantine.

The project is currently in alpha status, but will soon be used in a productive enterprise environment and possibly existing bugs will be fixed.

Requirements

Configuration

The pyquarantine module uses an INI-style configuration file. The sections are described below. If you have to specify a path in the config, you can always use a relative path to the last loaded config file.

Section "global"

Any available configuration option can be set in the global section as default instead of in a quarantine section.

The following configuration options are mandatory in the global section:

  • quarantines
    Comma-separated, ordered list of active quarantines. For each, there must be a section of the same name in the configuration.
  • preferred_quarantin_action
    Defines which quarantine action should be preferred if multiple quarantines are matching for multiple recipients.
    If at least one recipient receives the original e-mail due to whitelisting, the action is always ACCEPT. Possible values are:
    • first
    • last

Quarantine sections

The following configuration options are mandatory in each quarantine section:

  • regex
    Case insensitive regular expression to filter e-mail headers.
  • quarantine_type
    One of the quarantine-types described below.
  • action
    One of the actions described below.
  • notification_type
    One of the notification types described below.
  • whitelist_type
    One of the whitelist types described below.
  • smtp_host
    SMTP host to inject original e-mails. This is needed if not all recipients of an e-mail are whitelisted
  • smtp_port
    SMTP port

The following configuration options are optional in each quarantine section:

  • ignore_hosts
    Comma-separated list of host and network addresses to be ignored by this quarantine.
  • reject_reason
    Reason to return to the client if action is set to reject.

Quarantine types

  • NONE
    Original e-mails scrapped, sent to nirvana, black-holed or however you want to call it.

  • FILE
    Original e-mails are stored on the filesystem with a unique filename. The filename is available as a template variable used in notifiaction templates.
    The following configuration options are mandatory for this quarantine type:

    • quarantine_directory
      The directory in which quarantined e-mails are stored.

Notification types

  • NONE
    No quarantine notifications will be sent.

  • EMAIL
    Quarantine e-mail notifications are sent to recipients. The SMTP host and port, E-mail template, from-address and the subject are configurable for each quarantine. The templates must contain the notification e-mail text in HTML form.

    The following template variables are available:

    • {EMAIL_ENVELOPE_FROM}
      E-mail from-address received by the milter.
    • {EMAIL_FROM}
      Value of the from header of the original e-mail.
    • {EMAIL_TO}
      E-mail recipient address of this notification.
    • {EMAIL_SUBJECT}
      Configured e-mail subject.
    • {EMAIL_QUARANTINE_ID}
      Quarantine-ID of the original e-mail if available, empty otherwise.
    • {EMAIL_HTML_TEXT}
      Sanitized version of the e-mail text part of the original e-mail. Only harmless HTML tags and attributes are included. Images are replaced with the image set by notification_email_replacement_img option.

    Some template variables are only available if the regex of the matching quarantine contains subgroups or named subgroups (python syntax). This is useful to include information (e.g. virus names, spam points, ...) of the matching header within the notification.
    The following dynamic template variables are available:

    • {SUBGROUP_n}
      Content of a subgroup, 'n' will be replaced by the index number of each subgroup, starting with 0.
    • {subgroup_name}
      Content of a named subgroup, 'subgroup_name' will be replaced by its name.

    The following configuration options are mandatory for this notification type:

    • notification_email_envelope_from
      Notification e-mail envelope from-address.
    • notification_email_from
      Value of the notification e-mail from header. Every e-mail template variable described above is usable.
    • notification_email_subject
      Notification e-mail subject. All e-mail template variable described above is usable.
    • notification_email_template
      Path to the notification e-mail template. It is hold in memory during runtime.
    • notification_email_replacement_img
      Path to the image to replace images in e-mails. It is hold in memory during runtime. Leave it empty to disable.
    • notification_email_embedded_imgs
      Comma-separated list of images to embed into the notification e-mail. The Content-ID of each image will be set to the filename, so you can reference it from the e-mail template. All images are hold in memory during runtime.
      Leave empty to disable.

Actions

Every quarantine responds with a milter-action if an e-mail header matches the configured regular expression. Please think carefully what you set here or your MTA will do something you do not want.
The following actions are available:

  • ACCEPT
    Tell the MTA to continue processing the e-mail.
  • DISCARD
    Tell the MTA to silently discard the e-mail.
  • REJECT
    Tell the MTA to reject the e-mail.

Whitelist types

  • NONE
    No whitelist will be used.

  • DB
    A database whitelist will be used. All database types supported by peewee are available.

    The following configuration options are mandatory for this whitelist type:

    • whitelist_db_connection
      Database connection string (e.g. mysql://user:password@host:port).

    • whitelist_db_table
      Database table to use.

Developer information

Everyone who wants to improve or extend this project is very welcome.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyquarantine-0.0.1.tar.gz (40.2 kB view details)

Uploaded Source

Built Distribution

pyquarantine-0.0.1-py3-none-any.whl (36.9 kB view details)

Uploaded Python 3

File details

Details for the file pyquarantine-0.0.1.tar.gz.

File metadata

  • Download URL: pyquarantine-0.0.1.tar.gz
  • Upload date:
  • Size: 40.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.23.3 CPython/3.6.5

File hashes

Hashes for pyquarantine-0.0.1.tar.gz
Algorithm Hash digest
SHA256 d5d4f4066a78796fc7ad135738522d0eeb07cb4ac7f9d2ff131ed7d84df2fb04
MD5 ba3049bf9024014dd1638c6a36e54253
BLAKE2b-256 a62d7662857be33be28c0cb5e8b36eb9596fef78326851ceb0009403b38db71f

See more details on using hashes here.

File details

Details for the file pyquarantine-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: pyquarantine-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 36.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.9.1 tqdm/4.23.3 CPython/3.6.5

File hashes

Hashes for pyquarantine-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 50dc4b76112d5b62e954d77a327dd8f3311e75d7717dcf415f3a737b27e77bb2
MD5 2c15530ca5bec0853f2f77327988b62d
BLAKE2b-256 3b1a921ef434e51551053652332dac06e4de67e760a48a8806650b796615b8fd

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page