HEX
Server: LiteSpeed
System: Linux kapuas.iixcp.rumahweb.net 5.14.0-427.42.1.el9_4.x86_64 #1 SMP PREEMPT_DYNAMIC Fri Nov 1 14:58:02 EDT 2024 x86_64
User: mirz4654 (1666)
PHP: 8.1.33
Disabled: system,exec,escapeshellarg,escapeshellcmd,passthru,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,popen,pclose,dl,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setsid,posix_setuid,posix_setpgid,ini_alter,show_source,define_syslog_variables,symlink,syslog,openlog,openlog,closelog,ocinumcols,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dll,ftp,myshellexec,socket_bind,mail,posix_getwpuid
Upload Files
File: //opt/cloudlinux/venv/lib64/python3.11/site-packages/clconfigure/cagefs.py
# Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2024 All Rights Reserved
#
# Licensed under CLOUD LINUX LICENSE AGREEMENT
# https://cloudlinux.com/docs/LICENCE.TXT
#
import functools
import logging
import os

from clcommon.const import Feature
from clcommon.cpapi import is_panel_feature_supported
from clconfigure import run, task
from clconfigure.packages import install_package

CAGEFSCTL = "/usr/sbin/cagefsctl"


def _skip_without_cagefs(func):
    @functools.wraps(func)
    def decorator(*args, **kwargs):
        if not is_panel_feature_supported(Feature.CAGEFS):
            logging.debug("Feature 'CageFS' is not supported. Skipping...")
            return

        if not os.path.exists(CAGEFSCTL):
            logging.debug("CageFS is not installed. Skipping...")
            return

        return func(*args, **kwargs)
    return decorator


@_skip_without_cagefs
@task("Cleaning CageFS environment")
def clean_cagefs_without_lve_environment():
    if is_panel_feature_supported(Feature.LVE):
        logging.debug("LVE feature is supported. Skipping...")
        return

    result = run([CAGEFSCTL, "--clean-without-lve-environment"])
    if result.exitcode != 0:
        logging.warning("Unable to clean non-LVE CageFS enviroment. stdout: %s, stderr: %s",
                        result.stdout, result.stderr)


@_skip_without_cagefs
@task("Reconfiguring CageFS")
def reconfigure_cagefs():
    install_package("cagefs", reinstall=True)
    _rebuild_apache_directadmin()


def _rebuild_apache_directadmin():
    da_bin = "/usr/local/directadmin/directadmin"
    if not os.path.exists(da_bin):
        return

    result = run([da_bin, "build", "apache"])
    if result.exitcode != 0:
        logging.warning("Error during rebuilding Apache. stdout: %s, stderr: %s",
                        result.stdout, result.stderr)