Once you understand JSON-RPC’s Bits, you can assemble versions that match the different protocols.
In 1.0 a request object must always have all three fields. If you want a notification, you must set the id to null. The parameter must be an array of positional parameters. So a 1.0 request object always looks like:
data:image/s3,"s3://crabby-images/9f6bc/9f6bcf004824220a9b9d1867129f7735e9d05e39" alt="Request Object v1 Request Object v1"
Request Object v1
A 1.0 response object contains both a result and an error, but one of them must be null:
data:image/s3,"s3://crabby-images/bc041/bc0415db9587f22e6f94bb3b58e506186a541751" alt="Response Object Response Object"
Response Object v1
Version 2.0 changed a lot of the protocol designs to be more client-server oriented. It added a new field to identify the specification version, allows reduced fields, and named parameters to be passed.
So a 2.0 request object could look like:
data:image/s3,"s3://crabby-images/a5e74/a5e74aac563727bc3bca93791dfa322c8dda118d" alt="request object v2 (full) request object v2 (full)"
request object v2
data:image/s3,"s3://crabby-images/3129e/3129ec1b322a594986144948678ee68ed2fd1349" alt="request object v2 (no params) request object v2 (no params)"
request object v2 (no parameters)
data:image/s3,"s3://crabby-images/0291d/0291d0c68dca8b2b9ebdd7ecc41bfd8b9f6970d6" alt="request object (full, notification) request object (full, notification)"
request object (notification)
data:image/s3,"s3://crabby-images/ffdcd/ffdcd8ec6eca8d88b1eff35bb2c56fb7b7990734" alt="request object (no params, notification) request object (no params, notification)"
request object (no parameters, notification)
The response object could look like:
data:image/s3,"s3://crabby-images/fb977/fb9774208dffe35304fce11474cd90760482d329" alt="response object v2 response object v2"
response object v2
data:image/s3,"s3://crabby-images/2981a/2981abcb32c995dd509e7a55f4835f45995ee761" alt="reponse object (result only) reponse object (result only)"
response object (result only)
data:image/s3,"s3://crabby-images/9475e/9475e7d133ef20819ba0780f196abce79d892178" alt="response object v2 (error only) response object v2 (error only)"
response object v2 (error only)
The specification version field was added to make sure the client got back a response type it would expect. The absence of a version field means it cannot reduce the fields and needs to send them with null values like the 1.0 version does.
Reduced fields was included to make a cleaner response structure. Not to reduce the default wire-text length. It also solved the issue of handling a call who’s result was null. Incorrect coding assumptions could cause error handling to trigger on a valid result of null in v1 . Reducing the fields protects against that by providing a cleaner structure and the check of existence vs assumed intent by value.