It moves fields to the target field in a certain mode.
- In
allowmode, the specifiedfieldswill be moved - In
blockmode, the unspecifiedfieldswill be moved
pipelines:
example_pipeline:
...
actions:
- type: move
mode: allow
target: other
fields:
- log.stream
- zone
...The original event:
{
"service": "test",
"log": {
"level": "error",
"message": "error occurred",
"ts": "2023-10-30T13:35:33.638720813Z",
"stream": "stderr"
},
"zone": "z501"
}The resulting event:
{
"service": "test",
"log": {
"level": "error",
"message": "error occurred",
"ts": "2023-10-30T13:35:33.638720813Z"
},
"other": {
"stream": "stderr",
"zone": "z501"
}
}pipelines:
example_pipeline:
...
actions:
- type: move
mode: block
target: other
fields:
- log
...The original event:
{
"service": "test",
"log": {
"level": "error",
"message": "error occurred",
"ts": "2023-10-30T13:35:33.638720813Z",
"stream": "stderr"
},
"zone": "z501",
"other": {
"user": "ivanivanov"
}
}The resulting event:
{
"log": {
"level": "error",
"message": "error occurred",
"ts": "2023-10-30T13:35:33.638720813Z"
},
"other": {
"user": "ivanivanov",
"service": "test",
"zone": "z501"
}
}pipelines:
example_pipeline:
...
actions:
- type: move
mode: allow
target: other
fields:
- log.message
- error.message
- zone
...The original event:
{
"service": "test",
"log": {
"message": "some log",
"ts": "2023-10-30T13:35:33.638720813Z"
},
"error": {
"code": 1,
"message": "error occurred"
},
"zone": "z501"
}The resulting event:
{
"service": "test",
"log": {
"ts": "2023-10-30T13:35:33.638720813Z"
},
"error": {
"code": 1,
},
"other": {
"message": "error occurred",
"zone": "z501"
}
}fields []cfg.FieldSelector required
The list of the fields to move.
- In
blockmode, the maximumfieldsdepth is 1.- If several fields have the same end of the path, the last specified field will overwrite the previous ones.
mode string required
The mode of the moving. Available modes are one of: allow|block.
target cfg.FieldSelector required
The target field of the moving.
- In
blockmode, the maximumtargetdepth is 1.- If the
targetfield is existing non-object field, it will be overwritten as object field.
Generated using insane-doc