$94 GRAYBYTE WORDPRESS FILE MANAGER $57

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/cloudlinux/venv/lib/python3.11/site-packages/clconfigure/

HOME
Current File : /opt/cloudlinux/venv/lib/python3.11/site-packages/clconfigure//linksafe.py
# Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2018 All Rights Reserved
#
# Licensed under CLOUD LINUX LICENSE AGREEMENT
# https://cloudlinux.com/docs/LICENCE.TXT
#
from concurrent.futures import ThreadPoolExecutor
from typing import Iterator

from clcommon.utils import is_ubuntu
from clconfigure import task, run
from clconfigure.packages import install_package

# Files of the packages listed below are not supposed
# to allow creation of symlinks to them
PACKAGES_TO_EXCLUDE = {
    'alt-python27-cllib',
    'alt-php-xray',
    'alt-php-ssa',
}


def initialize_linksafe():
    # NOTE(vlebedev): Also we need to trigger linksafe scriptlets to properly initialize relevant UNIX groups.
    #                 Otherwise this problem may occur:
    #                 https://cloudlinux.zendesk.com/hc/en-us/articles/
    #                 115004139173-What-does-Error-failed-to-create-symlink-13-Permission-denied-mean
    install_package('cloudlinux-linksafe', reinstall=True)
    assign_linksafe_group()


@task("Assigning linksafe group to files of 'alt-*' packages residing under /opt/alt")
def assign_linksafe_group(concurrency: int = 5):
    with ThreadPoolExecutor(max_workers=concurrency) as tp:
        for package in _installed_packages_iter(
            "alt-php*",
            "alt-python*",
            "alt-ruby*",
        ):
            if package not in PACKAGES_TO_EXCLUDE:
                tp.submit(run, ['/usr/bin/cl-linksafe-apply-group', package])


def _installed_packages_iter(*patterns: str) -> Iterator[str]:
    if is_ubuntu():
        result = run(["dpkg-query", "-W", "-f", "${Package}\n", *patterns])
    else:
        result = run(["rpm", "-qa", *patterns])

    lines = result.stdout.strip().splitlines()
    for line in lines:
        yield line

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
17 Dec 2025 3.08 AM
root / root
0755
__pycache__
--
16 Dec 2025 9.35 PM
root / root
0755
cli
--
16 Dec 2025 9.30 PM
root / root
0755
spec
--
16 Dec 2025 9.30 PM
root / root
0755
Readme.md
1.606 KB
14 Nov 2025 9.12 PM
root / root
0644
__init__.py
3.094 KB
14 Nov 2025 9.12 PM
root / root
0644
awp.py
1.755 KB
14 Nov 2025 9.12 PM
root / root
0644
cagefs.py
1.81 KB
14 Nov 2025 9.12 PM
root / root
0644
clpro.py
0.848 KB
14 Nov 2025 9.12 PM
root / root
0644
files.py
0.911 KB
14 Nov 2025 9.12 PM
root / root
0644
limits.py
2.855 KB
14 Nov 2025 9.12 PM
root / root
0644
linksafe.py
1.755 KB
14 Nov 2025 9.12 PM
root / root
0644
lve.py
0.942 KB
14 Nov 2025 9.12 PM
root / root
0644
packages.py
3.18 KB
14 Nov 2025 9.12 PM
root / root
0644
services.py
2.29 KB
14 Nov 2025 9.12 PM
root / root
0644
watcher.py
4.936 KB
14 Nov 2025 9.12 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF