ACIL FM
Dark
Refresh
Current DIR:
/opt/imunify360/venv/lib/python3.11/site-packages/defence360agent/feature_management
/
opt
imunify360
venv
lib
python3.11
site-packages
defence360agent
feature_management
Upload
Zip Selected
Delete Selected
Pilih semua
Nama
Ukuran
Permission
Aksi
plugins
-
chmod
Open
Rename
Delete
rpc
-
chmod
Open
Rename
Delete
__pycache__
-
chmod
Open
Rename
Delete
checkers.py
2.45 MB
chmod
View
DL
Edit
Rename
Delete
constants.py
812 B
chmod
View
DL
Edit
Rename
Delete
control.py
2.5 MB
chmod
View
DL
Edit
Rename
Delete
exceptions.py
306 B
chmod
View
DL
Edit
Rename
Delete
hooks.py
2.39 MB
chmod
View
DL
Edit
Rename
Delete
lookup.py
2.76 MB
chmod
View
DL
Edit
Rename
Delete
model.py
2.32 MB
chmod
View
DL
Edit
Rename
Delete
utils.py
3.48 MB
chmod
View
DL
Edit
Rename
Delete
__init__.py
0 B
chmod
View
DL
Edit
Rename
Delete
Edit file: /opt/imunify360/venv/lib/python3.11/site-packages/defence360agent/feature_management/hooks.py
""" This module contains hook, which are called on feature management permission changes. Note that hooks are not executed automatically, developer is responsible to obtain specific hook using get_hook() function and call it. To add hook, create function with name equal to feature name """ import functools import logging from typing import Any, Callable, Optional from defence360agent.contracts.config import ConfigFile from defence360agent.feature_management.constants import AV, FULL, PROACTIVE logger = logging.getLogger(__name__) def _hook_stub(*_): return True def _result_warn(callback): @functools.wraps(callback) def wrap(user, value): result = callback(user, value) result or logger.warning( "Hook '%s(%s)' failed for user '%s'.", callback.__name__, value, user, ) return result return wrap @_result_warn def antivirus(user: Optional[str], value: Any) -> bool: """Called when 'av' feature is changed""" if not user: return True config = ConfigFile() config_value = config.get("MALWARE_SCANNING", "default_action") user_config = ConfigFile(user) user_config_value = user_config.get("MALWARE_SCANNING", "default_action") if value == FULL: user_config_value = None elif ( user_config_value and user_config_value.startswith("cleanup") and config_value and config_value.startswith("cleanup") ): user_config_value = "notify" try: user_config.set( "MALWARE_SCANNING", "default_action", user_config_value ) except Exception: return False return True @_result_warn def proactive(user: Optional[str], value: Any) -> bool: """Called when 'proactive' feature is changed""" if not user: return True # do nothing if no user specified config_value = None if value == FULL else "DISABLED" try: ConfigFile(user).set("PROACTIVE_DEFENCE", "mode", config_value) except Exception: return False return True HOOKS = { AV: antivirus, PROACTIVE: proactive, } def get_hook(feature: str) -> Callable[[Optional[str], Any], bool]: """ Get hook for specific feature. If no hook is implemented for this feature, return stub function :param feature: feature name :return: callable hook """ return HOOKS.get(feature, _hook_stub)
Simpan
Batal
Isi Zip:
Unzip
Create
Buat Folder
Buat File
Terminal / Execute
Run
Chmod Bulk
All File
All Folder
All File dan Folder
Apply