mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-23 01:43:43 +00:00
Fixed issues with web root settings not working.
Fixed more NoneType iterable errors.
This commit is contained in:
parent
b47b2e1f58
commit
032ddf2425
3 changed files with 31 additions and 36 deletions
|
@ -143,22 +143,9 @@ class IndexHandler(RequestHandler):
|
||||||
sickbeard.REMOTE_IP = self.request.remote_ip
|
sickbeard.REMOTE_IP = self.request.remote_ip
|
||||||
req_headers = self.request.headers
|
req_headers = self.request.headers
|
||||||
|
|
||||||
def delist_arguments(self, args):
|
|
||||||
"""
|
|
||||||
Takes a dictionary, 'args' and de-lists any single-item lists then
|
|
||||||
returns the resulting dictionary.
|
|
||||||
|
|
||||||
In other words, {'foo': ['bar']} would become {'foo': 'bar'}
|
|
||||||
"""
|
|
||||||
for arg, value in args.items():
|
|
||||||
if len(value) == 1:
|
|
||||||
args[arg] = value[0]
|
|
||||||
return args
|
|
||||||
|
|
||||||
def _dispatch(self):
|
def _dispatch(self):
|
||||||
|
|
||||||
args = None
|
path = self.request.uri.replace(sickbeard.WEB_ROOT,'').split('?')[0]
|
||||||
path = self.request.uri.split('?')[0]
|
|
||||||
|
|
||||||
method = path.strip('/').split('/')[-1]
|
method = path.strip('/').split('/')[-1]
|
||||||
if path.startswith('/api'):
|
if path.startswith('/api'):
|
||||||
|
@ -179,8 +166,10 @@ class IndexHandler(RequestHandler):
|
||||||
|
|
||||||
if klass and not method.startswith('_'):
|
if klass and not method.startswith('_'):
|
||||||
# Sanitize argument lists:
|
# Sanitize argument lists:
|
||||||
if self.request.arguments:
|
args = self.request.arguments
|
||||||
args = self.delist_arguments(self.request.arguments)
|
for arg, value in args.items():
|
||||||
|
if len(value) == 1:
|
||||||
|
args[arg] = value[0]
|
||||||
|
|
||||||
# Regular method handler for classes
|
# Regular method handler for classes
|
||||||
func = getattr(klass, method, None)
|
func = getattr(klass, method, None)
|
||||||
|
@ -193,29 +182,38 @@ class IndexHandler(RequestHandler):
|
||||||
func = getattr(klass, 'index', None)
|
func = getattr(klass, 'index', None)
|
||||||
|
|
||||||
if func:
|
if func:
|
||||||
if args:
|
return func(**args)
|
||||||
return func(**args)
|
|
||||||
else:
|
|
||||||
return func()
|
|
||||||
|
|
||||||
raise HTTPError(404)
|
raise HTTPError(404)
|
||||||
|
|
||||||
def redirect(self, url, permanent=False, status=None):
|
def redirect(self, url, permanent=False, status=None):
|
||||||
if not self._transforms:
|
self._transforms = []
|
||||||
self._transforms = []
|
super(IndexHandler, self).redirect(sickbeard.WEB_ROOT + url, permanent, status)
|
||||||
|
|
||||||
super(IndexHandler, self).redirect(url, permanent, status)
|
|
||||||
|
|
||||||
@asynchronous
|
@asynchronous
|
||||||
|
@gen.engine
|
||||||
def get(self, *args, **kwargs):
|
def get(self, *args, **kwargs):
|
||||||
try:
|
try:
|
||||||
self.finish(self._dispatch())
|
response = yield gen.Task(self.getresponse, self._dispatch)
|
||||||
|
self.finish(response)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger.log(ex(e), logger.ERROR)
|
logger.log(ex(e), logger.ERROR)
|
||||||
logger.log(u"Traceback: " + traceback.format_exc(), logger.DEBUG)
|
logger.log(u"Traceback: " + traceback.format_exc(), logger.DEBUG)
|
||||||
|
|
||||||
|
@asynchronous
|
||||||
|
@gen.engine
|
||||||
def post(self, *args, **kwargs):
|
def post(self, *args, **kwargs):
|
||||||
return self._dispatch()
|
try:
|
||||||
|
response = yield gen.Task(self.getresponse, self._dispatch)
|
||||||
|
self.finish(response)
|
||||||
|
except Exception as e:
|
||||||
|
logger.log(ex(e), logger.ERROR)
|
||||||
|
logger.log(u"Traceback: " + traceback.format_exc(), logger.DEBUG)
|
||||||
|
|
||||||
|
|
||||||
|
def getresponse(self, func, callback):
|
||||||
|
response = func()
|
||||||
|
callback(response)
|
||||||
|
|
||||||
def robots_txt(self, *args, **kwargs):
|
def robots_txt(self, *args, **kwargs):
|
||||||
""" Keep web crawlers out """
|
""" Keep web crawlers out """
|
||||||
|
@ -1465,8 +1463,6 @@ class ConfigGeneral(IndexHandler):
|
||||||
else:
|
else:
|
||||||
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
|
ui.notifications.message('Configuration Saved', ek.ek(os.path.join, sickbeard.CONFIG_FILE))
|
||||||
|
|
||||||
self.redirect("/home/")
|
|
||||||
|
|
||||||
class ConfigSearch(IndexHandler):
|
class ConfigSearch(IndexHandler):
|
||||||
def index(self, *args, **kwargs):
|
def index(self, *args, **kwargs):
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,6 @@ from tornado.ioloop import IOLoop
|
||||||
|
|
||||||
server = None
|
server = None
|
||||||
|
|
||||||
|
|
||||||
class MultiStaticFileHandler(StaticFileHandler):
|
class MultiStaticFileHandler(StaticFileHandler):
|
||||||
def initialize(self, paths, default_filename=None):
|
def initialize(self, paths, default_filename=None):
|
||||||
self.paths = paths
|
self.paths = paths
|
||||||
|
@ -101,21 +100,20 @@ def initWebServer(options={}):
|
||||||
app = Application([],
|
app = Application([],
|
||||||
debug=sickbeard.DEBUG,
|
debug=sickbeard.DEBUG,
|
||||||
gzip=True,
|
gzip=True,
|
||||||
xheaders=True,
|
|
||||||
cookie_secret='61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o/Vo='
|
cookie_secret='61oETzKXQAGaYdkL5gEmGeJJFuYh7EQnp2XdTP1o/Vo='
|
||||||
)
|
)
|
||||||
|
|
||||||
# Index Handler
|
# Index Handler
|
||||||
app.add_handlers(".*$", [
|
app.add_handlers(".*$", [
|
||||||
(r"/", RedirectHandler, {'url': '/home/'}),
|
(r"/", RedirectHandler, {'url': '%s/home/' % options['web_root']}),
|
||||||
(r'/api/(.*)(/?)', webapi.Api),
|
(r'%s/api/(.*)(/?)' % options['web_root'], webapi.Api),
|
||||||
(r'%s(.*)(/?)' % options['web_root'], webserve.IndexHandler)
|
(r'%s/(.*)(/?)' % options['web_root'], webserve.IndexHandler)
|
||||||
])
|
])
|
||||||
|
|
||||||
# Static Path Handler
|
# Static Path Handler
|
||||||
app.add_handlers(".*$", [
|
app.add_handlers(".*$", [
|
||||||
(r'/(favicon\.ico)', MultiStaticFileHandler,
|
(r'%s/(favicon\.ico)' % options['web_root'], MultiStaticFileHandler,
|
||||||
{'paths': '%s/%s' % (options['web_root'], 'images/ico/favicon.ico')}),
|
{'paths': [os.path.join(options['data_root'], 'images/ico/favicon.ico')]}),
|
||||||
(r'%s/%s/(.*)(/?)' % (options['web_root'], 'images'), MultiStaticFileHandler,
|
(r'%s/%s/(.*)(/?)' % (options['web_root'], 'images'), MultiStaticFileHandler,
|
||||||
{'paths': [os.path.join(options['data_root'], 'images'),
|
{'paths': [os.path.join(options['data_root'], 'images'),
|
||||||
os.path.join(sickbeard.CACHE_DIR, 'images'),
|
os.path.join(sickbeard.CACHE_DIR, 'images'),
|
||||||
|
|
|
@ -630,6 +630,7 @@ class RequestHandler(object):
|
||||||
self.set_status(status)
|
self.set_status(status)
|
||||||
self.set_header("Location", urlparse.urljoin(utf8(self.request.uri),
|
self.set_header("Location", urlparse.urljoin(utf8(self.request.uri),
|
||||||
utf8(url)))
|
utf8(url)))
|
||||||
|
|
||||||
self.finish()
|
self.finish()
|
||||||
|
|
||||||
def write(self, chunk):
|
def write(self, chunk):
|
||||||
|
|
Loading…
Reference in a new issue