2017-07-21 06:55:25 +02:00
|
|
|
import atexit
|
|
|
|
|
2017-11-16 00:53:11 +01:00
|
|
|
import tornado.web
|
2016-11-27 04:56:26 +01:00
|
|
|
from django.conf import settings
|
|
|
|
|
2017-11-16 00:53:11 +01:00
|
|
|
from zerver.lib.queue import get_queue_client
|
2020-06-11 00:54:34 +02:00
|
|
|
from zerver.tornado import autoreload
|
2016-11-27 04:56:26 +01:00
|
|
|
from zerver.tornado.handlers import AsyncDjangoHandler
|
|
|
|
|
2020-06-11 00:54:34 +02:00
|
|
|
|
2018-05-10 01:32:40 +02:00
|
|
|
def setup_tornado_rabbitmq() -> None: # nocoverage
|
2020-10-23 02:43:28 +02:00
|
|
|
# When tornado is shut down, disconnect cleanly from RabbitMQ
|
2017-07-21 06:55:25 +02:00
|
|
|
if settings.USING_RABBITMQ:
|
|
|
|
queue_client = get_queue_client()
|
|
|
|
atexit.register(lambda: queue_client.close())
|
2018-05-21 00:38:54 +02:00
|
|
|
autoreload.add_reload_hook(lambda: queue_client.close())
|
2017-07-21 06:55:25 +02:00
|
|
|
|
2020-09-16 22:17:31 +02:00
|
|
|
def create_tornado_application() -> tornado.web.Application:
|
2018-07-13 12:58:16 +02:00
|
|
|
urls = (
|
|
|
|
r"/notify_tornado",
|
|
|
|
r"/json/events",
|
|
|
|
r"/api/v1/events",
|
|
|
|
r"/api/v1/events/internal",
|
|
|
|
)
|
2016-11-27 04:56:26 +01:00
|
|
|
|
2020-09-16 22:19:07 +02:00
|
|
|
return tornado.web.Application(
|
|
|
|
[(url, AsyncDjangoHandler) for url in urls],
|
|
|
|
debug=settings.DEBUG,
|
|
|
|
autoreload=False,
|
|
|
|
# Disable Tornado's own request logging, since we have our own
|
|
|
|
log_function=lambda x: None
|
|
|
|
)
|