xml

Parses messages as an XML document, performs a mutation on the data, and then overwrites the previous contents with the new value.

# Config fields, showing default values
label: ""
xml:
  operator: ""
  cast: false

Operators

to_json

Converts an XML document into a JSON structure, where elements appear as keys of an object according to the following rules:

  • If an element contains attributes they are parsed by prefixing a hyphen, -, to the attribute label.

  • If the element is a simple element and has attributes, the element value is given the key #text.

  • XML comments, directives, and process instructions are ignored.

  • When elements are repeated the resulting JSON value is an array.

For example, given the following XML:

<root>
  <title>This is a title</title>
  <description tone="boring">This is a description</description>
  <elements id="1">foo1</elements>
  <elements id="2">foo2</elements>
  <elements>foo3</elements>
</root>

The resulting JSON structure would look like this:

{
  "root":{
    "title":"This is a title",
    "description":{
      "#text":"This is a description",
      "-tone":"boring"
    },
    "elements":[
      {"#text":"foo1","-id":"1"},
      {"#text":"foo2","-id":"2"},
      "foo3"
    ]
  }
}

With cast set to true, the resulting JSON structure would look like this:

{
  "root":{
    "title":"This is a title",
    "description":{
      "#text":"This is a description",
      "-tone":"boring"
    },
    "elements":[
      {"#text":"foo1","-id":1},
      {"#text":"foo2","-id":2},
      "foo3"
    ]
  }
}

Fields

operator

An XML operation to apply to messages.

Type: string

Default: ""

Options: to_json .

cast

Whether to try to cast values that are numbers and booleans to the right type. Default: all values are strings.

Type: bool

Default: false