import logging
from tic import command
from tic.utils import error
-from flask_cors import CORS
app = Flask(__name__)
-CORS(app)
@app.route('/')
def index():
try:
logger = logging.getLogger(__name__)
logger.info('%s - %s %s : data=%s' % (request.remote_addr, request.method, request.path, request.data))
- repo_info = json.loads(request.data)
- view_data = command.analyze(repo_info.get('repos'), repo_info.get('recipes'))
+ target_info = json.loads(request.data)
+ view_data = command.analyze(target_info.get('recipes'))
+ #view_data = command.analyze(None)
resp = makeresponse(view_data, None)
except error.TICError as err:
logger.error(err)
except ValueError as ve:
logger.error(ve)
resp = makeresponse(str(ve), ve)
+# except Exception as ex:
+# logger.error(ex)
+# resp = makeresponse(str(ex), ex)
+
+ return resp
+
+@app.route('/imports', methods=['POST'])
+def imports():
+ try:
+ logger = logging.getLogger(__name__)
+ logger.info('%s - %s %s : data=%s' % (request.remote_addr, request.method, request.path, request.data))
+ repo_info = json.loads(request.data)
+ view_data = command.imports(repo_info.get('recipes'))
+ resp = makeresponse(view_data, None)
+ except error.TICError as err:
+ logger.error(err)
+ resp = makeresponse(str(err), err)
except Exception as ex:
logger.error(ex)
resp = makeresponse(str(ex), ex)
try:
logger = logging.getLogger(__name__)
logger.info('%s - %s %s : data=%s' % (request.remote_addr, request.method, request.path, request.data))
-
+ exportInfo = json.loads(request.data)
+ export_type = request.args.get('format')
+ output = command.exports(export_type, exportInfo.get('recipes'), exportInfo.get('packages'), exportInfo.get('outdir'), exportInfo.get('filename'))
+ resp = makeresponse(output, None)
except error.TICError as err:
logger.error(err)
resp = makeresponse(str(err), err)
except ValueError as ve:
logger.error(ve)
resp = makeresponse(str(ve), ve)
- except Exception as ex:
- logger.error(ex)
- resp = makeresponse(str(ex), ex)
-
+# except Exception as ex:
+# logger.error(ex)
+# resp = makeresponse(str(ex), ex)
return resp
-def start(port_num=59001):
+def start(port_num=8082):
# cryptographic random generator
app.secret_key = os.urandom(24)
with app.test_request_context():
print(url_for('index'))
print(url_for('analysis'))
- app.run(host='0.0.0.0', port=port_num)
-
+ print(url_for('imports'))
+ print(url_for('exports'))
+ if isinstance(port_num, (str, unicode)):
+ port_num = int(port_num)
+ app.run(host='0.0.0.0', threaded=True, port=port_num)
def makeresponse(data, err):
status = 200
status = 400 # Bad Request
elif isinstance(err, Exception):
status = 500 # Internal Server Error
+ data='Internal Server Error'
res_body = json.dumps(ResultInfo('false', None, data)._asdict())
else:
res_body = json.dumps(ResultInfo('true', data, None)._asdict())
return ResultInfoType(result, data, message)
if __name__ == '__main__':
- start(59003)
+ start(8082)