8
0
Fork 0
mirror of https://gitlab2.federez.net/re2o/re2o synced 2025-01-26 10:04:22 +00:00
re2o/search/views.py

88 lines
3.3 KiB
Python
Raw Normal View History

2016-07-03 00:27:22 +02:00
# App de recherche pour re2o
2016-07-08 12:35:53 +02:00
# Augustin lemesle, Gabriel Détraz, Goulven Kermarec
2016-07-03 00:27:22 +02:00
# Gplv2
from django.shortcuts import render
from django.shortcuts import render_to_response, get_object_or_404
from django.core.context_processors import csrf
from django.template import Context, RequestContext, loader
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
from machines.models import Machine, Interface
2016-07-06 23:53:44 +02:00
from topologie.models import Port, Switch
2016-07-03 00:27:22 +02:00
from cotisations.models import Facture
2016-07-04 23:56:51 +02:00
from search.models import SearchForm, SearchFormPlus
2016-07-03 00:27:22 +02:00
from re2o.settings import SEARCH_RESULT
2016-07-03 00:27:22 +02:00
def form(ctx, template, request):
c = ctx
c.update(csrf(request))
return render_to_response(template, c, context_instance=RequestContext(request))
2016-07-09 17:45:13 +02:00
def search_result(search, type, request):
2016-07-04 23:56:51 +02:00
date_deb = None
date_fin = None
states=[]
co=[]
2016-07-06 23:53:44 +02:00
aff=[]
2016-07-04 23:56:51 +02:00
if(type):
aff = search.cleaned_data['affichage']
co = search.cleaned_data['connexion']
states = search.cleaned_data['filtre']
date_deb = search.cleaned_data['date_deb']
date_fin = search.cleaned_data['date_fin']
date_query = Q()
if aff==[]:
2016-07-06 23:53:44 +02:00
aff = ['0','1','2','3','4','5','6']
2016-07-04 23:56:51 +02:00
if date_deb != None:
date_query = date_query & Q(date__gte=date_deb)
if date_fin != None:
date_query = date_query & Q(date__lte=date_fin)
search = search.cleaned_data['search_field']
query = Q()
for s in states:
query = query | Q(state = s)
users = None
machines = None
factures = None
bans = None
whitelists = None
2016-07-06 23:53:44 +02:00
switchlist = None
portlist = None
2016-07-04 23:56:51 +02:00
connexion = []
for i in aff:
if i == '0':
users = User.objects.filter((Q(pseudo__icontains = search) | Q(name__icontains = search) | Q(surname__icontains = search)) & query)[:SEARCH_RESULT]
2016-07-04 23:56:51 +02:00
query = Q(user__pseudo__icontains = search) | Q(user__name__icontains = search) | Q(user__surname__icontains = search)
if i == '1':
machines = Machine.objects.filter(query)[:SEARCH_RESULT]
2016-07-04 23:56:51 +02:00
if i == '2':
factures = Facture.objects.filter(query & date_query)[:SEARCH_RESULT]
2016-07-04 23:56:51 +02:00
if i == '3':
bans = Ban.objects.filter(query)[:SEARCH_RESULT]
2016-07-04 23:56:51 +02:00
if i == '4':
whitelists = Whitelist.objects.filter(query)[:SEARCH_RESULT]
2016-07-06 23:53:44 +02:00
if i == '5':
portlist = Port.objects.filter(details__icontains = search)[:SEARCH_RESULT]
2016-07-06 23:53:44 +02:00
if i == '6':
switchlist = Switch.objects.filter(details__icontains = search)[:SEARCH_RESULT]
return {'users_list': users, 'machines_list' : machines, 'facture_list' : factures, 'ban_list' : bans, 'white_list': whitelists, 'port_list':portlist, 'switch_list':switchlist, 'max_result' : SEARCH_RESULT}
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 search(request):
2016-07-09 17:45:13 +02:00
search = SearchForm(request.POST or None)
if search.is_valid():
return form(search_result(search, False, request), 'search/index.html',request)
return form({'searchform' : search}, 'search/search.html', request)
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):
2016-07-09 17:45:13 +02:00
search = SearchFormPlus(request.POST or None)
if search.is_valid():
return form(search_result(search, True, request), 'search/index.html',request)
return form({'searchform' : search}, 'search/search.html', request)