Linux linux7.web4world.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
: 199.38.113.107 | : 216.73.216.178
Cant Read [ /etc/named.conf ]
?5.6.40
siddhapu
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
lib /
python2.7 /
site-packages /
[ HOME SHELL ]
Name
Size
Permission
Action
?;
Babel-0.9.6-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
Jinja2-2.7.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
_markerlib
[ DIR ]
drwxr-xr-x
?;
babel
[ DIR ]
drwxr-xr-x
?;
backports
[ DIR ]
drwxr-xr-x
?;
chardet
[ DIR ]
drwxr-xr-x
?;
chardet-2.2.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
clcommon
[ DIR ]
drwxr-xr-x
?;
decorator-3.4.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
iniparse
[ DIR ]
drwxr-xr-x
?;
isc
[ DIR ]
drwxr-xr-x
?;
jinja2
[ DIR ]
drwxr-xr-x
?;
jsonpatch-1.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
jsonpointer-1.9-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
kitchen
[ DIR ]
drwxr-xr-x
?;
kitchen-1.1.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
ply
[ DIR ]
drwxr-xr-x
?;
prettytable-0.7.2-py2.7.egg-in...
[ DIR ]
drwxr-xr-x
?;
procfs
[ DIR ]
drwxr-xr-x
?;
pyudev
[ DIR ]
drwxr-xr-x
?;
pyudev-0.15-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
requests
[ DIR ]
drwxr-xr-x
?;
rhn
[ DIR ]
drwxr-xr-x
?;
rpmUtils
[ DIR ]
drwxr-xr-x
?;
serial
[ DIR ]
drwxr-xr-x
?;
setuptools
[ DIR ]
drwxr-xr-x
?;
setuptools-0.9.8-py2.7.egg-inf...
[ DIR ]
drwxr-xr-x
?;
six-1.9.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
tuned
[ DIR ]
drwxr-xr-x
?;
urlgrabber
[ DIR ]
drwxr-xr-x
?;
urllib3
[ DIR ]
drwxr-xr-x
?;
urllib3-1.10.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
?;
yum
[ DIR ]
drwxr-xr-x
?;
yumutils
[ DIR ]
drwxr-xr-x
IPy-0.75-py2.7.egg-info
9.83
KB
-rw-r--r--
IPy.py
50.07
KB
-rw-r--r--
IPy.pyc
39.92
KB
-rw-r--r--
IPy.pyo
39.92
KB
-rw-r--r--
backports.ssl_match_hostname-3...
3.96
KB
-rw-r--r--
clsudo.py
12.65
KB
-rw-r--r--
clsudo.pyc
11.02
KB
-rw-r--r--
clsudo.pyo
11.02
KB
-rw-r--r--
configobj-4.7.2-py2.7.egg-info
2.08
KB
-rw-r--r--
configobj.py
86.1
KB
-rw-r--r--
configobj.pyc
64.72
KB
-rw-r--r--
configobj.pyo
64.72
KB
-rw-r--r--
decorator.py
10.39
KB
-rw-r--r--
decorator.pyc
8.36
KB
-rw-r--r--
decorator.pyo
8.32
KB
-rw-r--r--
easy-install.pth
209
B
-rw-r--r--
easy_install.py
126
B
-rw-r--r--
easy_install.pyc
315
B
-rw-r--r--
easy_install.pyo
315
B
-rw-r--r--
hwdata.py
5.89
KB
-rw-r--r--
hwdata.pyc
4.38
KB
-rw-r--r--
hwdata.pyo
4.38
KB
-rw-r--r--
iniparse-0.4-py2.7.egg-info
1.06
KB
-rw-r--r--
ipaddress-1.0.16-py2.7.egg-inf...
783
B
-rw-r--r--
ipaddress.py
78.03
KB
-rw-r--r--
ipaddress.pyc
73.75
KB
-rw-r--r--
ipaddress.pyo
73.57
KB
-rw-r--r--
isc-2.0-py2.7.egg-info
267
B
-rw-r--r--
jsonpatch.py
15.57
KB
-rw-r--r--
jsonpatch.pyc
16.98
KB
-rw-r--r--
jsonpatch.pyo
16.78
KB
-rw-r--r--
jsonpointer.py
9.15
KB
-rw-r--r--
jsonpointer.pyc
9.39
KB
-rw-r--r--
jsonpointer.pyo
9.24
KB
-rw-r--r--
pciutils-1.7.3-py2.7.egg-info
267
B
-rw-r--r--
pkg_resources.py
98.74
KB
-rw-r--r--
pkg_resources.pyc
105.5
KB
-rw-r--r--
pkg_resources.pyo
105.47
KB
-rw-r--r--
ply-3.4-py2.7.egg-info
900
B
-rw-r--r--
prettytable.py
52.93
KB
-rw-r--r--
prettytable.pyc
50.38
KB
-rw-r--r--
prettytable.pyo
49.46
KB
-rw-r--r--
pyparsing-1.5.6-py2.7.egg-info
670
B
-rw-r--r--
pyparsing.py
151.79
KB
-rw-r--r--
pyparsing.pyc
145.41
KB
-rw-r--r--
pyparsing.pyo
145.41
KB
-rw-r--r--
pyserial-2.6-py2.7.egg-info
1.37
KB
-rw-r--r--
python_linux_procfs-0.4.9-py2....
350
B
-rw-r--r--
pyzor-1.0.0-py2.7.egg
78.18
KB
-rw-r--r--
requests-2.6.0-py2.7.egg-info
39.41
KB
-rw-r--r--
rhnlib-2.5.65-py2.7.egg-info
345
B
-rw-r--r--
secureio.py
9.01
KB
-rw-r--r--
secureio.pyc
4.58
KB
-rw-r--r--
secureio.pyo
4.58
KB
-rw-r--r--
six.py
28.97
KB
-rw-r--r--
six.pyc
29.01
KB
-rw-r--r--
six.pyo
29.01
KB
-rw-r--r--
urlgrabber-3.10-py2.7.egg-info
2.21
KB
-rw-r--r--
validate.py
45.22
KB
-rw-r--r--
validate.pyc
45.62
KB
-rw-r--r--
validate.pyo
45.62
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : clsudo.py
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)
Close