-
Notifications
You must be signed in to change notification settings - Fork 0
/
netx_add_folder.py
134 lines (96 loc) · 3.83 KB
/
netx_add_folder.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
'''Add ingested assets to secondary folders via NetX API'''
import logging
import sys
import time
from utils import netx_api as un
from utils import csv_tools as uc
from utils import setup
# from dotenv import dotenv_values
def add_to_folder(row:dict, folder_id_list:dict, live_or_test:str):
'''For a given asset's filename and pathAdd folder-name, add the asset to the folder'''
# In case API needs rate-limiting
time.sleep(0.1)
# Given Identifier/Filename, Get Asset ID
asset_data = un.netx_get_asset_by_filename(
row['file'],
data_to_get=['asset.id','asset.folders'],
netx_env=live_or_test
)
if 'result' not in asset_data or len(asset_data['result']['results']) < 1:
logging.error(asset_data)
return
asset_id = asset_data['result']['results'][0]['id']
asset_folders = asset_data['result']['results'][0]['folders']
asset_orig_folder_ids = [folder['id'] for folder in asset_folders]
# Get Asset's Secondary Department-folders
folder_name = row['pathAdd']
if folder_name in folder_id_list.keys():
folder_id = folder_id_list[folder_name]
if folder_id in asset_orig_folder_ids:
log_message = f'Asset {asset_id} already in folder {folder_id}; Skipping'
print(log_message)
logging.info(log_message)
return
else:
log_error = f'Missing Folder {folder_name}'
logging.error(log_error)
return
# Add Asset to Folder/s -- https://developer.netx.net/#addassettofolder
folder_data = un.netx_add_asset_to_folder(asset_id, folder_id, netx_env=live_or_test)
if 'result' in folder_data:
folders = [folder['path'] for folder in folder_data['result']['folders']]
asset = folder_data['result']['file']['name']
log_message = f'{asset} - folders updated to: {folders}'
print(log_message)
# row['status'] = folder_data['result']
logging.info(log_message)
else:
print(f'ERROR - {folder_data}')
# row['status'] = folder_data
logging.error(folder_data)
return
def get_unique_folder_id_list(path_add_rows:list, live_or_test:str):
'''
Given a pathAdd CSV, retrieve folder IDs for a unique list of folder-names
Return a list of {folder_name:folder_id}
'''
unique_folders = []
for row in path_add_rows:
if row['pathAdd'] not in unique_folders:
unique_folders.append(row['pathAdd'])
folder_id_list = {}
if len(unique_folders) > 0:
for folder_name in unique_folders:
# Get Asset's Secondary Departments
folder_data = un.netx_get_folder_by_path(
folder_path=folder_name,
data_to_get=None,
netx_env=live_or_test
)
try:
folder_id = folder_data['result']['id']
folder_id_list[folder_name] = folder_id
except KeyError as err:
err_message = f'ERROR - {folder_data}: {err}'
print(err_message)
logging.error(err_message)
return folder_id_list
def main(live_or_test:str=None):
'''main function'''
if live_or_test is None:
input_args = sys.argv
live_or_test = setup.get_sys_argv(1)
else:
input_args = [live_or_test]
setup.start_log_dams_netx(config=None, cmd_args=input_args)
config = setup.get_config_dams_netx(live_or_test) # dotenv_values(".env")
input_csv = config['PATHADD_CSV']
path_add_rows = uc.rows(input_csv)
# Get id's for unique list of folders may be quicker
folder_id_list = get_unique_folder_id_list(path_add_rows, live_or_test)
# Add assets to folders
for row in path_add_rows:
add_to_folder(row, folder_id_list, live_or_test)
setup.stop_log_dams_netx()
if __name__ == '__main__':
main()