X7ROOT File Manager
Current Path:
/opt/cloudlinux/venv/lib/python3.11/site-packages/sentry_sdk/integrations
opt
/
cloudlinux
/
venv
/
lib
/
python3.11
/
site-packages
/
sentry_sdk
/
integrations
/
ðŸ“
..
📄
__init__.py
(6.67 KB)
ðŸ“
__pycache__
📄
_wsgi_common.py
(4.43 KB)
📄
aiohttp.py
(11.28 KB)
📄
argv.py
(963 B)
📄
arq.py
(6.58 KB)
📄
asgi.py
(11.54 KB)
📄
asyncio.py
(2.98 KB)
📄
atexit.py
(1.8 KB)
📄
aws_lambda.py
(15.44 KB)
📄
beam.py
(5.56 KB)
📄
boto3.py
(4.44 KB)
📄
bottle.py
(6.32 KB)
📄
celery.py
(18.65 KB)
📄
chalice.py
(4.66 KB)
📄
cloud_resource_context.py
(6.6 KB)
📄
dedupe.py
(1.16 KB)
ðŸ“
django
📄
excepthook.py
(2.21 KB)
📄
executing.py
(1.99 KB)
📄
falcon.py
(7.8 KB)
📄
fastapi.py
(4.39 KB)
📄
flask.py
(7.72 KB)
📄
gcp.py
(8.02 KB)
📄
gnu_backtrace.py
(2.86 KB)
ðŸ“
grpc
📄
httpx.py
(4.89 KB)
📄
huey.py
(4.59 KB)
📄
logging.py
(8.97 KB)
📄
loguru.py
(2.98 KB)
📄
modules.py
(2.06 KB)
ðŸ“
opentelemetry
📄
pure_eval.py
(4.45 KB)
📄
pymongo.py
(5.87 KB)
📄
pyramid.py
(7.27 KB)
📄
quart.py
(7.2 KB)
ðŸ“
redis
📄
rq.py
(5.28 KB)
📄
sanic.py
(11.06 KB)
📄
serverless.py
(1.93 KB)
📄
socket.py
(2.88 KB)
ðŸ“
spark
📄
sqlalchemy.py
(4.14 KB)
📄
starlette.py
(22.67 KB)
📄
starlite.py
(9.85 KB)
📄
stdlib.py
(8.06 KB)
📄
threading.py
(2.87 KB)
📄
tornado.py
(7.17 KB)
📄
trytond.py
(1.7 KB)
📄
wsgi.py
(9.36 KB)
Editing: _wsgi_common.py
import json from copy import deepcopy from sentry_sdk.hub import Hub, _should_send_default_pii from sentry_sdk.utils import AnnotatedValue from sentry_sdk._compat import text_type, iteritems from sentry_sdk._types import TYPE_CHECKING if TYPE_CHECKING: import sentry_sdk from typing import Any from typing import Dict from typing import Optional from typing import Union SENSITIVE_ENV_KEYS = ( "REMOTE_ADDR", "HTTP_X_FORWARDED_FOR", "HTTP_SET_COOKIE", "HTTP_COOKIE", "HTTP_AUTHORIZATION", "HTTP_X_API_KEY", "HTTP_X_FORWARDED_FOR", "HTTP_X_REAL_IP", ) SENSITIVE_HEADERS = tuple( x[len("HTTP_") :] for x in SENSITIVE_ENV_KEYS if x.startswith("HTTP_") ) def request_body_within_bounds(client, content_length): # type: (Optional[sentry_sdk.Client], int) -> bool if client is None: return False bodies = client.options["max_request_body_size"] return not ( bodies == "never" or (bodies == "small" and content_length > 10**3) or (bodies == "medium" and content_length > 10**4) ) class RequestExtractor(object): def __init__(self, request): # type: (Any) -> None self.request = request def extract_into_event(self, event): # type: (Dict[str, Any]) -> None client = Hub.current.client if client is None: return data = None # type: Optional[Union[AnnotatedValue, Dict[str, Any]]] content_length = self.content_length() request_info = event.get("request", {}) if _should_send_default_pii(): request_info["cookies"] = dict(self.cookies()) if not request_body_within_bounds(client, content_length): data = AnnotatedValue.removed_because_over_size_limit() else: parsed_body = self.parsed_body() if parsed_body is not None: data = parsed_body elif self.raw_data(): data = AnnotatedValue.removed_because_raw_data() else: data = None if data is not None: request_info["data"] = data event["request"] = deepcopy(request_info) def content_length(self): # type: () -> int try: return int(self.env().get("CONTENT_LENGTH", 0)) except ValueError: return 0 def cookies(self): # type: () -> Dict[str, Any] raise NotImplementedError() def raw_data(self): # type: () -> Optional[Union[str, bytes]] raise NotImplementedError() def form(self): # type: () -> Optional[Dict[str, Any]] raise NotImplementedError() def parsed_body(self): # type: () -> Optional[Dict[str, Any]] form = self.form() files = self.files() if form or files: data = dict(iteritems(form)) for key, _ in iteritems(files): data[key] = AnnotatedValue.removed_because_raw_data() return data return self.json() def is_json(self): # type: () -> bool return _is_json_content_type(self.env().get("CONTENT_TYPE")) def json(self): # type: () -> Optional[Any] try: if not self.is_json(): return None raw_data = self.raw_data() if raw_data is None: return None if isinstance(raw_data, text_type): return json.loads(raw_data) else: return json.loads(raw_data.decode("utf-8")) except ValueError: pass return None def files(self): # type: () -> Optional[Dict[str, Any]] raise NotImplementedError() def size_of_file(self, file): # type: (Any) -> int raise NotImplementedError() def env(self): # type: () -> Dict[str, Any] raise NotImplementedError() def _is_json_content_type(ct): # type: (Optional[str]) -> bool mt = (ct or "").split(";", 1)[0] return ( mt == "application/json" or (mt.startswith("application/")) and mt.endswith("+json") ) def _filter_headers(headers): # type: (Dict[str, str]) -> Dict[str, str] if _should_send_default_pii(): return headers return { k: ( v if k.upper().replace("-", "_") not in SENSITIVE_HEADERS else AnnotatedValue.removed_because_over_size_limit() ) for k, v in iteritems(headers) }
Upload File
Create Folder