Skip to content

Commit

Permalink
splunk connector added
Browse files Browse the repository at this point in the history
Signed-off-by: Shashank Reddy Boyapally <sboyapal@redhat.com>
  • Loading branch information
shashank-boyapally committed Oct 1, 2024
1 parent 3229459 commit 126da7b
Showing 1 changed file with 66 additions and 0 deletions.
66 changes: 66 additions & 0 deletions fmatch/splunk_matcher.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
#pylint: disable = C0209
"""
Matcher for splunk datasource
"""
import orjson
from splunklib import client, results


class SplunkMatcher:
"""Splunk data source matcher
"""
def __init__(self, host, port, username, password, indice): #pylint: disable = R0913
self.indice = indice
self.service = client.connect(
host=host, port=port, username=username, password=password
)

async def query(self, query, searchList="", max_results=10000):
"""
Query data from splunk server using splunk lib sdk
Args:
query (string): splunk query
OPTIONAL: searchList (string): additional query parameters for index
"""
query["count"] = max_results

# If additional search parameters are provided, include those in searchindex
searchindex = (
"search index={} {}".format(self.indice, searchList)
if searchList
else "search index={}".format(self.indice)
)
try:
oneshotsearch_results = self.service.jobs.oneshot(searchindex, **query)
except Exception as e: #pylint: disable = W0718
print("Error querying splunk: {}".format(e))
return None

# Get the results and display them using the JSONResultsReader
res_array = []
async for record in self._stream_results(oneshotsearch_results):
try:
res_array.append(
{
"data": orjson.loads(record["_raw"]), #pylint: disable = E1101
"host": record["host"],
"source": record["source"],
"sourcetype": record["sourcetype"],
"bucket": record["_bkt"],
"serial": record["_serial"],
"timestamp": record["_indextime"],
}
)
except Exception as e: #pylint: disable = W0718
print(f"Error on including Splunk record query in results array: {e}")

return res_array

async def _stream_results(self, oneshotsearch_results):
for record in results.JSONResultsReader(oneshotsearch_results):
yield record

async def close(self):
"""Closes splunk client connections"""
await self.service.logout()

0 comments on commit 126da7b

Please sign in to comment.