PATH:
opt
/
hc_python
/
lib
/
python3.12
/
site-packages
/
sentry_sdk
/
integrations
import sys import functools import sentry_sdk from sentry_sdk.consts import OP from sentry_sdk.integrations import Integration, DidNotEnable from sentry_sdk.utils import event_from_exception, logger, reraise try: import asyncio from asyncio.tasks import Task except ImportError: raise DidNotEnable("asyncio not available") from typing import cast, TYPE_CHECKING if TYPE_CHECKING: from typing import Any, Callable, TypeVar from collections.abc import Coroutine from sentry_sdk._types import ExcInfo T = TypeVar("T", bound=Callable[..., Any]) def get_name(coro): # type: (Any) -> str return ( getattr(coro, "__qualname__", None) or getattr(coro, "__name__", None) or "coroutine without __name__" ) def _wrap_coroutine(wrapped): # type: (Coroutine[Any, Any, Any]) -> Callable[[T], T] # Only __name__ and __qualname__ are copied from function to coroutine in CPython return functools.partial( functools.update_wrapper, wrapped=wrapped, # type: ignore assigned=("__name__", "__qualname__"), updated=(), ) def patch_asyncio(): # type: () -> None orig_task_factory = None try: loop = asyncio.get_running_loop() orig_task_factory = loop.get_task_factory() def _sentry_task_factory(loop, coro, **kwargs): # type: (asyncio.AbstractEventLoop, Coroutine[Any, Any, Any], Any) -> asyncio.Future[Any] @_wrap_coroutine(coro) async def _task_with_sentry_span_creation(): # type: () -> Any result = None with sentry_sdk.isolation_scope(): with sentry_sdk.start_span( op=OP.FUNCTION, name=get_name(coro), origin=AsyncioIntegration.origin, ): try: result = await coro except StopAsyncIteration as e: raise e from None except Exception: reraise(*_capture_exception()) return result task = None # Trying to use user set task factory (if there is one) if orig_task_factory: task = orig_task_factory( loop, _task_with_sentry_span_creation(), **kwargs ) if task is None: # The default task factory in `asyncio` does not have its own function # but is just a couple of lines in `asyncio.base_events.create_task()` # Those lines are copied here. # WARNING: # If the default behavior of the task creation in asyncio changes, # this will break! task = Task(_task_with_sentry_span_creation(), loop=loop, **kwargs) if task._source_traceback: # type: ignore del task._source_traceback[-1] # type: ignore # Set the task name to include the original coroutine's name try: cast("asyncio.Task[Any]", task).set_name( f"{get_name(coro)} (Sentry-wrapped)" ) except AttributeError: # set_name might not be available in all Python versions pass return task loop.set_task_factory(_sentry_task_factory) # type: ignore except RuntimeError: # When there is no running loop, we have nothing to patch. logger.warning( "There is no running asyncio loop so there is nothing Sentry can patch. " "Please make sure you call sentry_sdk.init() within a running " "asyncio loop for the AsyncioIntegration to work. " "See https://docs.sentry.io/platforms/python/integrations/asyncio/" ) def _capture_exception(): # type: () -> ExcInfo exc_info = sys.exc_info() client = sentry_sdk.get_client() integration = client.get_integration(AsyncioIntegration) if integration is not None: event, hint = event_from_exception( exc_info, client_options=client.options, mechanism={"type": "asyncio", "handled": False}, ) sentry_sdk.capture_event(event, hint=hint) return exc_info class AsyncioIntegration(Integration): identifier = "asyncio" origin = f"auto.function.{identifier}" @staticmethod def setup_once(): # type: () -> None patch_asyncio()
[-] gql.py
[edit]
[-] loguru.py
[edit]
[-] gnu_backtrace.py
[edit]
[-] sys_exit.py
[edit]
[-] wsgi.py
[edit]
[-] modules.py
[edit]
[-] aiohttp.py
[edit]
[-] serverless.py
[edit]
[-] quart.py
[edit]
[+]
__pycache__
[-] bottle.py
[edit]
[-] typer.py
[edit]
[-] tornado.py
[edit]
[-] __init__.py
[edit]
[-] launchdarkly.py
[edit]
[-] mcp.py
[edit]
[-] openfeature.py
[edit]
[-] pyramid.py
[edit]
[-] dedupe.py
[edit]
[-] socket.py
[edit]
[-] _asgi_common.py
[edit]
[-] arq.py
[edit]
[-] clickhouse_driver.py
[edit]
[-] sanic.py
[edit]
[-] unraisablehook.py
[edit]
[-] langgraph.py
[edit]
[-] otlp.py
[edit]
[-] aws_lambda.py
[edit]
[-] beam.py
[edit]
[-] atexit.py
[edit]
[-] asyncio.py
[edit]
[+]
openai_agents
[-] ariadne.py
[edit]
[+]
redis
[-] rq.py
[edit]
[-] dramatiq.py
[edit]
[-] starlette.py
[edit]
[-] _wsgi_common.py
[edit]
[-] cohere.py
[edit]
[-] huey.py
[edit]
[-] executing.py
[edit]
[+]
celery
[-] asyncpg.py
[edit]
[-] pymongo.py
[edit]
[-] argv.py
[edit]
[-] anthropic.py
[edit]
[-] httpx.py
[edit]
[-] chalice.py
[edit]
[-] ray.py
[edit]
[+]
opentelemetry
[-] litellm.py
[edit]
[-] huggingface_hub.py
[edit]
[-] stdlib.py
[edit]
[+]
google_genai
[+]
..
[-] threading.py
[edit]
[-] openai.py
[edit]
[+]
pydantic_ai
[-] falcon.py
[edit]
[+]
spark
[-] unleash.py
[edit]
[-] langchain.py
[edit]
[+]
django
[-] litestar.py
[edit]
[-] gcp.py
[edit]
[-] logging.py
[edit]
[-] excepthook.py
[edit]
[+]
grpc
[-] statsig.py
[edit]
[-] cloud_resource_context.py
[edit]
[-] sqlalchemy.py
[edit]
[-] trytond.py
[edit]
[-] fastapi.py
[edit]
[-] boto3.py
[edit]
[-] flask.py
[edit]
[-] asgi.py
[edit]
[-] rust_tracing.py
[edit]
[-] graphene.py
[edit]
[-] strawberry.py
[edit]
[-] pure_eval.py
[edit]
[-] starlite.py
[edit]