1
0
mirror of https://github.com/1Panel-dev/1Panel.git synced 2025-01-19 08:19:15 +08:00

feat: 增加 clamdscan 服务检测 (#5784)

This commit is contained in:
zhengkunwang 2024-07-12 14:11:25 +08:00 committed by GitHub
parent 03b04eea6b
commit 9a635e99b2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 47 additions and 43 deletions

View File

@ -54,19 +54,19 @@ func NewIClamService() IClamService {
return &ClamService{} return &ClamService{}
} }
func (f *ClamService) LoadBaseInfo() (dto.ClamBaseInfo, error) { func (c *ClamService) LoadBaseInfo() (dto.ClamBaseInfo, error) {
var baseInfo dto.ClamBaseInfo var baseInfo dto.ClamBaseInfo
baseInfo.Version = "-" baseInfo.Version = "-"
baseInfo.FreshVersion = "-" baseInfo.FreshVersion = "-"
exist1, _ := systemctl.IsExist(clamServiceNameCentOs) exist1, _ := systemctl.IsExist(clamServiceNameCentOs)
if exist1 { if exist1 {
f.serviceName = clamServiceNameCentOs c.serviceName = clamServiceNameCentOs
baseInfo.IsExist = true baseInfo.IsExist = true
baseInfo.IsActive, _ = systemctl.IsActive(clamServiceNameCentOs) baseInfo.IsActive, _ = systemctl.IsActive(clamServiceNameCentOs)
} }
exist2, _ := systemctl.IsExist(clamServiceNameUbuntu) exist2, _ := systemctl.IsExist(clamServiceNameUbuntu)
if exist2 { if exist2 {
f.serviceName = clamServiceNameUbuntu c.serviceName = clamServiceNameUbuntu
baseInfo.IsExist = true baseInfo.IsExist = true
baseInfo.IsActive, _ = systemctl.IsActive(clamServiceNameUbuntu) baseInfo.IsActive, _ = systemctl.IsActive(clamServiceNameUbuntu)
} }
@ -78,41 +78,39 @@ func (f *ClamService) LoadBaseInfo() (dto.ClamBaseInfo, error) {
if baseInfo.IsActive { if baseInfo.IsActive {
version, err := cmd.Exec("clamdscan --version") version, err := cmd.Exec("clamdscan --version")
if err != nil { if err == nil {
return baseInfo, nil
}
if strings.Contains(version, "/") { if strings.Contains(version, "/") {
baseInfo.Version = strings.TrimPrefix(strings.Split(version, "/")[0], "ClamAV ") baseInfo.Version = strings.TrimPrefix(strings.Split(version, "/")[0], "ClamAV ")
} else { } else {
baseInfo.Version = strings.TrimPrefix(version, "ClamAV ") baseInfo.Version = strings.TrimPrefix(version, "ClamAV ")
} }
} }
}
if baseInfo.FreshIsActive { if baseInfo.FreshIsActive {
version, err := cmd.Exec("freshclam --version") version, err := cmd.Exec("freshclam --version")
if err != nil { if err == nil {
return baseInfo, nil
}
if strings.Contains(version, "/") { if strings.Contains(version, "/") {
baseInfo.FreshVersion = strings.TrimPrefix(strings.Split(version, "/")[0], "ClamAV ") baseInfo.FreshVersion = strings.TrimPrefix(strings.Split(version, "/")[0], "ClamAV ")
} else { } else {
baseInfo.FreshVersion = strings.TrimPrefix(version, "ClamAV ") baseInfo.FreshVersion = strings.TrimPrefix(version, "ClamAV ")
} }
} }
}
return baseInfo, nil return baseInfo, nil
} }
func (f *ClamService) Operate(operate string) error { func (c *ClamService) Operate(operate string) error {
switch operate { switch operate {
case "start", "restart", "stop": case "start", "restart", "stop":
stdout, err := cmd.Execf("systemctl %s %s", operate, f.serviceName) stdout, err := cmd.Execf("systemctl %s %s", operate, c.serviceName)
if err != nil { if err != nil {
return fmt.Errorf("%s the %s failed, err: %s", operate, f.serviceName, stdout) return fmt.Errorf("%s the %s failed, err: %s", operate, c.serviceName, stdout)
} }
return nil return nil
case "fresh-start", "fresh-restart", "fresh-stop": case "fresh-start", "fresh-restart", "fresh-stop":
stdout, err := cmd.Execf("systemctl %s %s", strings.TrimPrefix(operate, "fresh-"), freshClamService) stdout, err := cmd.Execf("systemctl %s %s", strings.TrimPrefix(operate, "fresh-"), freshClamService)
if err != nil { if err != nil {
return fmt.Errorf("%s the %s failed, err: %s", operate, f.serviceName, stdout) return fmt.Errorf("%s the %s failed, err: %s", operate, c.serviceName, stdout)
} }
return nil return nil
default: default:
@ -120,7 +118,7 @@ func (f *ClamService) Operate(operate string) error {
} }
} }
func (f *ClamService) SearchWithPage(req dto.SearchWithPage) (int64, interface{}, error) { func (c *ClamService) SearchWithPage(req dto.SearchWithPage) (int64, interface{}, error) {
total, commands, err := clamRepo.Page(req.Page, req.PageSize, commonRepo.WithLikeName(req.Info)) total, commands, err := clamRepo.Page(req.Page, req.PageSize, commonRepo.WithLikeName(req.Info))
if err != nil { if err != nil {
return 0, nil, err return 0, nil, err
@ -151,7 +149,7 @@ func (f *ClamService) SearchWithPage(req dto.SearchWithPage) (int64, interface{}
return total, datas, err return total, datas, err
} }
func (f *ClamService) Create(req dto.ClamCreate) error { func (c *ClamService) Create(req dto.ClamCreate) error {
clam, _ := clamRepo.Get(commonRepo.WithByName(req.Name)) clam, _ := clamRepo.Get(commonRepo.WithByName(req.Name))
if clam.ID != 0 { if clam.ID != 0 {
return constant.ErrRecordExist return constant.ErrRecordExist
@ -168,7 +166,7 @@ func (f *ClamService) Create(req dto.ClamCreate) error {
return nil return nil
} }
func (f *ClamService) Update(req dto.ClamUpdate) error { func (c *ClamService) Update(req dto.ClamUpdate) error {
clam, _ := clamRepo.Get(commonRepo.WithByName(req.Name)) clam, _ := clamRepo.Get(commonRepo.WithByName(req.Name))
if clam.ID == 0 { if clam.ID == 0 {
return constant.ErrRecordNotFound return constant.ErrRecordNotFound
@ -188,7 +186,7 @@ func (f *ClamService) Update(req dto.ClamUpdate) error {
return nil return nil
} }
func (u *ClamService) Delete(req dto.ClamDelete) error { func (c *ClamService) Delete(req dto.ClamDelete) error {
for _, id := range req.Ids { for _, id := range req.Ids {
clam, _ := clamRepo.Get(commonRepo.WithByID(id)) clam, _ := clamRepo.Get(commonRepo.WithByID(id))
if clam.ID == 0 { if clam.ID == 0 {
@ -207,7 +205,10 @@ func (u *ClamService) Delete(req dto.ClamDelete) error {
return nil return nil
} }
func (u *ClamService) HandleOnce(req dto.OperateByID) error { func (c *ClamService) HandleOnce(req dto.OperateByID) error {
if cmd.Which("clamdscan") == false {
return buserr.New("ErrClamdscanNotFound")
}
clam, _ := clamRepo.Get(commonRepo.WithByID(req.ID)) clam, _ := clamRepo.Get(commonRepo.WithByID(req.ID))
if clam.ID == 0 { if clam.ID == 0 {
return constant.ErrRecordNotFound return constant.ErrRecordNotFound
@ -241,13 +242,13 @@ func (u *ClamService) HandleOnce(req dto.OperateByID) error {
global.LOG.Debugf("clamdscan --fdpass %s %s -l %s", strategy, clam.Path, logFile) global.LOG.Debugf("clamdscan --fdpass %s %s -l %s", strategy, clam.Path, logFile)
stdout, err := cmd.Execf("clamdscan --fdpass %s %s -l %s", strategy, clam.Path, logFile) stdout, err := cmd.Execf("clamdscan --fdpass %s %s -l %s", strategy, clam.Path, logFile)
if err != nil { if err != nil {
global.LOG.Errorf("clamdscan failed, stdout: %v, err: %v", string(stdout), err) global.LOG.Errorf("clamdscan failed, stdout: %v, err: %v", stdout, err)
} }
}() }()
return nil return nil
} }
func (u *ClamService) LoadRecords(req dto.ClamLogSearch) (int64, interface{}, error) { func (c *ClamService) LoadRecords(req dto.ClamLogSearch) (int64, interface{}, error) {
clam, _ := clamRepo.Get(commonRepo.WithByID(req.ClamID)) clam, _ := clamRepo.Get(commonRepo.WithByID(req.ClamID))
if clam.ID == 0 { if clam.ID == 0 {
return 0, nil, constant.ErrRecordNotFound return 0, nil, constant.ErrRecordNotFound
@ -294,7 +295,7 @@ func (u *ClamService) LoadRecords(req dto.ClamLogSearch) (int64, interface{}, er
} }
return int64(total), datas, nil return int64(total), datas, nil
} }
func (u *ClamService) LoadRecordLog(req dto.ClamLogReq) (string, error) { func (c *ClamService) LoadRecordLog(req dto.ClamLogReq) (string, error) {
logPath := path.Join(global.CONF.System.DataDir, resultDir, req.ClamName, req.RecordName) logPath := path.Join(global.CONF.System.DataDir, resultDir, req.ClamName, req.RecordName)
var tail string var tail string
if req.Tail != "0" { if req.Tail != "0" {
@ -310,7 +311,7 @@ func (u *ClamService) LoadRecordLog(req dto.ClamLogReq) (string, error) {
return string(stdout), nil return string(stdout), nil
} }
func (u *ClamService) CleanRecord(req dto.OperateByID) error { func (c *ClamService) CleanRecord(req dto.OperateByID) error {
clam, _ := clamRepo.Get(commonRepo.WithByID(req.ID)) clam, _ := clamRepo.Get(commonRepo.WithByID(req.ID))
if clam.ID == 0 { if clam.ID == 0 {
return constant.ErrRecordNotFound return constant.ErrRecordNotFound
@ -320,37 +321,37 @@ func (u *ClamService) CleanRecord(req dto.OperateByID) error {
return nil return nil
} }
func (u *ClamService) LoadFile(req dto.ClamFileReq) (string, error) { func (c *ClamService) LoadFile(req dto.ClamFileReq) (string, error) {
filePath := "" filePath := ""
switch req.Name { switch req.Name {
case "clamd": case "clamd":
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
filePath = "/etc/clamav/clamd.conf" filePath = "/etc/clamav/clamd.conf"
} else { } else {
filePath = "/etc/clamd.d/scan.conf" filePath = "/etc/clamd.d/scan.conf"
} }
case "clamd-log": case "clamd-log":
filePath = u.loadLogPath("clamd-log") filePath = c.loadLogPath("clamd-log")
if len(filePath) != 0 { if len(filePath) != 0 {
break break
} }
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
filePath = "/var/log/clamav/clamav.log" filePath = "/var/log/clamav/clamav.log"
} else { } else {
filePath = "/var/log/clamd.scan" filePath = "/var/log/clamd.scan"
} }
case "freshclam": case "freshclam":
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
filePath = "/etc/clamav/freshclam.conf" filePath = "/etc/clamav/freshclam.conf"
} else { } else {
filePath = "/etc/freshclam.conf" filePath = "/etc/freshclam.conf"
} }
case "freshclam-log": case "freshclam-log":
filePath = u.loadLogPath("freshclam-log") filePath = c.loadLogPath("freshclam-log")
if len(filePath) != 0 { if len(filePath) != 0 {
break break
} }
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
filePath = "/var/log/clamav/freshclam.log" filePath = "/var/log/clamav/freshclam.log"
} else { } else {
filePath = "/var/log/freshclam.log" filePath = "/var/log/freshclam.log"
@ -375,12 +376,12 @@ func (u *ClamService) LoadFile(req dto.ClamFileReq) (string, error) {
return string(stdout), nil return string(stdout), nil
} }
func (u *ClamService) UpdateFile(req dto.UpdateByNameAndFile) error { func (c *ClamService) UpdateFile(req dto.UpdateByNameAndFile) error {
filePath := "" filePath := ""
service := "" service := ""
switch req.Name { switch req.Name {
case "clamd": case "clamd":
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
service = clamServiceNameUbuntu service = clamServiceNameUbuntu
filePath = "/etc/clamav/clamd.conf" filePath = "/etc/clamav/clamd.conf"
} else { } else {
@ -388,7 +389,7 @@ func (u *ClamService) UpdateFile(req dto.UpdateByNameAndFile) error {
filePath = "/etc/clamd.d/scan.conf" filePath = "/etc/clamd.d/scan.conf"
} }
case "freshclam": case "freshclam":
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
filePath = "/etc/clamav/freshclam.conf" filePath = "/etc/clamav/freshclam.conf"
} else { } else {
filePath = "/etc/freshclam.conf" filePath = "/etc/freshclam.conf"
@ -458,16 +459,16 @@ func loadResultFromLog(pathItem string) dto.ClamLog {
} }
return data return data
} }
func (u *ClamService) loadLogPath(name string) string { func (c *ClamService) loadLogPath(name string) string {
confPath := "" confPath := ""
if name == "clamd-log" { if name == "clamd-log" {
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
confPath = "/etc/clamav/clamd.conf" confPath = "/etc/clamav/clamd.conf"
} else { } else {
confPath = "/etc/clamd.d/scan.conf" confPath = "/etc/clamd.d/scan.conf"
} }
} else { } else {
if u.serviceName == clamServiceNameUbuntu { if c.serviceName == clamServiceNameUbuntu {
confPath = "/etc/clamav/freshclam.conf" confPath = "/etc/clamav/freshclam.conf"
} else { } else {
confPath = "/etc/freshclam.conf" confPath = "/etc/freshclam.conf"

View File

@ -174,6 +174,7 @@ CutWebsiteLogSuccess: "{{ .name }} website log cut successfully, backup path {{
#toolbox #toolbox
ErrNotExistUser: "The current user does not exist. Please modify and retry!" ErrNotExistUser: "The current user does not exist. Please modify and retry!"
ErrBanAction: "Setting failed, the current {{ .name }} service is unavailable, please check and try again!" ErrBanAction: "Setting failed, the current {{ .name }} service is unavailable, please check and try again!"
ErrClamdscanNotFound: "The clamdscan command was not detected, please refer to the documentation to install it!"
#waf #waf
ErrScope: "Modification of this configuration is not supported" ErrScope: "Modification of this configuration is not supported"

View File

@ -175,6 +175,7 @@ CutWebsiteLogSuccess: "{{ .name }} 網站日誌切割成功,備份路徑 {{ .p
#toolbox #toolbox
ErrNotExistUser: "當前使用者不存在,請修改後重試!" ErrNotExistUser: "當前使用者不存在,請修改後重試!"
ErrBanAction: "設置失敗,當前 {{ .name }} 服務不可用,請檢查後重試!" ErrBanAction: "設置失敗,當前 {{ .name }} 服務不可用,請檢查後重試!"
ErrClamdscanNotFound: "未偵測到 clamdscan 指令,請參考文件安裝!"
#waf #waf
ErrScope: "不支援修改此配置" ErrScope: "不支援修改此配置"

View File

@ -177,6 +177,7 @@ CutWebsiteLogSuccess: "{{ .name }} 网站日志切割成功,备份路径 {{ .p
#toolbox #toolbox
ErrNotExistUser: "当前用户不存在,请修改后重试!" ErrNotExistUser: "当前用户不存在,请修改后重试!"
ErrBanAction: "设置失败,当前 {{ .name }} 服务不可用,请检查后重试!" ErrBanAction: "设置失败,当前 {{ .name }} 服务不可用,请检查后重试!"
ErrClamdscanNotFound: "未检测到 clamdscan 命令,请参考文档安装!"
#waf #waf
ErrScope: "不支持修改此配置" ErrScope: "不支持修改此配置"