JSON-RPC consists of two specifically “shaped” object as well as rules around their use. The image below represents all the parts of both versions 1 and versions 2 of the specification. Above the line is the request object. Below the line is the response object.
data:image/s3,"s3://crabby-images/8f9ea/8f9ea8f2b0ec12b074c59432e4e6bf83ae4c807f" alt="JSON-RPC Request and Response Objects JSON-RPC Request and Response Objects"
JSON-RPC Request and Response Objects
Lets break down the concept step by step.
You need to call a function:
data:image/s3,"s3://crabby-images/b3462/b3462c5a16f5a332b0b0d80595a92f8fa2198ffe" alt="JSON-RPC Method JSON-RPC Method"
function
That function probably has some parameters:
data:image/s3,"s3://crabby-images/2efd6/2efd6d4f2c535a30ecf60d39d414091ad0a41d53" alt="JSON-RPC Request Parameters Parameters"
parameter(s)
So what you want to perform on the server is this:
data:image/s3,"s3://crabby-images/9d5a9/9d5a9d3e4d0bc06807b1ada0c05427bc93cf1675" alt="Function Concept Function Concept"
conceptual function
Multiple calls could be happening at the same time, so you need an identifier to pair up the response to the request:
data:image/s3,"s3://crabby-images/0742b/0742b99f5d839be28ca3fce0af96fd80a9163a7e" alt="Identification Identification"
id
If you care about the function call’s result you generate this object “shape”:
data:image/s3,"s3://crabby-images/9f6bc/9f6bcf004824220a9b9d1867129f7735e9d05e39" alt="Request Object JSON-RPC Request Object"
Request Object
If you don’t care about the function call’s result, it is called a notification. The result still gets generated, but the server will never send it back over the “wire”:
data:image/s3,"s3://crabby-images/dcbd5/dcbd584a7a84c7850d7638908e58d0611f0e5d78" alt="Notification Request Object Notification Object"
Notification Object
Notifications will NOT send back any rpc errors either!
Now, the purpose of a function call is usually to get a result back:
data:image/s3,"s3://crabby-images/ffe9b/ffe9bf0e0cfb26389c3470ab04932f2e24c433ed" alt="Result Object Result Object"
Result Object
But if something went wrong in performing the call (an RPC handling, processing, or permission error) you would need to handle the error:
data:image/s3,"s3://crabby-images/1f9e7/1f9e7be2b74577d18308ff6f06c5a748cbec6dd6" alt="Error Object Error Object"
Error Object
Either way, what comes back would look like:
data:image/s3,"s3://crabby-images/bc041/bc0415db9587f22e6f94bb3b58e506186a541751" alt="Response Object Response Object"
Response Object
The only remaining data is the specification version property, which only exists after version 1.0 :
data:image/s3,"s3://crabby-images/5d667/5d667eff4687bc35d023071979bbfb26c0b2b4f0" alt="Specification Version Specification Version"
specification version
So your request object shape would look like the below:
data:image/s3,"s3://crabby-images/a5e74/a5e74aac563727bc3bca93791dfa322c8dda118d" alt="JSON-RPC Request Object request object"
request object
The response object shape would look like below:
data:image/s3,"s3://crabby-images/fb977/fb9774208dffe35304fce11474cd90760482d329" alt="Response Object JSON-RPC Response Object"
response object
Those are all the bits. Next we can talk about the combinations and specification requirements.