2022-07-23 11:01:41 +00:00
|
|
|
package route
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/sagernet/sing-box/adapter"
|
2022-07-24 14:54:16 +00:00
|
|
|
"github.com/sagernet/sing-box/common/warning"
|
|
|
|
C "github.com/sagernet/sing-box/constant"
|
|
|
|
)
|
|
|
|
|
|
|
|
var warnProcessNameOnNonSupportedPlatform = warning.New(
|
|
|
|
func() bool { return !(C.IsLinux || C.IsWindows || C.IsDarwin) },
|
|
|
|
"rule item `process_item` is only supported on Linux, Windows, and Mac OS X",
|
2022-07-23 11:01:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var _ RuleItem = (*ProcessItem)(nil)
|
|
|
|
|
|
|
|
type ProcessItem struct {
|
|
|
|
processes []string
|
|
|
|
processMap map[string]bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewProcessItem(processNameList []string) *ProcessItem {
|
2022-07-24 14:54:16 +00:00
|
|
|
warnProcessNameOnNonSupportedPlatform.Check()
|
2022-07-23 11:01:41 +00:00
|
|
|
rule := &ProcessItem{
|
|
|
|
processes: processNameList,
|
|
|
|
processMap: make(map[string]bool),
|
|
|
|
}
|
|
|
|
for _, processName := range processNameList {
|
|
|
|
rule.processMap[strings.ToLower(processName)] = true
|
|
|
|
}
|
|
|
|
return rule
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *ProcessItem) Match(metadata *adapter.InboundContext) bool {
|
|
|
|
if metadata.ProcessInfo == nil || metadata.ProcessInfo.ProcessPath == "" {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return r.processMap[strings.ToLower(filepath.Base(metadata.ProcessInfo.ProcessPath))]
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *ProcessItem) String() string {
|
|
|
|
var description string
|
|
|
|
pLen := len(r.processes)
|
|
|
|
if pLen == 1 {
|
|
|
|
description = "process_name=" + r.processes[0]
|
|
|
|
} else {
|
|
|
|
description = "process_name=[" + strings.Join(r.processes, " ") + "]"
|
|
|
|
}
|
|
|
|
return description
|
|
|
|
}
|