2019-01-22 17:44:17 -05:00
|
|
|
import aiohttp
|
|
|
|
import logging
|
2019-01-23 10:41:34 -05:00
|
|
|
from lbrynet.conf import Config
|
2019-01-22 17:44:17 -05:00
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
USER_AGENT = "AuthServiceProxy/0.1"
|
|
|
|
TWISTED_SECURE_SESSION = "TWISTED_SECURE_SESSION"
|
|
|
|
TWISTED_SESSION = "TWISTED_SESSION"
|
|
|
|
LBRY_SECRET = "LBRY_SECRET"
|
|
|
|
HTTP_TIMEOUT = 30
|
|
|
|
|
|
|
|
|
|
|
|
class JSONRPCException(Exception):
|
|
|
|
def __init__(self, rpc_error):
|
|
|
|
super().__init__()
|
|
|
|
self.error = rpc_error
|
|
|
|
|
|
|
|
|
2019-01-23 16:41:14 -05:00
|
|
|
async def daemon_rpc(conf: Config, method: str, *args, **kwargs):
|
|
|
|
async with aiohttp.ClientSession() as session:
|
|
|
|
message = {'method': method, 'params': [args, kwargs]}
|
|
|
|
async with session.get(conf.api_connection_url, json=message) as resp:
|
|
|
|
data = await resp.json()
|
|
|
|
if 'result' in data:
|
|
|
|
return data['result']
|
|
|
|
elif 'error' in data:
|
|
|
|
raise JSONRPCException(data['error'])
|