Commit e3e77ea1 authored by Daniel STAN's avatar Daniel STAN
Browse files

all_has_access filtre par service

et filter_active_interfaces aussi
parent 7b1e9946
...@@ -85,12 +85,18 @@ def all_whitelisted(search_time=DT_NOW): ...@@ -85,12 +85,18 @@ def all_whitelisted(search_time=DT_NOW):
).distinct() ).distinct()
def all_has_access(search_time=DT_NOW): def all_has_access(search_time=DT_NOW, service=None):
""" Renvoie tous les users beneficiant d'une connexion """ Renvoie tous les users beneficiant d'une connexion
: user adherent ou whiteliste et non banni """ : user adherent ou whiteliste et non banni.
Si service est fourni, ne considère (exclu) que les gens bannis pour
ce service.
"""
ban_set = Ban.objects.filter(date_end__gt=search_time)
if service:
ban_set = ban_set.filter(ban_type__inhibited_services=service)
return User.objects.filter( return User.objects.filter(
Q(state=User.STATE_ACTIVE) & Q(state=User.STATE_ACTIVE) &
~Q(ban__in=Ban.objects.filter(date_end__gt=search_time)) & ~Q(ban__in=ban_set) &
(Q(whitelist__in=Whitelist.objects.filter(date_end__gt=search_time)) | (Q(whitelist__in=Whitelist.objects.filter(date_end__gt=search_time)) |
Q(facture__in=Facture.objects.filter( Q(facture__in=Facture.objects.filter(
vente__in=Vente.objects.filter( vente__in=Vente.objects.filter(
...@@ -106,11 +112,12 @@ def all_has_access(search_time=DT_NOW): ...@@ -106,11 +112,12 @@ def all_has_access(search_time=DT_NOW):
).distinct() ).distinct()
def filter_active_interfaces(interface_set): def filter_active_interfaces(interface_set, service=None):
"""Filtre les machines autorisées à sortir sur internet dans une requête""" """Filtre les machines autorisées à sortir sur internet (ou juste pour
un service donné, si fourni) dans une requête"""
return interface_set.filter( return interface_set.filter(
machine__in=Machine.objects.filter( machine__in=Machine.objects.filter(
user__in=all_has_access() user__in=all_has_access(service=service)
).filter(active=True) ).filter(active=True)
).select_related('domain').select_related('machine')\ ).select_related('domain').select_related('machine')\
.select_related('type').select_related('ipv4')\ .select_related('type').select_related('ipv4')\
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment