Skip to content
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

On Chain Hook Registry #185

Closed
akarys92 opened this issue Jul 22, 2024 · 6 comments
Closed

On Chain Hook Registry #185

akarys92 opened this issue Jul 22, 2024 · 6 comments

Comments

@akarys92
Copy link

akarys92 commented Jul 22, 2024

Component

General design optimization (improving efficiency, cleanliness, or developer experience)

Describe the suggested feature and problem it solves.

Problem

Uniswap V4 supports a new concept called a hook where any developer can create an arbitrary contract that does some functionality in the swap process. This poses a problem for integrators with Uniswap V4 in both routing and interfaces.

  • Routers need to be able to find all the hooks that a pool could use, understand what they do and if they are safe and then finally decided if they want to route through those pools.
  • Interfaces need some way to be able to display metadata about hooks to their users so they can understand if they are safe to LP into.

Approach

To address these problems I propose HookRegistry, an ERC-721 based registry for managing hook contracts used in Uniswap V4.

HookRegistry allows the deployer of a hook contract to mint an NFT with metadata about the hook stored. Additionally, it enables auditors to sign these NFTs with a known key they publish, providing a mechanism for integrators to verify audits on chain and display metadata to users off-chain. An example of the recommended metadata structure would be:

struct HookMetadata {
        string name;
        string description;
        string contact;
        string docsLink;
        address[] auditors;
    }

Ideally this protocol would be deployed as part of the v4-periphery so that it sits on every chain Uniswap V4 is deployed to.

Describe the desired implementation.

The Hook Registry should be an ERC-721 compatible contract that supports the following functionality:

  • Minting Hook NFTs Allows the deployer of a hook to mint an NFT containing structured metadata about their hook. If the minter does not match the deployment address of the hook, they will not be able to mint.
  • Audit Signing Auditors are able to use a known key to sign hook NFTs confirming that they have audited them.
  • Update Metadata The creator of the original NFT (who is by definition the hook deployer) is the sole party able to update the metadata for a given hook.

Describe alternatives.

Off Chain Approach

Similar to TokenLists, we could maintain an off chain standard for publishing hook metadata and audit information like the following:

[
	{
		metadata: {
			name: (String) A display name for the hook
			address: (String) Address of the hook
			chainId: (Int) The chain the hook is deployed on.
			description: (String) User description of hook. 
			contact: (String) Contact for developer. 
			docs: (String) Docs for the hook.
		}, 
		audits: [
			{
				auditor: (String) Name of auditor, 
				link: (String) Link to the audit, 
				publicKey: (String) Auditors public key,
				signature: (String) Hook deployment address signed by the known key of the auditor.
			} 
		]
		signature: (String) Metadata object signed with the same private key that deployed the contact at metadata.address
	}, 
	...
]

We could then provide a set of tools that allows hook deployers and auditors to sign metadata just as they would on chain as well as tools that allow integrators to verify those signatures.

Although this would be a lighter weight implementation, it would require ongoing management from teams like Uniswap who would need to host these lists in perpetuity.

Additional context.

Open to other approaches!

Copy link

linear bot commented Jul 22, 2024

@snreynolds
Copy link
Member

Just jotting down an alternative....

Maybe we can publish a IHooksMetadata interface that exposes some of these properties natively on the Hook contract itself?

something like:


interface IHooksMetadata is IHooks {


          name()

          description()

          docs()

          audits()


}

Then an offchain hooks list can query these fields on the actual hook addresses should they be implemented?

@akarys92
Copy link
Author

Brief prototype of the ERC721 implementation, although I may be leaning towards @snreynolds idea now.

https://github.com/akarys92/v4-periphery/blob/HookRegistry/src/base/HookRegistry.sol

@marktoda
Copy link
Contributor

Takeaway -

  • Create IHooksMetadata interface
  • Create HooksList standard
  • hooks lists can pull info from IHooksMetadata, maybe index a standard one that includes all deployed hooks based on poolcreated events

@PoeAudits
Copy link

What about including some kind of digital fingerprint for the hook contract, like a bytes32 variable containing the hash of the deployed bytecode. Therefore any changes to the bytecode, or similar/deceptive looking hook contracts will generate unique values.

@snreynolds
Copy link
Member

Since we're liking the IHooksMetadata solution, will close this out. Thanks @akarys92 !

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants