summaryrefslogtreecommitdiff
path: root/Mailman/interfaces/archiver.py
diff options
context:
space:
mode:
authorBarry Warsaw2008-01-13 16:18:19 -0500
committerBarry Warsaw2008-01-13 16:18:19 -0500
commitd0867a4e0b4568f89168f1138784004e4e46ba55 (patch)
tree4e182668a895beabcb35a7659c37ac2fb04ca5bf /Mailman/interfaces/archiver.py
parent90355248db6f6619148abb2a9137c3a564345729 (diff)
parent0d0c030d50e4dbd11f33ccddb96cf13fd3470cd2 (diff)
downloadmailman-d0867a4e0b4568f89168f1138784004e4e46ba55.tar.gz
mailman-d0867a4e0b4568f89168f1138784004e4e46ba55.tar.zst
mailman-d0867a4e0b4568f89168f1138784004e4e46ba55.zip
Merge from rfc5064 branch.
Diffstat (limited to 'Mailman/interfaces/archiver.py')
-rw-r--r--Mailman/interfaces/archiver.py58
1 files changed, 58 insertions, 0 deletions
diff --git a/Mailman/interfaces/archiver.py b/Mailman/interfaces/archiver.py
new file mode 100644
index 000000000..3b96c5c53
--- /dev/null
+++ b/Mailman/interfaces/archiver.py
@@ -0,0 +1,58 @@
+# 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.
+
+"""Interface for archiving schemes."""
+
+from zope.interface import Interface, Attribute
+
+
+
+class IArchiver(Interface):
+ """An interface to the archiver."""
+
+ def get_list_url(mlist):
+ """Return the url to the top of the list's archive.
+
+ :param mlist: The IMailingList object.
+ :returns: The url string.
+ """
+
+ def get_message_url(mlist, message):
+ """Return the url to the message in the archive.
+
+ This url points directly to the message in the archive. This method
+ only calculates the url, it does not actually archive the message.
+
+ :param mlist: The IMailingList object.
+ :param message: The message object.
+ :returns: The url string or None if the message's archive url cannot
+ be calculated.
+ """
+
+ def archive_message(mlist, message):
+ """Send the message to the archiver.
+
+ This uses `get_message_url()` to calculate and return the url to the
+ message in the archives.
+
+ :param mlist: The IMailingList object.
+ :param message: The message object.
+ :returns: The url string or None if the message's archive url cannot
+ be calculated.
+ """
+
+ # XXX How to handle attachments?