-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathconfig.py
115 lines (101 loc) · 4.7 KB
/
config.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
from configparser import ConfigParser
import os
import yaml
from bento.common.utils import get_logger
class PluginConfig:
def __init__(self, config):
self.module_name = config['module']
self.class_name = config['class']
self.params = config.get('params')
class BentoConfig:
def __init__(self, config_file):
self.log = get_logger('Bento Config')
self.PSWD_ENV = 'NEO_PASSWORD'
if config_file is None:
# File-Loader related
self.temp_folder = None
self.queue_long_pull_time = None
self.visibility_timeout = None
self.indexd_guid_prefix = None
self.indexd_manifest_ext = None
self.rel_prop_delimiter = None
# Data-Loader Related
self.backup_folder = None
self.neo4j_uri = None
self.neo4j_user = None
self.neo4j_password = None
self.schema_files = None
self.prop_file = None
self.cheat_mode = None
self.dry_run = None
self.wipe_db = None
self.no_backup = None
self.yes = None
self.max_violations = None
self.s3_bucket = None
self.s3_folder = None
self.loading_mode = None
self.dataset = None
self.no_parents = None
self.split_transactions = None
else:
if os.path.isfile(config_file):
with open(config_file) as c_file:
config = yaml.safe_load(c_file)['Config']
#################################
# Folders
self.temp_folder = config.get('temp_folder')
if self.temp_folder:
self._create_folder(self.temp_folder)
self.backup_folder = config.get('backup_folder')
if self.backup_folder:
self._create_folder(self.backup_folder)
#################################
# File-loader related
if 'sqs' in config:
sqs = config['sqs']
self.queue_long_pull_time = sqs.get('long_pull_time')
self.visibility_timeout = sqs.get('visibility_timeout')
if 'indexd' in config:
indexd = config['indexd']
self.indexd_guid_prefix = indexd.get('GUID_prefix')
self.indexd_manifest_ext = indexd.get('ext')
if self.indexd_manifest_ext and not self.indexd_manifest_ext.startswith('.'):
self.indexd_manifest_ext = '.' + self.indexd_manifest_ext
self.slack_url = config.get('url')
#################################
# Data-loader related
self.rel_prop_delimiter = config.get('rel_prop_delimiter')
if 'neo4j' in config:
neo4j = config['neo4j']
self.neo4j_uri = neo4j.get('uri')
self.neo4j_user = neo4j.get('user')
self.neo4j_password = neo4j.get('password')
self.plugins = []
if 'plugins' in config:
for plugin in config.get('plugins', []) or []:
self.plugins.append(PluginConfig(plugin))
self.schema_files = config.get('schema')
self.prop_file = config.get('prop_file')
self.cheat_mode = config.get('cheat_mode')
self.dry_run = config.get('dry_run')
self.wipe_db = config.get('wipe_db')
self.no_backup = config.get('no_backup')
self.yes = config.get('no_confirmation')
self.max_violations = config.get('max_violations', 10)
self.s3_bucket = config.get('s3_bucket')
self.s3_folder = config.get('s3_folder')
self.loading_mode = config.get('loading_mode', 'UPSERT_MODE')
self.dataset = config.get('dataset')
self.no_parents = config.get('no_parents')
self.split_transactions = config.get('split_transactions')
else:
msg = f'Can NOT open configuration file "{config_file}"!'
self.log.error(msg)
raise Exception(msg)
def _create_folder(self, folder):
os.makedirs(folder, exist_ok=True)
if not os.path.isdir(folder):
msg = f'{folder} is not a folder!'
self.log.error(msg)
raise Exception(msg)