Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 10 additions & 9 deletions tom_targets/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@
from django.core.management import call_command
from django.core.paginator import Paginator
from django.db import transaction
from django.db.models import Q
from django_filters.views import FilterView
from django.http import HttpResponse
from django.http import HttpResponseRedirect, QueryDict, StreamingHttpResponse, HttpResponseBadRequest
Expand Down Expand Up @@ -108,17 +107,19 @@ class TargetNameSearchView(RedirectView):
"""

def get(self, request, *args, **kwargs):
target_name = self.kwargs['name']
# Tests fail without distinct but it works in practice, it is unclear as to why
target_name = self.kwargs['name'].strip()
# The Django query planner shows different results between in practice and unit tests
# django-guardian related querying is present in the test planner, but not in practice
targets = targets_for_user(request.user, Target.objects.all(), 'view_target').filter(
Q(name__icontains=target_name) | Q(aliases__name__icontains=target_name)
).distinct()
if targets.count() == 1:
return HttpResponseRedirect(reverse('targets:detail', kwargs={'pk': targets.first().id}))
else:
all_targets = targets_for_user(request.user, Target.objects.all(), 'view_target')
targets_main = all_targets.filter(name__icontains=target_name)
targets_alias = all_targets.filter(aliases__name__icontains=target_name)
targets = targets_main.union(targets_alias)
try:
target = targets.get()
except (Target.DoesNotExist, Target.MultipleObjectsReturned):
return HttpResponseRedirect(reverse('targets:list') + f'?name={target_name}')
else:
return HttpResponseRedirect(reverse('targets:detail', kwargs={'pk': target.id}))


class TargetCreateView(LoginRequiredMixin, CreateView):
Expand Down