1
0
mirror of https://github.com/aquasecurity/kube-bench.git synced 2025-01-20 12:41:03 +00:00
kube-bench/cmd/util.go

148 lines
3.0 KiB
Go
Raw Normal View History

package cmd
import (
"fmt"
"os"
"os/exec"
"strings"
"github.com/aquasecurity/kube-bench/check"
"github.com/fatih/color"
2017-07-25 00:34:07 +00:00
"github.com/golang/glog"
)
var (
// Print colors
colors = map[check.State]*color.Color{
check.PASS: color.New(color.FgGreen),
check.FAIL: color.New(color.FgRed),
check.WARN: color.New(color.FgYellow),
check.INFO: color.New(color.FgBlue),
}
)
func printlnWarn(msg string) {
2017-07-25 00:34:07 +00:00
fmt.Fprintf(os.Stderr, "[%s] %s\n",
colors[check.WARN].Sprintf("%s", check.WARN),
msg,
)
}
func sprintlnWarn(msg string) string {
2017-07-25 00:34:07 +00:00
return fmt.Sprintf("[%s] %s",
colors[check.WARN].Sprintf("%s", check.WARN),
msg,
)
}
func exitWithError(err error) {
fmt.Fprintf(os.Stderr, "\n%v\n", err)
os.Exit(1)
}
func continueWithError(err error, msg string) string {
if err != nil {
2017-07-25 00:34:07 +00:00
glog.V(1).Info(err)
}
2017-07-25 00:34:07 +00:00
if msg != "" {
fmt.Fprintf(os.Stderr, "%s\n", msg)
}
return ""
}
func cleanIDs(list string) []string {
list = strings.Trim(list, ",")
ids := strings.Split(list, ",")
for _, id := range ids {
id = strings.Trim(id, " ")
}
return ids
}
2017-07-25 00:34:07 +00:00
func verifyConf(confPath ...string) {
var missing string
for _, c := range confPath {
if _, err := os.Stat(c); err != nil && os.IsNotExist(err) {
2017-07-25 00:34:07 +00:00
continueWithError(err, "")
missing += c + ", "
}
}
2017-07-25 00:34:07 +00:00
if len(missing) > 0 {
missing = strings.Trim(missing, ", ")
printlnWarn(fmt.Sprintf("Missing kubernetes config files: %s", missing))
2017-07-25 00:34:07 +00:00
}
}
2017-07-25 00:34:07 +00:00
func verifyBin(binPath ...string) {
var binSlice []string
var bin string
var missing string
var notRunning string
// Construct proc name for ps(1)
for _, b := range binPath {
2017-07-13 01:01:18 +00:00
_, err := exec.LookPath(b)
2017-07-25 00:34:07 +00:00
bin = bin + "," + b
binSlice = append(binSlice, b)
if err != nil {
missing += b + ", "
continueWithError(err, "")
}
}
2017-07-25 00:34:07 +00:00
bin = strings.Trim(bin, ",")
2017-07-13 01:01:18 +00:00
2017-07-25 00:34:07 +00:00
cmd := exec.Command("ps", "-C", bin, "-o", "cmd", "--no-headers")
out, err := cmd.Output()
2017-07-25 00:34:07 +00:00
if err != nil {
continueWithError(fmt.Errorf("%s: %s", cmd.Args, err), "")
}
2017-07-25 00:34:07 +00:00
for _, b := range binSlice {
matched := strings.Contains(string(out), b)
if !matched {
2017-07-25 00:34:07 +00:00
notRunning += b + ", "
}
}
2017-07-25 00:34:07 +00:00
if len(missing) > 0 {
missing = strings.Trim(missing, ", ")
printlnWarn(fmt.Sprintf("Missing kubernetes binaries: %s", missing))
2017-07-25 00:34:07 +00:00
}
if len(notRunning) > 0 {
notRunning = strings.Trim(notRunning, ", ")
printlnWarn(fmt.Sprintf("Kubernetes binaries not running: %s", notRunning))
2017-07-25 00:34:07 +00:00
}
}
2017-07-25 00:34:07 +00:00
func verifyKubeVersion(b string) {
// These executables might not be on the user's path.
// TODO! Check the version number using kubectl, which is more likely to be on the path.
2017-07-13 01:01:18 +00:00
_, err := exec.LookPath(b)
2017-07-25 00:34:07 +00:00
if err != nil {
continueWithError(err, sprintlnWarn("Kubernetes version check skipped"))
2017-07-25 00:34:07 +00:00
return
}
2017-07-13 01:01:18 +00:00
cmd := exec.Command(b, "--version")
out, err := cmd.Output()
2017-07-25 00:34:07 +00:00
if err != nil {
continueWithError(err, sprintlnWarn("Kubernetes version check skipped"))
2017-07-25 00:34:07 +00:00
return
}
matched := strings.Contains(string(out), kubeVersion)
if !matched {
printlnWarn(fmt.Sprintf("Unsupported kubernetes version: %s", out))
}
}