fix: Added an object checking

- Checking if there are objects in the event, and then
  if there is at least 1 transaction object
- This prevents the module from crashing, but does not
  guaranty having a valid GoAML file (depending on
  objects and their relations)
pull/168/head
chrisr3d 2018-02-22 16:37:27 +01:00
parent 53b4a43448
commit b2b0fccd47
No known key found for this signature in database
GPG Key ID: 6BBED1B63A6D639F
1 changed files with 9 additions and 0 deletions

View File

@ -194,6 +194,15 @@ def handler(q=False):
config = request['config'].get('rentity_id') config = request['config'].get('rentity_id')
export_doc = GoAmlGeneration(config) export_doc = GoAmlGeneration(config)
export_doc.from_event(request['data'][0]) export_doc.from_event(request['data'][0])
if not export_doc.misp_event.Object:
misperrors['error'] = "There is no object in this event."
return misperrors
types = []
for obj in export_doc.misp_event.Object:
types.append(obj.name)
if 'transaction' not in types:
misperrors['error'] = "There is no transaction object in this event."
return misperrors
export_doc.parse_objects() export_doc.parse_objects()
export_doc.build_xml() export_doc.build_xml()
exp_doc = "{}{}".format(export_doc.xml.get('header'), export_doc.xml.get('data')) exp_doc = "{}{}".format(export_doc.xml.get('header'), export_doc.xml.get('data'))