1
0
mirror of https://github.com/netbox-community/netbox.git synced 2024-05-10 07:54:54 +00:00

143 lines
4.6 KiB
Python
Raw Normal View History

from circuits.models import Circuit
from dcim.models import Site, Rack, Device, RackReservation
from ipam.models import Aggregate, IPAddress, Prefix, VLAN, VRF
2020-11-11 16:07:38 -05:00
from netbox.views import generic
from utilities.tables import paginate_table
2019-10-07 08:29:32 +02:00
from virtualization.models import VirtualMachine, Cluster
2021-04-29 16:38:56 -04:00
from . import filtersets, forms, tables
from .models import Tenant, TenantGroup
2016-07-26 14:58:37 -04:00
#
# Tenant groups
#
2020-11-11 16:07:38 -05:00
class TenantGroupListView(generic.ObjectListView):
queryset = TenantGroup.objects.add_related_count(
TenantGroup.objects.all(),
Tenant,
'group',
'tenant_count',
cumulative=True
)
2016-07-26 14:58:37 -04:00
table = tables.TenantGroupTable
class TenantGroupView(generic.ObjectView):
queryset = TenantGroup.objects.all()
def get_extra_context(self, request, instance):
tenants = Tenant.objects.restrict(request.user, 'view').filter(
group=instance
)
tenants_table = tables.TenantTable(tenants)
tenants_table.columns.hide('group')
paginate_table(tenants_table, request)
return {
'tenants_table': tenants_table,
}
2020-11-11 16:07:38 -05:00
class TenantGroupEditView(generic.ObjectEditView):
queryset = TenantGroup.objects.all()
model_form = forms.TenantGroupForm
2016-07-26 14:58:37 -04:00
2020-11-11 16:07:38 -05:00
class TenantGroupDeleteView(generic.ObjectDeleteView):
queryset = TenantGroup.objects.all()
2020-11-11 16:07:38 -05:00
class TenantGroupBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = TenantGroup.objects.all()
model_form = forms.TenantGroupCSVForm
table = tables.TenantGroupTable
class TenantGroupBulkEditView(generic.BulkEditView):
queryset = TenantGroup.objects.add_related_count(
TenantGroup.objects.all(),
Tenant,
'group',
'tenant_count',
cumulative=True
)
2021-04-29 16:38:56 -04:00
filterset = filtersets.TenantGroupFilterSet
table = tables.TenantGroupTable
form = forms.TenantGroupBulkEditForm
2020-11-11 16:07:38 -05:00
class TenantGroupBulkDeleteView(generic.BulkDeleteView):
queryset = TenantGroup.objects.add_related_count(
TenantGroup.objects.all(),
Tenant,
'group',
'tenant_count',
cumulative=True
)
table = tables.TenantGroupTable
2016-07-26 14:58:37 -04:00
#
# Tenants
#
2020-11-11 16:07:38 -05:00
class TenantListView(generic.ObjectListView):
queryset = Tenant.objects.all()
2021-04-29 16:38:56 -04:00
filterset = filtersets.TenantFilterSet
filterset_form = forms.TenantFilterForm
2016-07-26 14:58:37 -04:00
table = tables.TenantTable
2020-11-11 16:07:38 -05:00
class TenantView(generic.ObjectView):
queryset = Tenant.objects.prefetch_related('group')
def get_extra_context(self, request, instance):
stats = {
'site_count': Site.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'rack_count': Rack.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'rackreservation_count': RackReservation.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'device_count': Device.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'vrf_count': VRF.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'prefix_count': Prefix.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'aggregate_count': Aggregate.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'ipaddress_count': IPAddress.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'vlan_count': VLAN.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'circuit_count': Circuit.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'virtualmachine_count': VirtualMachine.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
'cluster_count': Cluster.objects.restrict(request.user, 'view').filter(tenant=instance).count(),
}
return {
'stats': stats,
}
2016-07-26 14:58:37 -04:00
2020-11-11 16:07:38 -05:00
class TenantEditView(generic.ObjectEditView):
queryset = Tenant.objects.all()
model_form = forms.TenantForm
2016-07-26 14:58:37 -04:00
2020-11-11 16:07:38 -05:00
class TenantDeleteView(generic.ObjectDeleteView):
queryset = Tenant.objects.all()
2016-07-26 14:58:37 -04:00
2020-11-11 16:07:38 -05:00
class TenantBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Tenant.objects.all()
model_form = forms.TenantCSVForm
2016-07-26 14:58:37 -04:00
table = tables.TenantTable
2020-11-11 16:07:38 -05:00
class TenantBulkEditView(generic.BulkEditView):
queryset = Tenant.objects.prefetch_related('group')
2021-04-29 16:38:56 -04:00
filterset = filtersets.TenantFilterSet
table = tables.TenantTable
2016-07-26 14:58:37 -04:00
form = forms.TenantBulkEditForm
2020-11-11 16:07:38 -05:00
class TenantBulkDeleteView(generic.BulkDeleteView):
queryset = Tenant.objects.prefetch_related('group')
2021-04-29 16:38:56 -04:00
filterset = filtersets.TenantFilterSet
table = tables.TenantTable