summaryrefslogtreecommitdiffstats
path: root/debian/get_kaspdb
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-06 00:53:35 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-06 00:53:35 +0000
commit46ec4c5ae30e9137e303a1f7187da16da6378eb4 (patch)
tree94a4a825604057e5fda94b7249d8310605fe1c62 /debian/get_kaspdb
parentAdding upstream version 2.7.6. (diff)
downloadknot-46ec4c5ae30e9137e303a1f7187da16da6378eb4.tar.xz
knot-46ec4c5ae30e9137e303a1f7187da16da6378eb4.zip
Adding debian version 2.7.6-2.debian/2.7.6-2debian
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'debian/get_kaspdb')
-rwxr-xr-xdebian/get_kaspdb59
1 files changed, 59 insertions, 0 deletions
diff --git a/debian/get_kaspdb b/debian/get_kaspdb
new file mode 100755
index 0000000..5562c1d
--- /dev/null
+++ b/debian/get_kaspdb
@@ -0,0 +1,59 @@
+#!/usr/bin/python3
+
+import yaml, os.path, sys
+
+conf_file = '/etc/knot/knot.conf' if len(sys.argv) < 2 else sys.argv[1]
+ip_fields = ['listen', 'address', 'via', 'whitelist', 'network']
+
+try:
+ conf = yaml.load(open(conf_file, 'r'))
+except (yaml.scanner.ScannerError, yaml.parser.ParserError):
+ conf = False
+
+if not conf:
+ import io
+ conf_io = io.StringIO()
+ with open(conf_file) as f:
+ for line in f:
+ if line.split(':')[0].strip() not in ip_fields:
+ conf_io.write(line)
+ conf_io.seek(0)
+ try:
+ conf = yaml.load(conf_io)
+ except (yaml.scanner.ScannerError, yaml.parser.ParserError):
+ sys.exit(1)
+
+dirs = set()
+# if we have valid yaml use it
+if "template" in conf and conf["template"]:
+
+ for template in conf["template"]:
+ if "kasp-db" in template:
+ kasp_db = template["kasp-db"]
+ else:
+ continue
+
+ if not os.path.isabs(kasp_db):
+ if "storage" in template:
+ kasp_db = os.path.join(template["storage"], kasp_db)
+ else:
+ continue
+ dirs.add(kasp_db)
+
+if "zone" in conf and conf["zone"]:
+
+ for domain in conf["zone"]:
+ if "kasp-db" in domain:
+ kasp_db = domain["kasp-db"]
+ else:
+ continue
+
+ if not os.path.isabs(kasp_db):
+ if "storage" in kaspdomain:
+ kasp_db = os.path.join(domain["storage"], kasp_db)
+ else:
+ continue
+ dirs.add(kasp_db)
+
+for dir in dirs:
+ print(dir)