SILENT KILLERPanel

Current Path: > > opt > alt > python38 > lib > > python3.8 > site-packages > sentry_sdk > integrations


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/alt/python38/lib//python3.8/site-packages/sentry_sdk/integrations

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
django Directory - -
__init__.py File 4236 bytes April 05 2019 23:15:16.
_wsgi_common.py File 3666 bytes April 05 2019 23:15:16.
aiohttp.py File 3889 bytes April 05 2019 23:15:16.
argv.py File 894 bytes April 05 2019 23:15:16.
atexit.py File 1490 bytes April 05 2019 23:15:16.
aws_lambda.py File 6758 bytes April 05 2019 23:15:16.
bottle.py File 5527 bytes April 05 2019 23:15:16.
celery.py File 4423 bytes April 05 2019 23:15:16.
dedupe.py File 1085 bytes April 05 2019 23:15:16.
excepthook.py File 1335 bytes April 05 2019 23:15:16.
flask.py File 7272 bytes April 05 2019 23:15:16.
gnu_backtrace.py File 3008 bytes April 05 2019 23:15:16.
logging.py File 6019 bytes April 05 2019 23:15:16.
modules.py File 1239 bytes April 05 2019 23:15:16.
pyramid.py File 5914 bytes April 05 2019 23:15:16.
rq.py File 3273 bytes April 05 2019 23:15:16.
sanic.py File 7065 bytes April 05 2019 23:15:16.
serverless.py File 1238 bytes April 05 2019 23:15:16.
stdlib.py File 1869 bytes April 05 2019 23:15:16.
threading.py File 1597 bytes April 05 2019 23:15:16.
tornado.py File 6387 bytes April 05 2019 23:15:16.
wsgi.py File 7299 bytes April 05 2019 23:15:16.

Reading File: //opt/alt/python38/lib//python3.8/site-packages/sentry_sdk/integrations/__init__.py

"""This package"""
from __future__ import absolute_import

from threading import Lock

from sentry_sdk._compat import iteritems
from sentry_sdk.utils import logger

if False:
    from typing import Iterator
    from typing import Dict
    from typing import List
    from typing import Set
    from typing import Type
    from typing import Callable


_installer_lock = Lock()
_installed_integrations = set()  # type: Set[str]


def _generate_default_integrations_iterator(*import_strings):
    # type: (*str) -> Callable[[], Iterator[Type[Integration]]]
    def iter_default_integrations():
        # type: () -> Iterator[Type[Integration]]
        """Returns an iterator of the default integration classes:
        """
        from importlib import import_module

        for import_string in import_strings:
            module, cls = import_string.rsplit(".", 1)
            yield getattr(import_module(module), cls)

    for import_string in import_strings:
        iter_default_integrations.__doc__ += "\n- `{}`".format(  # type: ignore
            import_string
        )

    return iter_default_integrations


iter_default_integrations = _generate_default_integrations_iterator(
    "sentry_sdk.integrations.logging.LoggingIntegration",
    "sentry_sdk.integrations.stdlib.StdlibIntegration",
    "sentry_sdk.integrations.excepthook.ExcepthookIntegration",
    "sentry_sdk.integrations.dedupe.DedupeIntegration",
    "sentry_sdk.integrations.atexit.AtexitIntegration",
    "sentry_sdk.integrations.modules.ModulesIntegration",
    "sentry_sdk.integrations.argv.ArgvIntegration",
    "sentry_sdk.integrations.threading.ThreadingIntegration",
)

del _generate_default_integrations_iterator


def setup_integrations(integrations, with_defaults=True):
    # type: (List[Integration], bool) -> Dict[str, Integration]
    """Given a list of integration instances this installs them all.  When
    `with_defaults` is set to `True` then all default integrations are added
    unless they were already provided before.
    """
    integrations = dict(
        (integration.identifier, integration) for integration in integrations or ()
    )

    logger.debug("Setting up integrations (with default = %s)", with_defaults)

    if with_defaults:
        for integration_cls in iter_default_integrations():
            if integration_cls.identifier not in integrations:
                instance = integration_cls()
                integrations[instance.identifier] = instance

    for identifier, integration in iteritems(integrations):
        with _installer_lock:
            if identifier not in _installed_integrations:
                logger.debug(
                    "Setting up previously not enabled integration %s", identifier
                )
                try:
                    type(integration).setup_once()
                except NotImplementedError:
                    if getattr(integration, "install", None) is not None:
                        logger.warn(
                            "Integration %s: The install method is "
                            "deprecated. Use `setup_once`.",
                            identifier,
                        )
                        integration.install()
                    else:
                        raise
                _installed_integrations.add(identifier)

    for identifier in integrations:
        logger.debug("Enabling integration %s", identifier)

    return integrations


class Integration(object):
    """Baseclass for all integrations.

    To accept options for an integration, implement your own constructor that
    saves those options on `self`.
    """

    install = None
    """Legacy method, do not implement."""

    identifier = None  # type: str
    """String unique ID of integration type"""

    @staticmethod
    def setup_once():
        """
        Initialize the integration.

        This function is only called once, ever. Configuration is not available
        at this point, so the only thing to do here is to hook into exception
        handlers, and perhaps do monkeypatches.

        Inside those hooks `Integration.current` can be used to access the
        instance again.
        """
        raise NotImplementedError()

SILENT KILLER Tool