-
-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathvuln.go
39 lines (33 loc) · 736 Bytes
/
vuln.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package main
import (
"fmt"
"strings"
)
type Vulnerabilities uint8
func (v Vulnerabilities) String() string {
var tags []string
if v&CVE_2022_22965 != 0 {
tags = append(tags, "CVE-2022-22965")
}
return strings.Join(tags, ", ")
}
func (v *Vulnerabilities) Set(s string) error {
*v = 0
for _, tag := range strings.Split(s, ",") {
switch strings.ToLower(strings.Trim(tag, " ")) {
case "cve-2022-22965", "spring4shell", "springshell":
*v |= CVE_2022_22965
case "":
default:
return fmt.Errorf("invalid vulnerability '%s'", tag)
}
}
return nil
}
const (
CVE_2022_22965 = 1 << iota
)
const (
CheckDefaultVulnerabilities Vulnerabilities = CVE_2022_22965
CheckAllVulnerabilities Vulnerabilities = 0xff
)