Make misp-modules really asynchronous

pull/46/head
Raphaël Vinot 2016-08-24 00:22:03 +02:00
parent d6388e1c52
commit c822c2df9c
1 changed files with 17 additions and 14 deletions

View File

@ -22,8 +22,6 @@
import os import os
import signal import signal
import sys import sys
from tornado.ioloop import IOLoop
import tornado.web
import importlib import importlib
import json import json
import logging import logging
@ -31,6 +29,11 @@ import fnmatch
import argparse import argparse
import re import re
import tornado.web
from tornado.ioloop import IOLoop
from tornado.concurrent import run_on_executor
from concurrent.futures import ThreadPoolExecutor
try: try:
from .modules import * from .modules import *
HAS_PACKAGE_MODULES = True HAS_PACKAGE_MODULES = True
@ -166,23 +169,23 @@ class ListModules(tornado.web.RequestHandler):
self.write(json.dumps(ret)) self.write(json.dumps(ret))
@tornado.gen.coroutine
def async_module(request, write_fct):
jsonpayload = request.body.decode('utf-8')
x = json.loads(jsonpayload)
log.debug('MISP QueryModule request {0}'.format(jsonpayload))
ret = mhandlers[x['module']].handler(q=jsonpayload)
write_fct(json.dumps(ret))
class QueryModule(tornado.web.RequestHandler): class QueryModule(tornado.web.RequestHandler):
executor = ThreadPoolExecutor(None)
@run_on_executor
def run_request(self, jsonpayload):
x = json.loads(jsonpayload)
log.debug('MISP QueryModule request {0}'.format(jsonpayload))
return mhandlers[x['module']].handler(q=jsonpayload)
@tornado.gen.coroutine @tornado.gen.coroutine
def post(self): def post(self):
global mhandlers
try: try:
yield async_module(self.request, self.write) jsonpayload = self.request.body.decode('utf-8')
response = yield self.run_request(jsonpayload)
self.write(json.dumps(response))
except Exception: except Exception:
log.exception("Someting bad happened.") log.exception('Something went wrong:')
def main(): def main():