OXIESEC PANEL
- Current Dir:
/
/
opt
/
alt
/
python37
/
lib
/
python3.7
/
site-packages
/
sentry_sdk
/
integrations
Server IP: 2a02:4780:11:1084:0:327f:3464:10
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
02/16/2024 09:01:45 PM
rwxr-xr-x
📄
__init__.py
6.36 KB
07/27/2021 02:04:04 PM
rw-r--r--
📁
__pycache__
-
02/16/2024 09:01:45 PM
rwxr-xr-x
📄
_wsgi_common.py
4.65 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
aiohttp.py
7.77 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
argv.py
945 bytes
07/27/2021 02:04:04 PM
rw-r--r--
📄
asgi.py
8.26 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
atexit.py
1.79 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
aws_lambda.py
14.99 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
beam.py
5.53 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
boto3.py
4.05 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
bottle.py
6.06 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
celery.py
9.31 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
chalice.py
4.5 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
dedupe.py
1.14 KB
07/27/2021 02:04:04 PM
rw-r--r--
📁
django
-
02/16/2024 09:01:45 PM
rwxr-xr-x
📄
excepthook.py
2.14 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
executing.py
1.98 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
falcon.py
6.64 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
flask.py
7.3 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
gcp.py
7.84 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
gnu_backtrace.py
2.84 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
httpx.py
2.55 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
logging.py
7.54 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
modules.py
1.36 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
pure_eval.py
4.41 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
pyramid.py
6.91 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
redis.py
3 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
rq.py
4.84 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
sanic.py
8.44 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
serverless.py
1.92 KB
07/27/2021 02:04:04 PM
rw-r--r--
📁
spark
-
02/16/2024 09:01:45 PM
rwxr-xr-x
📄
sqlalchemy.py
2.87 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
stdlib.py
7.25 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
threading.py
2.79 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
tornado.py
7.02 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
trytond.py
1.69 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
wsgi.py
10.89 KB
07/27/2021 02:04:04 PM
rw-r--r--
Editing: redis.py
Close
from __future__ import absolute_import from sentry_sdk import Hub from sentry_sdk.utils import capture_internal_exceptions, logger from sentry_sdk.integrations import Integration from sentry_sdk._types import MYPY if MYPY: from typing import Any _SINGLE_KEY_COMMANDS = frozenset( ["decr", "decrby", "get", "incr", "incrby", "pttl", "set", "setex", "setnx", "ttl"] ) _MULTI_KEY_COMMANDS = frozenset(["del", "touch", "unlink"]) def _patch_rediscluster(): # type: () -> None try: import rediscluster # type: ignore except ImportError: return patch_redis_client(rediscluster.RedisCluster) # up to v1.3.6, __version__ attribute is a tuple # from v2.0.0, __version__ is a string and VERSION a tuple version = getattr(rediscluster, "VERSION", rediscluster.__version__) # StrictRedisCluster was introduced in v0.2.0 and removed in v2.0.0 # https://github.com/Grokzen/redis-py-cluster/blob/master/docs/release-notes.rst if (0, 2, 0) < version < (2, 0, 0): patch_redis_client(rediscluster.StrictRedisCluster) class RedisIntegration(Integration): identifier = "redis" @staticmethod def setup_once(): # type: () -> None import redis patch_redis_client(redis.StrictRedis) try: import rb.clients # type: ignore except ImportError: pass else: patch_redis_client(rb.clients.FanoutClient) patch_redis_client(rb.clients.MappingClient) patch_redis_client(rb.clients.RoutingClient) try: _patch_rediscluster() except Exception: logger.exception("Error occurred while patching `rediscluster` library") def patch_redis_client(cls): # type: (Any) -> None """ This function can be used to instrument custom redis client classes or subclasses. """ old_execute_command = cls.execute_command def sentry_patched_execute_command(self, name, *args, **kwargs): # type: (Any, str, *Any, **Any) -> Any hub = Hub.current if hub.get_integration(RedisIntegration) is None: return old_execute_command(self, name, *args, **kwargs) description = name with capture_internal_exceptions(): description_parts = [name] for i, arg in enumerate(args): if i > 10: break description_parts.append(repr(arg)) description = " ".join(description_parts) with hub.start_span(op="redis", description=description) as span: if name: span.set_tag("redis.command", name) if name and args: name_low = name.lower() if (name_low in _SINGLE_KEY_COMMANDS) or ( name_low in _MULTI_KEY_COMMANDS and len(args) == 1 ): span.set_tag("redis.key", args[0]) return old_execute_command(self, name, *args, **kwargs) cls.execute_command = sentry_patched_execute_command