-
Notifications
You must be signed in to change notification settings - Fork 346
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
Look into gRPC / Tendermint RPC for Cosmos SDK 0.45+ #885
Comments
this would be awesome. if grpc support is added we could neat things with grpc reflection to get possible queries and txs of a chain. |
@marbar3778 can you help with any item from the list above to make progress here? |
Sorry I looked into some of this but never responded. I think grpc should not be a replacement for rpc right now. But instead a way to at runtime interact with a chain without preexisting knowledge. With grpc there is no need for abciQuery without proof. Tx search and subscriptions should still be handled by the rpc, but txsearch has a path to deprecation so it should not be relied on instead the app developer should use a Postgres instance with the psql indexer on tendermint. |
Thanks for the insights.
All we do in CosmJS is statically typed. I wonder how this is envisioned to work. Even if we dynamically get available queries and custom message types from the chain, you need a code generator generating all the proto code for those types. |
this is the best example code I have seen so far. https://github.com/fdymylja/dynamic-cosmos. maybe @fdymylja could touch on this? |
Not familiar with JS protobuf, but there should be a protoreflection implementation available. And even if there isn't it shouldn't be too difficult to create. Once you get information on how a protobuf type looks like (what we care about is field tags + field kinds in order to know how to wire-encode them), you can work with any type as if it was a map<string, ArbitraryType>. Then once cosmos/cosmos-sdk#10977 is merged, you won't need to keep track of message signers anymore. If this is something you are planning to support let me know and I'll try to help. |
Thank you for the pointers. protobuf.js (unmaintained) supports the dynamic type generation at runtime. I just wonder why you would want all of this in the first place? The CosmJS users we see know exaxtly what their backend is and what is available thete. For them the abstraction of CosmJS is already overwhelming. Why move all the compile time safety we have right now and make it runtime problems? |
I'm not super familiar with cosmJS and especially how it is used by its consumers.
You can work both in a typed and untyped way. In golang clients we have certain use-cases that are unlocked through reflection (also because sdk's golang client is not really a client but something that is totally chain-specific and revolves around the CLI).
For example possible use cases in a frontend:
You could build a sort of etherscan in cosmos in which instead of dynamically querying contracts you can query module queriers. Same goes for tx messages. IDK if this is something that cosmjs supports/or wants to support, but as I said if you see value in it, let me know and I'll be happy to support. |
Thanks a lot for taking the time to describe all of this, @fdymylja! I'll have a think about it to see if this is useful for our context and maybe create a draft implementation independent of CosmJS. One thing that is clear is that using reflection and connecting to the gRPC endpoint should be discussed separately. |
Adding my 2 cents here. The switch to GRPC/RPC makes it much harder for infrastructure providers to perform smart caching and advanced load-balancing/rate limiting on requests, due to the more complex nature of the requests. For example, on current Secret Network mainnet when applying caching for traffic generated by Keplr we save about 50% of requests, since a lot of them go to endpoints that don't change much (voting, chain parameters, etc) - this has a compounding effect on response times, since it both returns requests much faster, and frees up resources for more intensive requests. Personally I think it makes the most sense for cosmjs as a frontend library to support the GRPC-gateway endpoints. Not only are they easier for developers and infra providers to work with, but having requests not connection-orriented is an advantage, since it allows for better load-balancing between multiple servers. I'm not enitrely familiar with how everything is hooked up behind the scenes on in the sdk, though, so I can only speak from the consumer side of things |
Love this conversation ❤️ To add to, or perhaps support what @fdymylja is saying, in terms of users: the multi-chain application developer is definitely one of them, especially as we move forward towards a 1000+ chain ecosystem. More specifically, that would be wallets who'd want to extend functionality, or applications that use core features available to most up-to-date chains, most notably Authz, Gov, Groups, Feegrant. All all of these allow you to take a Msg as an input to perform an action. Think DAOs being able to trade on Osmosis without Osmosis having to build a custom app, validators authorizing an account to perform a chain's specific modified staking Tx without that chain building a custom app for that, one multi-chain gov tool to create proposals, etc, all without using the CLI. This is currently not possible and I see a strong need for it. Just commenting here because I'm personally quite interested in getting this to work in the long term, and would have all 4 front-end projects that I'm currently involved in likely benefit from this. I can't comment much in terms of what its place would be inside CosmJS. I recognise that mixing this in with current CosmJS would confuse users in terms of where they can expect errors (runtime v.s. compilation). If anything, I can see |
adding the option to use grpc but not a replacement is easy enough and shouldnt have any requirements, surprised it hasnt happened yet. |
@tac0turtle please see #885 (comment) It seems there were two calls that we didn't have access to. It would be great for you and Simon to discuss this to find a proper resolution |
I'm also surprised Confio has not received any funding for this yet... It is listed as a Q3 goal in our 2023 ICF grant proposal. If we get our Q3 plan approved, it should be done then. |
They seem to make some optimisations such that the gRPC server will not longer just proxy through Tendermint. To increase concurrency I believe. This may mean it would be more sensible to call the gRPC server than Tendermint RPC. Maybe...
Anyway, something to look into when we add SDK 0.45+ support
cosmos/cosmos-sdk#10045 (comment)
The text was updated successfully, but these errors were encountered: