Blame lenses/mailscanner_rules.aug

Packit Service a2ae7a
(*
Packit Service a2ae7a
Module: Mailscanner_rules
Packit Service a2ae7a
  Parses MailScanner rules files.
Packit Service a2ae7a
Packit Service a2ae7a
Author: Andrew Colin Kissa <andrew@topdog.za.net>
Packit Service a2ae7a
  Baruwa Enterprise Edition http://www.baruwa.com
Packit Service a2ae7a
Packit Service a2ae7a
About: License
Packit Service a2ae7a
  This file is licensed under the LGPL v2+.
Packit Service a2ae7a
Packit Service a2ae7a
About: Configuration files
Packit Service a2ae7a
  This lens applies to MailScanner rules files
Packit Service a2ae7a
  The format is described below:
Packit Service a2ae7a
Packit Service a2ae7a
  # NOTE: Fields are separated by TAB characters --- Important!
Packit Service a2ae7a
  #
Packit Service a2ae7a
  # Syntax is allow/deny/deny+delete/rename/rename to replacement-text/email-addresses,
Packit Service a2ae7a
  #           then regular expression,
Packit Service a2ae7a
  #           then log text,
Packit Service a2ae7a
  #           then user report text.
Packit Service a2ae7a
  # The "email-addresses" can be a space or comma-separated list of email
Packit Service a2ae7a
  # addresses. If the rule hits, the message will be sent to these address(es)
Packit Service a2ae7a
  # instead of the original recipients.
Packit Service a2ae7a
Packit Service a2ae7a
  # If a rule is a "rename" rule, then the attachment filename will be renamed
Packit Service a2ae7a
  # according to the "Default Rename Pattern" setting in MailScanner.conf.
Packit Service a2ae7a
  # If a rule is a "rename" rule and the "to replacement-text" is supplied, then
Packit Service a2ae7a
  # the text matched by the regular expression in the 2nd field of the line
Packit Service a2ae7a
  # will be replaced with the "replacement-text" string.
Packit Service a2ae7a
  # For example, the rule
Packit Service a2ae7a
  # rename to .ppt	\.pps$	Renamed .pps to .ppt	Renamed .pps to .ppt
Packit Service a2ae7a
  # will find all filenames ending in ".pps" and rename them so they end in
Packit Service a2ae7a
  # ".ppt" instead.
Packit Service a2ae7a
*)
Packit Service a2ae7a
Packit Service a2ae7a
module Mailscanner_Rules =
Packit Service a2ae7a
autoload xfm
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 *                           USEFUL PRIMITIVES
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
let eol = del /\n/ "\n"
Packit Service a2ae7a
let ws         = del /[\t]+/ "\t"
Packit Service a2ae7a
let comment    = Util.comment
Packit Service a2ae7a
let empty      = Util.empty
Packit Service a2ae7a
let action     = /allow|deny|deny\+delete|rename|rename[ ]+to[ ]+[^# \t\n]+|([A-Za-z0-9_+.-]+@[A-Za-z0-9_.-]+[, ]?)+/
Packit Service a2ae7a
let non_space  = /[^# \t\n]+/
Packit Service a2ae7a
let non_tab    = /[^\t\n]+/
Packit Service a2ae7a
Packit Service a2ae7a
let field (l:string) (r:regexp)
Packit Service a2ae7a
               = [ label l . store r ]
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 *                               ENTRIES
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
let entry     = [ seq "rule" . field "action" action
Packit Service a2ae7a
                . ws . field "regex" non_tab
Packit Service a2ae7a
                . ws . field "log-text" non_tab
Packit Service a2ae7a
                . ws . field "user-report" non_tab
Packit Service a2ae7a
                . eol ]
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 *                                LENS
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
let lns        = (comment|empty|entry)*
Packit Service a2ae7a
Packit Service a2ae7a
let filter     = (incl "/etc/MailScanner/filename.rules.conf")
Packit Service a2ae7a
                . (incl "/etc/MailScanner/filetype.rules.conf")
Packit Service a2ae7a
                . (incl "/etc/MailScanner/archives.filename.rules.conf")
Packit Service a2ae7a
                . (incl "/etc/MailScanner/archives.filetype.rules.conf")
Packit Service a2ae7a
Packit Service a2ae7a
let xfm        = transform lns filter