ok

Mini Shell

Direktori : /opt/imunify360/venv/lib/python3.11/site-packages/im360/subsys/panels/no_cp/
Upload File :
Current File : //opt/imunify360/venv/lib/python3.11/site-packages/im360/subsys/panels/no_cp/panel.py

import os
from pathlib import Path
from typing import Optional, Set, Dict, Sequence

from defence360agent.subsys.panels.base import PanelException
from defence360agent.subsys.panels.no_cp import NoCP
from im360.subsys.panels.base import (
    ModSecurityInterface,
    PanelInterface,
    RemoteIPInterface,
)


class NoCPPanelInterface(PanelInterface):
    async def _get_all_admin_emails(self):
        return []

    def basedirs(self) -> Set[str]:
        return set()

    def http_ports(self) -> Set[int]:
        return set()

    def https_ports(self) -> Set[int]:
        return set()

    def remoteip_supported(self) -> bool:
        return True

    async def list_docroots(self) -> Sequence[str]:
        return []


class NoCPModSecurityInterface(ModSecurityInterface):
    REBUILD_HTTPDCONF_CMD = None

    @classmethod
    async def installed_modsec(cls):
        return False

    async def _install_settings(self):
        pass

    async def modsec_get_directive(self, directive_name, default=None):
        raise NotImplementedError

    async def reset_modsec_directives(self):
        pass

    async def reset_modsec_rulesets(self):
        pass

    async def revert_settings(self):
        pass

    @classmethod
    def _get_conf_dir(cls):
        pass

    @classmethod
    def get_app_specific_waf_config(cls):
        raise NotImplementedError

    @classmethod
    def detect_cwaf(cls):
        return False

    @classmethod
    async def modsec_vendor_list(cls) -> list:
        """Return a list of installed ModSecurity vendors."""
        return []

    @classmethod
    async def enabled_modsec_vendor_list(cls) -> list:
        """Return a list of enabled ModSecurity vendors."""
        return []

    @classmethod
    async def build_vendor_file_path(cls, vendor: str, filename: str) -> Path:
        raise PanelException("not implemented")

    @classmethod
    async def get_i360_vendor_name(cls) -> str:
        raise PanelException("not implemented")

    @classmethod
    async def get_i360_vendor_version(cls) -> str:
        raise PanelException("not implemented")

    @classmethod
    async def invalidate_installed_vendors_cache(cls):
        pass

    @classmethod
    async def _apply_modsec_files_update(cls):
        pass

    @classmethod
    def get_audit_log_path(cls):
        # IMUNIFY360_NOCP_MODSEC_AUDIT_LOG should not be set generally,
        # used for tests only
        return os.environ.get("IMUNIFY360_NOCP_MODSEC_AUDIT_LOG", None)

    @classmethod
    def get_audit_logdir_path(cls):
        pass

    @classmethod
    def write_global_disabled_rules(cls, rule_list):
        pass

    @classmethod
    async def sync_global_disabled_rules(cls, rule_list):
        pass

    @classmethod
    async def sync_disabled_rules_for_domains(
        cls, domain_rules_map: Dict[str, list]
    ):
        pass


class NoCPRemoteIPInterface(RemoteIPInterface):
    async def remoteip_activated(self) -> bool:
        return True

    async def remoteip_install(self) -> Optional[str]:
        raise PanelException("not supported")


class NoControlPanel(
    NoCPModSecurityInterface,
    NoCPPanelInterface,
    NoCPRemoteIPInterface,
    NoCP,
):
    pure_ftp_conf_cls = None

Zerion Mini Shell 1.0