diff options
| author | Barry Warsaw | 2007-12-27 23:04:08 -0500 |
|---|---|---|
| committer | Barry Warsaw | 2007-12-27 23:04:08 -0500 |
| commit | 13dea3a6736834e19ad569b5e3d70a79e096a55e (patch) | |
| tree | ab8448fd114436cd1dc9a1754ce8c9c7dfc865d4 /Mailman/interfaces/rule.py | |
| parent | 7923b90f0349f9e2dc891082e2e1c3bf23b4d79c (diff) | |
| download | mailman-13dea3a6736834e19ad569b5e3d70a79e096a55e.tar.gz mailman-13dea3a6736834e19ad569b5e3d70a79e096a55e.tar.zst mailman-13dea3a6736834e19ad569b5e3d70a79e096a55e.zip | |
Diffstat (limited to 'Mailman/interfaces/rule.py')
| -rw-r--r-- | Mailman/interfaces/rule.py | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/Mailman/interfaces/rule.py b/Mailman/interfaces/rule.py new file mode 100644 index 000000000..c0cf71697 --- /dev/null +++ b/Mailman/interfaces/rule.py @@ -0,0 +1,73 @@ +# Copyright (C) 2007 by the Free Software Foundation, Inc. +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, +# USA. + +"""Interface describing the basics of rules.""" + +from zope.interface import Interface, Attribute + + + +class DuplicateRuleError(Exception): + """A rule or rule name is added to a processor more than once.""" + + + +class IRule(Interface): + """A basic rule.""" + + name = Attribute('Rule name; must be unique.') + description = Attribute('A brief description of the rule.') + + def check(mlist, msg, msgdata): + """Run the rule. + + :param msg: The message object. + :param msgdata: The message metadata. + :return: A boolean specifying whether the rule was matched or not. + """ + + + +class IRuleProcessor(Interface): + """A rule processor.""" + + def process(mlist, msg, msgdata): + """Run all rules this processor knows about. + + :param mlist: The mailing list this message was posted to. + :param msg: The message object. + :param msgdata: The message metadata. + :return: A set of rule names that matched. + """ + + rules = Attribute('The set of all rules this processor knows about') + + def __getitem__(rule_name): + """Return the named rule. + + :param rule_name: The name of the rule. + :return: The IRule given by this name. + :raise: KeyError if no such rule is known by this processor. + """ + + def get(rule_name, default=None): + """Return the name rule. + + :param rule_name: The name of the rule. + :return: The IRule given by this name, or `default` if no such rule + is known by this processor. + """ |
