Skip to content

Commit 7d0990d

Browse files
committed
Added basic sigma test with arbitrary rules based on Shuffle File namespaces and sigmac
1 parent c9dad8e commit 7d0990d

File tree

8 files changed

+181
-72
lines changed

8 files changed

+181
-72
lines changed

analyze.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@
2121
try:
2222
with open(filepath, "r") as tmp:
2323
try:
24-
ret = yaml.load(tmp.read())
24+
ret = yaml.full_load(tmp.read())
2525
except yaml.scanner.ScannerError as e:
2626
print(f"Bad yaml in {filepath} (2): {e}")
2727
continue
@@ -51,7 +51,7 @@
5151
try:
5252
with open(apifile, "r") as tmp:
5353
try:
54-
apidata = yaml.load(tmp.read())
54+
apidata = yaml.full_load(tmp.read())
5555
except yaml.scanner.ScannerError as e:
5656
print(f"Bad yaml in {apifile} (2): {e}")
5757
continue
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,9 @@ FROM base
1818
COPY --from=builder /install /usr/local
1919
COPY src /app
2020

21+
# Fix python3.3 > issues
22+
RUN sed -i 's/from collections import Iterable/from collections.abc import Iterable/g' /usr/local/lib/python3.10/site-packages/sigma/config/collection.py
23+
2124
# Install any binary dependencies needed in our final image
2225
# RUN apk --no-cache add --update my_binary_dependency
2326

Lines changed: 55 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -10,27 +10,69 @@ tags:
1010
categories:
1111
- Testing
1212
actions:
13-
- name: run_python_script
13+
- name: get_searches
1414
description: Runs a python script defined by YOU
1515
parameters:
16-
- name: json_data
17-
description: The JSON to handle
16+
- name: engine
17+
description: The engine to translate to
1818
required: true
19-
multiline: true
20-
example: '{"data": "testing"}'
19+
options:
20+
- uberagent
21+
- sumologic-cse
22+
- netwitness-epl
23+
- netwitness
24+
- stix
25+
- es-rule
26+
- graylog
27+
- sqlite
28+
- sysmon
29+
- csharp
30+
- logpoint
31+
- mdatp
32+
- ala-rule
33+
- humio
34+
- crowdstrike
35+
- sumologic-cse-rule
36+
- elastalert
37+
- limacharlie
38+
- carbonblack
39+
- ala
40+
- arcsight
41+
- sql
42+
- logiq
43+
- grep
44+
- fireeye-helix
45+
- fieldlist
46+
- xpack-watcher
47+
- splunkxml
48+
- kibana
49+
- powershell
50+
- arcsight-esm
51+
- kibana-ndjson
52+
- qradar
53+
- qualys
54+
- es-qs
55+
- elastalert-dsl
56+
- splunk
57+
- sumologic
58+
- es-dsl
59+
- ee-outliers
60+
example: 'kibana'
2161
schema:
2262
type: string
23-
- name: function_to_execute
24-
description: The selected python function to run
63+
- name: backend
64+
description: The backend to use. If blank, space or list, this will return a list of options
2565
required: true
26-
multiline: true
27-
example: '1'
28-
options:
29-
- function_1
30-
- function_2
66+
multiline: false
67+
schema:
68+
type: string
69+
- name: shuffle_namespace
70+
description: The Shuffle
71+
required: true
72+
multiline: false
3173
schema:
3274
type: string
3375
returns:
3476
schema:
3577
type: string
36-
large_image: 
78+
large_image: 

sigma/1.0.0/requirements.txt

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
requests==2.25.1
2+
sigmatools==0.20

sigma/1.0.0/src/app.py

Lines changed: 96 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,96 @@
1+
import os
2+
import socket
3+
import asyncio
4+
import time
5+
import random
6+
import json
7+
import subprocess
8+
9+
from walkoff_app_sdk.app_base import AppBase
10+
11+
# Make file sample with namespace yara:
12+
## curl http://localhost:5001/api/v1/files/create -H "Authorization: Bearer 09627dcb-7e2a-4843-819b-417d268ff840" -d '{"filename": "HelloWorld.yml", "org_id": "11f67b76-6051-4425-b0d6-be23daac6d12", "workflow_id": "global", "namespace": "sigma"}'
13+
14+
# 1. Generate the api.yaml based on downloaded files
15+
# 2. Add a way to choose the rule and the target platform for it
16+
# 3. Add the possibility of translating rules back and forth
17+
18+
# 4. Make it so you can start with Mitre Att&ck techniques
19+
# and automatically get the right rules set up with your tools :O
20+
class Sigma(AppBase):
21+
__version__ = "1.0.0"
22+
app_name = "sigma" # this needs to match "name" in api.yaml
23+
24+
def __init__(self, redis, logger, console_logger=None):
25+
"""
26+
Each app should have this __init__ to set up Redis and logging.
27+
:param redis:
28+
:param logger:
29+
:param console_logger:
30+
"""
31+
super().__init__(redis, logger, console_logger)
32+
33+
def get_searches(self, engine, backend, shuffle_namespace):
34+
files = self.get_file_namespace(shuffle_namespace)
35+
self.logger.info(f"Files: {files}")
36+
37+
# This part should be in the SDK
38+
basedir = "rules"
39+
os.mkdir(basedir)
40+
for member in files.namelist():
41+
filename = os.path.basename(member)
42+
if not filename:
43+
continue
44+
45+
self.logger.info("File: %s" % member)
46+
source = files.open(member)
47+
with open("%s/%s" % (basedir, source.name), "wb+") as tmp:
48+
filedata = source.read()
49+
self.logger.info("Filedata (%s): %s" % (source.name, filedata))
50+
tmp.write(filedata)
51+
52+
self.logger.info(f"Dir: {os.listdir(basedir)}")
53+
54+
rule = shuffle_namespace
55+
#filename = "file.yaml"
56+
#with open(filename, "w+") as tmp:
57+
# tmp.write(rule)
58+
59+
code = "sigmac --target=%s" % engine
60+
#if len(backend) > 0:
61+
if backend:
62+
if "list" in backend:
63+
code += "--list"
64+
else:
65+
code += " -c %s" % backend
66+
67+
code += " rules/*"
68+
self.logger.info("Code: ", code)
69+
print(code)
70+
print()
71+
process = subprocess.Popen(
72+
code,
73+
stdout=subprocess.PIPE,
74+
stderr=subprocess.PIPE,
75+
text=True,
76+
shell=True, # nosec
77+
)
78+
stdout = process.communicate()
79+
item = ""
80+
if len(stdout[0]) > 0:
81+
print("Succesfully ran bash!")
82+
item = stdout[0]
83+
else:
84+
print("FAILED to run bash: ", stdout[1])
85+
item = stdout[1]
86+
87+
try:
88+
ret = item.decode("utf-8")
89+
return ret
90+
except Exception:
91+
return item
92+
93+
return item
94+
95+
if __name__ == "__main__":
96+
asyncio.run(Sigma.run(), debug=True)

sigma/1.0.0/src/file.yaml

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
title: Google Cloud Storage Buckets Enumeration
2+
id: e2feb918-4e77-4608-9697-990a1aaf74c3
3+
description: Detects when storage bucket is enumerated in Google Cloud.
4+
author: Austin Songer @austinsonger
5+
status: experimental
6+
date: 2021/08/14
7+
references:
8+
- https://cloud.google.com/storage/docs/json_api/v1/buckets
9+
logsource:
10+
product: gcp
11+
service: gcp.audit
12+
detection:
13+
selection:
14+
gcp.audit.method_name:
15+
- storage.buckets.list
16+
- storage.buckets.listChannels
17+
condition: selection
18+
level: low
19+
tags:
20+
- attack.discovery
21+
falsepositives:
22+
- Storage Buckets being enumerated may be performed by a system administrator. Verify whether the user identity, user agent, and/or hostname should be making changes in your environment.
23+
- Storage Buckets enumerated from unfamiliar users should be investigated. If known behavior is causing false positives, it can be exempted from the rule.

unsupported/sigma/1.0.0/requirements.txt

Lines changed: 0 additions & 1 deletion
This file was deleted.

0 commit comments

Comments
 (0)