summaryrefslogtreecommitdiff
path: root/mailman/interfaces/command.py
diff options
context:
space:
mode:
authorBarry Warsaw2008-04-26 01:39:14 -0400
committerBarry Warsaw2008-04-26 01:39:14 -0400
commitfbd382c07dc621bda9b724675b1df75746d07179 (patch)
tree28f18a653afc000b4b7595e7793e2b76c833ab9e /mailman/interfaces/command.py
parent574405b3aa5e3afa475c9e2904a27be40c0bbc83 (diff)
parent2547651d03cfdf23632ded85c05bb02161688d45 (diff)
downloadmailman-fbd382c07dc621bda9b724675b1df75746d07179.tar.gz
mailman-fbd382c07dc621bda9b724675b1df75746d07179.tar.zst
mailman-fbd382c07dc621bda9b724675b1df75746d07179.zip
Diffstat (limited to 'mailman/interfaces/command.py')
-rw-r--r--mailman/interfaces/command.py50
1 files changed, 50 insertions, 0 deletions
diff --git a/mailman/interfaces/command.py b/mailman/interfaces/command.py
new file mode 100644
index 000000000..553dcb0e3
--- /dev/null
+++ b/mailman/interfaces/command.py
@@ -0,0 +1,50 @@
+# Copyright (C) 2008 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.
+
+"""Interfaces defining email commands."""
+
+from zope.interface import Interface, Attribute
+
+
+
+class IEmailResults(Interface):
+ """The email command results object."""
+
+ output = Attribute('An output file object for printing results to.')
+
+
+
+class IEmailCommand(Interface):
+ """An email command."""
+
+ name = Attribute('Command name as seen in a -request email.')
+
+ argument_description = Attribute('Description of command arguments.')
+
+ description = Attribute('Command help.')
+
+ def process(mlist, msg, msgdata, arguments, results):
+ """Process the email command.
+
+ :param mlist: The mailing list target of the command.
+ :param msg: The original message object.
+ :param msgdata: The message metadata.
+ :param arguments: The command arguments tuple.
+ :param results: An IEmailResults object for these commands.
+ :return: True if further processing should be taken of the email
+ commands in this message.
+ """