Convert proxy config from multi to single setting

This commit is contained in:
Calum Lind 2014-02-16 16:50:05 +00:00
parent a5fa5d0451
commit fa0911dbdf
2 changed files with 51 additions and 41 deletions

View File

@ -538,6 +538,21 @@ class Core(component.Component):
i2p_dict = {"hostname": i2p_settings.hostname, "port": i2p_settings.port} i2p_dict = {"hostname": i2p_settings.hostname, "port": i2p_settings.port}
return i2p_dict return i2p_dict
@export
def get_proxy(self):
"""Returns the active listen port"""
proxy_settings = self.session.proxy()
proxy_dict = {
"type": proxy_settings.type.real,
"hostname": proxy_settings.hostname,
"username": proxy_settings.username,
"password": proxy_settings.password,
"port": proxy_settings.port,
"proxy_hostnames": proxy_settings.proxy_hostnames,
"proxy_peer_connections": proxy_settings.proxy_peer_connections
}
return proxy_dict
@export @export
def get_available_plugins(self): def get_available_plugins(self):
"""Returns a list of plugins available in the core""" """Returns a list of plugins available in the core"""

View File

@ -109,36 +109,18 @@ DEFAULT_PREFS = {
"path_chooser_max_popup_rows": 20, "path_chooser_max_popup_rows": 20,
"path_chooser_show_hidden_files": False, "path_chooser_show_hidden_files": False,
"new_release_check": True, "new_release_check": True,
"proxies": { "proxy": {
"peer": { "type": 0,
"type": 0, "hostname": "",
"hostname": "", "username": "",
"username": "", "password": "",
"password": "", "port": 8080,
"port": 8080 "proxy_hostnames": True,
}, "proxy_peer_connections": True,
"web_seed": { },
"type": 0, "i2p_proxy": {
"hostname": "", "hostname": "",
"username": "", "port": 0
"password": "",
"port": 8080
},
"tracker": {
"type": 0,
"hostname": "",
"username": "",
"password": "",
"port": 8080
},
"dht": {
"type": 0,
"hostname": "",
"username": "",
"password": "",
"port": 8080
},
}, },
"i2p_proxy": { "i2p_proxy": {
"hostname": "", "hostname": "",
@ -162,6 +144,11 @@ class PreferencesManager(component.Component):
def __init__(self): def __init__(self):
component.Component.__init__(self, "PreferencesManager") component.Component.__init__(self, "PreferencesManager")
self.config = deluge.configmanager.ConfigManager("core.conf", DEFAULT_PREFS) self.config = deluge.configmanager.ConfigManager("core.conf", DEFAULT_PREFS)
if "proxies" in self.config:
log.warning("Updating config file for proxy, using 'peer' values to fill new 'proxy' setting")
self.config["proxy"].update(self.config["proxies"]['peer'])
log.warning("New proxy config is: %s", self.config["proxy"])
del self.config["proxies"]
def start(self): def start(self):
self.core = component.get("Core") self.core = component.get("Core")
@ -430,17 +417,25 @@ class PreferencesManager(component.Component):
if self.new_release_timer and self.new_release_timer.running: if self.new_release_timer and self.new_release_timer.running:
self.new_release_timer.stop() self.new_release_timer.stop()
def _on_set_proxies(self, key, value): def _on_set_proxy(self, key, value):
for k, v in value.items(): log.debug("Setting proxy to: %s", value)
if v["type"]: proxy_settings = lt.proxy_settings()
proxy_settings = lt.proxy_settings() proxy_settings.type = lt.proxy_type(value["type"])
proxy_settings.type = lt.proxy_type(v["type"]) proxy_settings.username = value["username"]
proxy_settings.username = str(v["username"]) proxy_settings.password = value["password"]
proxy_settings.password = str(v["password"]) proxy_settings.hostname = value["hostname"]
proxy_settings.hostname = str(v["hostname"]) proxy_settings.port = v["port"]
proxy_settings.port = v["port"] self.session.set_proxy(proxy_settings)
log.debug("setting %s proxy settings", k)
getattr(self.session, "set_%s_proxy" % k)(proxy_settings) def _on_set_i2p_proxy(self, key, value):
log.debug("Setting I2P proxy to: %s", value)
proxy_settings = lt.proxy_settings()
proxy_settings.hostname = value["hostname"]
proxy_settings.port = value["port"]
try:
self.session.set_i2p_proxy(proxy_settings)
except RuntimeError as ex:
log.error("Unable to set I2P Proxy: %s", ex)
def _on_set_i2p_proxy(self, key, value): def _on_set_i2p_proxy(self, key, value):
log.debug("Setting I2P proxy to: %s", value) log.debug("Setting I2P proxy to: %s", value)