- added char conversion for mongo insertion, mongodb doesn't allow for '.' in keys names and sometimes machine names might include '.' char in them. We encode with ',,,' and decode back to '.'.

This commit is contained in:
maor.rayzin 2019-01-02 16:25:26 +02:00
parent 985f45d8de
commit 078470e257
1 changed files with 15 additions and 7 deletions

View File

@ -727,19 +727,18 @@ class ReportService:
} }
ReportExporterManager().export(report) ReportExporterManager().export(report)
mongo.db.report.drop() mongo.db.report.drop()
mongo.db.report.insert_one(ReportService.clean_report_before_mongo_insert(report)) mongo.db.report.insert_one(ReportService.encode_dot_char_before_mongo_insert(report))
return report return report
@staticmethod @staticmethod
def clean_report_before_mongo_insert(report_dict): def encode_dot_char_before_mongo_insert(report_dict):
""" """
mongodb doesn't allow for '.' and '$' in a key's name, this function replaces the '.' char with the unicode mongodb doesn't allow for '.' and '$' in a key's name, this function replaces the '.' char with the unicode
\u002E char instead. ,,, combo instead.
:return: :return: dict with formatted keys with no dots.
""" """
report_as_json = json_util.dumps(report_dict) report_as_json = json_util.dumps(report_dict).replace('.', ',,,')
report_as_json.replace('.', '\u002E')
return json_util.loads(report_as_json) return json_util.loads(report_as_json)
@ -758,10 +757,19 @@ class ReportService:
return False return False
@staticmethod
def decode_dot_char_before_mongo_insert(report_dict):
"""
this function replaces the ',,,' combo with the '.' char instead.
:return: report dict with formatted keys (',,,' -> '.')
"""
report_as_json = json_util.dumps(report_dict).replace(',,,', '.')
return json_util.loads(report_as_json)
@staticmethod @staticmethod
def get_report(): def get_report():
if ReportService.is_latest_report_exists(): if ReportService.is_latest_report_exists():
return mongo.db.report.find_one() return ReportService.decode_dot_char_before_mongo_insert(mongo.db.report.find_one())
return ReportService.generate_report() return ReportService.generate_report()
@staticmethod @staticmethod