Server IP : 85.214.239.14 / Your IP : 18.191.28.200 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /srv/modoboa/env/lib/python3.5/site-packages/braces/views/ |
Upload File : |
import warnings from django.core.exceptions import ImproperlyConfigured class SelectRelatedMixin(object): """ Mixin allows you to provide a tuple or list of related models to perform a select_related on. """ select_related = None # Default related fields to none def get_queryset(self): if self.select_related is None: # If no fields were provided, raise a configuration error raise ImproperlyConfigured( '{0} is missing the select_related property. This must be ' 'a tuple or list.'.format(self.__class__.__name__)) if not isinstance(self.select_related, (tuple, list)): # If the select_related argument is *not* a tuple or list, # raise a configuration error. raise ImproperlyConfigured( "{0}'s select_related property must be a tuple or " "list.".format(self.__class__.__name__)) # Get the current queryset of the view queryset = super(SelectRelatedMixin, self).get_queryset() if not self.select_related: warnings.warn('The select_related attribute is empty') return queryset return queryset.select_related(*self.select_related) class PrefetchRelatedMixin(object): """ Mixin allows you to provide a tuple or list of related models to perform a prefetch_related on. """ prefetch_related = None # Default prefetch fields to none def get_queryset(self): if self.prefetch_related is None: # If no fields were provided, raise a configuration error raise ImproperlyConfigured( '{0} is missing the prefetch_related property. This must be ' 'a tuple or list.'.format(self.__class__.__name__)) if not isinstance(self.prefetch_related, (tuple, list)): # If the prefetch_related argument is *not* a tuple or list, # raise a configuration error. raise ImproperlyConfigured( "{0}'s prefetch_related property must be a tuple or " "list.".format(self.__class__.__name__)) # Get the current queryset of the view queryset = super(PrefetchRelatedMixin, self).get_queryset() if not self.prefetch_related: warnings.warn('The prefetch_related attribute is empty') return queryset return queryset.prefetch_related(*self.prefetch_related) class OrderableListMixin(object): """ Mixin allows your users to order records using GET parameters """ orderable_columns = None orderable_columns_default = None ordering_default = None order_by = None ordering = None def get_context_data(self, **kwargs): """ Augments context with: * ``order_by`` - name of the field * ``ordering`` - order of ordering, either ``asc`` or ``desc`` """ context = super(OrderableListMixin, self).get_context_data(**kwargs) context["order_by"] = self.order_by context["ordering"] = self.ordering return context def get_orderable_columns(self): if not self.orderable_columns: raise ImproperlyConfigured( '{0} needs the ordering columns defined.'.format( self.__class__.__name__)) return self.orderable_columns def get_orderable_columns_default(self): if not self.orderable_columns_default: raise ImproperlyConfigured( '{0} needs the default ordering column defined.'.format( self.__class__.__name__)) return self.orderable_columns_default def get_ordering_default(self): if not self.ordering_default: return "asc" else: if self.ordering_default not in ["asc", "desc"]: raise ImproperlyConfigured( '{0} only allows asc or desc as ordering option'.format( self.__class__.__name__)) return self.ordering_default def get_ordered_queryset(self, queryset=None): """ Augments ``QuerySet`` with order_by statement if possible :param QuerySet queryset: ``QuerySet`` to ``order_by`` :return: QuerySet """ get_order_by = self.request.GET.get("order_by") if get_order_by in self.get_orderable_columns(): order_by = get_order_by else: order_by = self.get_orderable_columns_default() self.order_by = order_by self.ordering = self.get_ordering_default() if order_by and self.request.GET.get( "ordering", self.ordering) == "desc": order_by = "-" + order_by self.ordering = self.request.GET.get("ordering", self.ordering) return queryset.order_by(order_by) def get_queryset(self): """ Returns ordered ``QuerySet`` """ unordered_queryset = super(OrderableListMixin, self).get_queryset() return self.get_ordered_queryset(unordered_queryset)