Dot expander processor

Dot expander processor

Expands a field with dots into an object field. This processor allows fields with dots in the name to be accessible by other processors in the pipeline. Otherwise these fields can’t be accessed by any processor.

Table 15. Dot Expand Options

NameRequiredDefaultDescription

field

yes

-

The field to expand into an object field. If set to *, all top-level fields will be expanded.

path

no

-

The field that contains the field to expand. Only required if the field to expand is part another object field, because the field option can only understand leaf fields.

override

no

false

Controls the behavior when there is already an existing nested object that conflicts with the expanded field. When false, the processor will merge conflicts by combining the old and the new values into an array. When true, the value from the expanded field will overwrite the existing value.

description

no

-

Description of the processor. Useful for describing the purpose of the processor or its configuration.

if

no

-

Conditionally execute the processor. See Conditionally run a processor.

ignore_failure

no

false

Ignore failures for the processor. See Handling pipeline failures.

on_failure

no

-

Handle failures for the processor. See Handling pipeline failures.

tag

no

-

Identifier for the processor. Useful for debugging and metrics.

  1. {
  2. "dot_expander": {
  3. "field": "foo.bar"
  4. }
  5. }

For example the dot expand processor would turn this document:

  1. {
  2. "foo.bar" : "value"
  3. }

into:

  1. {
  2. "foo" : {
  3. "bar" : "value"
  4. }
  5. }

If there is already a bar field nested under foo then this processor merges the foo.bar field into it. If the field is a scalar value then it will turn that field into an array field.

For example, the following document:

  1. {
  2. "foo.bar" : "value2",
  3. "foo" : {
  4. "bar" : "value1"
  5. }
  6. }

is transformed by the dot_expander processor into:

  1. {
  2. "foo" : {
  3. "bar" : ["value1", "value2"]
  4. }
  5. }

Contrast that with when the override option is set to true.

  1. {
  2. "dot_expander": {
  3. "field": "foo.bar",
  4. "override": true
  5. }
  6. }

In that case, the value of the expanded field overrides the value of the nested object.

  1. {
  2. "foo" : {
  3. "bar" : "value2"
  4. }
  5. }

The value of field can also be set to a * to expand all top-level dotted field names:

  1. {
  2. "dot_expander": {
  3. "field": "*"
  4. }
  5. }

The dot expand processor would turn this document:

  1. {
  2. "foo.bar" : "value",
  3. "baz.qux" : "value"
  4. }

into:

  1. {
  2. "foo" : {
  3. "bar" : "value"
  4. },
  5. "baz" : {
  6. "qux" : "value"
  7. }
  8. }

If the dotted field is nested within a non-dotted structure, then use the path option to navigate the non-dotted structure:

  1. {
  2. "dot_expander": {
  3. "path": "foo"
  4. "field": "*"
  5. }
  6. }

The dot expand processor would turn this document:

  1. {
  2. "foo" : {
  3. "bar.one" : "value",
  4. "bar.two" : "value"
  5. }
  6. }

into:

  1. {
  2. "foo" : {
  3. "bar" : {
  4. "one" : "value",
  5. "two" : "value"
  6. }
  7. }
  8. }

If any field outside of the leaf field conflicts with a pre-existing field of the same name, then that field needs to be renamed first.

Consider the following document:

  1. {
  2. "foo": "value1",
  3. "foo.bar": "value2"
  4. }

Then the foo needs to be renamed first before the dot_expander processor is applied. So in order for the foo.bar field to properly be expanded into the bar field under the foo field the following pipeline should be used:

  1. {
  2. "processors" : [
  3. {
  4. "rename" : {
  5. "field" : "foo",
  6. "target_field" : "foo.bar"
  7. }
  8. },
  9. {
  10. "dot_expander": {
  11. "field": "foo.bar"
  12. }
  13. }
  14. ]
  15. }

The reason for this is that Ingest doesn’t know how to automatically cast a scalar field to an object field.