Skip to content

Commit

Permalink
Moved scripts that are not shared with other repo from bento-common r…
Browse files Browse the repository at this point in the history
…epo.
  • Loading branch information
n2iw committed Apr 23, 2021
1 parent 1e1557e commit 7062841
Show file tree
Hide file tree
Showing 16 changed files with 1,904 additions and 33 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
tmp/
venv/
env/
venv3_new/
.idea/
Pentaho-scripts/
__pycache__/
Expand All @@ -9,4 +10,4 @@ cmd.txt
tests/temp
config/data-loader.yml
config/file-loader.yml
backup/
backup/
2 changes: 1 addition & 1 deletion bento
104 changes: 104 additions & 0 deletions config.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
from configparser import ConfigParser
import os
import yaml

from bento.common.utils import get_logger


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.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)
48 changes: 48 additions & 0 deletions config_base.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
import os

import yaml

from bento.common.utils import get_logger


class BentoConfig:
def __init__(self, config_file, args, config_file_arg='config_file'):
self.log = get_logger('Bento Config')
if not config_file:
raise ValueError(f'Empty config file name')
if not os.path.isfile(config_file):
raise ValueError(f'"{config_file}" is not a file!')

self.config_file_arg = config_file_arg

with open(config_file) as c_file:
self.data = yaml.safe_load(c_file)['Config']
if self.data is None:
self.data = {}

self._override(args)

def _override(self, args):
for key, value in vars(args).items():
# Ignore config file argument
if key == self.config_file_arg:
continue
if isinstance(value, bool):
if value:
self.data[key] = value

elif value is not None:
self.data[key] = value

def create_folder(self, folder):
"""
Create given folder if not already exists
:param folder: folder path
:return:
"""
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)

Loading

0 comments on commit 7062841

Please sign in to comment.