mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-22 20:08:19 +00:00
Update account delete
This commit is contained in:
@@ -10,10 +10,12 @@ from seahub.auth.models import get_hexdigest
|
|||||||
from seahub.auth import login
|
from seahub.auth import login
|
||||||
from registration import signals
|
from registration import signals
|
||||||
#from registration.forms import RegistrationForm
|
#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.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:
|
try:
|
||||||
from seahub.settings import CLOUD_MODE
|
from seahub.settings import CLOUD_MODE
|
||||||
except ImportError:
|
except ImportError:
|
||||||
@@ -172,12 +174,24 @@ class User(object):
|
|||||||
"""
|
"""
|
||||||
When delete user, we should also delete group relationships.
|
When delete user, we should also delete group relationships.
|
||||||
"""
|
"""
|
||||||
# TODO: what about repos and groups?
|
|
||||||
if self.source == "DB":
|
if self.source == "DB":
|
||||||
source = "DB"
|
source = "DB"
|
||||||
else:
|
else:
|
||||||
source = "LDAP"
|
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)
|
ccnet_threaded_rpc.remove_emailuser(source, self.username)
|
||||||
Profile.objects.delete_profile_by_user(self.username)
|
Profile.objects.delete_profile_by_user(self.username)
|
||||||
|
|
||||||
|
@@ -15,8 +15,7 @@ from forms import DetailedProfileForm
|
|||||||
from models import Profile, DetailedProfile
|
from models import Profile, DetailedProfile
|
||||||
from utils import refresh_cache
|
from utils import refresh_cache
|
||||||
from seahub.auth.decorators import login_required
|
from seahub.auth.decorators import login_required
|
||||||
from seahub.utils import is_org_context, clear_token, is_pro_version, \
|
from seahub.utils import is_org_context, is_pro_version, is_valid_username
|
||||||
is_valid_username
|
|
||||||
from seahub.base.accounts import User
|
from seahub.base.accounts import User
|
||||||
from seahub.base.templatetags.seahub_tags import email2nickname
|
from seahub.base.templatetags.seahub_tags import email2nickname
|
||||||
from seahub.contacts.models import Contact
|
from seahub.contacts.models import Contact
|
||||||
@@ -159,7 +158,6 @@ def delete_user_account(request):
|
|||||||
|
|
||||||
user = User.objects.get(email=username)
|
user = User.objects.get(email=username)
|
||||||
user.delete()
|
user.delete()
|
||||||
clear_token(username)
|
|
||||||
|
|
||||||
if is_org_context(request):
|
if is_org_context(request):
|
||||||
org_id = request.user.org.org_id
|
org_id = request.user.org.org_id
|
||||||
|
@@ -738,7 +738,6 @@ def user_remove(request, email):
|
|||||||
seafile_api.remove_repo(repo.id)
|
seafile_api.remove_repo(repo.id)
|
||||||
|
|
||||||
user.delete()
|
user.delete()
|
||||||
clear_token(user.email)
|
|
||||||
messages.success(request, _(u'Successfully deleted %s') % user.username)
|
messages.success(request, _(u'Successfully deleted %s') % user.username)
|
||||||
except User.DoesNotExist:
|
except User.DoesNotExist:
|
||||||
messages.error(request, _(u'Failed to delete: the user does not exist'))
|
messages.error(request, _(u'Failed to delete: the user does not exist'))
|
||||||
|
Reference in New Issue
Block a user