Server IP : 66.29.132.122 / Your IP : 3.128.172.185 Web Server : LiteSpeed System : Linux business142.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : admazpex ( 531) PHP Version : 7.2.34 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /opt/hc_python/lib/python3.8/site-packages/sentry_sdk/ |
Upload File : |
import sys from typing import TYPE_CHECKING if TYPE_CHECKING: from typing import Any from typing import TypeVar T = TypeVar("T") PY37 = sys.version_info[0] == 3 and sys.version_info[1] >= 7 PY38 = sys.version_info[0] == 3 and sys.version_info[1] >= 8 PY310 = sys.version_info[0] == 3 and sys.version_info[1] >= 10 PY311 = sys.version_info[0] == 3 and sys.version_info[1] >= 11 def with_metaclass(meta, *bases): # type: (Any, *Any) -> Any class MetaClass(type): def __new__(metacls, name, this_bases, d): # type: (Any, Any, Any, Any) -> Any return meta(name, bases, d) return type.__new__(MetaClass, "temporary_class", (), {}) def check_uwsgi_thread_support(): # type: () -> bool # We check two things here: # # 1. uWSGI doesn't run in threaded mode by default -- issue a warning if # that's the case. # # 2. Additionally, if uWSGI is running in preforking mode (default), it needs # the --py-call-uwsgi-fork-hooks option for the SDK to work properly. This # is because any background threads spawned before the main process is # forked are NOT CLEANED UP IN THE CHILDREN BY DEFAULT even if # --enable-threads is on. One has to explicitly provide # --py-call-uwsgi-fork-hooks to force uWSGI to run regular cpython # after-fork hooks that take care of cleaning up stale thread data. try: from uwsgi import opt # type: ignore except ImportError: return True from sentry_sdk.consts import FALSE_VALUES def enabled(option): # type: (str) -> bool value = opt.get(option, False) if isinstance(value, bool): return value if isinstance(value, bytes): try: value = value.decode() except Exception: pass return value and str(value).lower() not in FALSE_VALUES # When `threads` is passed in as a uwsgi option, # `enable-threads` is implied on. threads_enabled = "threads" in opt or enabled("enable-threads") fork_hooks_on = enabled("py-call-uwsgi-fork-hooks") lazy_mode = enabled("lazy-apps") or enabled("lazy") if lazy_mode and not threads_enabled: from warnings import warn warn( Warning( "IMPORTANT: " "We detected the use of uWSGI without thread support. " "This might lead to unexpected issues. " 'Please run uWSGI with "--enable-threads" for full support.' ) ) return False elif not lazy_mode and (not threads_enabled or not fork_hooks_on): from warnings import warn warn( Warning( "IMPORTANT: " "We detected the use of uWSGI in preforking mode without " "thread support. This might lead to crashing workers. " 'Please run uWSGI with both "--enable-threads" and ' '"--py-call-uwsgi-fork-hooks" for full support.' ) ) return False return True