summaryrefslogtreecommitdiff
path: root/Mailman/database/usermanager.py
diff options
context:
space:
mode:
authorBarry Warsaw2007-06-10 19:14:10 -0400
committerBarry Warsaw2007-06-10 19:14:10 -0400
commit2551bc7cac27c268bbfb05b735e223cad02d5c27 (patch)
tree2384ff5290ad9dde90d47b30a2f134905b913253 /Mailman/database/usermanager.py
parent5bc4941f0b749830d5e4feb57be5f172e77e0631 (diff)
downloadmailman-2551bc7cac27c268bbfb05b735e223cad02d5c27.tar.gz
mailman-2551bc7cac27c268bbfb05b735e223cad02d5c27.tar.zst
mailman-2551bc7cac27c268bbfb05b735e223cad02d5c27.zip
Diffstat (limited to 'Mailman/database/usermanager.py')
-rw-r--r--Mailman/database/usermanager.py24
1 files changed, 24 insertions, 0 deletions
diff --git a/Mailman/database/usermanager.py b/Mailman/database/usermanager.py
index 95e4949ea..2f12188aa 100644
--- a/Mailman/database/usermanager.py
+++ b/Mailman/database/usermanager.py
@@ -53,3 +53,27 @@ class UserManager(object):
def get_user(self, address):
found = Address.get_by(address=address)
return found and found.user
+
+ def create_address(self, address, real_name=None):
+ found = Address.get_by(address=address)
+ if found:
+ raise Errors.ExistingAddressError(address)
+ if real_name is None:
+ real_name = ''
+ address = Address(address=address, real_name=real_name)
+ return address
+
+ def delete_address(self, address):
+ # If there's a user controlling this address, it has to first be
+ # unlinked before the address can be deleted.
+ if address.user:
+ address.user.unlink(address)
+ address.delete()
+
+ def get_address(self, address):
+ return Address.get_by(address=address)
+
+ @property
+ def addresses(self):
+ for address in Address.select():
+ yield address