From 670ad51de1dd09a77eabfffa12e5cf097aef52d3 Mon Sep 17 00:00:00 2001 From: Damien Churchill Date: Sat, 20 Mar 2010 14:14:46 +0000 Subject: [PATCH] drop the Config resource and just include it in a script tag on the index page this allows for dynamic base setting add support for setting the base via a request header X-Deluge-Header --- deluge/ui/web/index.html | 4 ++++ deluge/ui/web/server.py | 36 +++++++++++++++++------------------- 2 files changed, 21 insertions(+), 19 deletions(-) diff --git a/deluge/ui/web/index.html b/deluge/ui/web/index.html index 41663937d..138978843 100644 --- a/deluge/ui/web/index.html +++ b/deluge/ui/web/index.html @@ -11,6 +11,10 @@ % endfor + + % for script in scripts: diff --git a/deluge/ui/web/server.py b/deluge/ui/web/server.py index 44ea65c4e..02ff43683 100644 --- a/deluge/ui/web/server.py +++ b/deluge/ui/web/server.py @@ -122,21 +122,6 @@ def rpath(*paths): """ return os.path.join(current_dir, *paths) -class Config(resource.Resource): - """ - Writes out a javascript file that contains the WebUI configuration - available as Deluge.Config. - """ - - def render(self, request): - web_config = component.get("Web").get_config() - config = dict([(key, web_config[key]) for key in UI_CONFIG_KEYS]) - return compress("""deluge = { - author: 'Damien Churchill ', - version: '%s', - config: %s -}""" % (common.get_version(), common.json.dumps(config)), request) - class GetText(resource.Resource): def render(self, request): request.setHeader("content-type", "text/javascript; encoding=utf-8") @@ -333,7 +318,7 @@ class TopLevel(resource.Resource): "js/ext-extensions/TreeGridColumns.js", "js/ext-extensions/TreeGridRenderColumn.js", "js/ext-extensions/TreeGrid.js", - "config.js", + #"config.js", "gettext.js", "js/deluge-all/Deluge.js", "js/deluge-all/Deluge.Formatters.js", @@ -382,7 +367,6 @@ class TopLevel(resource.Resource): def __init__(self): resource.Resource.__init__(self) - self.putChild("config.js", Config()) self.putChild("css", LookupResource("Css", rpath("css"))) self.putChild("gettext.js", GetText()) self.putChild("flag", Flag()) @@ -477,9 +461,23 @@ class TopLevel(resource.Resource): template = Template(filename=rpath("index.html")) request.setHeader("content-type", "text/html; charset=utf-8") - base = component.get("DelugeWeb").base - return template.render(scripts=scripts, stylesheets=self.stylesheets, debug=debug, base=base) + if request.requestHeaders.hasHeader('x-deluge-base'): + base = request.requestHeaders.getRawHeaders('x-deluge-base')[-1] + else: + base = component.get("DelugeWeb").base + + web_config = component.get("Web").get_config() + web_config["base"] = base + config = dict([(key, web_config[key]) for key in UI_CONFIG_KEYS]) + js_config = """deluge = { + author: 'Damien Churchill ', + version: '%s', + config: %s +}""" % (common.get_version(), common.json.dumps(config)) + + return template.render(scripts=scripts, stylesheets=self.stylesheets, + debug=debug, base=base, js_config=js_config) class ServerContextFactory: