X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/python-jsonrpclib.git/blobdiff_plain/b9d42f9a2a933c88f016fdcb50998147a63f0b7e..a0cd6268562129127ef26cf22391d0a41ed2f05f:/jsonrpclib/jsonrpc.py diff --git a/jsonrpclib/jsonrpc.py b/jsonrpclib/jsonrpc.py index f74cd42..8e50079 100644 --- a/jsonrpclib/jsonrpc.py +++ b/jsonrpclib/jsonrpc.py @@ -102,9 +102,11 @@ def jloads(json_string): class ProtocolError(Exception): pass -class Transport(XMLTransport): +class TransportMixIn(object): """ Just extends the XMLRPC transport where necessary. """ user_agent = config.user_agent + # for Python 2.7 support + _connection = None def send_content(self, connection, request_body): connection.putheader("Content-Type", "application/json-rpc") @@ -113,26 +115,36 @@ class Transport(XMLTransport): if request_body: connection.send(request_body) - def _parse_response(self, file_h, sock): - response_body = '' - while 1: - if sock: - response = sock.recv(1024) - else: - response = file_h.read(1024) - if not response: - break - response_body += response - if self.verbose: - print 'body: %s' % response - return response_body - -class SafeTransport(XMLSafeTransport): - """ Just extends for HTTPS calls """ - user_agent = Transport.user_agent - send_content = Transport.send_content - _parse_response = Transport._parse_response + def getparser(self): + target = JSONTarget() + return JSONParser(target), target + +class JSONParser(object): + def __init__(self, target): + self.target = target + + def feed(self, data): + self.target.feed(data) + + def close(self): + pass + +class JSONTarget(object): + def __init__(self): + self.data = [] + def feed(self, data): + self.data.append(data) + + def close(self): + return ''.join(self.data) + +class Transport(TransportMixIn, XMLTransport): + pass + +class SafeTransport(TransportMixIn, XMLSafeTransport): + pass + class ServerProxy(XMLServerProxy): """ Unfortunately, much more of this class has to be copied since @@ -151,7 +163,8 @@ class ServerProxy(XMLServerProxy): self.__host, self.__handler = urllib.splithost(uri) if not self.__handler: # Not sure if this is in the JSON spec? - self.__handler = '/RPC2' + #self.__handler = '/' + self.__handler == '/' if transport is None: if schema == 'https': transport = SafeTransport()