Refactor jsonrpc_get.
Move parameter handling into its own function and better use the `.get()` function for dictionaries. Early return on the failed checks is more readable. The lambda function in the callback was long and hard to read so moved it out.
This commit is contained in:
parent
eef6312a17
commit
5aecd02668
2 changed files with 60 additions and 49 deletions
|
@ -298,7 +298,7 @@ ignored-classes=twisted.internet,RequestMessage
|
||||||
# List of members which are set dynamically and missed by pylint inference
|
# List of members which are set dynamically and missed by pylint inference
|
||||||
# system, and so shouldn't trigger E1101 when accessed. Python regular
|
# system, and so shouldn't trigger E1101 when accessed. Python regular
|
||||||
# expressions are accepted.
|
# expressions are accepted.
|
||||||
generated-members=
|
generated-members=lbrynet.lbrynet_daemon.LBRYDaemon.Parameters
|
||||||
|
|
||||||
|
|
||||||
[IMPORTS]
|
[IMPORTS]
|
||||||
|
|
|
@ -138,6 +138,11 @@ OK_CODE = 200
|
||||||
REMOTE_SERVER = "www.google.com"
|
REMOTE_SERVER = "www.google.com"
|
||||||
|
|
||||||
|
|
||||||
|
class Parameters(object):
|
||||||
|
def __init__(self, **kwargs):
|
||||||
|
self.__dict__.update(kwargs)
|
||||||
|
|
||||||
|
|
||||||
class LBRYDaemon(jsonrpc.JSONRPC):
|
class LBRYDaemon(jsonrpc.JSONRPC):
|
||||||
"""
|
"""
|
||||||
LBRYnet daemon, a jsonrpc interface to lbry functions
|
LBRYnet daemon, a jsonrpc interface to lbry functions
|
||||||
|
@ -1651,65 +1656,53 @@ class LBRYDaemon(jsonrpc.JSONRPC):
|
||||||
d.addCallbacks(lambda info: self._render_response(info, OK_CODE), lambda _: server.failure)
|
d.addCallbacks(lambda info: self._render_response(info, OK_CODE), lambda _: server.failure)
|
||||||
return d
|
return d
|
||||||
|
|
||||||
|
def _process_get_parameters(self, p):
|
||||||
|
"""Extract info from input parameters and fill in default values for `get` call."""
|
||||||
|
# TODO: this process can be abstracted s.t. each method
|
||||||
|
# can spec what parameters it expects and how to set default values
|
||||||
|
timeout = p.get('timeout', self.download_timeout)
|
||||||
|
download_directory = p.get('download_directory', self.download_directory)
|
||||||
|
file_name = p.get('file_name')
|
||||||
|
stream_info = p.get('stream_info')
|
||||||
|
sd_hash = get_sd_hash(stream_info)
|
||||||
|
wait_for_write = p.get('wait_for_write', True)
|
||||||
|
name = p.get('name')
|
||||||
|
return Parameters(
|
||||||
|
timout=timeout,
|
||||||
|
download_directory=download_directory,
|
||||||
|
file_name=file_name,
|
||||||
|
stream_info=stream_info,
|
||||||
|
sd_hash=sd_hash,
|
||||||
|
wait_for_write=wait_for_write,
|
||||||
|
name=name
|
||||||
|
)
|
||||||
|
|
||||||
def jsonrpc_get(self, p):
|
def jsonrpc_get(self, p):
|
||||||
"""
|
"""Download stream from a LBRY uri.
|
||||||
Download stream from a LBRY uri
|
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
'name': name to download, string
|
'name': name to download, string
|
||||||
'download_directory': optional, path to directory where file will be saved, string
|
'download_directory': optional, path to directory where file will be saved, string
|
||||||
'file_name': optional, a user specified name for the downloaded file
|
'file_name': optional, a user specified name for the downloaded file
|
||||||
'stream_info': optional, specified stream info overrides name
|
'stream_info': optional, specified stream info overrides name
|
||||||
|
'timout': optional
|
||||||
Returns:
|
Returns:
|
||||||
'stream_hash': hex string
|
'stream_hash': hex string
|
||||||
'path': path of download
|
'path': path of download
|
||||||
"""
|
"""
|
||||||
|
params = self._process_get_parameters(p)
|
||||||
if 'timeout' not in p.keys():
|
if not params.name:
|
||||||
timeout = self.download_timeout
|
return server.failure
|
||||||
else:
|
if params.name in self.waiting_on:
|
||||||
timeout = p['timeout']
|
return server.failure
|
||||||
|
d = self._download_name(name=params.name,
|
||||||
if 'download_directory' not in p.keys():
|
timeout=params.timeout,
|
||||||
download_directory = self.download_directory
|
download_directory=params.download_directory,
|
||||||
else:
|
stream_info=params.stream_info,
|
||||||
download_directory = p['download_directory']
|
file_name=params.file_name,
|
||||||
|
wait_for_write=params.wait_for_write)
|
||||||
if 'file_name' in p.keys():
|
d.addCallback(get_output_callback(params))
|
||||||
file_name = p['file_name']
|
|
||||||
else:
|
|
||||||
file_name = None
|
|
||||||
|
|
||||||
if 'stream_info' in p.keys():
|
|
||||||
stream_info = p['stream_info']
|
|
||||||
if 'sources' in stream_info.keys():
|
|
||||||
sd_hash = stream_info['sources']['lbry_sd_hash']
|
|
||||||
else:
|
|
||||||
sd_hash = stream_info['stream_hash']
|
|
||||||
else:
|
|
||||||
stream_info = None
|
|
||||||
|
|
||||||
if 'wait_for_write' in p.keys():
|
|
||||||
wait_for_write = p['wait_for_write']
|
|
||||||
else:
|
|
||||||
wait_for_write = True
|
|
||||||
|
|
||||||
if 'name' in p.keys():
|
|
||||||
name = p['name']
|
|
||||||
if p['name'] not in self.waiting_on.keys():
|
|
||||||
d = self._download_name(name=name, timeout=timeout, download_directory=download_directory,
|
|
||||||
stream_info=stream_info, file_name=file_name, wait_for_write=wait_for_write)
|
|
||||||
d.addCallback(lambda l: {'stream_hash': sd_hash,
|
|
||||||
'path': os.path.join(self.download_directory, l.file_name)}
|
|
||||||
if stream_info else
|
|
||||||
{'stream_hash': l.sd_hash,
|
|
||||||
'path': os.path.join(self.download_directory, l.file_name)})
|
|
||||||
d.addCallback(lambda message: self._render_response(message, OK_CODE))
|
d.addCallback(lambda message: self._render_response(message, OK_CODE))
|
||||||
else:
|
|
||||||
d = server.failure
|
|
||||||
else:
|
|
||||||
d = server.failure
|
|
||||||
|
|
||||||
return d
|
return d
|
||||||
|
|
||||||
def jsonrpc_stop_lbry_file(self, p):
|
def jsonrpc_stop_lbry_file(self, p):
|
||||||
|
@ -2261,3 +2254,21 @@ class LBRYDaemon(jsonrpc.JSONRPC):
|
||||||
|
|
||||||
d.addCallback(lambda _: self._render_response(True, OK_CODE))
|
d.addCallback(lambda _: self._render_response(True, OK_CODE))
|
||||||
return d
|
return d
|
||||||
|
|
||||||
|
|
||||||
|
def get_sd_hash(stream_info):
|
||||||
|
if not stream_info:
|
||||||
|
return None
|
||||||
|
try:
|
||||||
|
return stream_info['sources']['lbry_sd_hash']
|
||||||
|
except KeyError:
|
||||||
|
return stream_info.get('stream_hash')
|
||||||
|
|
||||||
|
|
||||||
|
def get_output_callback(params):
|
||||||
|
def callback(l):
|
||||||
|
return {
|
||||||
|
'stream_hash': params.sd_hash if params.stream_info else l.sd_hash,
|
||||||
|
'path': os.path.join(params.download_directory, l.file_name)
|
||||||
|
}
|
||||||
|
return callback
|
||||||
|
|
Loading…
Add table
Reference in a new issue