Use the tornado server to serve the application

This commit is contained in:
Roland Geider 2013-01-19 10:51:42 +01:00
parent 7722149768
commit 70407feab8
3 changed files with 24 additions and 3 deletions

25
openslides/main.py Executable file → Normal file
View File

@ -21,6 +21,13 @@ import threading
import time import time
import webbrowser import webbrowser
from tornado.options import options, define, parse_command_line
import tornado.httpserver
import tornado.ioloop
import tornado.web
import tornado.wsgi
import django.core.handlers.wsgi
import django.conf import django.conf
from django.core.management import execute_from_command_line from django.core.management import execute_from_command_line
@ -291,13 +298,25 @@ def create_or_reset_admin_user():
def start_openslides(addr, port, start_browser_url=None, extra_args=[]): def start_openslides(addr, port, start_browser_url=None, extra_args=[]):
argv = ["", "runserver", '--noreload'] + extra_args
argv.append("%s:%d" % (addr, port)) # Set the options
define('port', type=int, default=port)
define('address', default=addr)
# Open the browser
if start_browser_url: if start_browser_url:
start_browser(start_browser_url) start_browser(start_browser_url)
execute_from_command_line(argv)
# Start the server
app = tornado.wsgi.WSGIContainer(django.core.handlers.wsgi.WSGIHandler())
tornado_app = tornado.web.Application(
[
('.*', tornado.web.FallbackHandler, dict(fallback=app)),
])
server = tornado.httpserver.HTTPServer(tornado_app)
server.listen(port=options.port,
address=options.address)
tornado.ioloop.IOLoop.instance().start()
def start_browser(url): def start_browser(url):

View File

@ -5,3 +5,4 @@ PIL==1.1.7
coverage==3.6 coverage==3.6
django-discover-runner==0.2.2 django-discover-runner==0.2.2
pep8==1.4 pep8==1.4
tornado

View File

@ -44,6 +44,7 @@ setup(
'django-mptt', 'django-mptt',
'reportlab', 'reportlab',
'pil', 'pil',
'tornado',
], ],
entry_points={ entry_points={
'console_scripts': [ 'console_scripts': [