diff --git a/CHANGELOG.next.asciidoc b/CHANGELOG.next.asciidoc index 86ef19b1d90..cabb685f2cf 100644 --- a/CHANGELOG.next.asciidoc +++ b/CHANGELOG.next.asciidoc @@ -197,6 +197,7 @@ https://github.com/elastic/beats/compare/v8.8.1\...main[Check the HEAD diff] - Further rate limiting fix in the Okta provider of the Entity Analytics input. {issue}40106[40106] {pull}41977[41977] - Fix streaming input handling of invalid or empty websocket messages. {pull}42036[42036] - Fix awss3 document ID construction when using the CSV decoder. {pull}42019[42019] +- Fix Netflow Template Sharing configuration handling. {pull}42080[42080] *Heartbeat* diff --git a/x-pack/filebeat/input/netflow/decoder/config/config.go b/x-pack/filebeat/input/netflow/decoder/config/config.go index 84f1e050c1f..5297f3c4a31 100644 --- a/x-pack/filebeat/input/netflow/decoder/config/config.go +++ b/x-pack/filebeat/input/netflow/decoder/config/config.go @@ -136,6 +136,11 @@ func (c *Config) SequenceResetEnabled() bool { return c.detectReset } +// ShareTemplatesEnabled returns if template sharing is enabled. +func (c *Config) ShareTemplatesEnabled() bool { + return c.sharedTemplates +} + // Fields returns the configured fields. func (c *Config) Fields() fields.FieldDict { if c.fields == nil { diff --git a/x-pack/filebeat/input/netflow/decoder/v9/v9.go b/x-pack/filebeat/input/netflow/decoder/v9/v9.go index 2fafe452c62..4e67dde701f 100644 --- a/x-pack/filebeat/input/netflow/decoder/v9/v9.go +++ b/x-pack/filebeat/input/netflow/decoder/v9/v9.go @@ -50,13 +50,14 @@ func New(config config.Config) protocol.Protocol { func NewProtocolWithDecoder(decoder Decoder, config config.Config, logger *log.Logger) *NetflowV9Protocol { ctx, cancel := context.WithCancel(context.Background()) pd := &NetflowV9Protocol{ - ctx: ctx, - cancel: cancel, - decoder: decoder, - logger: logger, - Session: NewSessionMap(logger, config.ActiveSessionsMetric()), - timeout: config.ExpirationTimeout(), - detectReset: config.SequenceResetEnabled(), + ctx: ctx, + cancel: cancel, + decoder: decoder, + logger: logger, + Session: NewSessionMap(logger, config.ActiveSessionsMetric()), + timeout: config.ExpirationTimeout(), + detectReset: config.SequenceResetEnabled(), + shareTemplates: config.ShareTemplatesEnabled(), } if config.Cache() { diff --git a/x-pack/filebeat/input/netflow/decoder/v9/v9_test.go b/x-pack/filebeat/input/netflow/decoder/v9/v9_test.go index a98f6150f6a..67212c1e408 100644 --- a/x-pack/filebeat/input/netflow/decoder/v9/v9_test.go +++ b/x-pack/filebeat/input/netflow/decoder/v9/v9_test.go @@ -249,3 +249,53 @@ func TestCustomFields(t *testing.T) { assert.Contains(t, flows[0].Fields, "customField") assert.Equal(t, flows[0].Fields["customField"], "Hello :)") } + +func TestSharedTemplates(t *testing.T) { + templateAddr := test.MakeAddress(t, "127.0.0.1:12345") + flowsAddr := test.MakeAddress(t, "127.0.0.2:21234") + templatePacket := []uint16{ + // Header + // Version, Count, Uptime, Ts, SeqNo, Source + 9, 1, 11, 11, 22, 22, 33, 33, 0, 1234, + // Set #1 (template) + 0, 20, /*len of set*/ + 999, 3, /*len*/ + 1, 4, // Fields + 2, 4, + 3, 4, + } + flowsPacket := []uint16{ + // Header + // Version, Count, Uptime, Ts, SeqNo, Source + 9, 1, 11, 11, 22, 22, 33, 34, 0, 1234, + // Set #1 (template) + 999, 16, /*len of set*/ + 1, 1, + 2, 2, + 3, 3, + } + + t.Run("Template sharing enabled", func(t *testing.T) { + cfg := config.Defaults() + cfg.WithSharedTemplates(true) + proto := New(cfg) + flows, err := proto.OnPacket(test.MakePacket(templatePacket), templateAddr) + assert.NoError(t, err) + assert.Empty(t, flows) + flows, err = proto.OnPacket(test.MakePacket(flowsPacket), flowsAddr) + assert.NoError(t, err) + assert.Len(t, flows, 1) + }) + + t.Run("Template sharing disabled", func(t *testing.T) { + cfg := config.Defaults() + cfg.WithSharedTemplates(false) + proto := New(cfg) + flows, err := proto.OnPacket(test.MakePacket(templatePacket), templateAddr) + assert.NoError(t, err) + assert.Empty(t, flows) + flows, err = proto.OnPacket(test.MakePacket(flowsPacket), flowsAddr) + assert.NoError(t, err) + assert.Empty(t, flows) + }) +}