Metadata-Version: 2.1
Name: sentry-asgi
Version: 0.1.5
Summary: Sentry integration for ASGI frameworks.
Home-page: https://github.com/encode/sentry-asgi
Author: Tom Christie
Author-email: tom@tomchristie.com
License: BSD
Description: # sentry-asgi
        
        <a href="https://travis-ci.org/encode/sentry-asgi">
            <img src="https://travis-ci.org/encode/sentry-asgi.svg?branch=master" alt="Build Status">
        </a>
        <a href="https://codecov.io/gh/encode/sentry-asgi">
            <img src="https://codecov.io/gh/encode/sentry-asgi/branch/master/graph/badge.svg" alt="Coverage">
        </a>
        <a href="https://pypi.org/project/sentry-asgi/">
            <img src="https://badge.fury.io/py/sentry-asgi.svg" alt="Package version">
        </a>
        
        Sentry integration for ASGI frameworks.
        
        Installation:
        
        ```shell
        pip install sentry-asgi
        ```
        
        Usage:
        
        ```python
        from sentry_asgi import SentryMiddleware
        import sentry_sdk
        
        
        sentry_sdk.init(dsn=...)
        
        app = ...
        app = SentryMiddleware(app)
        ```
        
        Here's a more complete example, using Starlette:
        
        ```python
        import sentry_sdk
        from sentry_asgi import SentryMiddleware
        from sentry_asgi.executor import ContextPreservingExecutor  # Python 3.7+
        
        sentry_sdk.init(dsn=...)
        
        app = Starlette()
        
        @app.route("/")
        def homepage(request):
            raise ValueError("nope")
        
        @app.on_event("startup")
        async def setup_executor():
            executor = ContextPreservingExecutor()
            loop = asyncio.get_event_loop()
            loop.set_default_executor(executor)
        
        app.add_middleware(SentryMiddleware)
        ```
        
        ## Notes
        
        ### Python version support
        
        The Sentry SDK requires Python 3.7's `contextvars` support in order to properly
        tie messages and logging back to the request context that is added SentryMiddleware.
        
        On 3.6 and below the SentryMiddleware will capture and log application exceptions just fine,
        but will not properly tie in logging, messages, or breadcrumbs for any code that
        runs within a threadpool executor or subtask.
        
        ASGI frameworks should ensure that any thread pool executors [preserve the `contextvar` context](https://github.com/django/asgiref/issues/71).
        
        ### Endpoint information
        
        It is recommended that frameworks populate an "endpoint" key in the ASGI scope,
        to indicate which view function or class should be logged by the middleware.
        
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Environment :: Web Environment
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Operating System :: OS Independent
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Description-Content-Type: text/markdown
