view kallithea/lib/middleware/sentry.py @ 5986:b99e00fb6dd4

lock: simplify debug logging - use the actual response code
author Mads Kiilerich <madski@unity3d.com>
date Sat, 25 Jun 2016 02:57:44 +0200
parents 1948ede028ef
children
line wrap: on
line source

# -*- coding: utf-8 -*-
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
"""
kallithea.lib.middleware.sentry
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

middleware to handle sentry/raven publishing of errors

This file was forked by the Kallithea project in July 2014.
Original author and date, and relevant copyright and licensing information is below:
:created_on: September 18, 2012
:author: marcink
:copyright: (c) 2013 RhodeCode GmbH, and others.
:license: GPLv3, see LICENSE.md for more details.
"""


try:
    from raven.base import Client
    from raven.contrib.pylons import list_from_setting
    from raven.middleware import Sentry as Middleware
except ImportError:
    Sentry = None
else:
    class Sentry(Middleware):
        def __init__(self, app, config, client_cls=Client):
            client = client_cls(
                dsn=config.get('sentry.dsn'),
                servers=list_from_setting(config, 'sentry.servers'),
                name=config.get('sentry.name'),
                key=config.get('sentry.key'),
                public_key=config.get('sentry.public_key'),
                secret_key=config.get('sentry.secret_key'),
                project=config.get('sentry.project'),
                site=config.get('sentry.site'),
                include_paths=list_from_setting(config, 'sentry.include_paths'),
                exclude_paths=list_from_setting(config, 'sentry.exclude_paths'),
            )
            super(Sentry, self).__init__(app, client)