Flatten processor
The flatten processor transforms nested objects inside of events into flattened structures.
Configuration
The following table describes configuration options for the flatten processor.
| Option | Required | Type | Description | 
|---|---|---|---|
| source | Yes | String | The source key on which to perform the operation. If set to an empty string ( ""), then the processor uses the root of the event as the source. | 
| target | Yes | String | The target key to put into the flattened fields. If set to an empty string ( ""), then the processor uses the root of the event as the target. | 
| exclude_keys | No | List | The keys from the source field that should be excluded from processing. Default is an empty list ( []). | 
| remove_processed_fields | No | Boolean | When true, the processor removes all processed fields from the source. Default isfalse. | 
| remove_list_indices | No | Boolean | When true, the processor converts the fields from the source map into lists and puts the lists into the target field. Default isfalse. | 
| flatten_when | No | String | A conditional expression, such as /some-key == "test"', that determines whether theflattenprocessor will be run on the event. Default isnull, which means that all events will be processed unless otherwise stated. | 
| tags_on_failure | No | List | A list of tags to add to the event metadata when the event fails to process. | 
Usage
The following examples show how the flatten processor can be used in OpenSearch Data Prepper pipelines.
Minimum configuration
The following example shows only the parameters that are required for using the flatten processor, source and target:
...
  processor:
    - flatten:
        source: "key2"   
        target: "flattened-key2"  
...
For example, when the input event contains the following nested objects:
{
  "key1": "val1",
  "key2": {
    "key3": {
      "key4": "val2"
    }
  }
}
The flatten processor creates a flattened structure under the flattened-key2 object, as shown in the following output:
{
  "key1": "val1",
  "key2": {
    "key3": {
      "key4": "val2"
    }
  },
  "flattened-key2": {
    "key3.key4": "val2"
  }
}
Remove processed fields
Use the remove_processed_fields option when flattening all of an event’s nested objects. This removes all the event’s processed fields, as shown in the following example:
...
  processor:
    - flatten:
        source: ""   # empty string represents root of event
        target: ""   # empty string represents root of event
        remove_processed_fields: true
...
For example, when the input event contains the following nested objects:
{
  "key1": "val1",
  "key2": {
    "key3": {
      "key4": "val2"
    }
  },
  "list1": [
    {
      "list2": [
        {
          "name": "name1",
          "value": "value1"
        },
        {
          "name": "name2",
          "value": "value2"
        }
      ]
    }
  ]
}
The flatten processor creates a flattened structure in which all processed fields are absent, as shown in the following output:
{
  "key1": "val1",
  "key2.key3.key4": "val2",
  "list1[0].list2[0].name": "name1",
  "list1[0].list2[0].value": "value1",
  "list1[0].list2[1].name": "name2",
  "list1[0].list2[1].value": "value2",
}
Exclude specific keys from flattening
Use the exclude_keys option to prevent specific keys from being flattened in the output, as shown in the following example, where the key2 value is excluded:
...
  processor:
    - flatten:
        source: ""   # empty string represents root of event
        target: ""   # empty string represents root of event
        remove_processed_fields: true
        exclude_keys: ["key2"]
...
For example, when the input event contains the following nested objects:
{
  "key1": "val1",
  "key2": {
    "key3": {
      "key4": "val2"
    }
  },
  "list1": [
    {
      "list2": [
        {
          "name": "name1",
          "value": "value1"
        },
        {
          "name": "name2",
          "value": "value2"
        }
      ]
    }
  ]
}
All other nested objects in the input event, excluding the key2 key, will be flattened, as shown in the following example:
{
  "key1": "val1",
  "key2": {
    "key3": {
      "key4": "val2"
    }
  },
  "list1[0].list2[0].name": "name1",
  "list1[0].list2[0].value": "value1",
  "list1[0].list2[1].name": "name2",
  "list1[0].list2[1].value": "value2",
}
Remove list indexes
Use the remove_list_indices option to convert the fields from the source map into lists and put the lists into the target field, as shown in the following example:
...
  processor:
    - flatten:
        source: ""   # empty string represents root of event
        target: ""   # empty string represents root of event
        remove_processed_fields: true
        remove_list_indices: true
...
For example, when the input event contains the following nested objects:
{
  "key1": "val1",
  "key2": {
    "key3": {
      "key4": "val2"
    }
  },
  "list1": [
    {
      "list2": [
        {
          "name": "name1",
          "value": "value1"
        },
        {
          "name": "name2",
          "value": "value2"
        }
      ]
    }
  ]
}
The processor removes all indexes from the output and places them into the source map as a flattened, structured list, as shown in the following example:
{
  "key1": "val1",
  "key2.key3.key4": "val2",
  "list1[].list2[].name": ["name1","name2"],
  "list1[].list2[].value": ["value1","value2"]
}