Skip to main content

Customizable errors handler for flask application and blueprints

Project description

Set customizable default errors handler for flask app and blueprints.

You can register error handler for:

  • api that returns JSON, default response is as API problem specification like (see https://tools.ietf.org/html/rfc7807). Instead you can use your own response implementation passed as argument to ErrorHandler class: it must be a decorator and must take 3 args, a dict response, status code and dict headers.

  • web that returns html page or api response if request is XHR

  • you can register custom handlers for blueprint or the entire app

This module provide also an abstract ErrorDispatcher class in order to dispatch 404 or 405 error to the correct blueprint because flask Blueprint does not own url_prefix (see https://github.com/pallets/flask/issues/1498).

There are 2 concrete implementation:

  • SubdomainDispatcher: dispatch the error to the handler associate with blueprint with certain subdomain (if 2 or more Blueprint has the same subdomain the first blueprint handler matched is used)

  • URLPrefixDispatcher: dispatch the error to the handler associate with blueprint with certain url prefix. This will not work if 2 Blueprint are registered under the same url prefix, for example: Blueprint A registered under /prefix/blueprint, Blueprint B registered under /prefix, this dispatcher executes the handler of B in both case if B is registered after A.

Moreover you can create you own dispatcher by extending ErrorDispatcher class and implementing dispatch method. Only the last ErrorDispatcher registered is execute. This is the best solution I have found, suggestions are welcome.

QuickStart

Install flask_errors_handler using pip:

$ pip install Flask-ErrorsHandler

Example usage

from flask import Flask
from flask import abort
from flask import Blueprint

from flask_errors_handler import ErrorHandler


app = Flask(__name__)
app.config['ERROR_PAGE'] = 'error.html'

error = ErrorHandler(app)

custom = Blueprint('custom', __name__)
web = Blueprint('web', __name__)

error.api_register(app)
error.web_register(web)

@error.register(custom)
def error_handler(exc):
    return str(exc), 500, {'Content-Type': 'text/plain'}


@app.route('/api')
def index():
    abort(500, 'Error from app')


@web.route('/web')
def index():
    abort(500, 'Error from web blueprint')


@custom.route('/custom')
def index():
    abort(500, 'Error from custom blueprint')


app.register_blueprint(web)
app.run()

Configuration

  1. ERROR_PAGE: (default: None) path of html template to use for show error message

  2. ERROR_DEFAULT_MSG: (default: Unhandled Exception) default message for unhandled exceptions

  3. ERROR_XHR_ENABLED: (default: True) enable or disable api response where request is XHR

License MIT

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

Flask-ErrorsHandler-2.2.0.tar.gz (7.6 kB view details)

Uploaded Source

Built Distribution

Flask_ErrorsHandler-2.2.0-py3-none-any.whl (12.0 kB view details)

Uploaded Python 3

File details

Details for the file Flask-ErrorsHandler-2.2.0.tar.gz.

File metadata

  • Download URL: Flask-ErrorsHandler-2.2.0.tar.gz
  • Upload date:
  • Size: 7.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/39.1.0 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.6.5

File hashes

Hashes for Flask-ErrorsHandler-2.2.0.tar.gz
Algorithm Hash digest
SHA256 3616b3a5c05c51fee939100ac374738d4db81e701afd06e36c03e43354abb032
MD5 e5c1f51b0e57d27b77b9d461d47f74d3
BLAKE2b-256 5736da2eb99a4790327c96636b89cebf9b3c58d644de343270a80f0d43a4f4d3

See more details on using hashes here.

File details

Details for the file Flask_ErrorsHandler-2.2.0-py3-none-any.whl.

File metadata

  • Download URL: Flask_ErrorsHandler-2.2.0-py3-none-any.whl
  • Upload date:
  • Size: 12.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/39.1.0 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.6.5

File hashes

Hashes for Flask_ErrorsHandler-2.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bc2b5a2eabffa9deb4d6deca81d0ea13199837bcba749268fd02e36eb6891f3c
MD5 57bae8e27ca932c5ae85c24ab5800b7d
BLAKE2b-256 2acb6e75fe40ad2c154a96466a8cba9dde63617a3ffd10369b60af52c8e15199

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