-
Notifications
You must be signed in to change notification settings - Fork 296
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
docs: document rpc api versioning process. #2901
Conversation
I think this update is awesome. Had a quick question. From the previous issue, the two main approaches are:
I just want to clarify what you mean by "Per-RPC Versioning" and "versioned per-RPC endpoint" When you say those words, are you referring to the 2nd approach above, or just that the RPC API will have versions in general? (The reason I ask is because I also couldn't tell from the previous issue which approach you were going to move forward with. But the pro/con writeup was definitely helpful) |
After discussing the two approaches in chat with davec, versioning each RPC individually was the better approach and that is what this versioning process recommends. "Per-RPC Versioning" and "versioned per-RPC endpoint" are all referring to individual versioned endpoint for each RPC method here. Open to suggestions on wording it better. I will update the text to clearly indicate this where it unclear. I was supposed to comment on the issue regarding the preferred approach before writing the docs, missed a step there. |
This documents the process expected to be followed by contributors in versioning json-rpc api endpoints.
23fb19f
to
809ee69
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking really good, and I like this schema.
Hopefully my comments are clear and helpful!
docs/rpc_api_versioning.md
Outdated
|
||
### 1. Per-RPC Versioning | ||
|
||
To streamline API access in the process of transitioning between release |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I like the word streamline, but I think this sentence could be worded a bit better. I stumbled over it a few times. I also tweaked some of the language about "versioning endpoints" to be as clear as possible, I hope. See what you think.
"To prevent API compatibility issues when when transitioning between release versions, dcrd's JSON-RPC API methods will each have an individually versioned endpoint. Per-method endpoint versioning provides the flexibility needed to isolate the development of each method, and allows each method to evolve individually and exclusively from each other."
My thought process is:
- RPC is a protocol (adjective)
- The API is the general category (noun)
- The method is the main "thing" we're talking about.
- The endpoint is the way to access the main thing
- The endpoints are what are changing, but they're the method endpoints.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I think that's clearer. Will make the changes.
I'm going to leave this in draft still and look to add a section for versioning websocket endpoints. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the comments and structure makes sense. Unfortunately, I'm only a novice with golang, so I can't really comment on the code examples.
docs/rpc_api_versioning.md
Outdated
// ... | ||
} | ||
``` | ||
|
||
With the outlined schemes adhered to, the versioned endpoint should be ready |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This last sentence is clunky, and I'm not sure what you're trying to say. Is this a list of remaining steps to take before the new versioned endpoints API can be active? I don't really understand the second half of the sentence, but I gave it my best shot. Please feel free to modify:
Once all dcrd
JSON-RPC API methods are updated using the schema outlined above, the versioned endpoints will be ready for use. However, dcrctl
and other consumers will need to update their rpc/jsonrpc/types
dependencies and logic.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm saying dcrctl needs to be rebuilt with the updated jsonrpc types dependency to be able to access the new versioned commands.
Just realized having the default method name resolve to the current version of the endpoint will break consumers once they update. We don't want that, should be resolving to the older version instead. Will make the needed changes soon. |
This adds a section for versioning websockets according to the per-method versioning scheme. This also updates the documentation to keep the default method name resolving to the older version of a versioned endpoint to avoid breaking consumers on an upgrade.
10524df
to
510259f
Compare
This documents the process expected to be followed by contributors in versioning JSON-RPC API endpoints.
work towards #2746.