X7ROOT File Manager
Current Path:
/opt/imunify360/venv/lib/python3.11/site-packages/sentry_sdk/integrations
opt
/
imunify360
/
venv
/
lib
/
python3.11
/
site-packages
/
sentry_sdk
/
integrations
/
📁
..
📄
__init__.py
(6.36 KB)
📁
__pycache__
📄
_wsgi_common.py
(4.65 KB)
📄
aiohttp.py
(7.77 KB)
📄
argv.py
(945 B)
📄
asgi.py
(8.17 KB)
📄
atexit.py
(1.79 KB)
📄
aws_lambda.py
(12.64 KB)
📄
beam.py
(5.53 KB)
📄
boto3.py
(3.64 KB)
📄
bottle.py
(6.04 KB)
📄
celery.py
(8.91 KB)
📄
chalice.py
(4.47 KB)
📄
dedupe.py
(1.14 KB)
📁
django
📄
excepthook.py
(2.14 KB)
📄
executing.py
(1.98 KB)
📄
falcon.py
(6.64 KB)
📄
flask.py
(7.25 KB)
📄
gcp.py
(7.21 KB)
📄
gnu_backtrace.py
(2.84 KB)
📄
logging.py
(7.4 KB)
📄
modules.py
(1.36 KB)
📄
pure_eval.py
(4.41 KB)
📄
pyramid.py
(6.91 KB)
📄
redis.py
(3 KB)
📄
rq.py
(4.68 KB)
📄
sanic.py
(7.53 KB)
📄
serverless.py
(1.92 KB)
📁
spark
📄
sqlalchemy.py
(2.87 KB)
📄
stdlib.py
(7.18 KB)
📄
threading.py
(2.79 KB)
📄
tornado.py
(6.84 KB)
📄
trytond.py
(1.69 KB)
📄
wsgi.py
(10.13 KB)
Editing: threading.py
from __future__ import absolute_import import sys from threading import Thread, current_thread from sentry_sdk import Hub from sentry_sdk._compat import reraise from sentry_sdk._types import MYPY from sentry_sdk.integrations import Integration from sentry_sdk.utils import event_from_exception, capture_internal_exceptions if MYPY: from typing import Any from typing import TypeVar from typing import Callable from typing import Optional from sentry_sdk._types import ExcInfo F = TypeVar("F", bound=Callable[..., Any]) class ThreadingIntegration(Integration): identifier = "threading" def __init__(self, propagate_hub=False): # type: (bool) -> None self.propagate_hub = propagate_hub @staticmethod def setup_once(): # type: () -> None old_start = Thread.start def sentry_start(self, *a, **kw): # type: (Thread, *Any, **Any) -> Any hub = Hub.current integration = hub.get_integration(ThreadingIntegration) if integration is not None: if not integration.propagate_hub: hub_ = None else: hub_ = Hub(hub) # Patching instance methods in `start()` creates a reference cycle if # done in a naive way. See # https://github.com/getsentry/sentry-python/pull/434 # # In threading module, using current_thread API will access current thread instance # without holding it to avoid a reference cycle in an easier way. with capture_internal_exceptions(): new_run = _wrap_run(hub_, getattr(self.run, "__func__", self.run)) self.run = new_run # type: ignore return old_start(self, *a, **kw) # type: ignore Thread.start = sentry_start # type: ignore def _wrap_run(parent_hub, old_run_func): # type: (Optional[Hub], F) -> F def run(*a, **kw): # type: (*Any, **Any) -> Any hub = parent_hub or Hub.current with hub: try: self = current_thread() return old_run_func(self, *a, **kw) except Exception: reraise(*_capture_exception()) return run # type: ignore def _capture_exception(): # type: () -> ExcInfo hub = Hub.current exc_info = sys.exc_info() if hub.get_integration(ThreadingIntegration) is not None: # If an integration is there, a client has to be there. client = hub.client # type: Any event, hint = event_from_exception( exc_info, client_options=client.options, mechanism={"type": "threading", "handled": False}, ) hub.capture_event(event, hint=hint) return exc_info
Upload File
Create Folder