[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: cagefs.py
File is not writable. Editing disabled.
# coding=utf-8 # # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2021 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENCE.TXT # from __future__ import absolute_import import os from cllimits.cagefs_lib import CageFs, CageFsException from clconfig.cagefs_statistics_config import check_cagefs_initialized from clwizard.constants import MODULES_LOGS_DIR from clwizard.exceptions import InstallationFailedException from .base import ( WizardInstaller ) from clcommon.utils import ExternalProgramFailed from clcommon.const import Feature class CagefsInstaller(WizardInstaller): LOG_FILE = os.path.join(MODULES_LOGS_DIR, 'cagefs.log') _REQUIRED_CL_COMPONENT_SUPPORT = Feature.CAGEFS def __init__(self): super(CagefsInstaller, self).__init__() self.cgfs = CageFs(logger=self.app_logger) def _enable_existing_users(self): """ Enable all users statuses and after it toggle to initial mode :return: """ initial_mode = self.cgfs.get_user_mode() out = self.cgfs.set_enabled_mode() self.app_logger.info("Cagefs users status was updated to enabled: %s", out) if initial_mode == 'Disable All': self.cgfs.toggle_user_mode() def _set_enabled_mode(self): mode = self.cgfs.get_user_mode() self.app_logger.info("Current mode is: %s", mode) if mode == 'Disable All': self.app_logger.info("Try to set mode to Enable all") self.cgfs.toggle_user_mode() self.app_logger.info("Mode was toggled to Enable all") def _install_cagefs_package(self): if not self._is_package_installed('cagefs'): try: self._install_package('cagefs') except ExternalProgramFailed: raise InstallationFailedException() else: self.app_logger.info("Skip package installation, it is already installed") def _initialize_cagefs(self): if not check_cagefs_initialized(): try: out = self.cgfs.initialize_cagefs() self.app_logger.info("Cagefs was initialized: %s", out) except CageFsException as e: self.app_logger.error("Cagefs initializing failed with error: %s", str(e)) raise InstallationFailedException() else: self.app_logger.info("Initializing was skipped, cagefs was already initialized") def _enable_cagefs(self): try: out = self.cgfs.enable_cagefs() self.app_logger.info("Cagefs was enabled, ready for configuration\n %s", out) except CageFsException: raise InstallationFailedException() def run_installation(self, options): self._install_cagefs_package() self._initialize_cagefs() self._enable_cagefs() try: if options['enable_for_existing_users']: self._enable_existing_users() if options['enable_for_new_users']: self._set_enabled_mode() except CageFsException as e: self.app_logger.error("Can`t configure options: %s", str(e)) raise InstallationFailedException() @classmethod def supported_options(cls): return {'enable_for_existing_users', 'enable_for_new_users'} def initial_status(self): try: enabled_for_new = self.cgfs.get_user_mode() == 'Enable All' except CageFsException: self.app_logger.warning( 'Unable to detect cagefs mode, ' 'assuming that it is "Disable All"') enabled_for_new = False return { # we always allow user to initialize cagefs # bool needed to replace None with False # None is given when cagefs is not installed 'already_configured': bool(check_cagefs_initialized()), 'options': {'enable_for_new_users': enabled_for_new} }
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.93 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