Files
dougal-software/bin/human_exports_seis.py
2020-10-04 03:51:30 +02:00

75 lines
2.1 KiB
Python
Executable File
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#!/usr/bin/python3
"""
Export data that is entered directly into Dougal
as opposed to being read from external sources.
This data will be read back in when the database
is recreated for an existing survey.
"""
import os
from glob import glob
import pathlib
import string
import configuration
import requests
import json
#from datastore import Datastore
def sane_name(filename):
allowed_chars = string.ascii_letters + string.digits + " _-#+&^%$!();:.,"
return ''.join([c for c in filename if c in allowed_chars])
def write_file (filename, payload):
print("Writing to", filename)
tmpname = filename.parent / (filename.name + ".tmp")
filename.parent.mkdir(parents=True, exist_ok=True)
with open(tmpname, "w", encoding="utf8") as fd:
json.dump(payload, fd, indent=4, ensure_ascii=False)
os.rename(tmpname, filename)
def seis_data (survey):
try:
pathPrefix = survey["sse"]["path"]
except KeyError:
print("Survey does not define an export path for human data")
return
if not pathlib.Path(pathPrefix).exists():
print(pathPrefix)
raise ValueError("Export path does not exist")
print(f"Requesting sequences for {survey['id']}")
url = f"http://localhost:3000/api/project/{survey['id']}/sequence"
r = requests.get(url)
print(r.status_code, url)
for sequence in r.json():
if sequence['status'] not in ["final", "ntbp"]:
continue
filename = pathlib.Path(pathPrefix, "sequence{:0>3d}.json".format(sequence['sequence']))
if filename.exists():
print(f"Skipping export for sequence {sequence['sequence']} file already exists")
continue
print(f"Processing sequence {sequence['sequence']}")
url = f"http://localhost:3000/api/project/{survey['id']}/event?sequence={sequence['sequence']}&missing=t"
headers = { "Accept": "application/vnd.seis+json" }
r = requests.get(url, headers=headers)
if r.status_code == requests.codes.ok:
write_file(filename, r.json())
if __name__ == '__main__':
print("Reading configuration")
surveys = configuration.surveys()
print("Reading surveys")
for survey in surveys:
print(f'Survey: {survey["id"]} ({survey["schema"]})')
seis_data(survey)
print("Done")