2018-11-02 15:20:08 -04:00
|
|
|
from django.db.models import Count
|
2016-07-26 14:58:37 -04:00
|
|
|
from django.shortcuts import get_object_or_404, render
|
|
|
|
|
2016-08-03 14:24:09 -04:00
|
|
|
from circuits.models import Circuit
|
2017-11-15 12:54:49 -06:00
|
|
|
from dcim.models import Site, Rack, Device, RackReservation
|
2016-08-03 14:24:09 -04:00
|
|
|
from ipam.models import IPAddress, Prefix, VLAN, VRF
|
2016-07-26 14:58:37 -04:00
|
|
|
from utilities.views import (
|
2020-05-21 15:39:07 -04:00
|
|
|
BulkDeleteView, BulkEditView, BulkImportView, ObjectView, ObjectDeleteView, ObjectEditView, ObjectListView,
|
2016-07-26 14:58:37 -04:00
|
|
|
)
|
2019-10-07 08:29:32 +02:00
|
|
|
from virtualization.models import VirtualMachine, Cluster
|
2016-07-26 14:58:37 -04:00
|
|
|
from . import filters, forms, tables
|
2017-11-07 11:08:23 -05:00
|
|
|
from .models import Tenant, TenantGroup
|
2016-07-26 14:58:37 -04:00
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Tenant groups
|
|
|
|
#
|
|
|
|
|
2020-05-21 13:22:09 -04:00
|
|
|
class TenantGroupListView(ObjectListView):
|
2020-03-11 20:20:04 -04:00
|
|
|
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
|
|
|
|
|
|
|
|
|
2020-05-21 13:59:19 -04:00
|
|
|
class TenantGroupEditView(ObjectEditView):
|
2020-05-11 12:37:22 -04:00
|
|
|
queryset = TenantGroup.objects.all()
|
2017-09-12 13:54:44 -04:00
|
|
|
model_form = forms.TenantGroupForm
|
2016-07-26 14:58:37 -04:00
|
|
|
|
|
|
|
|
2020-07-01 12:08:26 -04:00
|
|
|
class TenantGroupDeleteView(ObjectDeleteView):
|
|
|
|
queryset = TenantGroup.objects.all()
|
|
|
|
|
|
|
|
|
2020-05-21 14:43:27 -04:00
|
|
|
class TenantGroupBulkImportView(BulkImportView):
|
2020-05-21 11:58:27 -04:00
|
|
|
queryset = TenantGroup.objects.all()
|
2017-10-09 15:09:40 -04:00
|
|
|
model_form = forms.TenantGroupCSVForm
|
|
|
|
table = tables.TenantGroupTable
|
|
|
|
|
|
|
|
|
2020-05-21 15:14:29 -04:00
|
|
|
class TenantGroupBulkDeleteView(BulkDeleteView):
|
2020-07-20 12:07:19 -04:00
|
|
|
queryset = TenantGroup.objects.add_related_count(
|
|
|
|
TenantGroup.objects.all(),
|
|
|
|
Tenant,
|
|
|
|
'group',
|
|
|
|
'tenant_count',
|
|
|
|
cumulative=True
|
|
|
|
)
|
2017-07-13 17:39:28 -04:00
|
|
|
table = tables.TenantGroupTable
|
2016-07-26 14:58:37 -04:00
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Tenants
|
|
|
|
#
|
|
|
|
|
2020-05-21 13:22:09 -04:00
|
|
|
class TenantListView(ObjectListView):
|
2020-10-30 16:52:40 -04:00
|
|
|
queryset = Tenant.objects.all()
|
2020-01-09 20:57:13 -05:00
|
|
|
filterset = filters.TenantFilterSet
|
|
|
|
filterset_form = forms.TenantFilterForm
|
2016-07-26 14:58:37 -04:00
|
|
|
table = tables.TenantTable
|
|
|
|
|
|
|
|
|
2020-05-21 15:39:07 -04:00
|
|
|
class TenantView(ObjectView):
|
|
|
|
queryset = Tenant.objects.prefetch_related('group')
|
2017-05-18 17:00:57 -04:00
|
|
|
|
|
|
|
def get(self, request, slug):
|
|
|
|
|
2020-05-21 15:39:07 -04:00
|
|
|
tenant = get_object_or_404(self.queryset, slug=slug)
|
2017-05-18 17:00:57 -04:00
|
|
|
stats = {
|
2020-06-01 11:43:49 -04:00
|
|
|
'site_count': Site.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'rack_count': Rack.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'rackreservation_count': RackReservation.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'device_count': Device.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'vrf_count': VRF.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'prefix_count': Prefix.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'ipaddress_count': IPAddress.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'vlan_count': VLAN.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'circuit_count': Circuit.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'virtualmachine_count': VirtualMachine.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
|
|
|
'cluster_count': Cluster.objects.restrict(request.user, 'view').filter(tenant=tenant).count(),
|
2017-05-18 17:00:57 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
return render(request, 'tenancy/tenant.html', {
|
|
|
|
'tenant': tenant,
|
|
|
|
'stats': stats,
|
|
|
|
})
|
2016-07-26 14:58:37 -04:00
|
|
|
|
|
|
|
|
2020-05-21 13:59:19 -04:00
|
|
|
class TenantEditView(ObjectEditView):
|
2020-05-11 12:37:22 -04:00
|
|
|
queryset = Tenant.objects.all()
|
2017-09-12 13:54:44 -04:00
|
|
|
model_form = forms.TenantForm
|
2016-07-26 14:58:37 -04:00
|
|
|
template_name = 'tenancy/tenant_edit.html'
|
|
|
|
|
|
|
|
|
2020-05-21 14:34:40 -04:00
|
|
|
class TenantDeleteView(ObjectDeleteView):
|
2020-05-11 12:47:01 -04:00
|
|
|
queryset = Tenant.objects.all()
|
2016-07-26 14:58:37 -04:00
|
|
|
|
|
|
|
|
2020-05-21 14:43:27 -04:00
|
|
|
class TenantBulkImportView(BulkImportView):
|
2020-05-21 11:58:27 -04:00
|
|
|
queryset = Tenant.objects.all()
|
2017-05-31 17:40:11 -04:00
|
|
|
model_form = forms.TenantCSVForm
|
2016-07-26 14:58:37 -04:00
|
|
|
table = tables.TenantTable
|
|
|
|
|
|
|
|
|
2020-05-21 15:07:20 -04:00
|
|
|
class TenantBulkEditView(BulkEditView):
|
2019-08-19 01:53:39 -04:00
|
|
|
queryset = Tenant.objects.prefetch_related('group')
|
2020-01-09 20:57:13 -05:00
|
|
|
filterset = filters.TenantFilterSet
|
2017-07-13 16:31:47 -04:00
|
|
|
table = tables.TenantTable
|
2016-07-26 14:58:37 -04:00
|
|
|
form = forms.TenantBulkEditForm
|
|
|
|
|
|
|
|
|
2020-05-21 15:14:29 -04:00
|
|
|
class TenantBulkDeleteView(BulkDeleteView):
|
2019-08-19 01:53:39 -04:00
|
|
|
queryset = Tenant.objects.prefetch_related('group')
|
2020-01-09 20:57:13 -05:00
|
|
|
filterset = filters.TenantFilterSet
|
2017-07-13 17:39:28 -04:00
|
|
|
table = tables.TenantTable
|