X7ROOT File Manager
Current Path:
/opt/imunify360/venv/lib/python3.11/site-packages/imav/plugins
opt
/
imunify360
/
venv
/
lib
/
python3.11
/
site-packages
/
imav
/
plugins
/
π
..
π
__init__.py
(0 B)
π
__pycache__
π
check_license.py
(9.47 KB)
π
conflicts.py
(3.18 KB)
π
event_hook_executor.py
(3.72 KB)
π
event_hooks.py
(3.47 KB)
π
generic_sensor.py
(6.11 KB)
π
im360_register.py
(2.8 KB)
π
imunify_patch_id.py
(2.12 KB)
π
inotify.py
(1.75 KB)
π
malware_filters.py
(3.68 KB)
π
mr_proper.py
(2.67 KB)
π
plesk_notifications.py
(3.82 KB)
π
post_action.py
(1.72 KB)
π
restore_from_backup.py
(3.37 KB)
π
server_pull.py
(2.56 KB)
π
service_manager.py
(3.93 KB)
π
wordpress.py
(11.43 KB)
Editing: conflicts.py
""" This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.Β See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program.Β If not, see <https://www.gnu.org/licenses/>. CopyrightΒ Β© 2019 Cloud Linux Software Inc. This software is also available under ImunifyAV commercial license, see <https://www.imunify360.com/legal/eula> """ from logging import getLogger from defence360agent.contracts.config import Malware as Config from defence360agent.utils import recurring_check from defence360agent.contracts.plugins import ( MessageSink, MessageSource, ) from imav.malwarelib.subsys import pure_ftpd from defence360agent.subsys.panels import hosting_panel from defence360agent.utils import Scope logger = getLogger(__name__) class Conflicts(MessageSource, MessageSink): SCOPE = Scope.IM360 def __init__(self): self._loop = None self._sink = None self._pure_check_task = None async def create_sink(self, loop): pass async def create_source(self, loop, sink): self._loop = loop self._sink = sink self._pure_check_task = self._loop.create_task( recurring_check(Config.CONFLICTS_CHECK_PERIOD)(self._check_pure)() ) async def shutdown(self): for t in [self._pure_check_task]: t.cancel() await t @staticmethod async def _check_pure(): if not pure_ftpd.detect(): return # pure-ftpd is not installed # ftp scan integration is enabled in config active_in_config = Config.PURE_SCAN # should ftp scan integration be enabled enabled = active_in_config and not Config.INOTIFY_ENABLED running = await pure_ftpd.uploadscript_status() thirdparty_uploadscript = pure_ftpd.thirdparty_uploadscript() if thirdparty_uploadscript is not None: if running: logger.info( "Third-party pure-uploadscript detected: %s," " disabling pure-ftpd scans", thirdparty_uploadscript, ) await pure_ftpd.uploadscript_disable() return panel = hosting_panel.HostingPanel() if enabled: if not running: logger.info("Enabling pure-ftpd service") await pure_ftpd.uploadscript_enable() if not pure_ftpd.scan_in_config_enabled(panel): logger.info("Enable upload script in pure-ftpd configs") await pure_ftpd.enable_scan_in_config(panel) # active & enabled & configured & running logger.info("FTP scan is enabled") elif running and not enabled: logger.info("Disabling pure-ftpd scans") await pure_ftpd.disable_purescan(panel)
Upload File
Create Folder