mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-11 20:14:13 +00:00
Convert proxy config from multi to single setting
This commit is contained in:
parent
a5fa5d0451
commit
fa0911dbdf
@ -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"""
|
||||||
|
@ -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)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user