|
@@ -22,7 +22,10 @@ from .forms import ConfirmationForm
|
|
from .paginator import EnhancedPaginator
|
|
from .paginator import EnhancedPaginator
|
|
|
|
|
|
|
|
|
|
-class annotate_custom_fields:
|
|
|
|
|
|
+class CustomFieldQueryset:
|
|
|
|
+ """
|
|
|
|
+ Annotate custom fields on objects within a QuerySet.
|
|
|
|
+ """
|
|
|
|
|
|
def __init__(self, queryset, custom_fields):
|
|
def __init__(self, queryset, custom_fields):
|
|
self.queryset = queryset
|
|
self.queryset = queryset
|
|
@@ -36,6 +39,18 @@ class annotate_custom_fields:
|
|
|
|
|
|
|
|
|
|
class ObjectListView(View):
|
|
class ObjectListView(View):
|
|
|
|
+ """
|
|
|
|
+ List a series of objects.
|
|
|
|
+
|
|
|
|
+ queryset: The queryset of objects to display
|
|
|
|
+ filter: A django-filter FilterSet that is applied to the queryset
|
|
|
|
+ filter_form: The form used to render filter options
|
|
|
|
+ table: The django-tables2 Table used to render the objects list
|
|
|
|
+ edit_permissions: Editing controls are displayed only if the user has these permissions
|
|
|
|
+ template_name: The name of the template
|
|
|
|
+ redirect_on_single_result: If True and the queryset returns only a single object, the user is automatically
|
|
|
|
+ redirected to that object
|
|
|
|
+ """
|
|
queryset = None
|
|
queryset = None
|
|
filter = None
|
|
filter = None
|
|
filter_form = None
|
|
filter_form = None
|
|
@@ -44,7 +59,7 @@ class ObjectListView(View):
|
|
template_name = None
|
|
template_name = None
|
|
redirect_on_single_result = True
|
|
redirect_on_single_result = True
|
|
|
|
|
|
- def get(self, request, *args, **kwargs):
|
|
|
|
|
|
+ def get(self, request):
|
|
|
|
|
|
model = self.queryset.model
|
|
model = self.queryset.model
|
|
object_ct = ContentType.objects.get_for_model(model)
|
|
object_ct = ContentType.objects.get_for_model(model)
|
|
@@ -61,7 +76,7 @@ class ObjectListView(View):
|
|
# Check for export template rendering
|
|
# Check for export template rendering
|
|
if request.GET.get('export'):
|
|
if request.GET.get('export'):
|
|
et = get_object_or_404(ExportTemplate, content_type=object_ct, name=request.GET.get('export'))
|
|
et = get_object_or_404(ExportTemplate, content_type=object_ct, name=request.GET.get('export'))
|
|
- queryset = annotate_custom_fields(self.queryset, custom_fields) if custom_fields else self.queryset
|
|
|
|
|
|
+ queryset = CustomFieldQueryset(self.queryset, custom_fields) if custom_fields else self.queryset
|
|
try:
|
|
try:
|
|
response = et.to_response(context_dict={'queryset': queryset},
|
|
response = et.to_response(context_dict={'queryset': queryset},
|
|
filename='netbox_{}'.format(model._meta.verbose_name_plural))
|
|
filename='netbox_{}'.format(model._meta.verbose_name_plural))
|
|
@@ -114,6 +129,17 @@ class ObjectListView(View):
|
|
|
|
|
|
|
|
|
|
class ObjectEditView(View):
|
|
class ObjectEditView(View):
|
|
|
|
+ """
|
|
|
|
+ Create or edit a single object.
|
|
|
|
+
|
|
|
|
+ model: The model of the object being edited
|
|
|
|
+ form_class: The form used to create or edit the object
|
|
|
|
+ fields_initial: A set of fields that will be prepopulated in the form from the request parameters
|
|
|
|
+ template_name: The name of the template
|
|
|
|
+ obj_list_url: The name of the URL used to display a list of this object type
|
|
|
|
+ use_obj_view: If True, the user will be directed to a view of the object after it has been edited. Otherwise, the
|
|
|
|
+ user will be directed to the object's list view (defined as `obj_list_url`).
|
|
|
|
+ """
|
|
model = None
|
|
model = None
|
|
form_class = None
|
|
form_class = None
|
|
fields_initial = []
|
|
fields_initial = []
|
|
@@ -195,6 +221,13 @@ class ObjectEditView(View):
|
|
|
|
|
|
|
|
|
|
class ObjectDeleteView(View):
|
|
class ObjectDeleteView(View):
|
|
|
|
+ """
|
|
|
|
+ Delete a single object.
|
|
|
|
+
|
|
|
|
+ model: The model of the object being edited
|
|
|
|
+ template_name: The name of the template
|
|
|
|
+ redirect_url: Name of the URL to which the user is redirected after deleting the object
|
|
|
|
+ """
|
|
model = None
|
|
model = None
|
|
template_name = 'utilities/obj_delete.html'
|
|
template_name = 'utilities/obj_delete.html'
|
|
redirect_url = None
|
|
redirect_url = None
|
|
@@ -213,7 +246,7 @@ class ObjectDeleteView(View):
|
|
return obj.get_parent_url()
|
|
return obj.get_parent_url()
|
|
return reverse('home')
|
|
return reverse('home')
|
|
|
|
|
|
- def get(self, request, *args, **kwargs):
|
|
|
|
|
|
+ def get(self, request, **kwargs):
|
|
|
|
|
|
obj = self.get_object(kwargs)
|
|
obj = self.get_object(kwargs)
|
|
form = ConfirmationForm()
|
|
form = ConfirmationForm()
|
|
@@ -225,14 +258,14 @@ class ObjectDeleteView(View):
|
|
'cancel_url': self.get_cancel_url(obj),
|
|
'cancel_url': self.get_cancel_url(obj),
|
|
})
|
|
})
|
|
|
|
|
|
- def post(self, request, *args, **kwargs):
|
|
|
|
|
|
+ def post(self, request, **kwargs):
|
|
|
|
|
|
obj = self.get_object(kwargs)
|
|
obj = self.get_object(kwargs)
|
|
form = ConfirmationForm(request.POST)
|
|
form = ConfirmationForm(request.POST)
|
|
if form.is_valid():
|
|
if form.is_valid():
|
|
try:
|
|
try:
|
|
obj.delete()
|
|
obj.delete()
|
|
- except ProtectedError, e:
|
|
|
|
|
|
+ except ProtectedError as e:
|
|
handle_protectederror(obj, request, e)
|
|
handle_protectederror(obj, request, e)
|
|
return redirect(obj.get_absolute_url())
|
|
return redirect(obj.get_absolute_url())
|
|
msg = u'Deleted {} {}'.format(self.model._meta.verbose_name, obj)
|
|
msg = u'Deleted {} {}'.format(self.model._meta.verbose_name, obj)
|
|
@@ -254,6 +287,14 @@ class ObjectDeleteView(View):
|
|
|
|
|
|
|
|
|
|
class BulkAddView(View):
|
|
class BulkAddView(View):
|
|
|
|
+ """
|
|
|
|
+ Create new objects in bulk.
|
|
|
|
+
|
|
|
|
+ form: Form class
|
|
|
|
+ model: The model of the objects being created
|
|
|
|
+ template_name: The name of the template
|
|
|
|
+ redirect_url: Name of the URL to which the user is redirected after creating the objects
|
|
|
|
+ """
|
|
form = None
|
|
form = None
|
|
model = None
|
|
model = None
|
|
template_name = None
|
|
template_name = None
|
|
@@ -305,19 +346,27 @@ class BulkAddView(View):
|
|
|
|
|
|
|
|
|
|
class BulkImportView(View):
|
|
class BulkImportView(View):
|
|
|
|
+ """
|
|
|
|
+ Import objects in bulk (CSV format).
|
|
|
|
+
|
|
|
|
+ form: Form class
|
|
|
|
+ table: The django-tables2 Table used to render the list of imported objects
|
|
|
|
+ template_name: The name of the template
|
|
|
|
+ obj_list_url: The name of the URL to use for the cancel button
|
|
|
|
+ """
|
|
form = None
|
|
form = None
|
|
table = None
|
|
table = None
|
|
template_name = None
|
|
template_name = None
|
|
obj_list_url = None
|
|
obj_list_url = None
|
|
|
|
|
|
- def get(self, request, *args, **kwargs):
|
|
|
|
|
|
+ def get(self, request):
|
|
|
|
|
|
return render(request, self.template_name, {
|
|
return render(request, self.template_name, {
|
|
'form': self.form(),
|
|
'form': self.form(),
|
|
'obj_list_url': self.obj_list_url,
|
|
'obj_list_url': self.obj_list_url,
|
|
})
|
|
})
|
|
|
|
|
|
- def post(self, request, *args, **kwargs):
|
|
|
|
|
|
+ def post(self, request):
|
|
|
|
|
|
form = self.form(request.POST)
|
|
form = self.form(request.POST)
|
|
if form.is_valid():
|
|
if form.is_valid():
|
|
@@ -351,6 +400,15 @@ class BulkImportView(View):
|
|
|
|
|
|
|
|
|
|
class BulkEditView(View):
|
|
class BulkEditView(View):
|
|
|
|
+ """
|
|
|
|
+ Edit objects in bulk.
|
|
|
|
+
|
|
|
|
+ cls: The model of the objects being edited
|
|
|
|
+ parent_cls: The model of the parent object (if any)
|
|
|
|
+ form: The form class used to edit objects in bulk
|
|
|
|
+ template_name: The name of the template
|
|
|
|
+ default_redirect_url: Name of the URL to which the user is redirected after editing the objects
|
|
|
|
+ """
|
|
cls = None
|
|
cls = None
|
|
parent_cls = None
|
|
parent_cls = None
|
|
form = None
|
|
form = None
|
|
@@ -480,6 +538,15 @@ class BulkEditView(View):
|
|
|
|
|
|
|
|
|
|
class BulkDeleteView(View):
|
|
class BulkDeleteView(View):
|
|
|
|
+ """
|
|
|
|
+ Delete objects in bulk.
|
|
|
|
+
|
|
|
|
+ cls: The model of the objects being deleted
|
|
|
|
+ parent_cls: The model of the parent object (if any)
|
|
|
|
+ form: The form class used to delete objects in bulk
|
|
|
|
+ template_name: The name of the template
|
|
|
|
+ default_redirect_url: Name of the URL to which the user is redirected after deleting the objects
|
|
|
|
+ """
|
|
cls = None
|
|
cls = None
|
|
parent_cls = None
|
|
parent_cls = None
|
|
form = None
|
|
form = None
|
|
@@ -521,7 +588,7 @@ class BulkDeleteView(View):
|
|
queryset = self.cls.objects.filter(pk__in=pk_list)
|
|
queryset = self.cls.objects.filter(pk__in=pk_list)
|
|
try:
|
|
try:
|
|
deleted_count = queryset.delete()[1][self.cls._meta.label]
|
|
deleted_count = queryset.delete()[1][self.cls._meta.label]
|
|
- except ProtectedError, e:
|
|
|
|
|
|
+ except ProtectedError as e:
|
|
handle_protectederror(list(queryset), request, e)
|
|
handle_protectederror(list(queryset), request, e)
|
|
return redirect(redirect_url)
|
|
return redirect(redirect_url)
|
|
|
|
|
|
@@ -547,7 +614,9 @@ class BulkDeleteView(View):
|
|
})
|
|
})
|
|
|
|
|
|
def get_form(self):
|
|
def get_form(self):
|
|
- """Provide a standard bulk delete form if none has been specified for the view"""
|
|
|
|
|
|
+ """
|
|
|
|
+ Provide a standard bulk delete form if none has been specified for the view
|
|
|
|
+ """
|
|
|
|
|
|
class BulkDeleteForm(ConfirmationForm):
|
|
class BulkDeleteForm(ConfirmationForm):
|
|
pk = ModelMultipleChoiceField(queryset=self.cls.objects.all(), widget=MultipleHiddenInput)
|
|
pk = ModelMultipleChoiceField(queryset=self.cls.objects.all(), widget=MultipleHiddenInput)
|