summaryrefslogtreecommitdiff
path: root/src/mailman/interfaces/address.py
diff options
context:
space:
mode:
authorBarry Warsaw2009-01-25 13:01:41 -0500
committerBarry Warsaw2009-01-25 13:01:41 -0500
commiteefd06f1b88b8ecbb23a9013cd223b72ca85c20d (patch)
tree72c947fe16fce0e07e996ee74020b26585d7e846 /src/mailman/interfaces/address.py
parent07871212f74498abd56bef3919bf3e029eb8b930 (diff)
downloadmailman-eefd06f1b88b8ecbb23a9013cd223b72ca85c20d.tar.gz
mailman-eefd06f1b88b8ecbb23a9013cd223b72ca85c20d.tar.zst
mailman-eefd06f1b88b8ecbb23a9013cd223b72ca85c20d.zip
Diffstat (limited to 'src/mailman/interfaces/address.py')
-rw-r--r--src/mailman/interfaces/address.py101
1 files changed, 101 insertions, 0 deletions
diff --git a/src/mailman/interfaces/address.py b/src/mailman/interfaces/address.py
new file mode 100644
index 000000000..968ded3ee
--- /dev/null
+++ b/src/mailman/interfaces/address.py
@@ -0,0 +1,101 @@
+# Copyright (C) 2007-2009 by the Free Software Foundation, Inc.
+#
+# This file is part of GNU Mailman.
+#
+# GNU Mailman 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 3 of the License, or (at your option)
+# any later version.
+#
+# GNU Mailman 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
+# GNU Mailman. If not, see <http://www.gnu.org/licenses/>.
+
+"""Interface for email address related information."""
+
+from __future__ import absolute_import, unicode_literals
+
+__metaclass__ = type
+__all__ = [
+ 'AddressAlreadyLinkedError',
+ 'AddressError',
+ 'AddressNotLinkedError',
+ 'ExistingAddressError',
+ 'IAddress',
+ ]
+
+
+from zope.interface import Interface, Attribute
+from mailman.interfaces.errors import MailmanError
+
+
+
+class AddressError(MailmanError):
+ """A general address-related error occurred."""
+
+
+class ExistingAddressError(AddressError):
+ """The given email address already exists."""
+
+
+class AddressAlreadyLinkedError(AddressError):
+ """The address is already linked to a user."""
+
+
+class AddressNotLinkedError(AddressError):
+ """The address is not linked to the user."""
+
+
+
+
+class IAddress(Interface):
+ """Email address related information."""
+
+ address = Attribute(
+ """Read-only text email address.""")
+
+ original_address = Attribute(
+ """Read-only original case-preserved address.
+
+ For almost all intents and purposes, addresses in Mailman are case
+ insensitive, however because RFC 2821 allows for case sensitive local
+ parts, Mailman preserves the case of the original address when
+ emailing the user.
+
+ `original_address` will be the same as address if the original address
+ was all lower case. Otherwise `original_address` will be the case
+ preserved address; `address` will always be lower case.
+ """)
+
+ real_name = Attribute(
+ """Optional real name associated with the email address.""")
+
+ registered_on = Attribute(
+ """The date and time at which this email address was registered.
+
+ Registeration is really the date at which this address became known to
+ us. It may have been explicitly registered by a user, or it may have
+ been implicitly registered, e.g. by showing up in a non-member
+ posting.""")
+
+ verified_on = Attribute(
+ """The date and time at which this email address was validated, or
+ None if the email address has not yet been validated. The specific
+ method of validation is not defined here.""")
+
+ def subscribe(mailing_list, role):
+ """Subscribe the address to the given mailing list with the given role.
+
+ :param mailing_list: The IMailingList being subscribed to.
+ :param role: A MemberRole enum value.
+ :return: The IMember representing this subscription.
+ :raises AlreadySubscribedError: If the address is already subscribed
+ to the mailing list with the given role.
+ """
+
+ preferences = Attribute(
+ """This address's preferences.""")