Example #1
0
def delete(request, user_pk=None):
    '''
    Delete a user account and all his data, requires\
    password confirmation first

    If no user_pk is present, the user visiting the URL will\
    be deleted, otherwise a gym administrator is deleting a different user
    '''

    if user_pk:
        user = get_object_or_404(User, pk=user_pk)
        form_action = reverse('core:user:delete', kwargs={'user_pk': user_pk})

        # Forbidden if the user has not enough rights, doesn't belong to the
        # gym or is an admin as well. General admins can delete all users.
        if not request.user.has_perm('gym.manage_gyms') \
                and (not request.user.has_perm('gym.manage_gym')
                     or request.user.userprofile.gym_id !=
                     user.userprofile.gym_id
                     or user.has_perm('gym.manage_gym')
                     or user.has_perm('gym.gym_trainer')
                     or user.has_perm('gym.manage_gyms')):
            return HttpResponseForbidden()
    else:
        user = request.user
        form_action = reverse('core:user:delete')

    form = PasswordConfirmationForm(user=request.user)

    if request.method == 'POST':
        form = PasswordConfirmationForm(data=request.POST, user=request.user)
        if form.is_valid():

            user.delete()
            messages.success(
                request, _('Account "{0}" was successfully deleted').format(
                    user.username))

            if not user_pk:
                django_logout(request)
                return HttpResponseRedirect(reverse('software:features'))
            else:
                gym_pk = request.user.userprofile.gym_id
                return HttpResponseRedirect(reverse('gym:gym:user-list',
                                                    kwargs={'pk': gym_pk}))
    context = {'form': form,
               'user_delete': user,
               'form_action': form_action}

    return render(request, 'user/delete_account.html', context)
Example #2
0
File: user.py Project: itsdtr/wger
def delete(request):
    '''
    Delete the user account and all his data. Requires password confirmation first
    '''
    form = PasswordConfirmationForm(user=request.user)
    if request.method == 'POST':
        form = PasswordConfirmationForm(data=request.POST, user=request.user)
        if form.is_valid():
            request.user.delete()
            django_logout(request)
            messages.success(request, _('Your account was successfully deleted'))
            return HttpResponseRedirect(reverse('software:features'))
    context = {'form': form}

    return render(request, 'user/delete_account.html', context)
Example #3
0
def delete(request, user_pk=None):
    '''
    Delete a user account and all his data, requires password confirmation first

    If no user_pk is present, the user visiting the URL will be deleted, otherwise
    a gym administrator is deleting a different user
    '''

    if user_pk:
        user = get_object_or_404(User, pk=user_pk)
        form_action = reverse('core:user:delete', kwargs={'user_pk': user_pk})

        # Forbidden if the user has not enough rights, doesn't belong to the
        # gym or is an admin as well. General admins can delete all users.
        if not request.user.has_perm('gym.manage_gyms') \
                and (not request.user.has_perm('gym.manage_gym')
                     or request.user.userprofile.gym_id != user.userprofile.gym_id
                     or user.has_perm('gym.manage_gym')
                     or user.has_perm('gym.gym_trainer')
                     or user.has_perm('gym.manage_gyms')):
            return HttpResponseForbidden()
    else:
        user = request.user
        form_action = reverse('core:user:delete')

    form = PasswordConfirmationForm(user=request.user)

    if request.method == 'POST':
        form = PasswordConfirmationForm(data=request.POST, user=request.user)
        if form.is_valid():

            user.delete()
            messages.success(request,
                             _('Account "{0}" was successfully deleted').format(user.username))

            if not user_pk:
                django_logout(request)
                return HttpResponseRedirect(reverse('software:features'))
            else:
                gym_pk = request.user.userprofile.gym_id
                return HttpResponseRedirect(reverse('gym:gym:user-list', kwargs={'pk': gym_pk}))
    context = {'form': form,
               'user_delete': user,
               'form_action': form_action}

    return render(request, 'user/delete_account.html', context)
Example #4
0
def delete(request, user_pk=None):
    """
    Delete a user account and all his data, requires password confirmation first

    If no user_pk is present, the user visiting the URL will be deleted, otherwise
    a gym administrator is deleting a different user
    """

    if user_pk:
        user = get_object_or_404(User, pk=user_pk)
        form_action = reverse("core:user:delete", kwargs={"user_pk": user_pk})

        # Forbidden if the user has not enough rights, doesn't belong to the
        # gym or is an admin as well
        if (
            not request.user.has_perm("gym.manage_gym")
            or request.user.userprofile.gym_id != user.userprofile.gym_id
            or user.has_perm("gym.manage_gym")
            or user.has_perm("gym.gym_trainer")
            or user.has_perm("gym.manage_gyms")
        ):
            return HttpResponseForbidden()
    else:
        user = request.user
        form_action = reverse("core:user:delete")

    form = PasswordConfirmationForm(user=request.user)

    if request.method == "POST":
        form = PasswordConfirmationForm(data=request.POST, user=request.user)
        if form.is_valid():

            user.delete()
            messages.success(request, _('Account "{0}" was successfully deleted').format(user.username))

            if not user_pk:
                django_logout(request)
                return HttpResponseRedirect(reverse("software:features"))
            else:
                gym_pk = request.user.userprofile.gym_id
                return HttpResponseRedirect(reverse("gym:gym:user-list", kwargs={"pk": gym_pk}))
    context = {"form": form, "user_delete": user, "form_action": form_action}

    return render(request, "user/delete_account.html", context)