[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: cphulk.py
File is not writable. Editing disabled.
#!/opt/imunify360/venv/bin/python3 import os import logging import re import time from defence360agent.contracts.plugins import LogStreamReader from defence360agent.utils import RecurringCheckStop, recurring_check from defence360agent.contracts.messages import MessageType logger = logging.getLogger(__name__) class cpHulkSensor(LogStreamReader): source_file = '/usr/local/cpanel/logs/cphulkd.log' PLUGIN_ID = 'cphulk' _PARSE_LOG_RECORD_REGEX = re.compile( r'Login Blocked: .+' r'\[Remote IP Address\]=\[(.+?)\].+' r'\((\d+)/\d+ failures\).+') async def create_sensor(self, loop, sink): logdir = os.path.dirname(self.source_file) if os.path.exists(logdir): return await super().create_sensor(loop, sink) logger.info( "%r won't be monitored: %r doesn't exist", self.source_file, logdir, ) @recurring_check(0) async def _infinite_read_and_proceed(self, stream_reader): bytes_ = await stream_reader.readline() if not bytes_: # eof raise RecurringCheckStop() else: line = bytes_.decode() match = self._PARSE_LOG_RECORD_REGEX.search(line) if match: # Need field "name" for incident validation incident = MessageType.SensorIncident( message=match.group(0), attackers_ip=match.group(1), retries=int(match.group(2)), plugin_id=self.PLUGIN_ID, rule=None, name='Login Blocked by cpHulk', timestamp=time.time(), ) await self._sink.process_message(incident)
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: server05.hostinghome.co.in
Server IP: 192.168.74.40
PHP Version: 7.4.33
Server Software: Apache
System: Linux server05.hostinghome.co.in 3.10.0-962.3.2.lve1.5.81.el7.x86_64 #1 SMP Wed May 31 10:36:47 UTC 2023 x86_64
HDD Total: 1.95 TB
HDD Free: 690.32 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Disabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes
gcc:
Yes
pkexec:
No
git:
Yes
User Info
Username: itsweb
User ID (UID): 1619
Group ID (GID): 1621
Script Owner UID: 1619
Current Dir Owner: N/A