2017-01-15 18:01:18 -05:00
|
|
|
# Re2o est un logiciel d'administration développé initiallement au rezometz. Il
|
|
|
|
# se veut agnostique au réseau considéré, de manière à être installable en
|
|
|
|
# quelques clics.
|
|
|
|
#
|
|
|
|
# Copyright © 2017 Gabriel Détraz
|
|
|
|
# Copyright © 2017 Goulven Kermarec
|
|
|
|
# Copyright © 2017 Augustin Lemesle
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License along
|
|
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
|
2017-11-02 19:58:20 +00:00
|
|
|
"""The views for the search app, responsible for finding the matches
|
|
|
|
Augustin lemesle, Gabriel Détraz, Goulven Kermarec, Maël Kervella
|
|
|
|
Gplv2"""
|
|
|
|
|
2017-09-11 01:29:24 +02:00
|
|
|
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2016-07-03 00:27:22 +02:00
|
|
|
from django.shortcuts import render
|
2016-07-08 12:35:53 +02:00
|
|
|
from django.contrib.auth.decorators import login_required
|
2016-07-03 00:27:22 +02:00
|
|
|
|
|
|
|
from django.db.models import Q
|
2016-07-04 23:56:51 +02:00
|
|
|
from users.models import User, Ban, Whitelist
|
2017-11-02 19:58:20 +00:00
|
|
|
from machines.models import Machine
|
2017-11-02 16:06:44 +00:00
|
|
|
from topologie.models import Port, Switch, Room
|
2016-07-03 00:27:22 +02:00
|
|
|
from cotisations.models import Facture
|
2017-06-26 01:29:34 +02:00
|
|
|
from preferences.models import GeneralOption
|
2017-11-01 23:19:41 +00:00
|
|
|
from search.forms import (
|
|
|
|
SearchForm,
|
|
|
|
SearchFormPlus,
|
|
|
|
CHOICES_USER,
|
|
|
|
CHOICES_AFF,
|
|
|
|
initial_choices
|
|
|
|
)
|
2017-11-02 00:25:24 +00:00
|
|
|
from re2o.utils import SortTable
|
2016-10-12 22:58:41 +02:00
|
|
|
|
2017-11-02 19:26:20 +00:00
|
|
|
|
|
|
|
def is_int(variable):
|
|
|
|
""" Check if the variable can be casted to an integer """
|
|
|
|
|
|
|
|
try:
|
|
|
|
int(variable)
|
|
|
|
except ValueError:
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2017-11-01 23:19:41 +00:00
|
|
|
def get_results(query, request, filters={}):
|
2017-11-02 19:26:20 +00:00
|
|
|
""" Construct the correct filters to match differents fields of some models
|
|
|
|
with the given query according to the given filters.
|
|
|
|
The match field are either CharField or IntegerField that will be displayed
|
|
|
|
on the results page (else, one might not see why a result has matched the
|
|
|
|
query). IntegerField are matched against the query only if it can be casted
|
|
|
|
to an int."""
|
|
|
|
|
2017-11-01 23:19:41 +00:00
|
|
|
start = filters.get('s', None)
|
|
|
|
end = filters.get('e', None)
|
|
|
|
user_state = filters.get('u', initial_choices(CHOICES_USER))
|
|
|
|
aff = filters.get('a', initial_choices(CHOICES_AFF))
|
|
|
|
|
2017-11-02 19:58:20 +00:00
|
|
|
options, _ = GeneralOption.objects.get_or_create()
|
2017-11-01 23:19:41 +00:00
|
|
|
max_result = options.search_display_page
|
|
|
|
|
|
|
|
results = {
|
|
|
|
'users_list': User.objects.none(),
|
2017-11-02 19:58:20 +00:00
|
|
|
'machines_list': Machine.objects.none(),
|
|
|
|
'factures_list': Facture.objects.none(),
|
|
|
|
'bans_list': Ban.objects.none(),
|
2017-11-02 15:09:24 +00:00
|
|
|
'whitelists_list': Whitelist.objects.none(),
|
2017-11-02 16:06:44 +00:00
|
|
|
'rooms_list': Room.objects.none(),
|
2017-11-02 15:09:24 +00:00
|
|
|
'switch_ports_list': Port.objects.none(),
|
|
|
|
'switches_list': Switch.objects.none()
|
2017-11-01 23:19:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Users
|
|
|
|
if '0' in aff:
|
2017-11-02 20:06:19 +00:00
|
|
|
filter_user_list = (
|
|
|
|
Q(
|
|
|
|
surname__icontains=query
|
|
|
|
) | Q(
|
|
|
|
adherent__name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
pseudo__icontains=query
|
|
|
|
) | Q(
|
|
|
|
club__room__name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
adherent__room__name__icontains=query
|
|
|
|
)
|
|
|
|
) & Q(state__in=user_state)
|
2017-11-01 23:19:41 +00:00
|
|
|
if not request.user.has_perms(('cableur',)):
|
|
|
|
filter_user_list &= Q(id=request.user.id)
|
2017-11-02 00:25:24 +00:00
|
|
|
results['users_list'] = User.objects.filter(filter_user_list)
|
|
|
|
results['users_list'] = SortTable.sort(
|
|
|
|
results['users_list'],
|
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.USERS_INDEX
|
|
|
|
)
|
2017-11-01 23:19:41 +00:00
|
|
|
|
|
|
|
# Machines
|
|
|
|
if '1' in aff:
|
|
|
|
filter_machine_list = Q(
|
2017-11-02 19:26:20 +00:00
|
|
|
name__icontains=query
|
2017-11-02 20:06:19 +00:00
|
|
|
) | (
|
|
|
|
Q(
|
|
|
|
user__pseudo__icontains=query
|
|
|
|
) & Q(
|
|
|
|
user__state__in=user_state
|
|
|
|
)
|
2017-11-01 23:19:41 +00:00
|
|
|
) | Q(
|
2017-11-02 19:26:20 +00:00
|
|
|
interface__domain__name__icontains=query
|
2017-11-01 23:19:41 +00:00
|
|
|
) | Q(
|
2017-11-02 19:26:20 +00:00
|
|
|
interface__domain__related_domain__name__icontains=query
|
2017-11-01 23:19:41 +00:00
|
|
|
) | Q(
|
2017-11-02 19:26:20 +00:00
|
|
|
interface__mac_address__icontains=query
|
2017-11-01 23:19:41 +00:00
|
|
|
) | Q(
|
2017-11-02 19:26:20 +00:00
|
|
|
interface__ipv4__ipv4__icontains=query
|
2017-11-01 23:19:41 +00:00
|
|
|
)
|
|
|
|
if not request.user.has_perms(('cableur',)):
|
2017-11-02 13:43:41 +00:00
|
|
|
filter_machine_list &= Q(user__id=request.user.id)
|
2017-11-02 00:25:24 +00:00
|
|
|
results['machines_list'] = Machine.objects.filter(filter_machine_list)
|
|
|
|
results['machines_list'] = SortTable.sort(
|
|
|
|
results['machines_list'],
|
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.MACHINES_INDEX
|
|
|
|
)
|
2017-11-01 23:19:41 +00:00
|
|
|
|
|
|
|
# Factures
|
|
|
|
if '2' in aff:
|
2017-11-02 19:26:20 +00:00
|
|
|
filter_facture_list = Q(
|
|
|
|
user__pseudo__icontains=query
|
2017-11-02 20:06:19 +00:00
|
|
|
) & Q(
|
|
|
|
user__state__in=user_state
|
2017-11-02 19:26:20 +00:00
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
if start is not None:
|
2017-11-02 00:25:24 +00:00
|
|
|
filter_facture_list &= Q(date__gte=start)
|
2017-11-02 19:58:20 +00:00
|
|
|
if end is not None:
|
2017-11-02 00:25:24 +00:00
|
|
|
filter_facture_list &= Q(date__lte=end)
|
2017-11-02 15:09:24 +00:00
|
|
|
results['factures_list'] = Facture.objects.filter(filter_facture_list)
|
|
|
|
results['factures_list'] = SortTable.sort(
|
|
|
|
results['factures_list'],
|
2017-11-02 00:25:24 +00:00
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.COTISATIONS_INDEX
|
|
|
|
)
|
2017-11-01 23:19:41 +00:00
|
|
|
|
|
|
|
# Bans
|
|
|
|
if '3' in aff:
|
2017-11-02 20:06:19 +00:00
|
|
|
date_filter = (
|
|
|
|
Q(
|
|
|
|
user__pseudo__icontains=query
|
|
|
|
) & Q(
|
|
|
|
user__state__in=user_state
|
|
|
|
)
|
2017-11-02 19:26:20 +00:00
|
|
|
) | Q(
|
|
|
|
raison__icontains=query
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
if start is not None:
|
2017-11-01 23:19:41 +00:00
|
|
|
date_filter &= (
|
|
|
|
Q(date_start__gte=start) & Q(date_end__gte=start)
|
|
|
|
) | (
|
|
|
|
Q(date_start__lte=start) & Q(date_end__gte=start)
|
|
|
|
) | (
|
|
|
|
Q(date_start__gte=start) & Q(date_end__lte=start)
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
if end is not None:
|
2017-11-01 23:19:41 +00:00
|
|
|
date_filter &= (
|
|
|
|
Q(date_start__lte=end) & Q(date_end__lte=end)
|
|
|
|
) | (
|
|
|
|
Q(date_start__lte=end) & Q(date_end__gte=end)
|
|
|
|
) | (
|
|
|
|
Q(date_start__gte=end) & Q(date_end__lte=end)
|
|
|
|
)
|
2017-11-02 16:54:06 +00:00
|
|
|
results['bans_list'] = Ban.objects.filter(date_filter)
|
2017-11-02 15:09:24 +00:00
|
|
|
results['bans_list'] = SortTable.sort(
|
|
|
|
results['bans_list'],
|
2017-11-02 00:25:24 +00:00
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.USERS_INDEX_BAN
|
|
|
|
)
|
2017-11-01 23:19:41 +00:00
|
|
|
|
|
|
|
# Whitelists
|
|
|
|
if '4' in aff:
|
2017-11-02 20:06:19 +00:00
|
|
|
date_filter = (
|
|
|
|
Q(
|
|
|
|
user__pseudo__icontains=query
|
|
|
|
) & Q(
|
|
|
|
user__state__in=user_state
|
|
|
|
)
|
2017-11-02 19:26:20 +00:00
|
|
|
) | Q(
|
|
|
|
raison__icontains=query
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
if start is not None:
|
2017-11-01 23:19:41 +00:00
|
|
|
date_filter &= (
|
|
|
|
Q(date_start__gte=start) & Q(date_end__gte=start)
|
|
|
|
) | (
|
|
|
|
Q(date_start__lte=start) & Q(date_end__gte=start)
|
|
|
|
) | (
|
|
|
|
Q(date_start__gte=start) & Q(date_end__lte=start)
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
if end is not None:
|
2017-11-01 23:19:41 +00:00
|
|
|
date_filter &= (
|
|
|
|
Q(date_start__lte=end) & Q(date_end__lte=end)
|
|
|
|
) | (
|
|
|
|
Q(date_start__lte=end) & Q(date_end__gte=end)
|
|
|
|
) | (
|
|
|
|
Q(date_start__gte=end) & Q(date_end__lte=end)
|
|
|
|
)
|
2017-11-02 16:54:06 +00:00
|
|
|
results['whitelists_list'] = Whitelist.objects.filter(date_filter)
|
2017-11-02 15:09:24 +00:00
|
|
|
results['whitelists_list'] = SortTable.sort(
|
|
|
|
results['whitelists_list'],
|
2017-11-02 00:25:24 +00:00
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.USERS_INDEX_WHITE
|
|
|
|
)
|
2017-11-01 23:19:41 +00:00
|
|
|
|
2017-11-02 16:06:44 +00:00
|
|
|
# Rooms
|
2017-11-01 23:19:41 +00:00
|
|
|
if '5' in aff and request.user.has_perms(('cableur',)):
|
2017-11-02 16:54:06 +00:00
|
|
|
filter_rooms_list = Q(
|
|
|
|
details__icontains=query
|
|
|
|
) | Q(
|
|
|
|
name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
port__details=query
|
|
|
|
)
|
2017-11-02 16:06:44 +00:00
|
|
|
results['rooms_list'] = Room.objects.filter(filter_rooms_list)
|
|
|
|
results['rooms_list'] = SortTable.sort(
|
|
|
|
results['rooms_list'],
|
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.TOPOLOGIE_INDEX_ROOM
|
|
|
|
)
|
|
|
|
|
|
|
|
# Switch ports
|
|
|
|
if '6' in aff and request.user.has_perms(('cableur',)):
|
2017-11-02 19:58:20 +00:00
|
|
|
filter_ports_list = Q(
|
2017-11-02 16:54:06 +00:00
|
|
|
room__name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
machine_interface__domain__name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
related__switch__switch_interface__domain__name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
radius__icontains=query
|
|
|
|
) | Q(
|
|
|
|
vlan_force__name__icontains=query
|
2017-11-02 19:26:20 +00:00
|
|
|
) | Q(
|
|
|
|
details__icontains=query
|
2017-11-02 16:54:06 +00:00
|
|
|
)
|
2017-11-02 19:26:20 +00:00
|
|
|
if is_int(query):
|
2017-11-02 19:58:20 +00:00
|
|
|
filter_ports_list |= Q(
|
2017-11-02 19:26:20 +00:00
|
|
|
port=query
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
results['switch_ports_list'] = Port.objects.filter(filter_ports_list)
|
2017-11-02 15:09:24 +00:00
|
|
|
results['switch_ports_list'] = SortTable.sort(
|
|
|
|
results['switch_ports_list'],
|
2017-11-02 00:25:24 +00:00
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.TOPOLOGIE_INDEX_PORT
|
|
|
|
)
|
2016-11-01 15:29:12 +01:00
|
|
|
|
2017-11-01 23:19:41 +00:00
|
|
|
# Switches
|
2017-11-02 16:06:44 +00:00
|
|
|
if '7' in aff and request.user.has_perms(('cableur',)):
|
2017-11-02 19:58:20 +00:00
|
|
|
filter_switches_list = Q(
|
2017-11-02 16:54:06 +00:00
|
|
|
switch_interface__domain__name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
switch_interface__ipv4__ipv4__icontains=query
|
|
|
|
) | Q(
|
|
|
|
location__icontains=query
|
|
|
|
) | Q(
|
|
|
|
stack__name__icontains=query
|
|
|
|
) | Q(
|
|
|
|
model__reference__icontains=query
|
|
|
|
) | Q(
|
|
|
|
model__constructor__name__icontains=query
|
2017-11-02 19:26:20 +00:00
|
|
|
) | Q(
|
|
|
|
details__icontains=query
|
2017-11-02 16:54:06 +00:00
|
|
|
)
|
2017-11-02 19:26:20 +00:00
|
|
|
if is_int(query):
|
2017-11-02 19:58:20 +00:00
|
|
|
filter_switches_list |= Q(
|
2017-11-02 19:26:20 +00:00
|
|
|
number=query
|
|
|
|
) | Q(
|
|
|
|
stack_member_id=query
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
results['switches_list'] = Switch.objects.filter(filter_switches_list)
|
2017-11-02 15:09:24 +00:00
|
|
|
results['switches_list'] = SortTable.sort(
|
|
|
|
results['switches_list'],
|
2017-11-02 00:25:24 +00:00
|
|
|
request.GET.get('col'),
|
|
|
|
request.GET.get('order'),
|
|
|
|
SortTable.TOPOLOGIE_INDEX
|
|
|
|
)
|
|
|
|
|
2017-11-02 19:58:20 +00:00
|
|
|
for name, val in results.items():
|
|
|
|
results[name] = val.distinct()[:max_result]
|
2016-11-01 15:29:12 +01:00
|
|
|
|
2017-11-01 23:19:41 +00:00
|
|
|
results.update({'max_result': max_result})
|
2017-11-02 00:35:22 +00:00
|
|
|
results.update({'search_term': query})
|
2016-11-01 15:29:12 +01:00
|
|
|
|
2017-11-01 23:19:41 +00:00
|
|
|
return results
|
2016-07-04 23:56:51 +02:00
|
|
|
|
2017-11-02 19:58:20 +00:00
|
|
|
|
2016-07-08 12:35:53 +02:00
|
|
|
@login_required
|
2016-07-04 23:56:51 +02:00
|
|
|
def search(request):
|
2017-11-02 19:58:20 +00:00
|
|
|
""" La page de recherche standard """
|
2017-11-01 16:01:10 +00:00
|
|
|
search_form = SearchForm(request.GET or None)
|
|
|
|
if search_form.is_valid():
|
2017-11-01 23:19:41 +00:00
|
|
|
return render(
|
|
|
|
request,
|
|
|
|
'search/index.html',
|
|
|
|
get_results(
|
|
|
|
search_form.cleaned_data.get('q', ''),
|
|
|
|
request,
|
|
|
|
search_form.cleaned_data
|
|
|
|
)
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
return render(request, 'search/search.html', {'search_form': search_form})
|
|
|
|
|
2016-07-04 23:56:51 +02:00
|
|
|
|
2016-07-08 12:35:53 +02:00
|
|
|
@login_required
|
2016-07-04 23:56:51 +02:00
|
|
|
def searchp(request):
|
2017-11-02 19:58:20 +00:00
|
|
|
""" La page de recherche avancée """
|
2017-11-01 16:01:10 +00:00
|
|
|
search_form = SearchFormPlus(request.GET or None)
|
|
|
|
if search_form.is_valid():
|
2017-11-01 23:19:41 +00:00
|
|
|
return render(
|
|
|
|
request,
|
|
|
|
'search/index.html',
|
|
|
|
get_results(
|
|
|
|
search_form.cleaned_data.get('q', ''),
|
|
|
|
request,
|
|
|
|
search_form.cleaned_data
|
|
|
|
)
|
|
|
|
)
|
2017-11-02 19:58:20 +00:00
|
|
|
return render(request, 'search/search.html', {'search_form': search_form})
|