summaryrefslogtreecommitdiff
path: root/src/mailman/interfaces/registrar.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/mailman/interfaces/registrar.py')
-rw-r--r--src/mailman/interfaces/registrar.py83
1 files changed, 83 insertions, 0 deletions
diff --git a/src/mailman/interfaces/registrar.py b/src/mailman/interfaces/registrar.py
new file mode 100644
index 000000000..d90966e2d
--- /dev/null
+++ b/src/mailman/interfaces/registrar.py
@@ -0,0 +1,83 @@
+# 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 describing a user registration service.
+
+This is a higher level interface to user registration, address confirmation,
+etc. than the IUserManager. The latter does no validation, syntax checking,
+or confirmation, while this interface does.
+"""
+
+from __future__ import absolute_import, unicode_literals
+
+__metaclass__ = type
+__all__ = [
+ 'IRegistrar',
+ ]
+
+
+from zope.interface import Interface
+
+
+
+class IRegistrar(Interface):
+ """Interface for registering and verifying addresses and users.
+
+ This is a higher level interface to user registration, address
+ confirmation, etc. than the IUserManager. The latter does no validation,
+ syntax checking, or confirmation, while this interface does.
+ """
+
+ def register(address, real_name=None, mlist=None):
+ """Register the email address, requesting verification.
+
+ No IAddress or IUser is created during this step, but after successful
+ confirmation, it is guaranteed that an IAddress with a linked IUser
+ will exist. When a verified IAddress matching address already exists,
+ this method will do nothing, except link a new IUser to the IAddress
+ if one is not yet associated with the address.
+
+ In all cases, the email address is sanity checked for validity first.
+
+ :param address: The textual email address to register.
+ :param real_name: The optional real name of the user.
+ :return: The confirmation token string.
+ :raises InvalidEmailAddress: if the address is not allowed.
+ """
+
+ def confirm(token):
+ """Confirm the pending registration matched to the given `token`.
+
+ Confirmation ensures that the IAddress exists and is linked to an
+ IUser, with the latter being created and linked if necessary.
+
+ :param token: A token matching a pending event with a type of
+ 'registration'.
+ :return: Boolean indicating whether the confirmation succeeded or
+ not. It may fail if the token is no longer in the database, or if
+ the token did not match a registration event.
+ """
+
+ def discard(token):
+ """Discard the pending registration matched to the given `token`.
+
+ The event record is discarded and the IAddress is not verified. No
+ IUser is created.
+
+ :param token: A token matching a pending event with a type of
+ 'registration'.
+ """