mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-12 04:24:27 +00:00
fix a bug when the host_id doesn't exist
This commit is contained in:
parent
04af8965bc
commit
117d50b728
@ -740,46 +740,46 @@ class WebApi(JSONComponent):
|
|||||||
:param host_id: the hash id of the host
|
:param host_id: the hash id of the host
|
||||||
:type host_id: string
|
:type host_id: string
|
||||||
"""
|
"""
|
||||||
main_deferred = Deferred()
|
|
||||||
|
|
||||||
(host_id, host, port, user, password) = self.get_host(host_id)
|
def response(status, info=None):
|
||||||
|
return host_id, host, port, status, info
|
||||||
|
|
||||||
def callback(status, info=None):
|
try:
|
||||||
main_deferred.callback((host_id, host, port, status, info))
|
host_id, host, port, user, password = self.get_host(host_id)
|
||||||
|
except TypeError, e:
|
||||||
|
return response(_("Offline"))
|
||||||
|
|
||||||
def on_connect(connected, c, host_id):
|
def on_connect(connected, c, host_id):
|
||||||
def on_info(info, c):
|
def on_info(info, c):
|
||||||
c.disconnect()
|
c.disconnect()
|
||||||
callback(_("Online"), info)
|
return response(_("Online"), info)
|
||||||
|
|
||||||
def on_info_fail(reason, c):
|
def on_info_fail(reason, c):
|
||||||
c.disconnect()
|
c.disconnect()
|
||||||
callback(_("Offline"))
|
return response(_("Offline"))
|
||||||
|
|
||||||
if not connected:
|
if not connected:
|
||||||
callback(_("Offline"))
|
return response(_("Offline"))
|
||||||
return
|
|
||||||
|
|
||||||
d = c.daemon.info()
|
return c.daemon.info(
|
||||||
d.addCallback(on_info, c)
|
).addCallback(on_info, c
|
||||||
d.addErrback(on_info_fail, c)
|
).addErrback(on_info_fail, c)
|
||||||
|
|
||||||
def on_connect_failed(reason, host_id):
|
def on_connect_failed(reason, host_id):
|
||||||
callback(_("Offline"))
|
return response(_("Offline"))
|
||||||
|
|
||||||
if client.connected() and (host, port, "localclient" if not \
|
if client.connected() and (host, port, "localclient" if not
|
||||||
user and host in ("127.0.0.1", "localhost") else \
|
user and host in ("127.0.0.1", "localhost") else
|
||||||
user) == client.connection_info():
|
user) == client.connection_info():
|
||||||
def on_info(info):
|
def on_info(info):
|
||||||
callback(_("Connected"), info)
|
return response(_("Connected"), info)
|
||||||
|
|
||||||
client.daemon.info().addCallback(on_info)
|
return client.daemon.info().addCallback(on_info)
|
||||||
else:
|
else:
|
||||||
c = Client()
|
c = Client()
|
||||||
d = c.connect(host, port, user, password)
|
return c.connect(host, port, user, password
|
||||||
d.addCallback(on_connect, c, host_id)
|
).addCallback(on_connect, c, host_id
|
||||||
d.addErrback(on_connect_failed, host_id)
|
).addErrback(on_connect_failed, host_id)
|
||||||
return main_deferred
|
|
||||||
|
|
||||||
@export
|
@export
|
||||||
def start_daemon(self, port):
|
def start_daemon(self, port):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user