- 
                Notifications
    You must be signed in to change notification settings 
- Fork 179
Hooks Wizard v0.0.1 #628
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
base: master
Are you sure you want to change the base?
Hooks Wizard v0.0.1 #628
Conversation
| Important Review skippedAuto incremental reviews are disabled on this repository. Please check the settings in the CodeRabbit UI or the  You can disable this status message by setting the  Note Other AI code review bot(s) detectedCodeRabbit has detected other AI code review bot(s) in this pull request and will avoid duplicating their findings in the review comments. This may lead to a less comprehensive review. WalkthroughThis pull request introduces comprehensive Uniswap v4 Hooks support to the OpenZeppelin Wizard. It adds a new  Changes
 Sequence Diagram(s)sequenceDiagram
    participant User as User
    participant UI as UI (HooksControls)
    participant API as buildGeneric<br/>(hooks.ts)
    participant Builder as ContractBuilder
    participant Printer as printContract
    participant Output as Generated Code
    User->>UI: Configure hook options<br/>(hook type, permissions, shares)
    UI->>API: Call buildHooks(opts)
    API->>Builder: new ContractBuilder()
    API->>Builder: applyCommonDefaults()
    API->>Builder: addAccessControl()
    API->>Builder: addCurrencySettler()
    API->>Builder: addSafeCast()
    API->>Builder: addTransientStorage()
    API->>Builder: addShares (ERC20/6909/1155)
    API->>Builder: addHook(hook type)<br/>+ permissions setup
    Builder-->>API: Contract object
    UI->>Printer: printContract(contract, opts)
    Printer->>Printer: printTopLevelComments()
    Printer->>Printer: printLibraries()
    Printer->>Printer: printCompatibleLibraryVersions()
    Printer-->>UI: Solidity code
    UI->>Output: Display with<br/>syntax highlighting
    User->>Output: Copy/Download/Remix
sequenceDiagram
    participant Client as MCP Client
    participant Server as MCP Server
    participant Handler as registerUniswapHooks
    participant Generator as buildGeneric
    participant Printer as printSolidityContract
    participant Response as Tool Response
    Client->>Server: Call uniswapHooks tool<br/>with hook config params
    Server->>Handler: Tool input received
    Handler->>Generator: buildGeneric(opts)
    Generator-->>Handler: Contract object
    Handler->>Printer: printSolidityContract(contract, opts)
    Printer->>Printer: Add additionalCompatibleLibraries<br/>for OpenZeppelin Uniswap Hooks
    Printer-->>Handler: Solidity code string
    Handler->>Response: Wrap code in<br/>safePrintSolidityCodeBlock()
    Response-->>Client: Tool response with<br/>Solidity code block
Estimated code review effort🎯 4 (Complex) | ⏱️ ~60 minutes This PR introduces substantial new functionality with high complexity: a complete new hooks package with 15+ hook implementations, significant extensions to core solidity abstractions (Contract/ContractBuilder public APIs, library support), dense logic for permission management and contract building, new UI components with reactive state management, and MCP tooling integration. The heterogeneity spans multiple packages with varying logic density. Multiple integration points require verification of correctness across the ecosystem (type safety, API consistency, import resolution). Possibly related PRs
 Suggested reviewers
 Pre-merge checks and finishing touches❌ Failed checks (1 warning)
 ✅ Passed checks (2 passed)
 Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. Comment  | 
| All contributors have signed the CLA  ✍️ ✅ | 
| PR TypeEnhancement Description
 Diagram Walkthroughflowchart LR
  A["Core Solidity"] --> B["Using Directives"]
  C["Uniswap Hooks Core"] --> D["Hook Types"]
  C --> E["Contract Builder"]
  F["UI Components"] --> G["Hooks Controls"]
  F --> H["Navigation"]
  I["Public Pages"] --> J["Routing"]
  D --> K["Generated Contract"]
  E --> K
 | 
| Relevant files | |||||||||||||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Enhancement | 20 files
 | ||||||||||||||||||||||||||||||||||||||||
| Configuration changes | |||||||||||||||||||||||||||||||||||||||||
| Additional files | 
| PR Reviewer Guide 🔍Here are some key observations to aid the review process: 
 | 
| I confirm that I have read and hereby agree to the OpenZeppelin Contributor License Agreement | 
| PR Code Suggestions ✨Explore these optional code suggestions: 
 | ||||||||||||||||||||||
| All alerts resolved. Learn more about Socket for GitHub. This PR previously contained dependency changes with security issues that have been resolved, removed, or ignored. Ignoring alerts on: 
 | 
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.
Nice work!
I am thinking maybe there could be a compile test for each of hook's basic configuration?
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.
LGTM!
Reminder when Uniswap Hooks 1.2.0 is released:
-  Update devDependencies in packages/core/uniswap-hooks/package.json
- Update UI hyperlink injection to point to v1.2.0 tag
| @SocketSecurity ignore-all | 
Pending:
v0.0.0.alpha
Next release in a posterior PR: