2016-08-23 00:40:38 +08:00
|
|
|
from __future__ import print_function # In python 2.7
|
2016-08-02 04:54:41 +08:00
|
|
|
|
2015-09-29 22:01:09 +08:00
|
|
|
import os
|
2016-08-02 04:54:41 +08:00
|
|
|
import sys
|
2017-10-31 19:55:29 +08:00
|
|
|
import time
|
2018-05-18 00:24:50 +08:00
|
|
|
import logging
|
2017-10-31 19:55:29 +08:00
|
|
|
|
2017-08-25 22:47:08 +08:00
|
|
|
BASE_PATH = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
|
|
|
if BASE_PATH not in sys.path:
|
|
|
|
sys.path.insert(0, BASE_PATH)
|
|
|
|
|
2018-06-01 00:27:26 +08:00
|
|
|
from cc.island_logger import json_setup_logging
|
|
|
|
# This is here in order to catch EVERYTHING, some functions are being called on imports the log init needs to be on top.
|
|
|
|
json_setup_logging(default_path='island_logger_default_config.json', default_level=logging.DEBUG)
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2017-08-25 22:47:08 +08:00
|
|
|
from cc.app import init_app
|
2017-09-13 18:30:28 +08:00
|
|
|
from cc.utils import local_ip_addresses
|
2018-02-23 02:33:40 +08:00
|
|
|
from cc.environment.environment import env
|
2017-10-31 19:55:29 +08:00
|
|
|
from cc.database import is_db_server_up
|
2015-09-29 22:01:09 +08:00
|
|
|
|
2018-05-18 00:24:50 +08:00
|
|
|
|
|
|
|
def main():
|
2016-08-01 01:40:05 +08:00
|
|
|
from tornado.wsgi import WSGIContainer
|
|
|
|
from tornado.httpserver import HTTPServer
|
|
|
|
from tornado.ioloop import IOLoop
|
|
|
|
|
2018-02-23 02:33:40 +08:00
|
|
|
mongo_url = os.environ.get('MONGO_URL', env.get_mongo_url())
|
2017-10-31 19:55:29 +08:00
|
|
|
|
|
|
|
while not is_db_server_up(mongo_url):
|
2018-05-18 00:24:50 +08:00
|
|
|
logger.info('Waiting for MongoDB server')
|
2017-10-31 19:55:29 +08:00
|
|
|
time.sleep(1)
|
2017-10-16 15:40:07 +08:00
|
|
|
|
2017-10-31 19:55:29 +08:00
|
|
|
app = init_app(mongo_url)
|
2018-02-23 02:33:40 +08:00
|
|
|
if env.is_debug():
|
2017-10-16 15:40:07 +08:00
|
|
|
app.run(host='0.0.0.0', debug=True, ssl_context=('server.crt', 'server.key'))
|
|
|
|
else:
|
|
|
|
http_server = HTTPServer(WSGIContainer(app),
|
|
|
|
ssl_options={'certfile': os.environ.get('SERVER_CRT', 'server.crt'),
|
|
|
|
'keyfile': os.environ.get('SERVER_KEY', 'server.key')})
|
2018-02-23 02:33:40 +08:00
|
|
|
http_server.listen(env.get_island_port())
|
2018-05-18 00:24:50 +08:00
|
|
|
logger.info(
|
|
|
|
'Monkey Island Server is running on https://{}:{}'.format(local_ip_addresses()[0], env.get_island_port()))
|
2017-10-16 15:40:07 +08:00
|
|
|
IOLoop.instance().start()
|
|
|
|
|
2018-05-18 00:24:50 +08:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|