OpenRPC provides classes to rapidly develop an OpenRPC server.
Project description
Installation
OpenRPC is on PyPI and can be installed with:
pip install openrpc
Usage
This library provides an OpenRPCServer
class that can be used to
quickly create an OpenRPCServer; it takes as an argument an InfoObject
which needs at minimum a title and version.
from openrpc.objects import InfoObject
from openrpc.server import OpenRPCServer
rpc = OpenRPCServer(InfoObject(title="Demo Server", version="1.0.0"))
Register a function as an RPC Method
To register a method with the OpenRPCServer add the @rpc.method
decorator to a method.
@rpc.method
def add(a: int, b: int) -> int:
return a + b
RPC Discover
The rpc.discover
method is automatically generated. It relies heavily
on type hints.
Process JSON RPC Request
OpenRPC is transport agnostic. To use it, pass JSON RPC requests to the
process_request
method.
req = """
{
"id": 1,
"method": "add",
"params": {"a": 2, "b": 2},
"jsonrpc": "2.0"
}
"""
rpc.process_request(req) # '{"id": 1, "result": 4, "jsonrpc": "2.0}'
Example
from flask import Flask, Response, jsonify, request
from openrpc.objects import InfoObject
from openrpc.server import OpenRPCServer
app = Flask(__name__)
rpc = OpenRPCServer(InfoObject(title="Demo Server", version="1.0.0"))
@rpc.method
def add(a: int, b: int) -> int:
return a + b
@app.route("/api/v1/", methods=["POST"])
def process_rpc() -> Response:
return jsonify(rpc.process_request(request.json))
if __name__ == "__main__":
app.run()
Example In
[
{
"id": 1,
"method": "add",
"params": {"a": 1, "b": 3},
"jsonrpc": "2.0"
}, {
"id": 2,
"method": "add",
"params": [5, 7],
"jsonrpc": "2.0"
}, {
"id": 3,
"method": "add",
"params": [11, "thirteen"],
"jsonrpc": "2.0"
}
]
Example Result Out
[
{
"id": 1,
"result": 4,
"jsonrpc": "2.0"
}, {
"id": 2,
"result": 12,
"jsonrpc": "2.0"
}, {
"id": 3,
"error": {
"code": -32000,
"message": "TypeError: unsupported operand type(s) for +: 'int' and 'str'"
},
"jsonrpc": "2.0"
}
]
Example RPC Discover
{
"openrpc": "1.2.6",
"info": {
"title": "Demo Server",
"version": "1.0.0"
},
"methods": [
{
"name": "add",
"params": [
{
"name": "a",
"schema": {
"type": "number"
},
"required": true
},
{
"name": "b",
"schema": {
"type": "number"
},
"required": true
}
],
"result": {
"name": "result",
"schema": {
"type": "number"
},
"required": true
}
}
],
"components": {
"schemas": {}
}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
openrpc-1.0.4.tar.gz
(23.2 kB
view hashes)