# Output backends for sigmac # Copyright 2016-2018 Thomas Patzke, Florian Roth, Roey # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # You should have received a copy of the GNU Lesser General Public License # along with this program. If not, see . import re import sigma from .base import SingleTextQueryBackend from .mixins import MultiRuleOutputMixin class SplunkBackend(SingleTextQueryBackend): """Converts Sigma rule into Splunk Search Processing Language (SPL).""" identifier = "splunk" active = True index_field = "index" # \ -> \\ # \* -> \* # \\* -> \\* reEscape = re.compile('("|(?" panel_inf = "" panel_suf = "$field1.earliest$$field1.latest$1" \ "" \ "
" dash_pre = "
" \ "-24h@hnow
" dash_suf = "
" queries = dash_pre reEscape = re.compile('("|(?", ">") self.queries += query self.queries += self.panel_suf def finalize(self): self.queries += self.dash_suf return self.queries