All Apps and Add-ons

Splunk App for Stream: When analyzing DNS data, is there a way to receive the result a bit more structured?

mathiask
Communicator

Is there a way to receive the result a bit more structured?
Currently the result is kinda mess

host_addr contains a list of IPs
hostname contains a list of hostnames
name contains a list of domains
Each list seems sorted lexicografically

Is there a way to determine how the actual response looked like?
Or at least which hostname is associated with which A AAAA or CNAME?

Greetings
Mathias

Tags (2)
0 Karma
1 Solution

sroback_splunk
Splunk Employee
Splunk Employee

Hi, The Stream development team has added this as a feature request. Upcoming versions of the product will include hierarchical data support that provides more structured output. thanks

View solution in original post

sroback_splunk
Splunk Employee
Splunk Employee

Hi, The Stream development team has added this as a feature request. Upcoming versions of the product will include hierarchical data support that provides more structured output. thanks

mathiask
Communicator

I just want to short explain the use case (and maybe hopefully increasing the incentive)

I would like to perform passive DNS lookups.
pDNS has proven to be a valuable tool within the security community.
Having the data structured will help greatly in achieving that.

Currently the data is kinda structured when I compare the _raw Event, when i compare it with the dig response
name{} contains the left column
host_type{} contains the middle column
hostname{} contains the hostnames of the right column
host_addr{} contains the right column
each of the list is sorted from top down. But since the results/right column are split into two lists it is quite a pain in the ass to wiggle it out.
Based on these assumptions I managed to mvzip the data together

index="esm-url-monitor-stream" | rename "hostname{}" as hostname, "host_addr{}" as host_addr, "host_type{}" as host_type, "name{}" as name | eval a=mvzip(name,host_type) | eval b=mvzip(name,host_type) | eval a=mvfilter(match(a,"address")) | eval b=mvfilter(!match(b,"address")) | eval a=mvzip(a,host_addr) | eval b=mvzip(b,hostname)

This produces a (IP result list) and b (hostname list) as comma separated string containing the response.
These can now probably again taken apart and then further processed and later presented in a proper way.

But I am not sure if this might still work for DNS requests having multiple requests or DNSSEC etc

0 Karma

mathiask
Communicator

Thanks. This would really help.

0 Karma
Get Updates on the Splunk Community!

Stay Connected: Your Guide to May Tech Talks, Office Hours, and Webinars!

Take a look below to explore our upcoming Community Office Hours, Tech Talks, and Webinars this month. This ...

They're back! Join the SplunkTrust and MVP at .conf24

With our highly anticipated annual conference, .conf, comes the fez-wearers you can trust! The SplunkTrust, as ...

Enterprise Security Content Update (ESCU) | New Releases

Last month, the Splunk Threat Research Team had two releases of new security content via the Enterprise ...