Skip to content

Commit

Permalink
cmd/tetra: add option to tetra to filter on event types
Browse files Browse the repository at this point in the history
This commit adds the ability to filter on the event types.

Signed-off-by: darox <maderdario@gmail.com>
  • Loading branch information
darox authored and willfindlay committed Oct 6, 2023
1 parent e2eb1d5 commit fb26d23
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 0 deletions.
22 changes: 22 additions & 0 deletions cmd/tetra/getevents/getevents.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"fmt"
"io"
"os"
"strings"

"github.com/cilium/tetragon/api/v1/tetragon"
"github.com/cilium/tetragon/cmd/tetra/common"
Expand Down Expand Up @@ -41,6 +42,7 @@ type Opts struct {
Output string
Color string
IncludeFields []string
EventTypes []string
ExcludeFields []string
Namespaces []string
Namespace []string // deprecated: use Namespaces
Expand Down Expand Up @@ -86,7 +88,15 @@ var GetFilter = func() *tetragon.Filter {
if len(Options.Pods) > 0 {
filter.PodRegex = Options.Pods
}
// Is used to filter on the event types i.e. PROCESS_EXEC, PROCESS_EXIT etc.
if len(Options.EventTypes) > 0 {
var eventType tetragon.EventType

for _, v := range Options.EventTypes {
eventType = tetragon.EventType(tetragon.EventType_value[v])
filter.EventSet = append(filter.EventSet, eventType)
}
}
return &filter
}

Expand Down Expand Up @@ -151,6 +161,17 @@ func New() *cobra.Command {
return fmt.Errorf("invalid value for %q flag: %s", "color", Options.Color)
}

for _, v := range Options.EventTypes {
if _, found := tetragon.EventType_value[v]; !found {
var supportedEventTypes string
for _, v := range tetragon.EventType_name {
supportedEventTypes += v + ", "
}
supportedEventTypes = strings.TrimSuffix(supportedEventTypes, ", ")
return fmt.Errorf("invalid value for %q flag: %s. Supported are %s", "event-types", v, supportedEventTypes)
}
}

// merge deprecated to new flags, appending since order does not matter
Options.Namespaces = append(Options.Namespaces, Options.Namespace...)
Options.Pods = append(Options.Pods, Options.Pod...)
Expand All @@ -174,6 +195,7 @@ func New() *cobra.Command {
flags.StringVarP(&Options.Output, common.KeyOutput, "o", "json", "Output format. json or compact")
flags.StringVar(&Options.Color, "color", "auto", "Colorize compact output. auto, always, or never")
flags.StringSliceVarP(&Options.IncludeFields, "include-fields", "f", nil, "Include only fields in events")
flags.StringSliceVarP(&Options.EventTypes, "event-types", "e", nil, "Include only events of given types")
flags.StringSliceVarP(&Options.ExcludeFields, "exclude-fields", "F", nil, "Exclude fields from events")

flags.StringSliceVarP(&Options.Namespaces, "namespaces", "n", nil, "Get events by Kubernetes namespaces")
Expand Down
25 changes: 25 additions & 0 deletions cmd/tetra/getevents/getevents_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,31 @@ func Test_GetEvents_Namespaces(t *testing.T) {
})
}

func Test_GetEvents_EventTypes(t *testing.T) {
t.Run("FilterProcessExec", func(t *testing.T) {
testutils.MockPipedFile(t, testutils.RepoRootPath("testdata/events.json"))
cmd := New()
cmd.SetArgs([]string{"--event-types", "PROCESS_EXEC"})
output := testutils.RedirectStdoutExecuteCmd(t, cmd)
assert.Equal(t, 3, bytes.Count(output, []byte("\n")))
})

t.Run("FilterInexistent", func(t *testing.T) {
cmd := New()
cmd.SetArgs([]string{"--event-types", "INEXISTENT"})

// redirect stderr and stdout to not pollute test outputs. Here it
// works, compared to other use case where we have to redirect manually,
// because Cobra internal error mechanism calls internal Print methods.
var devNull bytes.Buffer
cmd.SetErr(&devNull)
cmd.SetOut(&devNull)

err := cmd.Execute()
assert.Error(t, err)
})
}

func Test_GetEvents_Pods(t *testing.T) {
t.Run("FilterTie", func(t *testing.T) {
testutils.MockPipedFile(t, testutils.RepoRootPath("testdata/events.json"))
Expand Down

0 comments on commit fb26d23

Please sign in to comment.