2016-03-01 11:23:03 -05:00
|
|
|
import django_filters
|
2016-07-14 13:53:30 -04:00
|
|
|
from django.db.models import Q
|
|
|
|
|
|
2016-03-01 11:23:03 -05:00
|
|
|
from dcim.models import Site
|
2016-08-23 11:18:00 -04:00
|
|
|
from extras.filters import CustomFieldFilterSet
|
2016-07-26 17:10:11 -04:00
|
|
|
from tenancy.models import Tenant
|
2019-05-07 13:07:01 -04:00
|
|
|
from utilities.filters import NameSlugSearchFilterSet, TagFilter
|
2018-02-06 14:06:05 -05:00
|
|
|
from .constants import CIRCUIT_STATUS_CHOICES
|
2017-02-01 15:01:56 -05:00
|
|
|
from .models import Provider, Circuit, CircuitTermination, CircuitType
|
2016-03-01 11:23:03 -05:00
|
|
|
|
|
|
|
|
|
2019-05-07 12:25:33 -04:00
|
|
|
class ProviderFilter(CustomFieldFilterSet):
|
2017-03-01 13:09:19 -05:00
|
|
|
q = django_filters.CharFilter(
|
|
|
|
|
method='search',
|
2016-07-14 13:53:30 -04:00
|
|
|
label='Search',
|
|
|
|
|
)
|
|
|
|
|
site_id = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='circuits__terminations__site',
|
2016-07-14 13:53:30 -04:00
|
|
|
queryset=Site.objects.all(),
|
|
|
|
|
label='Site',
|
|
|
|
|
)
|
|
|
|
|
site = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='circuits__terminations__site__slug',
|
2016-07-14 13:53:30 -04:00
|
|
|
queryset=Site.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Site (slug)',
|
|
|
|
|
)
|
2018-11-12 15:48:58 -05:00
|
|
|
tag = TagFilter()
|
2016-07-14 13:53:30 -04:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = Provider
|
2019-05-07 13:07:01 -04:00
|
|
|
fields = ['id', 'name', 'slug', 'asn', 'account']
|
2016-07-14 13:53:30 -04:00
|
|
|
|
2017-03-01 13:09:19 -05:00
|
|
|
def search(self, queryset, name, value):
|
|
|
|
|
if not value.strip():
|
|
|
|
|
return queryset
|
2016-07-14 13:53:30 -04:00
|
|
|
return queryset.filter(
|
|
|
|
|
Q(name__icontains=value) |
|
2016-07-29 12:51:23 -04:00
|
|
|
Q(account__icontains=value) |
|
2017-06-19 16:10:18 -04:00
|
|
|
Q(noc_contact__icontains=value) |
|
|
|
|
|
Q(admin_contact__icontains=value) |
|
2016-07-29 12:51:23 -04:00
|
|
|
Q(comments__icontains=value)
|
2016-07-14 13:53:30 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
2019-01-31 13:36:30 -05:00
|
|
|
class CircuitTypeFilter(NameSlugSearchFilterSet):
|
2017-06-19 16:10:18 -04:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = CircuitType
|
2019-05-07 13:55:48 -04:00
|
|
|
fields = ['id', 'name', 'slug']
|
2017-06-19 16:10:18 -04:00
|
|
|
|
|
|
|
|
|
2019-05-07 12:25:33 -04:00
|
|
|
class CircuitFilter(CustomFieldFilterSet):
|
2017-03-01 13:09:19 -05:00
|
|
|
q = django_filters.CharFilter(
|
|
|
|
|
method='search',
|
2016-03-01 11:23:03 -05:00
|
|
|
label='Search',
|
|
|
|
|
)
|
|
|
|
|
provider_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Provider.objects.all(),
|
|
|
|
|
label='Provider (ID)',
|
|
|
|
|
)
|
|
|
|
|
provider = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='provider__slug',
|
2016-03-01 11:23:03 -05:00
|
|
|
queryset=Provider.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Provider (slug)',
|
|
|
|
|
)
|
|
|
|
|
type_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=CircuitType.objects.all(),
|
|
|
|
|
label='Circuit type (ID)',
|
|
|
|
|
)
|
|
|
|
|
type = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='type__slug',
|
2016-03-01 11:23:03 -05:00
|
|
|
queryset=CircuitType.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Circuit type (slug)',
|
|
|
|
|
)
|
2018-02-06 14:06:05 -05:00
|
|
|
status = django_filters.MultipleChoiceFilter(
|
|
|
|
|
choices=CIRCUIT_STATUS_CHOICES,
|
|
|
|
|
null_value=None
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
tenant_id = django_filters.ModelMultipleChoiceFilter(
|
2016-07-26 17:10:11 -04:00
|
|
|
queryset=Tenant.objects.all(),
|
|
|
|
|
label='Tenant (ID)',
|
|
|
|
|
)
|
2017-10-30 17:20:22 -04:00
|
|
|
tenant = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='tenant__slug',
|
2016-07-26 17:10:11 -04:00
|
|
|
queryset=Tenant.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Tenant (slug)',
|
|
|
|
|
)
|
2016-03-01 11:23:03 -05:00
|
|
|
site_id = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='terminations__site',
|
2016-03-01 11:23:03 -05:00
|
|
|
queryset=Site.objects.all(),
|
|
|
|
|
label='Site (ID)',
|
|
|
|
|
)
|
|
|
|
|
site = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='terminations__site__slug',
|
2016-03-01 11:23:03 -05:00
|
|
|
queryset=Site.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Site (slug)',
|
|
|
|
|
)
|
2018-11-12 15:48:58 -05:00
|
|
|
tag = TagFilter()
|
2016-03-01 11:23:03 -05:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = Circuit
|
2019-05-07 13:07:01 -04:00
|
|
|
fields = ['id', 'cid', 'install_date', 'commit_rate']
|
2016-03-01 11:23:03 -05:00
|
|
|
|
2017-03-01 13:09:19 -05:00
|
|
|
def search(self, queryset, name, value):
|
|
|
|
|
if not value.strip():
|
|
|
|
|
return queryset
|
2016-07-29 12:51:23 -04:00
|
|
|
return queryset.filter(
|
|
|
|
|
Q(cid__icontains=value) |
|
2017-01-03 17:00:43 -05:00
|
|
|
Q(terminations__xconnect_id__icontains=value) |
|
|
|
|
|
Q(terminations__pp_info__icontains=value) |
|
2018-11-05 13:53:22 -05:00
|
|
|
Q(terminations__description__icontains=value) |
|
2017-01-17 15:18:03 -05:00
|
|
|
Q(description__icontains=value) |
|
2016-07-29 12:51:23 -04:00
|
|
|
Q(comments__icontains=value)
|
2017-01-04 16:56:28 -05:00
|
|
|
).distinct()
|
2017-02-01 15:01:56 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class CircuitTerminationFilter(django_filters.FilterSet):
|
2017-06-19 16:10:18 -04:00
|
|
|
q = django_filters.CharFilter(
|
|
|
|
|
method='search',
|
|
|
|
|
label='Search',
|
|
|
|
|
)
|
2017-02-01 15:01:56 -05:00
|
|
|
circuit_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Circuit.objects.all(),
|
|
|
|
|
label='Circuit',
|
|
|
|
|
)
|
2017-06-19 16:10:18 -04:00
|
|
|
site_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Site.objects.all(),
|
|
|
|
|
label='Site (ID)',
|
|
|
|
|
)
|
|
|
|
|
site = django_filters.ModelMultipleChoiceFilter(
|
2018-11-02 13:46:28 -04:00
|
|
|
field_name='site__slug',
|
2017-06-19 16:10:18 -04:00
|
|
|
queryset=Site.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
|
|
|
|
label='Site (slug)',
|
|
|
|
|
)
|
2017-02-01 15:01:56 -05:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = CircuitTermination
|
2017-06-19 16:10:18 -04:00
|
|
|
fields = ['term_side', 'port_speed', 'upstream_speed', 'xconnect_id']
|
|
|
|
|
|
|
|
|
|
def search(self, queryset, name, value):
|
|
|
|
|
if not value.strip():
|
|
|
|
|
return queryset
|
|
|
|
|
return queryset.filter(
|
|
|
|
|
Q(circuit__cid__icontains=value) |
|
|
|
|
|
Q(xconnect_id__icontains=value) |
|
2018-11-05 13:53:22 -05:00
|
|
|
Q(pp_info__icontains=value) |
|
|
|
|
|
Q(description__icontains=value)
|
2017-06-19 16:10:18 -04:00
|
|
|
).distinct()
|