Hackfut Security 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__
π
conflicts.py
(3.18 KB)
π
event_hook_executor.py
(3.39 KB)
π
event_hooks.py
(3.36 KB)
π
generic_sensor.py
(5.88 KB)
π
inotify.py
(1.75 KB)
π
malware_filters.py
(3.11 KB)
π
mr_proper.py
(2.37 KB)
π
post_action.py
(2.25 KB)
π
restore_from_backup.py
(3.43 KB)
π
server_pull.py
(1.5 KB)
Editing: post_action.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 typing import Dict from defence360agent.contracts.messages import MessageType from defence360agent.contracts.plugins import ( MessageSink, MessageSource, expect, ) from imav.malwarelib.config import MalwareHitStatus from imav.malwarelib.model import MalwareHit from defence360agent.utils import Scope logger = getLogger(__name__) class PostAction(MessageSink, MessageSource): PROCESSING_ORDER = MessageSink.ProcessingOrder.POST_ACTION SCOPE = Scope.IM360 async def create_sink(self, loop): pass async def create_source(self, loop, sink): self._sink = sink @expect(MessageType.MalwareCleanup) async def process_post_action(self, message: Dict): post_action = message.pop("post_action", None) if not post_action: return scan_id = message["scan_id"] cause = message["cause"] initiator = message["initiator"] found_hits = [ hit for hit in message["hits"] if hit.status == MalwareHitStatus.FOUND ] other_hits = [ hit for hit in message["hits"] if hit.status != MalwareHitStatus.FOUND ] if await post_action( hits=found_hits, scan_id=scan_id, cause=cause, initiator=initiator, sink=self._sink, ): message["hits"] = MalwareHit.refresh_hits(found_hits) + other_hits return message
Upload File
Create Folder