Initial YakPanel commit
This commit is contained in:
36
class/safe_warning/sw_chmod_stickybit.py
Normal file
36
class/safe_warning/sw_chmod_stickybit.py
Normal file
@@ -0,0 +1,36 @@
|
||||
#!/usr/bin/python
|
||||
# coding: utf-8
|
||||
|
||||
import os, sys, public
|
||||
_title = 'Check temporary directory for sticky bit'
|
||||
_version = 1.0 # 版本
|
||||
_ps = "Check if the temporary directory has the sticky bit permission set" # 描述
|
||||
_level = 2 # 风险级别: 1.提示(低) 2.警告(中) 3.危险(高)
|
||||
_date = '2023-03-09' # 最后更新时间
|
||||
_ignore = os.path.exists("data/warning/ignore/sw_chmod_stickybit.pl")
|
||||
_tips = [
|
||||
"Use the chmod +t [file name] command to modify the permissions of the file",
|
||||
]
|
||||
_help = ''
|
||||
_remind = 'This solution prevents system users from accidentally deleting files on the server. '
|
||||
|
||||
def check_run():
|
||||
'''
|
||||
@name 开始检测
|
||||
@return tuple (status<bool>,msg<string>)
|
||||
'''
|
||||
# result_list存放未配置粘滞位的目录名
|
||||
result_list = []
|
||||
tmp_path = ['/var/tmp', '/tmp']
|
||||
for t in tmp_path:
|
||||
# 文件不存在则跳过,保险操作。
|
||||
if not os.path.exists(t):
|
||||
continue
|
||||
result_str = public.ExecShell('find {} -maxdepth 0 -perm /01000 -type d'.format(t))[0].strip()
|
||||
if not result_str[1]:
|
||||
result_list.append(t)
|
||||
if result_list:
|
||||
result = '、'.join(result_list)
|
||||
return False, 'The following directories do not have sticky bit permissions set:{}'.format(result)
|
||||
else:
|
||||
return True, 'Risk-free'
|
||||
Reference in New Issue
Block a user