D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
alt
/
python37
/
lib
/
python3.7
/
site-packages
/
clwpos
/
optimization_features
/
Filename :
configurations.py
back
Copy
# -*- coding: utf-8 -*- # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2022 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENSE.TXT # configurations.py - configuration helpers for AccelerateWP optimization features from pathlib import Path from typing import Optional, Dict, Tuple, Union from clwpos import gettext as _ from clwpos.cl_wpos_exceptions import WposError from clwpos.utils import check_domain, home_dir from clwpos.wp_utils import WordpressError from .features import Feature from ..user.website_check import RollbackException def to_interface_name(feature): return Feature(feature).to_interface_name() def convert_features_dict_to_interface(features_dict): return {to_interface_name(feature): state for feature, state in features_dict.items()} def convert_feature_list_to_interface(features_list): return [to_interface_name(feature) for feature in features_list] class DocRootPath(str): """This class represent path to doc_root.""" pass class DomainName(str): """This class represent domain name.""" pass def disable_without_config_affecting( arg: Union[DocRootPath, DomainName], wp_path: str, *, module: str, domain=None ) -> Optional[WordpressError]: """ Deactivate and delete specified wordpress module. :param arg: user's docroot or domain :param wp_path: path to user's wordpress directory :param module: module on which to perform disable operations :param domain: userdomain :return: error if error was happened else None """ if isinstance(arg, DomainName): doc_root = check_domain(arg)[-1] domain = arg elif isinstance(arg, DocRootPath): doc_root = Path(home_dir(), arg) if not domain: raise ValueError('Domain must be specified') abs_wp_path = str(Path(doc_root).joinpath(wp_path).absolute()) last_error = None errors = Feature(module).disable(abs_wp_path, domain=domain, website=wp_path) if errors: last_error = errors[-1] return last_error def enable_without_config_affecting( arg: Union[DocRootPath, DomainName], wp_path: str, *, module: str, domain=None, ignore_errors=False ) -> Tuple[bool, Dict[str, Union[str, dict]]]: """ Install and activate specified wordpress module. :param arg: user's docroot or domain :param wp_path: path to user's wordpress directory :param module: module on which to perform enable operations :param domain: userdomain :param ignore_errors: if True, skip additional checks during enabling :return: tuple that consists of enabling status and details """ if isinstance(arg, DomainName): __, doc_root = check_domain(arg) domain = arg elif isinstance(arg, DocRootPath): doc_root = Path(home_dir(), arg) if not domain: raise ValueError('Domain must be specified') else: raise ValueError("Invalid argument format") wp_path = wp_path.lstrip("/") abs_wp_path = str(Path(doc_root).joinpath(wp_path).absolute()) # try to install plugin feature = Feature(module) try: feature.install(abs_wp_path) except WposError as e: return False, dict( message=_("WordPress plugin installation failed. " "Try again and contact your system administrator if issue persists."), details=e.message, context=e.context ) # try to activate plugin try: feature.enable(abs_wp_path, domain=domain, website=wp_path, skip_checkers=ignore_errors) except WposError as e: feature.disable(abs_wp_path, domain=domain, website=wp_path) if isinstance(e, RollbackException): return False, { 'context': e.context, 'result': e.message, 'issues': e.errors } return False, dict( message=_("WordPress plugin activation failed. Changes were reverted and caching module is now disabled. " "Try again and contact your system administrator if issue persists."), details=e.message, context=e.context ) return True, {}