Skip to main content
Glama

OpenZeppelin Contracts MCP Server

Official
by OpenZeppelin
CONTRIBUTING.md5.14 kB
Contributing to OpenZeppelin Contracts Wizard ======= Contributions to OpenZeppelin Contracts Wizard are welcome. Please review the information below to test out and contribute your changes. ## Project layout - `packages/common` contains common code used internally by some of the below packages. - `packages/core` contains the code generation logic for each language under separately named subfolders. - `packages/mcp` contains the MCP server. - `packages/ui` is the interface built in Svelte. ## Building and testing the project ### Prerequisites The following prerequisites are required to build the project locally: - [Node.js](https://nodejs.org/) - [Yarn](https://yarnpkg.com/getting-started/install) - [Deno](https://github.com/denoland/deno?tab=readme-ov-file#installation) (Optional) to run a local API server for the AI Assistant - Note that using the shell installation method is recommended (the `upgrade` command, which allows you to install a specific Deno version, is not always available when installing Deno with other installers). - To install the version of Deno that matches the Netlify deploy environment, run `deno upgrade --version 1.46.3`. - When adding dependencies for the Deno app add the dependency as a dev dependency using yarn, map the dependency to the Deno equivalent url in import_map.json and import it like a typescript dependency in the app. ### Installing dependencies From the root directory: - ```yarn install``` The dependencies must be installed at least once before proceeding to any of the below. ### Running tests From each language's subfolder under `packages/core`: - ```yarn test``` Ensure that all tests pass. If you are adding new functionality, include testcases as appropriate. If tests fail due to snapshots not matching and the new behavior is expected, run `yarn test:update-snapshots` to update AVA snapshots and commit the changes. > [!TIP] > From the root directory, you can use `yarn run:core` to run specific commands within `core/{language}` folders. > For example, running `yarn run:core cairo test` from the root directory will run tests for Cairo. ### Running linter From the root directory: - ```yarn lint``` If linting errors or warnings occur, run `yarn lint --fix` to attempt to auto-fix issues. If there are remaining issues that cannot be auto-fixed, manually address them and re-run the command to ensure it passes. ### Running formatter From the root directory: - ```yarn format:{check|write}``` If formatting errors or warnings occur when running `yarn format:check`, run `yarn format:write` to attempt to auto-fix issues. It is recommended to use an automatic formatter in your code editor or run this command before making your merge request as formatting errors will fail CI. ### Running the UI From the `packages/ui` directory: - Run `yarn dev` to start a local server for the UI. - Default port is 8080. To use another port, set the environment variable `PORT`, for example: `PORT=800 yarn dev` ### Running the AI Assistant (Optional) Create a `.env` file at the root directory, set the environment variable `OPENAI_API_KEY` using your OpenAI API key, and configure your OpenAI project limits to allow the `gpt-4o-mini` model or set the environment variable `OPENAI_MODEL` to a specific model. Then from the `packages/ui` directory: - In one terminal, start the UI according to the above section if the UI isn't already running. - In another terminal, run `yarn dev:api` to start a local API server which handles AI Assistant functions. - Default port is 3000. To use another port, set the environment variable `API_PORT` > [!TIP] > You can also start both the UI and API servers simultaneously by running `yarn dev` from the root directory. ### Testing the MCP server (Optional) #### Running MCP tests From the `packages/mcp` directory: - ```yarn test``` #### Running the local MCP server in your IDE 1. From the `packages/mcp` directory, run `yarn watch` to compile and watch for changes. 2. Configure your IDE's MCP configuration file with the following, replacing `<ABSOLUTE_PATH_TO_WIZARD_PROJECT_ROOT>` with the absolute path to the root directory of this repository: ``` { "mcpServers": { "openzeppelin-contracts-wizard": { "command": "node", "args": [ "<ABSOLUTE_PATH_TO_WIZARD_PROJECT_ROOT>/packages/mcp/dist/index.js" ] } } } ``` 3. When you make changes to the MCP server's code, refresh the MCP server in your IDE to pick up the changes. ## Creating Pull Requests (PRs) As a contributor, we ask that you fork this repository, work on your own fork and then submit pull requests. The pull requests will be reviewed and eventually merged into the main repo. See ["Fork-a-Repo"](https://help.github.com/articles/fork-a-repo/) for how this works. ### Adding Changesets If your PR modifies code generation logic under `packages/core`, you will need to add changesets for the relevant packages to summarize the changes. The PR's `Changeset` GitHub check will give an error if this condition is not satisfied. - To add a changeset: from the root directory, run `yarn changeset`

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/OpenZeppelin/contracts-wizard'

If you have feedback or need assistance with the MCP directory API, please join our Discord server