Skip to main content

Bounce users out of your view by raising an exception

Project description

Bounce users out of your view by raising an exception

Introduction

You’re probably used to this sort of workflow:

from django.http import Http404
from django.views.generic import TemplateView

class MyView(TemplateView):
    def get_context(self, **kwargs):
        # do some stuff
        raise Http404

…but wouldn’t it be nice if rather than just bombing out with a 404, you could bounce the user out to a redirect and attach a friendly message? That’s what django-tigger does!

from django.core.urlresolvers import reverse
from django.views.generic import TemplateView
from tigger.exceptions import Bounce

class MyView(TemplateView):
    def get_context(self, **kwargs):
        # do some stuff
        raise Bounce(
            reverse("some-url"),
            message="The wonderful thing about tiggers...",
            level="SUCCESS"
        )

The above code will bounce the user to whatever some-url resolves to and dump a message on the screen using the Django messaging framework.

Installation

  1. Use pip: pip install django-tigger.

  2. Add django_tigger.middleware.BouncingMiddleware to your MIDDLEWARE list in your Django settings. Note that you don’t need to add this to INSTALLED_APPS as this package doesn’t have any models, migrations, or anything that would require that.

Use

Basically anywhere you want to just bail out of your current process and instead redirect the user, call Bounce() and pass in a few arguments:

  • url: The only required argument, this is where you’re bouncing your user to.

  • message: If supplied, this will attach a message to the user’s session using the Django messaging framework

  • level: The level of the message. Must be one of DEBUG, INFO, SUCCESS, WARNING, ERROR. The default is INFO.

Support

I’ve used this in Python 3 and Django 1.11, but I see no reason why it wouldn’t work in Python 2.7 and Django 1.10. Older than that though, and you’ll have trouble. Newer than that, and you should be fine.

This isn’t particularly complex code ;-)

Colophon

The wonderful thing about tiggers
Is tiggers are wonderful things
Their tops are made out of rubber
Their bottoms are made out of springs
They're bouncy, trouncy, flouncy, pouncy fun, fun, fun, fun, fun
But the most wonderful thing about tiggers is I'm the only one
I'm the only one.
-- Winnie the Pooh and Tigger Too!, 1974

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-tigger-1.1.0.tar.gz (3.4 kB view details)

Uploaded Source

Built Distribution

django_tigger-1.1.0-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file django-tigger-1.1.0.tar.gz.

File metadata

File hashes

Hashes for django-tigger-1.1.0.tar.gz
Algorithm Hash digest
SHA256 6aaab4cde698efdbf992fdb14e8e4944a1b45202b1d4d73ba096619499c58f10
MD5 331de0b20815df26db61faab538d7b81
BLAKE2b-256 12f9023b9b46be28c6ba9b0dfd644d678940648e8c3ebaf63bc931d1ee9a77be

See more details on using hashes here.

File details

Details for the file django_tigger-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for django_tigger-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5bec7d21e9081ff0fc200bdd99b340b84d20b4df401ff5a2990a762542b9eaae
MD5 52d9a8f239076f3c57851c2f4010f27a
BLAKE2b-256 c7df0faf797f42be5f6fe057c85997b9ea6584e90fab658c447c0bbceea81d3d

See more details on using hashes here.

Supported by

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