Views' widget metric to be the addition of two field sums

Hi all,

Note: Using Graylog 3.0.2+1686930

Basically, a CEF log message includes (among others) two values, in and out, to represent the byte count in both directions. All I want is to add a new column to a table widget in Views that displays the following metrics:


The latter I have issues with.

After much reading and testing, I went the path of Pipelines and created a Pipeline rule that will read in and out and add them together, believing the set_field would allow me to create a new field (d’oh).

For illustration, here is the Pipeline rule:

    rule "get_total_bytes"
       has_field("in") && has_field("out")
       let total = to_double($ + to_double($message.out);

Tried using extractors, but the log has been appropriately extracted by the CEF decoder. Since the value I want is not within the log structure and I would prefer not to alter any other message field, I cannot see how extractors would help.

So, any ideas on how to display “sum(in)+sum(out)” in a Views Widget?

After further reading it appears I had to change the “Message Processors Configuration” to the below. Then the pipeline rule above worked.

#	Processor	                         Status
1	AWS Instance Name Lookup	 active
2	GeoIP Resolver	                 active
3	Message Filter Chain	         active
4	Pipeline Processor	                 active

try to convert to string the total before you write it to field
or try to map the field to double in elasticsearch

The pipeline itself works fine. My error was that I connected the pipeline to a stream other than all messages. By doing this the pipeline could not have been applied to the other stream as the message is only routed to other streams at the message filter chain.

Anyone please correct me if I’m wrong.

So by connecting this rule to all messages stream, the new field was created and persisted across the streams.