-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathlogscan.py
70 lines (57 loc) · 1.94 KB
/
logscan.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
from pathlib import Path
from prefect import flow, task, get_run_logger
from tiled.client import from_profile
tiled_client = from_profile("nsls2")["srx"]
tiled_client_raw = tiled_client["raw"]
def find_scanid(logfile_path, scanid):
is_scanid = False
with open(logfile_path) as lf:
for line in lf:
params = line.strip().split("\t")
if int(params[0]) == scanid:
is_scanid = True
break
return is_scanid
@task
def logscan_detailed(scanid):
logger = get_run_logger()
h = tiled_client_raw[scanid]
if (
"Beamline Commissioning (beamline staff only)".lower()
in h.start["proposal"]["type"].lower()
):
userdatadir = (
f"/nsls2/data/srx/proposals/commissioning/{h.start['data_session']}/"
)
else:
userdatadir = (
f"/nsls2/data/srx/proposals/{h.start['cycle']}/{h.start['data_session']}/"
)
if not Path(userdatadir).exists():
logger.info(
"Incorrect path. Check cycle and proposal id in document. Not running the logger on this document."
)
return
logfile_path = userdatadir + f"logfile{h.start['data_session']}.txt"
is_scanid = False
if Path(logfile_path).exists():
is_scanid = find_scanid(logfile_path, h.start["scan_id"])
if not is_scanid:
with open(logfile_path, "a") as userlogf:
userlogf.write(
str(h.start["scan_id"])
+ "\t"
+ str(h.start["uid"])
+ "\t"
+ str(h.start["scan"]["type"])
+ "\t"
+ str(h.start["scan"]["scan_input"])
+ "\n"
)
logger.info(f"Added {h.start['scan_id']} to the logs")
@flow(log_prints=True)
def logscan(ref):
logger = get_run_logger()
logger.info("Start writing logfile...")
logscan_detailed(ref)
logger.info("Finish writing logfile.")