Getting Data In

Compare list of used credentials in events with list of total credentials in lookup

parkz
Explorer

I have a lookup of all active credentials from tenable called tio_credentials.csv. I have a search that lists unique credentials used, like so:

`tenable` `io` earliest=-15d pluginID=19506
| rex field=plugin_output "'(?<domain>.*\\\)?(?P<Credentialed_Checks>.*)'"
| stats dc(host-ip) as count by Credentialed_Checks

 

How do I compare the list of credentials from Splunk events with the lookup in a way that shows all the credentials in the lookup that aren't showing up in events? I'm new to splunk and trying to see if there's any credentials we can remove from our credentials list.

Labels (1)
0 Karma
1 Solution

ITWhisperer
SplunkTrust
SplunkTrust

Depending on what your credentials field is in your csv

`tenable` `io` earliest=-15d pluginID=19506
| rex field=plugin_output "'(?<domain>.*\\\)?(?P<Credentialed_Checks>.*)'"
| stats dc(host-ip) as count by Credentialed_Checks
| append
  [| inputlookup tio_credentials.csv
   | rename credential as Credentialed_Checks
   | eval csv="True"
   | fields csv Credentialed_Checks]
| stats count values(csv) as csv by Credentialed_Checks
| where count = 1 AND csv="True"

View solution in original post

richgalloway
SplunkTrust
SplunkTrust

The general method is to read the lookup file using a where clause that excludes credentials that are indexed.  The SPL looks something like this:

| inputlookup tio_credentials.csv where NOT [ search `tenable` `io` earliest=-15d pluginID=19506
  | rex field=plugin_output "'(?<domain>.*\\\)?(?P<Credentialed_Checks>.*)'"
  | stats dc(host-ip) as count by Credentialed_Checks
  | rename Credentialed_Checks as <<equivalent field name in the lookup>>
  | fields - count
  | format ]

 

---
If this reply helps you, Karma would be appreciated.
0 Karma

ITWhisperer
SplunkTrust
SplunkTrust

Depending on what your credentials field is in your csv

`tenable` `io` earliest=-15d pluginID=19506
| rex field=plugin_output "'(?<domain>.*\\\)?(?P<Credentialed_Checks>.*)'"
| stats dc(host-ip) as count by Credentialed_Checks
| append
  [| inputlookup tio_credentials.csv
   | rename credential as Credentialed_Checks
   | eval csv="True"
   | fields csv Credentialed_Checks]
| stats count values(csv) as csv by Credentialed_Checks
| where count = 1 AND csv="True"
Get Updates on the Splunk Community!

Holistic Visibility and Effective Alerting Across IT and OT Assets

Instead of effective and unified solutions, they’re left with tool fatigue, disjointed alerts and siloed ...

SOC Modernization: How Automation and Splunk SOAR are Shaping the Next-Gen Security ...

Security automation is no longer a luxury but a necessity. Join us to learn how Splunk ES and SOAR empower ...

Ask It, Fix It: Faster Investigations with AI Assistant in Observability Cloud

  Join us in this Tech Talk and learn about the recently launched AI Assistant in Observability Cloud. With ...