summaryrefslogtreecommitdiff
path: root/utils.py
diff options
context:
space:
mode:
authorTrygve Laugstøl <trygvis@inamo.no>2020-12-27 20:28:00 +0100
committerTrygve Laugstøl <trygvis@inamo.no>2020-12-27 20:28:00 +0100
commit64c0fb097a6c9482460f1bebbcb393b617956ca3 (patch)
tree83f79d36d516a45f630ec14316c9b324369024ac /utils.py
parent9f3e8bce09100a539ff3a0c67da1db028ce51f73 (diff)
downloadrules-sandbox-64c0fb097a6c9482460f1bebbcb393b617956ca3.tar.gz
rules-sandbox-64c0fb097a6c9482460f1bebbcb393b617956ca3.tar.bz2
rules-sandbox-64c0fb097a6c9482460f1bebbcb393b617956ca3.tar.xz
rules-sandbox-64c0fb097a6c9482460f1bebbcb393b617956ca3.zip
Saving output from first phase too
Diffstat (limited to 'utils.py')
-rw-r--r--utils.py51
1 files changed, 51 insertions, 0 deletions
diff --git a/utils.py b/utils.py
new file mode 100644
index 0000000..06c6500
--- /dev/null
+++ b/utils.py
@@ -0,0 +1,51 @@
+import os
+import os.path
+import yaml
+from durable.lang import *
+
+def write_facts(ruleset: set):
+ facts = get_facts(ruleset)
+
+ types = set((f.get("type") for f in facts))
+
+ print(f"types: {types}")
+
+ out_dir = "out"
+ if not os.path.exists(out_dir):
+ os.mkdir(out_dir)
+
+ basedir = os.path.join(out_dir, ruleset)
+ if os.path.exists(basedir):
+ for f in os.listdir(basedir):
+ p = os.path.join(basedir, f)
+ if os.path.isdir(p):
+ for f2 in os.listdir(p):
+ os.remove(os.path.join(p, f2))
+ os.rmdir(p)
+ else:
+ os.remove(p)
+ os.rmdir(basedir)
+ os.mkdir(basedir)
+
+ for t in types:
+ typedir = os.path.join(basedir, t)
+ os.mkdir(typedir)
+
+ fs = []
+ for f in facts:
+ if f["type"] != t:
+ continue
+ try:
+ del f["sid"]
+ except KeyError:
+ pass
+ fs.append(f)
+
+ i = 0
+ for fact in sorted(fs, key=lambda f: f["key"]):
+ key = fact["key"]
+ path = os.path.join(typedir, f"{key.replace('/', '_')}.yaml")
+ with open(path, "w") as f:
+ s = yaml.dump(fact)
+ f.write(s)
+ i = i + 1