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
|
2022-11-03 11:58:26 -07:00
|
|
|
from django.utils.translation import gettext as _
|
2016-07-14 13:53:30 -04:00
|
|
|
|
2022-05-16 16:16:51 -04:00
|
|
|
from dcim.filtersets import CabledObjectFilterSet
|
2021-03-08 13:28:53 -05:00
|
|
|
from dcim.models import Region, Site, SiteGroup
|
2022-03-30 17:17:36 -04:00
|
|
|
from ipam.models import ASN
|
2022-07-12 12:30:07 -04:00
|
|
|
from netbox.filtersets import NetBoxModelFilterSet, OrganizationalModelFilterSet
|
2022-03-18 14:39:22 +00:00
|
|
|
from tenancy.filtersets import ContactModelFilterSet, TenancyFilterSet
|
2021-04-29 16:12:31 -04:00
|
|
|
from utilities.filters import TreeNodeMultipleChoiceFilter
|
2019-11-07 11:10:46 -05:00
|
|
|
from .choices import *
|
2021-03-18 11:10:48 -04:00
|
|
|
from .models import *
|
2016-03-01 11:23:03 -05:00
|
|
|
|
2020-01-08 17:20:31 -05:00
|
|
|
__all__ = (
|
2020-01-09 20:25:33 -05:00
|
|
|
'CircuitFilterSet',
|
|
|
|
|
'CircuitTerminationFilterSet',
|
|
|
|
|
'CircuitTypeFilterSet',
|
2021-04-01 10:21:41 -04:00
|
|
|
'ProviderNetworkFilterSet',
|
2023-03-29 07:27:11 -05:00
|
|
|
'ProviderAccountFilterSet',
|
2020-01-09 20:25:33 -05:00
|
|
|
'ProviderFilterSet',
|
2020-01-08 17:20:31 -05:00
|
|
|
)
|
|
|
|
|
|
2016-03-01 11:23:03 -05:00
|
|
|
|
2022-03-18 13:17:11 -04:00
|
|
|
class ProviderFilterSet(NetBoxModelFilterSet, ContactModelFilterSet):
|
2020-01-03 13:52:50 -05:00
|
|
|
region_id = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=Region.objects.all(),
|
2020-02-09 17:46:21 -05:00
|
|
|
field_name='circuits__terminations__site__region',
|
|
|
|
|
lookup_expr='in',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Region (ID)'),
|
2020-01-03 13:52:50 -05:00
|
|
|
)
|
|
|
|
|
region = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=Region.objects.all(),
|
2020-02-09 17:46:21 -05:00
|
|
|
field_name='circuits__terminations__site__region',
|
|
|
|
|
lookup_expr='in',
|
2020-01-03 13:52:50 -05:00
|
|
|
to_field_name='slug',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Region (slug)'),
|
2020-01-03 13:52:50 -05:00
|
|
|
)
|
2021-03-08 13:28:53 -05:00
|
|
|
site_group_id = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=SiteGroup.objects.all(),
|
|
|
|
|
field_name='circuits__terminations__site__group',
|
|
|
|
|
lookup_expr='in',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site group (ID)'),
|
2021-03-08 13:28:53 -05:00
|
|
|
)
|
|
|
|
|
site_group = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=SiteGroup.objects.all(),
|
|
|
|
|
field_name='circuits__terminations__site__group',
|
|
|
|
|
lookup_expr='in',
|
|
|
|
|
to_field_name='slug',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site group (slug)'),
|
2021-03-08 13:28:53 -05:00
|
|
|
)
|
2016-07-14 13:53:30 -04:00
|
|
|
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(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site'),
|
2016-07-14 13:53:30 -04:00
|
|
|
)
|
|
|
|
|
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',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site (slug)'),
|
2016-07-14 13:53:30 -04:00
|
|
|
)
|
2022-03-30 17:17:36 -04:00
|
|
|
asn_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='asns',
|
|
|
|
|
queryset=ASN.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('ASN (ID)'),
|
2022-03-30 17:17:36 -04:00
|
|
|
)
|
2016-07-14 13:53:30 -04:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = Provider
|
2023-03-29 07:27:11 -05:00
|
|
|
fields = ['id', 'name', 'slug']
|
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) |
|
2023-03-29 07:27:11 -05:00
|
|
|
Q(accounts__account__icontains=value) |
|
|
|
|
|
Q(accounts__name__icontains=value) |
|
2016-07-29 12:51:23 -04:00
|
|
|
Q(comments__icontains=value)
|
2016-07-14 13:53:30 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
2023-03-29 07:27:11 -05:00
|
|
|
class ProviderAccountFilterSet(NetBoxModelFilterSet):
|
|
|
|
|
provider_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Provider.objects.all(),
|
|
|
|
|
label=_('Provider (ID)'),
|
|
|
|
|
)
|
|
|
|
|
provider = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='provider__slug',
|
|
|
|
|
queryset=Provider.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
|
|
|
|
label=_('Provider (slug)'),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = ProviderAccount
|
|
|
|
|
fields = ['id', 'name', 'account', 'description']
|
|
|
|
|
|
|
|
|
|
def search(self, queryset, name, value):
|
|
|
|
|
if not value.strip():
|
|
|
|
|
return queryset
|
|
|
|
|
return queryset.filter(
|
|
|
|
|
Q(name__icontains=value) |
|
|
|
|
|
Q(account__icontains=value) |
|
|
|
|
|
Q(comments__icontains=value)
|
|
|
|
|
).distinct()
|
|
|
|
|
|
|
|
|
|
|
2022-01-27 09:24:20 -05:00
|
|
|
class ProviderNetworkFilterSet(NetBoxModelFilterSet):
|
2021-03-18 11:10:48 -04:00
|
|
|
provider_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Provider.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Provider (ID)'),
|
2021-03-18 11:10:48 -04:00
|
|
|
)
|
|
|
|
|
provider = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='provider__slug',
|
|
|
|
|
queryset=Provider.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Provider (slug)'),
|
2021-03-18 11:10:48 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
class Meta:
|
2021-04-01 10:21:41 -04:00
|
|
|
model = ProviderNetwork
|
2022-02-25 14:06:45 -05:00
|
|
|
fields = ['id', 'name', 'service_id', 'description']
|
2021-03-18 11:10:48 -04:00
|
|
|
|
|
|
|
|
def search(self, queryset, name, value):
|
|
|
|
|
if not value.strip():
|
|
|
|
|
return queryset
|
|
|
|
|
return queryset.filter(
|
2021-06-08 14:06:17 -04:00
|
|
|
Q(name__icontains=value) |
|
2021-12-23 13:50:01 -05:00
|
|
|
Q(service_id__icontains=value) |
|
2021-03-18 11:10:48 -04:00
|
|
|
Q(description__icontains=value) |
|
|
|
|
|
Q(comments__icontains=value)
|
|
|
|
|
).distinct()
|
|
|
|
|
|
|
|
|
|
|
2021-04-29 15:59:11 -04:00
|
|
|
class CircuitTypeFilterSet(OrganizationalModelFilterSet):
|
2017-06-19 16:10:18 -04:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = CircuitType
|
2022-02-24 17:03:37 +01:00
|
|
|
fields = ['id', 'name', 'slug', 'description']
|
2017-06-19 16:10:18 -04:00
|
|
|
|
|
|
|
|
|
2022-03-18 13:17:11 -04:00
|
|
|
class CircuitFilterSet(NetBoxModelFilterSet, TenancyFilterSet, ContactModelFilterSet):
|
2016-03-01 11:23:03 -05:00
|
|
|
provider_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Provider.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Provider (ID)'),
|
2016-03-01 11:23:03 -05:00
|
|
|
)
|
|
|
|
|
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',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Provider (slug)'),
|
2016-03-01 11:23:03 -05:00
|
|
|
)
|
2023-03-29 07:27:11 -05:00
|
|
|
provider_account_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='provider_account',
|
|
|
|
|
queryset=ProviderAccount.objects.all(),
|
|
|
|
|
label=_('ProviderAccount (ID)'),
|
|
|
|
|
)
|
2021-04-01 10:21:41 -04:00
|
|
|
provider_network_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='terminations__provider_network',
|
|
|
|
|
queryset=ProviderNetwork.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('ProviderNetwork (ID)'),
|
2021-03-18 14:32:28 -04:00
|
|
|
)
|
2016-03-01 11:23:03 -05:00
|
|
|
type_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=CircuitType.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Circuit type (ID)'),
|
2016-03-01 11:23:03 -05:00
|
|
|
)
|
|
|
|
|
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',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Circuit type (slug)'),
|
2016-03-01 11:23:03 -05:00
|
|
|
)
|
2018-02-06 14:06:05 -05:00
|
|
|
status = django_filters.MultipleChoiceFilter(
|
2019-11-07 11:10:46 -05:00
|
|
|
choices=CircuitStatusChoices,
|
2018-02-06 14:06:05 -05:00
|
|
|
null_value=None
|
|
|
|
|
)
|
2019-08-28 12:12:27 -04:00
|
|
|
region_id = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=Region.objects.all(),
|
2020-02-09 17:46:21 -05:00
|
|
|
field_name='terminations__site__region',
|
|
|
|
|
lookup_expr='in',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Region (ID)'),
|
2019-08-28 12:12:27 -04:00
|
|
|
)
|
|
|
|
|
region = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=Region.objects.all(),
|
2020-02-09 17:46:21 -05:00
|
|
|
field_name='terminations__site__region',
|
|
|
|
|
lookup_expr='in',
|
2019-08-28 12:12:27 -04:00
|
|
|
to_field_name='slug',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Region (slug)'),
|
2019-08-28 12:12:27 -04:00
|
|
|
)
|
2021-03-08 13:28:53 -05:00
|
|
|
site_group_id = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=SiteGroup.objects.all(),
|
|
|
|
|
field_name='terminations__site__group',
|
|
|
|
|
lookup_expr='in',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site group (ID)'),
|
2021-03-08 13:28:53 -05:00
|
|
|
)
|
|
|
|
|
site_group = TreeNodeMultipleChoiceFilter(
|
|
|
|
|
queryset=SiteGroup.objects.all(),
|
|
|
|
|
field_name='terminations__site__group',
|
|
|
|
|
lookup_expr='in',
|
|
|
|
|
to_field_name='slug',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site group (slug)'),
|
2021-03-08 13:28:53 -05:00
|
|
|
)
|
|
|
|
|
site_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='terminations__site',
|
|
|
|
|
queryset=Site.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site (ID)'),
|
2021-03-08 13:28:53 -05:00
|
|
|
)
|
|
|
|
|
site = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
field_name='terminations__site__slug',
|
|
|
|
|
queryset=Site.objects.all(),
|
|
|
|
|
to_field_name='slug',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site (slug)'),
|
2021-03-08 13:28:53 -05:00
|
|
|
)
|
2016-03-01 11:23:03 -05:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = Circuit
|
2022-06-22 15:09:50 -04:00
|
|
|
fields = ['id', 'cid', 'description', 'install_date', 'termination_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
|
|
|
|
|
|
|
|
|
2022-07-06 14:09:25 -04:00
|
|
|
class CircuitTerminationFilterSet(NetBoxModelFilterSet, CabledObjectFilterSet):
|
2017-06-19 16:10:18 -04:00
|
|
|
q = django_filters.CharFilter(
|
|
|
|
|
method='search',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Search'),
|
2017-06-19 16:10:18 -04:00
|
|
|
)
|
2017-02-01 15:01:56 -05:00
|
|
|
circuit_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Circuit.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Circuit'),
|
2017-02-01 15:01:56 -05:00
|
|
|
)
|
2017-06-19 16:10:18 -04:00
|
|
|
site_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=Site.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site (ID)'),
|
2017-06-19 16:10:18 -04:00
|
|
|
)
|
|
|
|
|
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',
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('Site (slug)'),
|
2017-06-19 16:10:18 -04:00
|
|
|
)
|
2021-04-01 10:21:41 -04:00
|
|
|
provider_network_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
|
|
queryset=ProviderNetwork.objects.all(),
|
2022-11-03 11:58:26 -07:00
|
|
|
label=_('ProviderNetwork (ID)'),
|
2021-03-18 11:57:59 -04:00
|
|
|
)
|
2017-02-01 15:01:56 -05:00
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
model = CircuitTermination
|
2022-06-01 16:48:56 -04:00
|
|
|
fields = ['id', 'term_side', 'port_speed', 'upstream_speed', 'xconnect_id', 'description', 'cable_end']
|
2017-06-19 16:10:18 -04:00
|
|
|
|
|
|
|
|
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()
|