Skip to content

Commit

Permalink
[Filebeat][httpjson] Change append transform to initiate new fields a…
Browse files Browse the repository at this point in the history
…s a slice (elastic#25074)

* changing the append processor to create a single value as list, not only if two or more values are added

* removing mistake typo

* add changelog entry

(cherry picked from commit 2b11cf8)
  • Loading branch information
P1llus committed Apr 14, 2021
1 parent 44efc6f commit 66a05e5
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 2 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.next.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,9 @@ https://github.com/elastic/beats/compare/v7.0.0-alpha2...master[Check the HEAD d
- Fix parsing issues with nested JSON payloads in Elasticsearch audit log fileset. {pull}22975[22975]
- Rename `network.direction` values in crowdstrike/falcon to `ingress`/`egress`. {pull}23041[23041]
- Rename `s3` input to `aws-s3` input. {pull}23469[23469]
- Possible values for Netflow's locality fields (source.locality, destination.locality and flow.locality) are now `internal` and `external`, instead of `private` and `public`. {issue}24272[24272] {pull}24295[24295]
- Add User Agent Parser for Azure Sign In Logs Ingest Pipeline {pull}23201[23201]
- Changes filebeat httpjson input's append transform to create a list even with only a single value{pull}25074[25074]

*Heartbeat*

Expand Down
2 changes: 1 addition & 1 deletion x-pack/filebeat/docs/inputs/input-httpjson.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,7 @@ The access limitations are described in the corresponding configuration sections
[float]
==== `append`

Appends a value to a list. If the field does not exist, the first entry will be a scalar value, and subsequent additions will convert the value to a list.
Appends a value to an array. If the field does not exist, the first entry will create a new array. If the field exists, the value is appended to the existing field and converted to a list.

["source","yaml",subs="attributes"]
----
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ func appendToCommonMap(m common.MapStr, key, val string) error {
if val == "" {
return nil
}
var value interface{} = val
var value interface{}
if found, _ := m.HasKey(key); found {
prev, _ := m.GetValue(key)
switch t := prev.(type) {
Expand All @@ -131,6 +131,8 @@ func appendToCommonMap(m common.MapStr, key, val string) error {
value = []interface{}{prev, val}
}

} else {
value = []interface{}{val}
}
if _, err := m.Put(key, value); err != nil {
return err
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,16 @@ func TestAppendFunctions(t *testing.T) {
expectedTr: transformable{"body": common.MapStr{"a_key": []interface{}{"a_value", "another_value"}}},
expectedErr: nil,
},
{
name: "appendBodyWithSingleValue",
tfunc: appendBody,
paramCtx: &transformContext{},
paramTr: transformable{"body": common.MapStr{}},
paramKey: "a_key",
paramVal: "a_value",
expectedTr: transformable{"body": common.MapStr{"a_key": []interface{}{"a_value"}}},
expectedErr: nil,
},
{
name: "appendHeader",
tfunc: appendHeader,
Expand Down

0 comments on commit 66a05e5

Please sign in to comment.