/fluent-plugin-flatten-types

Annotate types of json to avoid conflicts in ElastcSearch. No conflicts anymore

Primary LanguageRubyApache License 2.0Apache-2.0

fluent-plugin-flatten-types

Fluentd filter plugin annotate types. Annotates json object end value to avoid conflicts with random overlaping data.

Installation

RubyGems

$ gem install fluent-plugin-flatten-types

Usage


<filter **>
  @type flatten_types
</filter>

Input

{
  "name": "junaid",
  "type": 20,
  "values": [1, "2323", { "name": "randy" }],
  "random_json": {
    "__str__": true,
    "response": {
      "code": "AX12312",
      "message": "Cannot parse"
    }
  }
}

Output

{
  "name_s": "junaid",
  "type_n": 20,
  "values_a": [{ "v_n": 1 }, { "v_n": "2323" }, { "v": { "name": "randy" } }],
  "random_json_s": "{\"__str__\":true,\"response\":{\"code\":\"AX12312\",\"message\":\"Cannot parse\"}}"
}

key transforms based on type

type example tranform
number "type": 20 "type_n": 20
string "name": "kaleo" "name_s": "kaleo"
array "values": [...] "values_a": [...]
array[element] [2, "3"] [{ "v_n" : 2 }, {"v_s": "3"}]
boolean "is_enabled": false "is_enabled_b": false
map "object": {} "object": {}

Additional feature.

setting __str__ to true in any map will stringify the map

Copyright