Server IP : 162.0.209.157 / Your IP : 18.189.170.65 [ Web Server : LiteSpeed System : Linux premium178.web-hosting.com 4.18.0-513.24.1.lve.2.el8.x86_64 #1 SMP Fri May 24 12:42:50 UTC 2024 x86_64 User : balaoqob ( 2395) PHP Version : 8.0.30 Disable Function : NONE Domains : 1 Domains MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /opt/imunify360/venv/lib64/python3.11/site-packages/clcommon/ |
Upload File : |
# -*- coding: utf-8 -*- # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2018 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENSE.TXT # import datetime import fcntl import sys import psutil class ClAuditLog: def __init__(self, log_file_name: str): self._log_file_name = log_file_name def info_log_write(self, msg: str = ""): dt_now = datetime.datetime.now() current_proc = psutil.Process() # Initialize default values parent_proc_name, parent_proc_cmdline = "<Unknown_name>", "<Unknown_cmdline>" parent_proc_pid = current_proc.ppid() # Attempt to get the parent process properties parent_proc = current_proc.parent() if parent_proc is not None: with parent_proc.oneshot(): parent_proc_name = parent_proc.name() parent_proc_cmdline = " ".join(parent_proc.cmdline()) try: with open(self._log_file_name, "a", encoding="utf-8") as f: fcntl.lockf(f.fileno(), fcntl.LOCK_EX | fcntl.LOCK_NB) f.write( f"{dt_now.strftime('%Y.%m.%d %H:%M:%S')}: " f"Parent process: {parent_proc_name} ({parent_proc_cmdline}) " f"(Parent PID: {parent_proc_pid}): Args: {sys.argv[1:]} {msg}\n" ) except (IOError, OSError): # Ignore all file errors pass