[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: db_info_lib.py
File is not writable. Editing disabled.
# -*- coding: utf-8 -*- # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2019 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENSE.TXT from __future__ import absolute_import import re import os from clcommon.utils import run_command, ExternalProgramFailed class MysqlInfo(object): def __init__(self): self.mysqld_v = self.retrieve_server_info() @staticmethod def get_binary(): """ Find mysql server binary :return: path to mysql binary """ try: os.stat('/usr/sbin/mysqld') return '/usr/sbin/mysqld' except OSError: return '/usr/libexec/mysqld' def retrieve_server_info(self): """ Get server information through `<mysql_server_binary> -V` command :return: full command output """ try: return run_command([self.get_binary(), '-V']) except ExternalProgramFailed: # may be no such file or unknown error happen return None def get(self): """ Return gathered data :return: dict( 'vendor': MySQL|MariaDB|Percona, 'version': server version in the form of {major}.{minor} or {major}.{minor}-{release} for percona, 'cll-lve': patches from CL applied or not (True|False) ) """ return { 'vendor': self.get_vendor(), 'version': self.get_version(), 'cll-lve': self.is_patched() } def get_vendor(self): """ Extract MySQL vendor from server info :return: MySQL|MariaDB|Percona or `unknown` if failed to apply regex or None if there is no server info (this usually means that there are no MySQL installed) """ if self.mysqld_v is None: return None # regex to find vendor -- something, starting from round bracket and followed by `Server` # (see test_clconfig_db_info_lib.py for detailed examples) p = re.compile(r'(?<=\().+(?=\sServer)') try: # we need only first word of first element return p.findall(self.mysqld_v)[0].split()[0] except IndexError: return 'unknown' def get_version(self): """ Retrieve MySQL server version from server info :return: X.X.X e.g. 10.2.16|5.6.39, includes release for percona (X.X.X-X.X e.g. 5.6.40-84.0) or `unknown` if failed to apply regex or None if there is no server info (this usually means that there are no MySQL installed) """ if self.mysqld_v is None: return None # regex to find version -- numbers, divided by `.` or `-` which go after `Ver` # (see test_clconfig_db_info_lib.py for detailed examples) p = re.compile(r'(?<=Ver\s)[0-9\.\-]+') try: # we need first element, also should sanitize from trailing `-` return p.findall(self.mysqld_v)[0].rstrip('-') except IndexError: return 'unknown' def is_patched(self): """ Retrieve information about CL patch by `cll-lve` in server info :return: True if contains `cll-lve` seq False otherwise or None if there is no server info (this usually means that there are no MySQL installed) """ if self.mysqld_v is None: return None return 'cll-lve' in self.mysqld_v
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.89 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