-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsecond_pass.py
169 lines (127 loc) · 6.66 KB
/
second_pass.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
import logging
import functools
import json
from collections import OrderedDict
import pandas as pd
from util import gen_readme
from settings import CZO_ACCOUNTS, CZO_DATA_CSV, README_COLUMN_MAP_PATH, \
README_SHOW_MAPS, HS_EXTERNAL_FULL_DOMAIN, SECOND_PASS_FILE
from api_helpers import _extract_value_from_df_row_dict, string_to_list
from accounts import CZOHSAccount
def query_lookup_table(czo_id, lookup_data_df, attr="hs_id"):
v = lookup_data_df.loc[czo_id][attr]
if str(v) == "-1" or str(v).lower() == "nan" or len(str(v)) == 0:
return None
return v
def get_resource_file_url(hs_id, filename):
landing = get_resource_landing_page_url(hs_id)
file = "{landing}data/contents/{filename}".format(landing=landing,
filename=filename)
return file
def get_resource_landing_page_url(hs_id):
hs_res_url = "{HS_FULL_DOMAIN}/resource/{hs_id}/".format(HS_FULL_DOMAIN=HS_EXTERNAL_FULL_DOMAIN,
hs_id=hs_id)
return hs_res_url
def build_maps_md(map_filename, hs_id):
map_url = get_resource_file_url(hs_id, map_filename)
md = "![alt text]({url} '{tooltip}')".format(url=map_url,
tooltip=map_filename)
return md
def build_related_dataset_md(res_id, czo_id, czo_data_df=None):
res_url = get_resource_landing_page_url(res_id)
res_title = None
if czo_data_df is not None:
try:
res_title = get_dict_by_czo_id(czo_id, czo_data_df)["title"]
except:
pass
md = "[{res_title}]({url} '{tooltip}')".format(res_title=res_title if res_title is not None else res_id,
url=res_url,
tooltip=res_id)
return md
def get_dict_by_czo_id(czo_id, czo_data_df):
czo_row_dict = czo_data_df.loc[czo_data_df['czo_id'] == czo_id].to_dict(orient='records')[0]
return czo_row_dict
def second_pass(czo_csv_path, lookup_csv_path, czo_accounts):
logging.info("\n\nSecond Pass Started")
# read czo csv
czo_data_df = pd.read_csv(czo_csv_path)
# read lookup table and set czo_id as index
lookup_data_df = pd.read_csv(lookup_csv_path, index_col=1)
readme_counter = 0
ex_metadata_counter = 0
with open(README_COLUMN_MAP_PATH) as f:
readme_column_map = json.load(f, object_pairs_hook=OrderedDict)
for index, row in lookup_data_df.iterrows():
czo_id = index
# get hs_id
hs_id = query_lookup_table(czo_id, lookup_data_df)
# get resource owner
hs_owner = query_lookup_table(czo_id, lookup_data_df, attr="uname")
public = query_lookup_table(czo_id, lookup_data_df, attr="public")
maps = query_lookup_table(czo_id, lookup_data_df, attr="maps")
if None not in (hs_id, hs_owner):
logging.info("Updating {0} - {1} by account {2}".format(hs_id, czo_id, hs_owner))
hs = czo_accounts.get_hs_by_uname(hs_owner)
czo_row_dict = get_dict_by_czo_id(czo_id, czo_data_df)
related_datasets_md = []
try: # update czo_id
related_datasets = _extract_value_from_df_row_dict(czo_row_dict, "RELATED_DATASETS", required=False)
if related_datasets is not None:
related_datasets_list = string_to_list(related_datasets)
print("Related datasets {}".format(related_datasets_list))
czo_id_list = list(map(lambda x: int(str.strip(x)), related_datasets_list))
hs_id_list = list(map(functools.partial(query_lookup_table, lookup_data_df=lookup_data_df),
czo_id_list))
related_datasets_md = list(map(functools.partial(build_related_dataset_md,
czo_data_df=czo_data_df), hs_id_list,
czo_id_list))
# update czo_row_dict for readme.md
czo_row_dict["RELATED_DATASETS"] = "\n\r".join(related_datasets_md)
# get existing extended metadata
extented_metadata = hs.resource(hs_id).scimeta.get()
res_urls = list(map(get_resource_landing_page_url, hs_id_list))
extented_metadata["related_datasets_hs"] = ", ".join(res_urls)
hs.resource(hs_id).scimeta.custom(extented_metadata)
logging.info("Extended metadata")
ex_metadata_counter += 1
except Exception as ex:
logging.error(
"Failed to updated ex_metadata {0} - {1}: {2}".format(hs_id, czo_id, str(ex)))
# update maps
try:
if README_SHOW_MAPS and maps is not None:
maps_md = list(map(functools.partial(build_maps_md,
hs_id=hs_id),
maps.split('|')))
# update czo_row_dict for readme.md
czo_row_dict["map_uploads"] = "\n\r".join(maps_md)
except Exception as ex:
logging.error(
"Failed to process Maps for ReadMe {0} - {1}: {2}".format(hs_id, czo_id, str(ex)))
# generate readme.md file
if readme_column_map is not None:
readme_path = gen_readme(czo_row_dict, related_datasets_md)
try:
file_add_respone = hs.addResourceFile(hs_id, readme_path)
logging.info("Creating ReadMe file {}".format(readme_path))
readme_counter += 1
except IndexError as index_err:
logging.error('Resource exists hs: {} czo: {} - {}'.format(hs_id, czo_id, index_err))
if not public:
try:
hs.setAccessRules(hs_id, public=True)
except Exception:
logging.error("Failed to make Resource Public")
logging.info("Second Pass Done: {} ex metadata updated; {} ReadMe files created\n\n".format(ex_metadata_counter,
readme_counter))
if __name__ == "__main__":
logging.basicConfig(
level=logging.INFO,
format="%(asctime)s [%(levelname)-5.5s] %(message)s",
handlers=[logging.StreamHandler()])
lookup_path = SECOND_PASS_FILE
czo_accounts = CZOHSAccount(CZO_ACCOUNTS)
second_pass(CZO_DATA_CSV,
lookup_path,
czo_accounts)