A library for writing asynchronous JSON-RPC servers and clients in Python, using Twisted. It aims to be as simple and easy to understand (and hack) as possible.
Read more about JSON-RPC at http://www.jsonrpc.org/
-
Support for HTTP and HTTPS as protocol (via twisted.web) and for more lightweight netstring (see http://cr.yp.to/proto/netstrings.txt )
-
Support for HTTP authentization - only basic, not digest; use SSL for encrypted credentials.
-
Support for HTTP persistent connections and Factory to create proxies to different URLs
-
Support for HTTP compression
-
Full standards compliance.
-
Support both JSON-RPC standards at once - great if you don't control your clients.
-
'Just work' with various clients (i.e. PHP, C++, JavaScript...).
-
Detailed examples :-) .
-
More tests, better (functionality) coverage. This applies to every project, always :-) .
-
Refactoring, mostly tests.
- test_server and test_jsonrpc
- test_client and test_netstringclient
-
JSON is well readable for a human. It's easy to use Wireshark (www.wireshark.org) or similar for debugging.
-
JSON-RPC version 1 doesn't talk about batch requests. In order to support both standards at once, fastjsonrpc supports it just like in version 2. It ties JSON-RPC version to the method call, not the request as a whole.
-
I didn't test the JSON Class hinting, as mentioned in the version 1 spec. I leave this to the JSON parsing capabilities of respective libraries.
-
SSL client test raises an error after shutDown. Looks like a bug in Trial and we can ignore it.