-
Notifications
You must be signed in to change notification settings - Fork 38
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
Radspec: move known function list to be a parameter / run-time extension #88
Comments
What you think of allow users to publish using aragonPM to the
I'm still trying to figure out how we can get the information from the Agent 🤔 |
I wonder if it is feasible to just have a mapping of 4bytes -> description as opposed to having to apply descriptions to every method of every address, since a lot of contracts on mainnet are really just duplicates of existing contracts or implementations of a specific interface/standard (like ERC20). Each of these contracts probably share the same descriptions, such as the case with ERC20 and other token standards. Radspec has the capacity to tweak the descriptions depending on the context of the contract (e.g. include the appropriate token symbol by fetching it from the contract). I think that would greatly simplify the format that descriptions need to be stored in on an on-chain or off-chain external registry, and it would also provide opportunities for fast lookups and caching. Thoughts? |
I think this is the way to go, and I believe it's pretty much what we're doing by checking the on-chain registry (and we may also want to check 4byte.directory), but we will still want overrides for specific addresses once we know about them. For example, |
There is an on-chain registry? Also, if it is any help then we can fairly easily pull out a list of all 4bytes and their Radspec descriptions for all existing Aragon apps from Apiary :) |
There's the parity one that is used by some wallets (see how we use it and However, the problem with these registries is that any one can register the signature, and it's first-in-first-come. |
Radspec itself should defer to a number of sources to fetch function descriptions, but ideally we would allow the user to specify their own overrides either during instantiation or runtime. It is also likely important that these overrides can be applied globally, or only for some contract addresses.
Doing so will allow us to move hardcoded function names away from the package itself to be closer to their intended use case (e.g. #87).
The text was updated successfully, but these errors were encountered: