Skip to main content

Avoid boring views and urls.

Project description

Problematic

When having a look at Ruby on Rails, I discovered a nice feature that was missing in Django: controllers. Contrary to what I often read, views in Django are not really equivalent to controllers in Rails. A Rails controller basically is a set of Django views and Django URL patterns. Apart from driving off boring URL work, this is a clean way to group views that belongs to the same model.

Any good djangonaut would make the connection with generic views − especially class-based. This is the easiest solution to avoid repeating the same code with a few changes. But this is not simplifying URL patterns and we often have to define such files:

# views.py
from django.views.generic import ListView, DetailView  # and so on…
from .models import Example


class ExampleListView(ListView):
    model = Example


class ExampleDetailView(DetailView):
    model = Example

# and so on…
# urls.py
from django.urls import path
from .views import *


urlpatterns = [
    path('examples/', ExampleListView.as_view(), name='example_index'),
    path('examples/<int:pk>', ExampleDetailView.as_view(),
        name='example_detail'),
    # and so on…
]

With a single model, this looks easy. With complex applications containing dozens of models, this looks painful − and definitely not DRY [1].

Solution

django-viewsets proposes a solution inspired of Rails controllers. ViewSet is a class that builds a set of URL patterns from a set of class-based generic views. It is designed to be overridable, so that it fits standard as well as advanced use.

Installation

[sudo] pip install django-viewsets

You don’t have to change your project settings.py.

Usage

ModelViewSet

Provided views and urls

Generic view

URL

URL name

ListView

your-models/

your-model_index

DetailView

your-models/[pk]

your-model_detail

CreateView

your-models/create/

your-model_create

UpdateView

your-models/[pk]/update

your-model_update

DeleteView

your-models/[pk]/delete

your-model_delete

Basic use

In your application (or project) urls.py:

from django.urls import path, include
from viewsets import ModelViewSet
from .models import YourModel

urlpatterns = [
    path('', include(ModelViewSet(YourModel).urls)),
]

You can also provide other basic attributes as keyword arguments. For example, if you want to use slugs instead of primary keys in URL patterns, lines 2 and 6 become:

from viewsets import ModelViewSet, SLUG  # line 2
url('', include(ModelViewSet(YourModel, id_pattern=SLUG).urls)),  # line 6

Advanced use

This allow more customization.

In your application views.py:

from viewsets import ModelViewSet
from .models import YourModel

class YourModelViewSet(ModelViewSet):
    model = YourModel

In your application (or project) urls.py:

from django.urls import path, include
from .views import YourModelViewSet

urlpatterns = [
    path('', include(YourModelViewSet().urls)),
]

What is interesting in this use is that you can easily customize views and urls. Let’s say you want to use primary keys in update and delete url patterns, but you want to use slugs in detail view. The fastest way to do it is:

from viewsets import ModelViewSet, SLUG

class CustomModelViewSet(ModelViewSet):
    def __init__(self, *args, **kwargs):
        self.views['detail_view']['pattern'] = SLUG
        super(CustomModelViewSet, self).__init__(*args, **kwargs)

Here we don’t set the model attribute, so that CustomModelViewSet can be used for any of your models. Of course, you can now use CustomModelViewSet with basic use as well as Advanced use. And we could have set model, if this viewset was meant to be used only with a specific model.

Basic Attributes

model

The model class from which ModelViewSet will create views and urls. This is the only mandatory attribute.

base_url_pattern

Overrides your-models in all URL patterns. Calculated from model._meta.verbose_name_plural if unset.

base_url_name

Overrides your-model in all URL names. Calculated from model._meta.verbose_name if unset.

id_pattern

Overrides [pk] in all URL patterns. You can either use viewsets.PK or viewsets.SLUG.

excluded_views

A sequence of keys from the views. Unset by default. Example: ('create_view', 'delete_view',).

namespace

Set this if your application has a URL namespace. It is used to redirect to main_view in delete_view. You can also set main_url.

main_view

Used to calculate main_url. 'list_view' by default.

main_url

The main url where delete_view redirects. If set, main_view is ignored.

Advanced attributes

views

Dictionary defining views and URLs. CRUD [2] by default.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_viewsets-0.3.0.tar.gz (6.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_viewsets-0.3.0-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file django_viewsets-0.3.0.tar.gz.

File metadata

  • Download URL: django_viewsets-0.3.0.tar.gz
  • Upload date:
  • Size: 6.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.15

File hashes

Hashes for django_viewsets-0.3.0.tar.gz
Algorithm Hash digest
SHA256 eba954004cf39fd3cbbe909252300f63406c2c4e23f99949fce2f3ea5b3c26b5
MD5 423d163d4e8d93e7ef0f2d8c3c036b7d
BLAKE2b-256 1fbc6872a9a59839bb52b8446eb07038d4b5e06aaa89eac35bc962e49178ab74

See more details on using hashes here.

File details

Details for the file django_viewsets-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_viewsets-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 57eb0b65a6e25fab9b236de9b1ffa8b16ff61e9cc24ea72069672325ff5bbf73
MD5 52bd8d166e5d6e10eeb1056ffc9f0cfb
BLAKE2b-256 f8e5733606dd02cd39d42f0cff8d4b2f0494c2744172b051d58087da09fadad1

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page