1
0
mirror of https://github.com/haiwen/seahub.git synced 2025-09-22 11:57:34 +00:00

Update account delete

This commit is contained in:
zhengxie
2015-07-23 10:45:25 +08:00
parent b75913c9a8
commit cadc6cb370
3 changed files with 18 additions and 7 deletions

View File

@@ -10,10 +10,12 @@ from seahub.auth.models import get_hexdigest
from seahub.auth import login
from registration import signals
#from registration.forms import RegistrationForm
from seaserv import ccnet_threaded_rpc, unset_repo_passwd, is_passwd_set
from seaserv import ccnet_threaded_rpc, unset_repo_passwd, is_passwd_set, \
seafile_api
from seahub.profile.models import Profile, DetailedProfile
from seahub.utils import is_valid_username, is_user_password_strong
from seahub.utils import is_valid_username, is_user_password_strong, \
clear_token
try:
from seahub.settings import CLOUD_MODE
except ImportError:
@@ -172,12 +174,24 @@ class User(object):
"""
When delete user, we should also delete group relationships.
"""
# TODO: what about repos and groups?
if self.source == "DB":
source = "DB"
else:
source = "LDAP"
owned_repos = []
orgs = ccnet_threaded_rpc.get_orgs_by_user(self.username)
if orgs:
for org in orgs:
owned_repos += seafile_api.get_org_owned_repo_list(org.org_id,
self.username)
else:
owned_repos += seafile_api.get_owned_repo_list(self.username)
for r in owned_repos:
seafile_api.remove_repo(r.id)
clear_token(self.username)
ccnet_threaded_rpc.remove_emailuser(source, self.username)
Profile.objects.delete_profile_by_user(self.username)

View File

@@ -15,8 +15,7 @@ from forms import DetailedProfileForm
from models import Profile, DetailedProfile
from utils import refresh_cache
from seahub.auth.decorators import login_required
from seahub.utils import is_org_context, clear_token, is_pro_version, \
is_valid_username
from seahub.utils import is_org_context, is_pro_version, is_valid_username
from seahub.base.accounts import User
from seahub.base.templatetags.seahub_tags import email2nickname
from seahub.contacts.models import Contact
@@ -159,7 +158,6 @@ def delete_user_account(request):
user = User.objects.get(email=username)
user.delete()
clear_token(username)
if is_org_context(request):
org_id = request.user.org.org_id

View File

@@ -738,7 +738,6 @@ def user_remove(request, email):
seafile_api.remove_repo(repo.id)
user.delete()
clear_token(user.email)
messages.success(request, _(u'Successfully deleted %s') % user.username)
except User.DoesNotExist:
messages.error(request, _(u'Failed to delete: the user does not exist'))