OXIESEC PANEL
- Current Dir:
/
/
opt
/
alt
/
python37
/
lib
/
python3.7
/
site-packages
/
sentry_sdk
Server IP: 2a02:4780:11:1084:0:327f:3464:10
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
09/05/2025 09:36:16 AM
rwxr-xr-x
📄
__init__.py
854 bytes
07/27/2021 02:04:04 PM
rw-r--r--
📁
__pycache__
-
02/16/2024 09:01:45 PM
rwxr-xr-x
📄
_compat.py
2.3 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
_functools.py
2.22 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
_queue.py
8.21 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
_types.py
1.24 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
api.py
4.66 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
attachments.py
1.75 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
client.py
13.64 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
consts.py
3.6 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
debug.py
1.11 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
envelope.py
8.35 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
hub.py
21.62 KB
07/27/2021 02:04:04 PM
rw-r--r--
📁
integrations
-
02/16/2024 09:01:45 PM
rwxr-xr-x
📄
py.typed
0 bytes
07/27/2021 02:04:04 PM
rw-r--r--
📄
scope.py
15.62 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
serializer.py
15.92 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
session.py
5.41 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
sessions.py
5.69 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
tracing.py
25.22 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
transport.py
12.13 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
utils.py
26.79 KB
07/27/2021 02:04:04 PM
rw-r--r--
📄
worker.py
4.04 KB
07/27/2021 02:04:04 PM
rw-r--r--
Editing: worker.py
Close
import os import threading from time import sleep, time from sentry_sdk._compat import check_thread_support from sentry_sdk._queue import Queue, Full from sentry_sdk.utils import logger from sentry_sdk.consts import DEFAULT_QUEUE_SIZE from sentry_sdk._types import MYPY if MYPY: from typing import Any from typing import Optional from typing import Callable _TERMINATOR = object() class BackgroundWorker(object): def __init__(self, queue_size=DEFAULT_QUEUE_SIZE): # type: (int) -> None check_thread_support() self._queue = Queue(queue_size) # type: Queue self._lock = threading.Lock() self._thread = None # type: Optional[threading.Thread] self._thread_for_pid = None # type: Optional[int] @property def is_alive(self): # type: () -> bool if self._thread_for_pid != os.getpid(): return False if not self._thread: return False return self._thread.is_alive() def _ensure_thread(self): # type: () -> None if not self.is_alive: self.start() def _timed_queue_join(self, timeout): # type: (float) -> bool deadline = time() + timeout queue = self._queue queue.all_tasks_done.acquire() try: while queue.unfinished_tasks: delay = deadline - time() if delay <= 0: return False queue.all_tasks_done.wait(timeout=delay) return True finally: queue.all_tasks_done.release() def start(self): # type: () -> None with self._lock: if not self.is_alive: self._thread = threading.Thread( target=self._target, name="raven-sentry.BackgroundWorker" ) self._thread.daemon = True self._thread.start() self._thread_for_pid = os.getpid() def kill(self): # type: () -> None """ Kill worker thread. Returns immediately. Not useful for waiting on shutdown for events, use `flush` for that. """ logger.debug("background worker got kill request") with self._lock: if self._thread: try: self._queue.put_nowait(_TERMINATOR) except Full: logger.debug("background worker queue full, kill failed") self._thread = None self._thread_for_pid = None def flush(self, timeout, callback=None): # type: (float, Optional[Any]) -> None logger.debug("background worker got flush request") with self._lock: if self.is_alive and timeout > 0.0: self._wait_flush(timeout, callback) logger.debug("background worker flushed") def _wait_flush(self, timeout, callback): # type: (float, Optional[Any]) -> None initial_timeout = min(0.1, timeout) if not self._timed_queue_join(initial_timeout): pending = self._queue.qsize() + 1 logger.debug("%d event(s) pending on flush", pending) if callback is not None: callback(pending, timeout) if not self._timed_queue_join(timeout - initial_timeout): pending = self._queue.qsize() + 1 logger.error("flush timed out, dropped %s events", pending) def submit(self, callback): # type: (Callable[[], None]) -> bool self._ensure_thread() try: self._queue.put_nowait(callback) return True except Full: return False def _target(self): # type: () -> None while True: callback = self._queue.get() try: if callback is _TERMINATOR: break try: callback() except Exception: logger.error("Failed processing job", exc_info=True) finally: self._queue.task_done() sleep(0)