123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708 |
- from __future__ import unicode_literals
- import django_filters
- from django.contrib.auth.models import User
- from django.db.models import Q
- from netaddr import EUI
- from netaddr.core import AddrFormatError
- from extras.filters import CustomFieldFilterSet
- from tenancy.models import Tenant
- from utilities.filters import NullableCharFieldFilter, NumericInFilter
- from virtualization.models import Cluster
- from .constants import (
- IFACE_FF_LAG, NONCONNECTABLE_IFACE_TYPES, STATUS_CHOICES, VIRTUAL_IFACE_TYPES, WIRELESS_IFACE_TYPES,
- )
- from .models import (
- ConsolePort, ConsolePortTemplate, ConsoleServerPort, ConsoleServerPortTemplate, Device, DeviceBay,
- DeviceBayTemplate, DeviceRole, DeviceType, Interface, InterfaceConnection, InterfaceTemplate, Manufacturer,
- InventoryItem, Platform, PowerOutlet, PowerOutletTemplate, PowerPort, PowerPortTemplate, Rack, RackGroup,
- RackReservation, RackRole, Region, Site,
- )
- class RegionFilter(django_filters.FilterSet):
- parent_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Region.objects.all(),
- label='Parent region (ID)',
- )
- parent = django_filters.ModelMultipleChoiceFilter(
- name='parent__slug',
- queryset=Region.objects.all(),
- to_field_name='slug',
- label='Parent region (slug)',
- )
- class Meta:
- model = Region
- fields = ['name', 'slug']
- class SiteFilter(CustomFieldFilterSet, django_filters.FilterSet):
- id__in = NumericInFilter(name='id', lookup_expr='in')
- q = django_filters.CharFilter(
- method='search',
- label='Search',
- )
- region_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Region.objects.all(),
- label='Region (ID)',
- )
- region = django_filters.ModelMultipleChoiceFilter(
- name='region__slug',
- queryset=Region.objects.all(),
- to_field_name='slug',
- label='Region (slug)',
- )
- tenant_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Tenant.objects.all(),
- label='Tenant (ID)',
- )
- tenant = django_filters.ModelMultipleChoiceFilter(
- name='tenant__slug',
- queryset=Tenant.objects.all(),
- to_field_name='slug',
- label='Tenant (slug)',
- )
- class Meta:
- model = Site
- fields = ['q', 'name', 'slug', 'facility', 'asn', 'contact_name', 'contact_phone', 'contact_email']
- def search(self, queryset, name, value):
- if not value.strip():
- return queryset
- qs_filter = (
- Q(name__icontains=value) |
- Q(facility__icontains=value) |
- Q(physical_address__icontains=value) |
- Q(shipping_address__icontains=value) |
- Q(contact_name__icontains=value) |
- Q(contact_phone__icontains=value) |
- Q(contact_email__icontains=value) |
- Q(comments__icontains=value)
- )
- try:
- qs_filter |= Q(asn=int(value.strip()))
- except ValueError:
- pass
- return queryset.filter(qs_filter)
- class RackGroupFilter(django_filters.FilterSet):
- site_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Site.objects.all(),
- label='Site (ID)',
- )
- site = django_filters.ModelMultipleChoiceFilter(
- name='site__slug',
- queryset=Site.objects.all(),
- to_field_name='slug',
- label='Site (slug)',
- )
- class Meta:
- model = RackGroup
- fields = ['site_id', 'name', 'slug']
- class RackRoleFilter(django_filters.FilterSet):
- class Meta:
- model = RackRole
- fields = ['name', 'slug', 'color']
- class RackFilter(CustomFieldFilterSet, django_filters.FilterSet):
- id__in = NumericInFilter(name='id', lookup_expr='in')
- q = django_filters.CharFilter(
- method='search',
- label='Search',
- )
- facility_id = NullableCharFieldFilter()
- site_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Site.objects.all(),
- label='Site (ID)',
- )
- site = django_filters.ModelMultipleChoiceFilter(
- name='site__slug',
- queryset=Site.objects.all(),
- to_field_name='slug',
- label='Site (slug)',
- )
- group_id = django_filters.ModelMultipleChoiceFilter(
- queryset=RackGroup.objects.all(),
- label='Group (ID)',
- )
- group = django_filters.ModelMultipleChoiceFilter(
- name='group__slug',
- queryset=RackGroup.objects.all(),
- to_field_name='slug',
- label='Group',
- )
- tenant_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Tenant.objects.all(),
- label='Tenant (ID)',
- )
- tenant = django_filters.ModelMultipleChoiceFilter(
- name='tenant__slug',
- queryset=Tenant.objects.all(),
- to_field_name='slug',
- label='Tenant (slug)',
- )
- role_id = django_filters.ModelMultipleChoiceFilter(
- queryset=RackRole.objects.all(),
- label='Role (ID)',
- )
- role = django_filters.ModelMultipleChoiceFilter(
- name='role__slug',
- queryset=RackRole.objects.all(),
- to_field_name='slug',
- label='Role (slug)',
- )
- class Meta:
- model = Rack
- fields = ['name', 'serial', 'type', 'width', 'u_height', 'desc_units']
- def search(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(name__icontains=value) |
- Q(facility_id__icontains=value) |
- Q(serial__icontains=value.strip()) |
- Q(comments__icontains=value)
- )
- class RackReservationFilter(django_filters.FilterSet):
- id__in = NumericInFilter(name='id', lookup_expr='in')
- q = django_filters.CharFilter(
- method='search',
- label='Search',
- )
- rack_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Rack.objects.all(),
- label='Rack (ID)',
- )
- site_id = django_filters.ModelMultipleChoiceFilter(
- name='rack__site',
- queryset=Site.objects.all(),
- label='Site (ID)',
- )
- site = django_filters.ModelMultipleChoiceFilter(
- name='rack__site__slug',
- queryset=Site.objects.all(),
- to_field_name='slug',
- label='Site (slug)',
- )
- group_id = django_filters.ModelMultipleChoiceFilter(
- name='rack__group',
- queryset=RackGroup.objects.all(),
- label='Group (ID)',
- )
- group = django_filters.ModelMultipleChoiceFilter(
- name='rack__group__slug',
- queryset=RackGroup.objects.all(),
- to_field_name='slug',
- label='Group',
- )
- user_id = django_filters.ModelMultipleChoiceFilter(
- queryset=User.objects.all(),
- label='User (ID)',
- )
- user = django_filters.ModelMultipleChoiceFilter(
- name='user',
- queryset=User.objects.all(),
- to_field_name='username',
- label='User (name)',
- )
- class Meta:
- model = RackReservation
- fields = ['created']
- def search(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(rack__name__icontains=value) |
- Q(rack__facility_id__icontains=value) |
- Q(user__username__icontains=value) |
- Q(description__icontains=value)
- )
- class ManufacturerFilter(django_filters.FilterSet):
- class Meta:
- model = Manufacturer
- fields = ['name', 'slug']
- class DeviceTypeFilter(CustomFieldFilterSet, django_filters.FilterSet):
- id__in = NumericInFilter(name='id', lookup_expr='in')
- q = django_filters.CharFilter(
- method='search',
- label='Search',
- )
- manufacturer_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Manufacturer.objects.all(),
- label='Manufacturer (ID)',
- )
- manufacturer = django_filters.ModelMultipleChoiceFilter(
- name='manufacturer__slug',
- queryset=Manufacturer.objects.all(),
- to_field_name='slug',
- label='Manufacturer (slug)',
- )
- class Meta:
- model = DeviceType
- fields = [
- 'model', 'slug', 'part_number', 'u_height', 'is_full_depth', 'is_console_server', 'is_pdu',
- 'is_network_device', 'subdevice_role',
- ]
- def search(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(manufacturer__name__icontains=value) |
- Q(model__icontains=value) |
- Q(part_number__icontains=value) |
- Q(comments__icontains=value)
- )
- class DeviceTypeComponentFilterSet(django_filters.FilterSet):
- devicetype_id = django_filters.ModelMultipleChoiceFilter(
- queryset=DeviceType.objects.all(),
- name='device_type_id',
- label='Device type (ID)',
- )
- class ConsolePortTemplateFilter(DeviceTypeComponentFilterSet):
- class Meta:
- model = ConsolePortTemplate
- fields = ['name']
- class ConsoleServerPortTemplateFilter(DeviceTypeComponentFilterSet):
- class Meta:
- model = ConsoleServerPortTemplate
- fields = ['name']
- class PowerPortTemplateFilter(DeviceTypeComponentFilterSet):
- class Meta:
- model = PowerPortTemplate
- fields = ['name']
- class PowerOutletTemplateFilter(DeviceTypeComponentFilterSet):
- class Meta:
- model = PowerOutletTemplate
- fields = ['name']
- class InterfaceTemplateFilter(DeviceTypeComponentFilterSet):
- class Meta:
- model = InterfaceTemplate
- fields = ['name', 'form_factor', 'mgmt_only']
- class DeviceBayTemplateFilter(DeviceTypeComponentFilterSet):
- class Meta:
- model = DeviceBayTemplate
- fields = ['name']
- class DeviceRoleFilter(django_filters.FilterSet):
- class Meta:
- model = DeviceRole
- fields = ['name', 'slug', 'color']
- class PlatformFilter(django_filters.FilterSet):
- class Meta:
- model = Platform
- fields = ['name', 'slug']
- class DeviceFilter(CustomFieldFilterSet, django_filters.FilterSet):
- id__in = NumericInFilter(name='id', lookup_expr='in')
- q = django_filters.CharFilter(
- method='search',
- label='Search',
- )
- manufacturer_id = django_filters.ModelMultipleChoiceFilter(
- name='device_type__manufacturer',
- queryset=Manufacturer.objects.all(),
- label='Manufacturer (ID)',
- )
- manufacturer = django_filters.ModelMultipleChoiceFilter(
- name='device_type__manufacturer__slug',
- queryset=Manufacturer.objects.all(),
- to_field_name='slug',
- label='Manufacturer (slug)',
- )
- device_type_id = django_filters.ModelMultipleChoiceFilter(
- queryset=DeviceType.objects.all(),
- label='Device type (ID)',
- )
- role_id = django_filters.ModelMultipleChoiceFilter(
- name='device_role_id',
- queryset=DeviceRole.objects.all(),
- label='Role (ID)',
- )
- role = django_filters.ModelMultipleChoiceFilter(
- name='device_role__slug',
- queryset=DeviceRole.objects.all(),
- to_field_name='slug',
- label='Role (slug)',
- )
- tenant_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Tenant.objects.all(),
- label='Tenant (ID)',
- )
- tenant = django_filters.ModelMultipleChoiceFilter(
- name='tenant__slug',
- queryset=Tenant.objects.all(),
- to_field_name='slug',
- label='Tenant (slug)',
- )
- platform_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Platform.objects.all(),
- label='Platform (ID)',
- )
- platform = django_filters.ModelMultipleChoiceFilter(
- name='platform__slug',
- queryset=Platform.objects.all(),
- to_field_name='slug',
- label='Platform (slug)',
- )
- name = NullableCharFieldFilter()
- asset_tag = NullableCharFieldFilter()
- site_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Site.objects.all(),
- label='Site (ID)',
- )
- site = django_filters.ModelMultipleChoiceFilter(
- name='site__slug',
- queryset=Site.objects.all(),
- to_field_name='slug',
- label='Site name (slug)',
- )
- rack_group_id = django_filters.ModelMultipleChoiceFilter(
- name='rack__group',
- queryset=RackGroup.objects.all(),
- label='Rack group (ID)',
- )
- rack_id = django_filters.ModelMultipleChoiceFilter(
- name='rack',
- queryset=Rack.objects.all(),
- label='Rack (ID)',
- )
- cluster_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Cluster.objects.all(),
- label='VM cluster (ID)',
- )
- model = django_filters.ModelMultipleChoiceFilter(
- name='device_type__slug',
- queryset=DeviceType.objects.all(),
- to_field_name='slug',
- label='Device model (slug)',
- )
- status = django_filters.MultipleChoiceFilter(
- choices=STATUS_CHOICES,
- null_value=None
- )
- is_full_depth = django_filters.BooleanFilter(
- name='device_type__is_full_depth',
- label='Is full depth',
- )
- is_console_server = django_filters.BooleanFilter(
- name='device_type__is_console_server',
- label='Is a console server',
- )
- is_pdu = django_filters.BooleanFilter(
- name='device_type__is_pdu',
- label='Is a PDU',
- )
- is_network_device = django_filters.BooleanFilter(
- name='device_type__is_network_device',
- label='Is a network device',
- )
- mac_address = django_filters.CharFilter(
- method='_mac_address',
- label='MAC address',
- )
- has_primary_ip = django_filters.BooleanFilter(
- method='_has_primary_ip',
- label='Has a primary IP',
- )
- class Meta:
- model = Device
- fields = ['serial']
- def search(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(name__icontains=value) |
- Q(serial__icontains=value.strip()) |
- Q(inventory_items__serial__icontains=value.strip()) |
- Q(asset_tag=value.strip()) |
- Q(comments__icontains=value)
- ).distinct()
- def _mac_address(self, queryset, name, value):
- value = value.strip()
- if not value:
- return queryset
- try:
- mac = EUI(value.strip())
- return queryset.filter(interfaces__mac_address=mac).distinct()
- except AddrFormatError:
- return queryset.none()
- def _has_primary_ip(self, queryset, name, value):
- if value:
- return queryset.filter(
- Q(primary_ip4__isnull=False) |
- Q(primary_ip6__isnull=False)
- )
- else:
- return queryset.exclude(
- Q(primary_ip4__isnull=False) |
- Q(primary_ip6__isnull=False)
- )
- class DeviceComponentFilterSet(django_filters.FilterSet):
- device_id = django_filters.ModelChoiceFilter(
- queryset=Device.objects.all(),
- label='Device (ID)',
- )
- device = django_filters.ModelChoiceFilter(
- queryset=Device.objects.all(),
- to_field_name='name',
- label='Device (name)',
- )
- class ConsolePortFilter(DeviceComponentFilterSet):
- class Meta:
- model = ConsolePort
- fields = ['name']
- class ConsoleServerPortFilter(DeviceComponentFilterSet):
- class Meta:
- model = ConsoleServerPort
- fields = ['name']
- class PowerPortFilter(DeviceComponentFilterSet):
- class Meta:
- model = PowerPort
- fields = ['name']
- class PowerOutletFilter(DeviceComponentFilterSet):
- class Meta:
- model = PowerOutlet
- fields = ['name']
- class InterfaceFilter(django_filters.FilterSet):
- """
- Not using DeviceComponentFilterSet for Interfaces because we need to glean the ordering logic from the parent
- Device's DeviceType.
- """
- device = django_filters.CharFilter(
- method='filter_device',
- name='name',
- label='Device',
- )
- device_id = django_filters.NumberFilter(
- method='filter_device',
- name='pk',
- label='Device (ID)',
- )
- type = django_filters.CharFilter(
- method='filter_type',
- label='Interface type',
- )
- lag_id = django_filters.ModelMultipleChoiceFilter(
- name='lag',
- queryset=Interface.objects.all(),
- label='LAG interface (ID)',
- )
- mac_address = django_filters.CharFilter(
- method='_mac_address',
- label='MAC address',
- )
- class Meta:
- model = Interface
- fields = ['name', 'form_factor', 'enabled', 'mtu', 'mgmt_only']
- def filter_device(self, queryset, name, value):
- try:
- device = Device.objects.select_related('device_type').get(**{name: value})
- ordering = device.device_type.interface_ordering
- return queryset.filter(device=device).order_naturally(ordering)
- except Device.DoesNotExist:
- return queryset.none()
- def filter_type(self, queryset, name, value):
- value = value.strip().lower()
- return {
- 'physical': queryset.exclude(form_factor__in=NONCONNECTABLE_IFACE_TYPES),
- 'virtual': queryset.filter(form_factor__in=VIRTUAL_IFACE_TYPES),
- 'wireless': queryset.filter(form_factor__in=WIRELESS_IFACE_TYPES),
- 'lag': queryset.filter(form_factor=IFACE_FF_LAG),
- }.get(value, queryset.none())
- def _mac_address(self, queryset, name, value):
- value = value.strip()
- if not value:
- return queryset
- try:
- mac = EUI(value.strip())
- return queryset.filter(mac_address=mac)
- except AddrFormatError:
- return queryset.none()
- class DeviceBayFilter(DeviceComponentFilterSet):
- class Meta:
- model = DeviceBay
- fields = ['name']
- class InventoryItemFilter(DeviceComponentFilterSet):
- parent_id = django_filters.ModelMultipleChoiceFilter(
- queryset=InventoryItem.objects.all(),
- label='Parent inventory item (ID)',
- )
- manufacturer_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Manufacturer.objects.all(),
- label='Manufacturer (ID)',
- )
- manufacturer = django_filters.ModelMultipleChoiceFilter(
- name='manufacturer__slug',
- queryset=Manufacturer.objects.all(),
- to_field_name='slug',
- label='Manufacturer (slug)',
- )
- asset_tag = NullableCharFieldFilter()
- class Meta:
- model = InventoryItem
- fields = ['name', 'part_id', 'serial', 'discovered']
- class ConsoleConnectionFilter(django_filters.FilterSet):
- site = django_filters.CharFilter(
- method='filter_site',
- label='Site (slug)',
- )
- device = django_filters.CharFilter(
- method='filter_device',
- label='Device',
- )
- class Meta:
- model = ConsolePort
- fields = ['name', 'connection_status']
- def filter_site(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(cs_port__device__site__slug=value)
- def filter_device(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(device__name__icontains=value) |
- Q(cs_port__device__name__icontains=value)
- )
- class PowerConnectionFilter(django_filters.FilterSet):
- site = django_filters.CharFilter(
- method='filter_site',
- label='Site (slug)',
- )
- device = django_filters.CharFilter(
- method='filter_device',
- label='Device',
- )
- class Meta:
- model = PowerPort
- fields = ['name', 'connection_status']
- def filter_site(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(power_outlet__device__site__slug=value)
- def filter_device(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(device__name__icontains=value) |
- Q(power_outlet__device__name__icontains=value)
- )
- class InterfaceConnectionFilter(django_filters.FilterSet):
- site = django_filters.CharFilter(
- method='filter_site',
- label='Site (slug)',
- )
- device = django_filters.CharFilter(
- method='filter_device',
- label='Device',
- )
- class Meta:
- model = InterfaceConnection
- fields = ['connection_status']
- def filter_site(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(interface_a__device__site__slug=value) |
- Q(interface_b__device__site__slug=value)
- )
- def filter_device(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(interface_a__device__name__icontains=value) |
- Q(interface_b__device__name__icontains=value)
- )
|