HEX
Server: LiteSpeed
System: Linux atali.colombiahosting.com.co 5.14.0-570.12.1.el9_6.x86_64 #1 SMP PREEMPT_DYNAMIC Tue May 13 06:11:55 EDT 2025 x86_64
User: coopserp (1713)
PHP: 8.2.29
Disabled: dl,exec,passthru,proc_open,proc_close,shell_exec,memory_limit,system,popen,curl_multi_exec,show_source,symlink,link,leak,listen,diskfreespace,tmpfile,ignore_user_abord,highlight_file,source,show_source,fpaththru,virtual,posix_ctermid,posix_getcwd,posix_getegid,posix_geteuid,posix_getgid,posix_getgrgid,posix_getgrnam,posix_getgroups,posix_getlogin,posix_getpgid,posix_getpgrp,posix_getpid,posix,posix_getppid,posix_getpwnam,posix_getpwuid,posix_getrlimit,posix_getsid,posix_getuid,posix_isatty,posix_kill,posix_mkfifo,posix_setegid,posix_seteuid,posix_setgid,posix_setpgid,posix_setsid,posix_setid,posix_times,posix_ttyname,posix_uname,proc_get_status,proc_nice,proc_terminate
Upload Files
File: //opt/cloudlinux/venv/lib/python3.11/site-packages/clcommon/cllog.py
# -*- 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