Linux server.edchosting.com 4.18.0-553.79.1.lve.el7h.x86_64 #1 SMP Wed Oct 15 16:34:46 UTC 2025 x86_64
LiteSpeed
Server IP : 75.98.162.185 & Your IP : 216.73.216.163
Domains :
Cant Read [ /etc/named.conf ]
User : goons4good
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
lib /
python2.7 /
site-packages /
Delete
Unzip
Name
Size
Permission
Date
Action
Babel-0.9.6-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 14:49
Jinja2-2.7.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 14:49
SSSDConfig
[ DIR ]
drwxr-xr-x
2024-01-28 05:23
_markerlib
[ DIR ]
drwxr-xr-x
2021-09-16 10:43
babel
[ DIR ]
drwxr-xr-x
2021-09-16 14:49
backports
[ DIR ]
drwxr-xr-x
2021-09-16 10:43
chardet
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
chardet-2.2.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
clcommon
[ DIR ]
drwxr-xr-x
2021-09-16 14:49
dateutil
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
decorator-3.4.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
dns
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
dnspython-1.12.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
enum
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
firewall
[ DIR ]
drwxr-xr-x
2021-09-16 10:45
google
[ DIR ]
drwxr-xr-x
2021-09-16 14:53
idna
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
idna-2.4-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
iniparse
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
iotop
[ DIR ]
drwxr-xr-x
2021-09-16 10:49
ipaclient
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
ipaclient-4.6.8-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
ipalib
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
ipalib-4.6.8-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
ipaplatform
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
ipaplatform-4.6.8-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
ipapython
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
ipapython-4.6.8-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
isc
[ DIR ]
drwxr-xr-x
2025-03-18 04:00
javapackages
[ DIR ]
drwxr-xr-x
2021-09-17 00:00
javapackages-1.0.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-17 00:00
jinja2
[ DIR ]
drwxr-xr-x
2021-09-16 14:49
jwcrypto
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
jwcrypto-0.4.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
kitchen
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
kitchen-1.1.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
netaddr
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
nose
[ DIR ]
drwxr-xr-x
2021-09-16 10:54
nose-1.3.7-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 10:54
ply
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
procfs
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
protobuf-2.5.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 14:53
pyasn1
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
pyasn1-0.1.9-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
pyasn1_modules
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
pyasn1_modules-0.0.8-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
pycparser
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
pycparser-2.14-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
pycriu
[ DIR ]
drwxr-xr-x
2022-10-05 03:35
python_dateutil-1.5-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
python_yubico-1.2.3-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
pyudev
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
pyudev-0.15-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
qrcode
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
qrcode-5.0.1-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
requests
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
rhn
[ DIR ]
drwxr-xr-x
2021-09-16 14:49
rpmUtils
[ DIR ]
drwxr-xr-x
2022-08-19 05:00
setuptools
[ DIR ]
drwxr-xr-x
2021-09-16 10:43
setuptools-0.9.8-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2021-09-16 10:43
six-1.9.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
slip
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
supervisor
[ DIR ]
drwxr-xr-x
2024-07-29 10:18
supervisor-3.4.0-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2024-07-29 10:18
tuned
[ DIR ]
drwxr-xr-x
2022-09-25 02:17
urlgrabber
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
urllib3
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
urllib3-1.10.2-py2.7.egg-info
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
usb
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
yubico
[ DIR ]
drwxr-xr-x
2022-07-26 09:09
yum
[ DIR ]
drwxr-xr-x
2022-08-19 05:00
yumutils
[ DIR ]
drwxr-xr-x
2021-09-16 10:31
IPy-0.75-py2.7.egg-info
9.83
KB
-rw-r--r--
2014-06-10 03:18
IPy.py
50.07
KB
-rw-r--r--
2011-04-12 07:53
IPy.pyc
39.92
KB
-rw-r--r--
2014-06-10 03:18
IPy.pyo
39.92
KB
-rw-r--r--
2014-06-10 03:18
SSSDConfig-1.16.5-py2.7.egg-info
205
B
-rw-r--r--
2024-01-25 11:03
backports.ssl_match_hostname-3.5.0.1-py2.7.egg-info
3.96
KB
-rw-r--r--
2018-04-10 22:25
clsudo.py
12.65
KB
-rw-r--r--
2017-06-01 12:14
clsudo.pyc
11.02
KB
-rw-r--r--
2017-06-01 12:14
clsudo.pyo
11.02
KB
-rw-r--r--
2017-06-01 12:14
configobj-4.7.2-py2.7.egg-info
2.08
KB
-rw-r--r--
2014-06-10 02:57
configobj.py
86.1
KB
-rw-r--r--
2010-02-27 16:36
configobj.pyc
64.72
KB
-rw-r--r--
2014-06-10 02:57
configobj.pyo
64.72
KB
-rw-r--r--
2014-06-10 02:57
crit-0.0.1-py2.7.egg-info
231
B
-rw-r--r--
2022-09-12 02:27
decorator.py
10.39
KB
-rw-r--r--
2012-10-18 04:49
decorator.pyc
8.36
KB
-rw-r--r--
2014-06-09 19:45
decorator.pyo
8.32
KB
-rw-r--r--
2014-06-09 19:45
easy_install.py
126
B
-rw-r--r--
2013-07-15 13:12
easy_install.pyc
315
B
-rw-r--r--
2017-08-02 06:18
easy_install.pyo
315
B
-rw-r--r--
2017-08-02 06:18
enum34-1.0.4-py2.7.egg-info
28.04
KB
-rw-r--r--
2015-11-19 18:31
hwdata.py
5.89
KB
-rw-r--r--
2012-03-02 11:22
hwdata.pyc
4.38
KB
-rw-r--r--
2014-09-17 11:02
hwdata.pyo
4.38
KB
-rw-r--r--
2014-09-17 11:02
iniparse-0.4-py2.7.egg-info
1.06
KB
-rw-r--r--
2014-06-09 18:04
iotop-0.6-py2.7.egg-info
348
B
-rw-r--r--
2018-10-30 18:23
ipaddr-2.1.11-py2.7.egg-info
588
B
-rw-r--r--
2019-08-06 15:09
ipaddr.py
58.16
KB
-rw-r--r--
2019-08-06 15:09
ipaddr.pyc
56.22
KB
-rw-r--r--
2019-08-06 15:09
ipaddr.pyo
56.03
KB
-rw-r--r--
2019-08-06 15:09
ipaddress-1.0.16-py2.7.egg-info
783
B
-rw-r--r--
2016-11-05 12:37
ipaddress.py
78.03
KB
-rw-r--r--
2015-12-28 12:09
ipaddress.pyc
73.75
KB
-rw-r--r--
2016-11-05 12:37
ipaddress.pyo
73.57
KB
-rw-r--r--
2016-11-05 12:37
ipaplatform-4.6.8-py2.7-nspkg.pth
322
B
-rw-r--r--
2023-06-13 03:24
isc-2.0-py2.7.egg-info
267
B
-rw-r--r--
2025-03-04 05:23
netaddr-0.7.5-py2.7.egg-info
4.42
KB
-rw-r--r--
2018-04-10 23:05
pciutils-1.7.3-py2.7.egg-info
267
B
-rw-r--r--
2014-09-17 11:02
pkg_resources.py
98.74
KB
-rw-r--r--
2013-07-15 13:12
pkg_resources.pyc
105.5
KB
-rw-r--r--
2017-08-02 06:18
pkg_resources.pyo
105.47
KB
-rw-r--r--
2017-08-02 06:18
ply-3.4-py2.7.egg-info
900
B
-rw-r--r--
2017-08-02 20:46
protobuf-2.5.0-py2.7-nspkg.pth
307
B
-rw-r--r--
2015-11-27 15:32
pyparsing-1.5.6-py2.7.egg-info
670
B
-rw-r--r--
2014-06-09 18:15
pyparsing.py
151.79
KB
-rw-r--r--
2014-06-09 18:15
pyparsing.pyc
145.41
KB
-rw-r--r--
2014-06-09 18:15
pyparsing.pyo
145.41
KB
-rw-r--r--
2014-06-09 18:15
python_linux_procfs-0.4.9-py2.7.egg-info
350
B
-rw-r--r--
2019-08-08 22:08
pyusb-1.0.0b1-py2.7.egg-info
508
B
-rw-r--r--
2015-03-06 00:15
requests-2.6.0-py2.7.egg-info
39.41
KB
-rw-r--r--
2020-10-13 12:05
rhnlib-2.5.65-py2.7.egg-info
345
B
-rw-r--r--
2018-10-30 14:36
secureio.py
9.01
KB
-rw-r--r--
2017-06-01 12:14
secureio.pyc
4.58
KB
-rw-r--r--
2017-06-01 12:14
secureio.pyo
4.58
KB
-rw-r--r--
2017-06-01 12:14
six.py
28.97
KB
-rw-r--r--
2015-01-02 11:33
six.pyc
29.01
KB
-rw-r--r--
2015-11-19 21:55
six.pyo
29.01
KB
-rw-r--r--
2015-11-19 21:55
slip-0.4.0-py2.7.egg-info
196
B
-rw-r--r--
2018-04-10 21:49
slip.dbus-0.4.0-py2.7.egg-info
269
B
-rw-r--r--
2018-04-10 21:49
supervisor-3.4.0-py2.7-nspkg.pth
319
B
-rw-r--r--
2020-03-10 20:45
typing-3.5.2.2-py2.7.egg-info
1.35
KB
-rw-r--r--
2020-04-22 15:39
typing.py
55.94
KB
-rw-r--r--
2016-06-08 14:10
typing.pyc
64.45
KB
-rw-r--r--
2020-04-22 15:39
typing.pyo
63.65
KB
-rw-r--r--
2020-04-22 15:39
urlgrabber-3.10-py2.7.egg-info
2.21
KB
-rw-r--r--
2020-04-01 00:14
validate.py
45.22
KB
-rw-r--r--
2014-06-10 02:57
validate.pyc
45.62
KB
-rw-r--r--
2014-06-10 02:57
validate.pyo
45.62
KB
-rw-r--r--
2014-06-10 02: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)